:root{--bg: #faf5ff;--bg-card: #ffffff;--bg-elevated: #ffffff;--bg-glass: rgba(192, 132, 252, .04);--bg-glass-hover: rgba(192, 132, 252, .08);--border: rgba(192, 132, 252, .12);--border-hover: rgba(192, 132, 252, .25);--text: #1a1a1a;--text-secondary: #6b5b7b;--text-tertiary: #9a8aa8;--accent: #c084fc;--accent-light: rgba(192, 132, 252, .1);--accent-hover: #a855f7;--accent-gradient: linear-gradient(135deg, #c084fc, #e879f9);--accent-soft: linear-gradient(135deg, rgba(192,132,252,.06), rgba(232,121,249,.04));--shadow-sm: 0 1px 2px rgba(192, 132, 252, .06);--shadow-md: 0 4px 12px rgba(192, 132, 252, .08);--shadow-lg: 0 8px 28px rgba(192, 132, 252, .1);--shadow-xl: 0 16px 48px rgba(192, 132, 252, .12);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 24px;--nav-height: 46px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .4s cubic-bezier(.34, 1.56, .64, 1);--elevation-1: 0 1px 2px rgba(192,132,252,.06);--elevation-2: 0 4px 12px rgba(192,132,252,.08);--elevation-3: 0 8px 28px rgba(192,132,252,.1);--elevation-4: 0 16px 48px rgba(192,132,252,.12);--glass-bg: rgba(255,255,255,.92);--glass-border: rgba(192,132,252,.1);--glass-shadow: 0 4px 30px rgba(192,132,252,.06);--el-bg-color: #faf5ff;--el-bg-color-overlay: #ffffff;--el-bg-color-page: #faf5ff;--el-text-color-primary: #1a1a1a;--el-text-color-regular: #555555;--el-text-color-secondary: #6b5b7b;--el-text-color-placeholder: #9a8aa8;--el-border-color: rgba(192, 132, 252, .12);--el-border-color-light: rgba(192, 132, 252, .08);--el-border-color-lighter: rgba(192, 132, 252, .05);--el-fill-color: rgba(192, 132, 252, .05);--el-fill-color-light: rgba(192, 132, 252, .08);--el-fill-color-lighter: rgba(192, 132, 252, .04);--el-fill-color-blank: #ffffff;--el-mask-color: rgba(0, 0, 0, .35);--el-color-primary: #c084fc;--el-color-primary-light-3: #a855f7;--el-color-primary-light-5: #d8b4fe;--el-color-primary-light-7: #e9d5ff;--el-color-primary-light-8: #f3e8ff;--el-color-primary-light-9: #faf5ff;--el-color-primary-dark-2: #a855f7;--el-box-shadow: 0 4px 12px rgba(192, 132, 252, .1);--el-box-shadow-light: 0 2px 6px rgba(192, 132, 252, .06);--el-border-radius-base: var(--radius-sm);--el-border-radius-small: 8px;--el-border-radius-round: 999px;--el-border-radius-circle: 50% }@media(prefers-color-scheme:dark){:root{--bg: #1a0f2e;--bg-card: #24183d;--bg-elevated: #2d1f47;--bg-glass: rgba(192, 132, 252, .08);--bg-glass-hover: rgba(192, 132, 252, .14);--border: rgba(192, 132, 252, .15);--border-hover: rgba(192, 132, 252, .25);--text: #f5f0ff;--text-secondary: #c4b5d4;--text-tertiary: #9a8aaa;--accent: #c084fc;--accent-light: rgba(192, 132, 252, .15);--accent-hover: #d8b4fe;--accent-gradient: linear-gradient(135deg, #c084fc, #e879f9);--accent-soft: linear-gradient(135deg, rgba(192,132,252,.08), rgba(232,121,249,.06));--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .55);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .6);--glass-bg: rgba(36,24,61,.92);--glass-border: rgba(192,132,252,.12);--glass-shadow: 0 4px 30px rgba(0,0,0,.5);--elevation-1: 0 1px 2px rgba(0,0,0,.4);--elevation-2: 0 4px 12px rgba(0,0,0,.5);--elevation-3: 0 8px 28px rgba(0,0,0,.55);--elevation-4: 0 16px 48px rgba(0,0,0,.6);--el-bg-color: #1a0f2e;--el-bg-color-overlay: #24183d;--el-bg-color-page: #1a0f2e;--el-text-color-primary: #f5f0ff;--el-text-color-regular: #c4b5d4;--el-text-color-secondary: #c4b5d4;--el-text-color-placeholder: #9a8aaa;--el-border-color: rgba(192, 132, 252, .15);--el-border-color-light: rgba(192, 132, 252, .1);--el-border-color-lighter: rgba(192, 132, 252, .06);--el-fill-color: rgba(192, 132, 252, .08);--el-fill-color-light: rgba(192, 132, 252, .12);--el-fill-color-lighter: rgba(192, 132, 252, .05);--el-fill-color-blank: #24183d;--el-mask-color: rgba(0, 0, 0, .7);--el-color-primary: #c084fc;--el-color-primary-light-3: #d8b4fe;--el-color-primary-light-5: #a78bfa;--el-color-primary-light-7: #7c3aed;--el-color-primary-light-8: #5b21b6;--el-color-primary-light-9: #2d1f47;--el-color-primary-dark-2: #d8b4fe;--el-box-shadow: 0 4px 12px rgba(0, 0, 0, .5);--el-box-shadow-light: 0 2px 6px rgba(0, 0, 0, .4) }}*{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,PingFang SC,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}::selection{background:var(--accent-light);color:var(--accent)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px;transition:outline-offset .1s ease}html{scroll-behavior:smooth}img{color:transparent}img[loading=lazy]{animation:img-fade-in .3s ease}@keyframes img-fade-in{0%{opacity:0}to{opacity:1}}@keyframes breathe{0%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}@keyframes loading-dot{0%{transform:scale(.6);opacity:.3}40%{transform:scale(1);opacity:1}}@keyframes slide-up-fade{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse-ring{0%{transform:scale(1);opacity:.5}to{transform:scale(1.5);opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-scale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse-soft{0%{opacity:1}50%{opacity:.6}}@keyframes progress-stripes{0%{background-position:0 0}to{background-position:20px 0}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes float-slow{0%{transform:translateY(0) rotate(0)}33%{transform:translateY(-8px) rotate(1deg)}66%{transform:translateY(4px) rotate(-1deg)}}.fade-slide-enter-active{transition:opacity .25s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.34,1.56,.64,1)}.fade-slide-leave-active{transition:opacity .15s cubic-bezier(.4,0,.2,1),transform .15s cubic-bezier(.4,0,.2,1)}.fade-slide-enter-from{opacity:0;transform:translateY(12px) scale(.98)}.fade-slide-leave-to{opacity:0;transform:translateY(-6px) scale(.98)}.fade-up-enter-active{transition:all .3s cubic-bezier(.4,0,.2,1)}.fade-up-leave-active{transition:all .2s cubic-bezier(.4,0,.2,1)}.fade-up-enter-from{opacity:0;transform:translateY(16px)}.fade-up-leave-to{opacity:0;transform:translateY(-8px)}.scale-in-enter-active{transition:all .35s cubic-bezier(.34,1.56,.64,1)}.scale-in-leave-active{transition:all .2s cubic-bezier(.4,0,.2,1)}.scale-in-enter-from{opacity:0;transform:scale(.85)}.scale-in-leave-to{opacity:0;transform:scale(.9)}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}.fade-scale-enter-active{transition:all .2s cubic-bezier(.34,1.56,.64,1)}.fade-scale-leave-active{transition:all .15s ease}.fade-scale-enter-from,.fade-scale-leave-to{opacity:0;transform:scale(.8)}.slide-up-enter-active{transition:all .3s cubic-bezier(.4,0,.2,1)}.slide-up-leave-active{transition:all .2s cubic-bezier(.4,0,.2,1)}.slide-up-enter-from{opacity:0;transform:translateY(20px)}.slide-up-leave-to{opacity:0;transform:translateY(-10px)}.shake-enter-active{animation:shake-in .4s cubic-bezier(.34,1.56,.64,1)}.shake-leave-active{transition:opacity .2s ease,transform .2s ease}.shake-enter-from{opacity:0;transform:translate(-10px)}.shake-leave-to{opacity:0;transform:translateY(-8px)}@keyframes shake-in{0%{opacity:0;transform:translate(-20px)}60%{transform:translate(6px)}80%{transform:translate(-3px)}to{opacity:1;transform:translate(0)}}.animate-in{animation:fade-up .4s cubic-bezier(.4,0,.2,1) both}.animate-in-d1{animation-delay:.05s}.animate-in-d2{animation-delay:.1s}.animate-in-d3{animation-delay:.15s}.animate-in-d4{animation-delay:.2s}.animate-in-d5{animation-delay:.25s}.glass{background:var(--glass-bg);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid var(--glass-border)}.text-gradient{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.elevation-1{box-shadow:var(--elevation-1)}.elevation-2{box-shadow:var(--elevation-2)}.elevation-3{box-shadow:var(--elevation-3)}.elevation-4{box-shadow:var(--elevation-4)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.4;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.005) 2px,rgba(0,0,0,.005) 4px)}.tactile:active{transform:scale(.96)!important}.glow-ring:focus-visible{outline:none;box-shadow:0 0 0 4px var(--accent-light)}.loading-dots:after{content:"";display:inline-block;animation:loading-dot 1.4s ease-in-out infinite both}.loading-dots span{display:inline-block;width:4px;height:4px;border-radius:50%;background:currentColor;margin:0 1px;animation:loading-dot 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.img-blur{filter:blur(20px);transition:filter .5s cubic-bezier(.4,0,.2,1)}.img-blur.loaded{filter:blur(0)}.hover-sweep{position:relative;text-decoration:none}.hover-sweep:after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent-gradient);transition:width .3s cubic-bezier(.4,0,.2,1);border-radius:2px}.hover-sweep:hover:after{width:100%}.skeleton-shimmer{background:linear-gradient(90deg,var(--bg-glass) 25%,var(--bg-glass-hover) 37%,var(--bg-glass) 63%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 20px;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden;-webkit-user-select:none;user-select:none;white-space:nowrap;line-height:1}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 10px #40a9ff40}.btn-primary:hover:not(:disabled){box-shadow:0 8px 24px #40a9ff59;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0) scale(.97)}.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}.btn-outline:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-light);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none}.btn-ghost:hover:not(:disabled){background:var(--bg-glass);color:var(--text)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 10px #ef444440}.btn-danger:hover:not(:disabled){box-shadow:0 8px 24px #ef444459;transform:translateY(-2px)}.btn-sm{padding:6px 14px;font-size:12px;border-radius:8px}.btn-lg{padding:12px 28px;font-size:15px;border-radius:12px}.btn-block{width:100%}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-base)}.card-hover:hover{transform:translateY(-2px);box-shadow:var(--elevation-3);border-color:var(--border-hover)}.card-glass{background:var(--glass-bg);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid var(--glass-border);border-radius:var(--radius-md)}.card-flat{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-sm)}.tag{display:inline-flex;align-items:center;height:22px;padding:0 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--accent-light);color:var(--accent);white-space:nowrap;transition:all var(--transition-fast)}.tag-hot{background:#ef44441a;color:#ef4444}.tag-success{background:#10b9811a;color:#10b981}.tag-warning{background:#f59e0b1a;color:#f59e0b}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;font-size:10px;font-weight:700;background:var(--accent);color:#fff;line-height:1}.skeleton{border-radius:var(--radius-md);overflow:hidden;background:var(--bg-card);border:1px solid var(--border)}.skeleton-img{width:100%;aspect-ratio:4 / 3;background:linear-gradient(90deg,var(--bg-glass) 25%,var(--bg-glass-hover) 50%,var(--bg-glass) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.skeleton-body{padding:12px 14px 14px}.skeleton-line{height:12px;border-radius:6px;background:linear-gradient(90deg,var(--bg-glass) 25%,var(--bg-glass-hover) 50%,var(--bg-glass) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;margin-bottom:8px}.skeleton-line-short{width:55%}.client-layout{min-height:100vh;padding-bottom:var(--nav-height);background:var(--bg)}.page{max-width:100%;margin:0 auto;padding:0 0 16px}.hp-header{position:relative;overflow:hidden;background:linear-gradient(180deg,#fef8f4 0%,#fdf2ee 40%,var(--bg) 100%);padding:0 0 4px;margin-bottom:12px;transition:box-shadow .3s ease}.hp-header-scrolled{box-shadow:0 1px 0 var(--border)}.hp-header-glow{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}@media(hover:hover){.hp-header-glow:before{content:"";position:absolute;top:-120px;right:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(244,114,182,.08) 0%,transparent 60%)}.hp-header-glow:after{content:"";position:absolute;bottom:-60px;left:-40px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(64,169,255,.06) 0%,transparent 60%)}}.hp-header-inner{max-width:1000px;margin:0 auto;padding:20px 16px 12px;position:relative;z-index:1}.hp-top-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}.hp-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.hp-brand-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#7ec1ff,#40a9ff);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px #40a9ff4d;transition:all .35s cubic-bezier(.34,1.56,.64,1)}.hp-brand-icon:hover{transform:scale(1.1) rotate(-5deg);box-shadow:0 6px 20px #40a9ff66}.hp-brand-icon svg{width:22px;height:22px;display:block}.hp-brand-text{display:flex;flex-direction:column;gap:1px}.hp-brand-name{font-size:18px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,#40a9ff,#7ec1ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.hp-brand-desc{font-size:11px;color:var(--text-tertiary);font-weight:500;letter-spacing:.3px}.hp-search-box{flex:1;position:relative;min-width:0}.hp-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--text-tertiary);pointer-events:none;transition:color .25s ease}.hp-search-box:focus-within .hp-search-icon{color:var(--accent)}.hp-search-input{width:100%;padding:10px 16px 10px 42px;border:1.5px solid var(--border);border-radius:999px;background:var(--bg-card);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #00000008;-webkit-appearance:none}.hp-search-box.focused .hp-search-input{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-light),0 2px 8px #40a9ff14;padding-right:40px}.hp-search-input::placeholder{color:var(--text-tertiary);font-weight:400;transition:color .2s,opacity .2s}.hp-search-box.focused .hp-search-input::placeholder{color:var(--text-secondary);opacity:.6}.hp-search-clear{position:absolute;right:6px;top:50%;transform:translateY(-50%) scale(.8);width:26px;height:26px;border-radius:50%;border:none;background:var(--bg-glass-hover);color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;animation:clear-in .2s cubic-bezier(.34,1.56,.64,1) forwards;transition:background .15s,color .15s;padding:0}.hp-search-clear:hover{background:var(--border-hover);color:var(--text-secondary)}.hp-search-clear svg{width:14px;height:14px;display:block}@keyframes clear-in{0%{opacity:1;transform:translateY(-50%) scale(1)}}.hp-cats-row{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:2px 0;position:relative}.hp-cats-row::-webkit-scrollbar{display:none}.hp-cat-indicator{position:absolute;bottom:2px;height:28px;border-radius:999px;background:linear-gradient(135deg,#7ec1ff,#40a9ff);z-index:0;transition:transform .35s cubic-bezier(.34,1.56,.64,1),width .35s cubic-bezier(.34,1.56,.64,1);pointer-events:none;box-shadow:0 2px 8px #40a9ff33}.hp-cat{flex-shrink:0;display:inline-flex;align-items:center;gap:4px;padding:7px 16px;border-radius:999px;font-size:13px;font-weight:600;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-family:inherit;-webkit-user-select:none;user-select:none;white-space:nowrap;box-shadow:0 1px 2px #00000005;position:relative;z-index:1}.hp-cat:hover{border-color:#f59e9e;color:#e05a5a;transform:translateY(-2px);box-shadow:0 4px 12px #ef44441a}.hp-cat:active{transform:scale(.95)}.hp-cat.active{border-color:transparent;color:#fff;font-weight:700;background:transparent;box-shadow:none}.hp-cat.active:hover{transform:translateY(-2px);color:#fff}.hp-cat-emoji{font-size:14px;line-height:1}.hp-section-label{display:flex;align-items:center;gap:6px;font-size:15px;font-weight:700;color:var(--text);margin-bottom:14px;padding:0 16px;max-width:1000px;margin-left:auto;margin-right:auto}.hp-section-icon{font-size:16px;line-height:1}.hp-section-count{margin-left:auto;font-size:12px;font-weight:500;color:var(--text-tertiary);background:var(--bg-glass);padding:2px 10px;border-radius:999px}.hp-featured{max-width:1000px;margin:0 auto 24px;padding:0 16px}.hp-featured-scroll{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media(max-width:640px){.hp-featured-scroll{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.hp-featured-scroll{grid-template-columns:repeat(4,1fr)}}.hp-fcard{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;text-decoration:none;color:inherit;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s ease,border-color .3s ease;box-shadow:0 1px 2px #0000000a;animation:slide-up-fade .4s cubic-bezier(.34,1.56,.64,1) both}.hp-fcard-img{position:relative;overflow:hidden;aspect-ratio:4 / 3;background:var(--bg-glass)}.hp-fcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.hp-fcard-over{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.6));display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.hp-fcard-btn{padding:6px 20px;border-radius:999px;font-size:12px;font-weight:700;background:#fffffff2;color:var(--accent);transform:translateY(6px);transition:all .3s ease}.hp-fcard-body{padding:10px 12px;display:flex;align-items:center;gap:6px}.hp-fcard-title{flex:1;font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-fcard-usage{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.hp-main{max-width:1000px;margin:0 auto;padding:0 16px}.hp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;content-visibility:auto;contain-intrinsic-size:280px}@media(min-width:640px){.hp-grid{grid-template-columns:repeat(3,1fr);gap:16px}}@media(min-width:900px){.hp-grid{grid-template-columns:repeat(4,1fr)}}.hp-gcard{contain-intrinsic-size:320px;display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;text-decoration:none;color:inherit;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s ease,border-color .3s ease;box-shadow:0 1px 2px #0000000a;animation:slide-up-fade .25s cubic-bezier(.34,1.56,.64,1) both;animation-delay:var(--delay, 0s);position:relative;content-visibility:auto;contain:layout style paint;cursor:pointer;-webkit-tap-highlight-color:transparent}.hp-gcard:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .35s ease;box-shadow:0 4px 8px #0000000a,0 12px 32px #0000000f,0 24px 60px #0000000a}@media(hover:hover){.hp-gcard:hover{transform:translateY(-5px);border-color:var(--accent)}.hp-gcard:hover:after{opacity:1}.hp-gcard:nth-child(odd):hover{transform:translateY(-5px) perspective(800px) rotateY(1.5deg)}.hp-gcard:nth-child(2n):hover{transform:translateY(-5px) perspective(800px) rotateY(-1.5deg)}.hp-gcard:hover .hp-gcard-img img{transform:scale(1.15)}.hp-gcard:hover .hp-gcard-over{opacity:1}.hp-gcard:hover .hp-gcard-btn{transform:translateY(0);background:#fff;box-shadow:0 8px 28px #0003}.hp-fcard:hover{transform:translateY(-4px);box-shadow:0 8px 24px #40a9ff1a;border-color:var(--accent)}.hp-fcard:hover .hp-fcard-img img{transform:scale(1.1)}.hp-fcard:hover .hp-fcard-over{opacity:1}.hp-fcard:hover .hp-fcard-btn{transform:translateY(0)}.hp-gcard-tag:hover{filter:brightness(1.1);transform:scale(1.04)}.hp-gcard-btn:hover{transform:translateY(-2px)!important;box-shadow:0 12px 32px #00000040!important}}.hp-gcard-img{position:relative;overflow:hidden;aspect-ratio:1 / 1;background:var(--bg-glass)}.hp-gcard-img-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--bg-glass) 25%,var(--bg-glass-hover) 50%,var(--bg-glass) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;z-index:1}.hp-gcard-img img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1),opacity .4s ease;opacity:0}.hp-gcard-img img.loaded{opacity:1}.hp-gcard-over{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 25%,rgba(0,0,0,.65));display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .35s cubic-bezier(.4,0,.2,1)}.hp-gcard-btn{padding:8px 24px;border-radius:999px;font-size:13px;font-weight:700;background:#fffffff2;color:var(--accent);transition:all .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 10px #0000001f;transform:translateY(8px);border:none;cursor:pointer;font-family:inherit;line-height:1}.hp-gcard-hot{position:absolute;top:8px;left:8px;padding:2px 10px;border-radius:999px;font-size:10px;font-weight:700;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;box-shadow:0 2px 8px #ef444459;animation:breathe 2.5s ease-in-out infinite;z-index:2}.hp-gcard-foot{display:flex;padding:10px 12px;border-top:1px solid var(--border);background:var(--bg-card);min-width:0}.hp-gcard-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.hp-gcard-title{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.hp-gcard-extra{display:flex;align-items:center;gap:6px}.hp-gcard-tag{flex-shrink:0;padding:1px 8px;border-radius:999px;font-size:10px;font-weight:600;background:var(--accent-light);color:var(--accent);line-height:1.6}.hp-gcard-usage{font-size:10px;color:var(--text-tertiary);flex-shrink:0}.hp-empty{text-align:center;padding:60px 20px 80px;color:var(--text-tertiary);animation:fade-up .4s ease;max-width:1000px;margin:0 auto}.hp-empty-icon{display:inline-flex;width:80px;height:80px;border-radius:50%;background:var(--bg-glass);align-items:center;justify-content:center;margin-bottom:16px;color:var(--text-tertiary);position:relative}.hp-empty-icon svg{width:80px;height:80px;opacity:.5}.hp-empty-ring{animation:draw-ring 1.2s cubic-bezier(.4,0,.2,1) forwards}.hp-empty-sweep{animation:sweep-line 2s ease-in-out infinite;transform-origin:center}@keyframes draw-ring{0%{stroke-dashoffset:0}}@keyframes sweep-line{0%{opacity:.2;transform:translate(0)}50%{opacity:.5;transform:translate(4px)}}.hp-empty-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}.hp-empty-desc{font-size:13px;color:var(--text-tertiary);margin:0 0 20px;line-height:1.6}.hp-empty-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 24px;border-radius:999px;border:1.5px solid var(--accent);background:transparent;color:var(--accent);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease}.hp-empty-btn:hover{background:var(--accent-light);transform:translateY(-1px)}.hp-more{display:flex;justify-content:center;padding:24px 0 16px}.hp-more-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 32px;border-radius:999px;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-base);font-family:inherit;box-shadow:var(--elevation-1)}.hp-more-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-light);transform:translateY(-2px);box-shadow:var(--elevation-2)}.hp-more-btn:active:not(:disabled){transform:scale(.96)}.hp-more-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.hp-spin{animation:spin .8s linear infinite;width:14px;height:14px}.hp-end{display:flex;align-items:center;justify-content:center;gap:16px;padding:28px 0 24px}.hp-end-line{display:block;width:48px;height:1px;background:var(--border)}.hp-end-text{font-size:12px;color:var(--text-tertiary);flex-shrink:0}.tag{display:inline-flex;align-items:center;height:22px;padding:0 10px;border-radius:999px;font-size:10px;font-weight:600;background:var(--accent-light);color:var(--accent)}.gp-view{max-width:640px;margin:0 auto;padding:0 16px 32px;position:relative;min-height:100vh}.gp-view:before{content:"";position:fixed;top:-20%;right:-20%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(64,169,255,.07) 0%,transparent 60%);pointer-events:none;z-index:0;animation:float-slow 15s ease-in-out infinite}.gp-view:after{content:"";position:fixed;bottom:-10%;left:-20%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(232,160,200,.06) 0%,transparent 60%);pointer-events:none;z-index:0;animation:float-slow 10s ease-in-out infinite reverse}.gp-bar{display:flex;align-items:center;gap:8px;padding:14px 0;margin-bottom:20px;position:relative;z-index:1}.gp-back{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;padding:8px 14px;border-radius:999px;background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);transition:all var(--transition-fast);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.gp-back:hover{color:var(--text);border-color:var(--border-hover)}.gp-back:active{transform:scale(.95)}.gp-bar-title{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.gp-body{position:relative;z-index:1;display:flex;flex-direction:column;gap:16px}.gp-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 24px;border-radius:28px;background:linear-gradient(135deg,#40a9ff0f,#7ec1ff0f);border:2px dashed rgba(64,169,255,.15);cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);text-align:center;position:relative;overflow:hidden}.gp-upload:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 40%,rgba(64,169,255,.04) 0%,transparent 50%),radial-gradient(ellipse at 70% 60%,rgba(232,160,200,.04) 0%,transparent 50%);pointer-events:none}.gp-upload:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 32px #40a9ff1a;background:linear-gradient(135deg,#40a9ff14,#7ec1ff14)}.gp-upload:active{transform:scale(.97)}.gp-upload.drag-over{border-color:var(--accent);border-style:solid;background:linear-gradient(135deg,#40a9ff1f,#7ec1ff1a);transform:scale(1.01);box-shadow:0 0 0 4px #40a9ff1a;animation:border-glow 1.2s ease-in-out infinite}.gp-upload-icon{width:56px;height:56px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 16px #40a9ff40;animation:float 3s ease-in-out infinite;position:relative;z-index:1}.gp-upload-icon svg{width:24px;height:24px}.gp-upload-label{font-size:17px;font-weight:600;color:var(--text);position:relative;z-index:1}.gp-upload-hint{font-size:13px;color:var(--text-tertiary);position:relative;z-index:1}.gp-upload-paste{font-size:12px;color:var(--text-tertiary);opacity:.5;transition:opacity .2s;position:relative;z-index:1}.gp-upload:hover .gp-upload-paste{opacity:1}.gp-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:20px;padding:18px;box-shadow:var(--glass-shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:box-shadow var(--transition-base)}.gp-card-hd{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.gp-card-hd svg{width:14px;height:14px;color:var(--accent);flex-shrink:0}.gp-card-bd{color:var(--text)}.gp-tpl-strip{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.gp-tpl-strip::-webkit-scrollbar{display:none}.gp-tpl-thumb{flex-shrink:0;width:72px;height:72px;border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s;opacity:.6}.gp-tpl-thumb:hover{opacity:.85}.gp-tpl-thumb.active{border-color:var(--accent);opacity:1;box-shadow:0 0 0 1px var(--accent)}.gp-tpl-thumb img{width:100%;height:100%;object-fit:cover;display:block}.gp-tpl-name{font-size:15px;font-weight:700;color:var(--text);line-height:1.4}.gp-tpl-desc{margin-top:4px;font-size:13px;color:var(--text-secondary);line-height:1.7}.gp-carousel-wrap{margin-top:12px}.gp-prompt{font-size:13px;color:var(--text-secondary);line-height:1.7;padding:14px;background:var(--accent-soft);border-radius:14px;border-left:3px solid var(--accent)}.gp-opt{display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:500;color:var(--text)}.gp-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 24px;border:none;border-radius:999px;font-size:16px;font-weight:700;font-family:inherit;background:linear-gradient(135deg,#40a9ff,#7ec1ff);background-size:200% 100%;color:#fff;cursor:pointer;box-shadow:0 4px 20px #40a9ff4d;transition:all .25s cubic-bezier(.4,0,.2,1);line-height:1;position:relative;overflow:hidden;letter-spacing:.3px}.gp-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transform:translate(-100%);transition:transform .6s ease}.gp-btn:hover:not(:disabled):before{transform:translate(100%)}.gp-btn:hover:not(:disabled){box-shadow:0 8px 32px #40a9ff66;transform:translateY(-2px);background-position:100% 0}.gp-btn:active:not(:disabled){transform:translateY(0) scale(.97)}.gp-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}.gp-btn svg{flex-shrink:0}.gp-img-section{display:flex;flex-direction:column;gap:12px}.gp-img-frame{border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #0000000f;background:var(--bg-glass);line-height:0}.gp-img{width:100%;display:block}.gp-img-actions{display:flex;gap:8px}.gp-btn-sm{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:8px 18px;border-radius:999px;font-size:13px;font-weight:600;font-family:inherit;border:1px solid var(--border);background:var(--glass-bg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);line-height:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gp-btn-sm:hover{border-color:var(--accent);color:var(--accent);background:#40a9ff0f}.gp-btn-sm:active{transform:scale(.95)}.gp-btn-sm.primary{background:linear-gradient(135deg,#40a9ff,#7ec1ff);color:#fff;border-color:transparent;box-shadow:0 2px 8px #40a9ff33}.gp-btn-sm.primary:hover{box-shadow:0 6px 18px #40a9ff4d;transform:translateY(-1px);color:#fff}.gp-progress{margin-top:4px;padding:16px 18px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slide-up-fade .3s ease}.gp-progress-bar{height:5px;background:var(--bg-glass);border-radius:999px;overflow:hidden}.gp-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#40a9ff,#7ec1ff,#40a9ff);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;transition:width .5s cubic-bezier(.4,0,.2,1);position:relative}.gp-progress-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;box-shadow:0 0 10px #40a9ff4d;opacity:.5}.gp-progress-label{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:13px;color:var(--text-secondary)}.gp-progress-pct{margin-left:auto;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums;min-width:3em;text-align:right}.gp-result{margin-top:4px;animation:slide-up-fade .4s cubic-bezier(.34,1.56,.64,1)}.gp-result-hd{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:700;color:var(--text);margin-bottom:12px}.gp-result-hd svg{color:var(--accent);width:16px;height:16px}.gp-result-img{width:100%;border-radius:20px;box-shadow:0 4px 20px #0000000f;display:block;cursor:zoom-in;transition:transform .3s ease,box-shadow .3s ease}.gp-result-img:hover{transform:scale(1.005);box-shadow:0 8px 32px #00000014}.gp-result-err{padding:12px;text-align:center;font-size:13px;color:#ef4444;background:#ef44440d;border-radius:14px;margin-top:8px}.gp-result-badge{margin-left:auto;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;background:#10b9811a;color:#10b981}.gp-result-tip{text-align:center;font-size:11px;color:var(--text-tertiary);margin-top:6px}.gp-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#00000073;color:#fff;font-size:13px;font-weight:600;border-radius:20px}.gp-img-overlay .gp-spinner.light{width:28px;height:28px;border-color:#fff3;border-top-color:#fff}.gp-img-frame.generating{position:relative;animation:gen-pulse 1.5s ease-in-out infinite}@keyframes gen-pulse{0%,to{box-shadow:0 0 #40a9ff4d}50%{box-shadow:0 0 0 8px #40a9ff00}}.gp-btn-pulse{animation:btn-pulse 2s ease-in-out infinite}@keyframes btn-pulse{0%,to{box-shadow:0 0 rgba(var(--accent-rgb,99,102,241),.3)}50%{box-shadow:0 0 0 8px rgba(var(--accent-rgb,99,102,241),0)}}.gp-error{margin-top:4px;padding:20px;border-radius:20px;background:var(--glass-bg);border:1px solid rgba(239,68,68,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:fade-up .3s ease}.gp-error-title{font-size:15px;font-weight:700;color:#ef4444;margin-bottom:6px}.gp-error-msg{font-size:13px;color:var(--text-secondary);line-height:1.6}.gp-error-actions{margin-top:14px;display:flex;gap:8px}.gp-state-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 24px;border-radius:28px;background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.gp-spinner{width:36px;height:36px;border:3px solid rgba(64,169,255,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.gp-state-text{font-size:15px;color:var(--text-secondary);font-weight:500}.gp-history{margin-top:4px}.gp-history-hd{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.gp-history-hd svg{width:14px;height:14px;color:var(--accent)}.gp-hstrip{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.gp-hitem{border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;aspect-ratio:1;position:relative;border:1px solid var(--border)}.gp-hitem:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 16px #40a9ff26}.gp-hitem img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.gp-hitem:hover img{transform:scale(1.06)}.gp-hitem-time{position:absolute;bottom:4px;right:4px;font-size:9px;font-weight:600;color:#fff;background:#0009;padding:1px 6px;border-radius:4px;z-index:1;line-height:1.4}.gp-h-empty{font-size:13px;color:var(--text-tertiary);padding:16px 0;text-align:center}.gp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000d9;display:flex;align-items:center;justify-content:center;cursor:pointer;animation:fade-in .2s ease}.gp-overlay-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:#ffffff14;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:1}.gp-overlay-close:hover{background:#ffffff26;transform:scale(1.1)}.gp-overlay-close svg{width:20px;height:20px}.gp-overlay-img{max-width:92vw;max-height:90vh;border-radius:16px;box-shadow:0 20px 60px #0006;animation:fade-scale .3s cubic-bezier(.34,1.56,.64,1);cursor:default}.status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--text-tertiary);animation:pulse-soft 1.5s ease-in-out infinite}.status-dot.queued{background:#f59e0b}.status-dot.running{background:var(--accent);animation-duration:1s}.status-dot.success{background:#10b981;animation:none}.status-dot.failed{background:#ef4444;animation:none}.spacer{flex:1}.history-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}@media(max-width:600px){.history-grid{grid-template-columns:repeat(4,1fr)}}.history-item{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);background:var(--bg-card)}.history-item:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--elevation-2)}.history-item img{width:100%;height:80px;object-fit:cover;display:block}.hi-label{display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:10px;color:var(--text-tertiary);font-weight:500}.hi-time{margin-left:auto;font-size:9px;opacity:.7;flex-shrink:0}.hp-scroll-top{position:fixed;bottom:80px;right:20px;z-index:90;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border);background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:var(--elevation-2);font-size:0}.hp-scroll-top:hover{transform:translateY(-3px);box-shadow:var(--elevation-3);border-color:var(--accent);color:var(--accent)}.hp-scroll-top:active{transform:scale(.92)}.hp-scroll-ring{position:absolute;width:36px;height:36px;color:var(--accent);pointer-events:none}.hp-scroll-ring-fill{transition:stroke-dashoffset .3s cubic-bezier(.4,0,.2,1)}.hp-scroll-arrow{width:20px;height:20px;position:relative;z-index:1}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:var(--glass-bg);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-around;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav a,.bottom-nav>a{display:flex;flex-direction:column;align-items:center;gap:1px;text-decoration:none;color:var(--text-tertiary);font-size:9px;font-weight:500;padding:5px 20px;border-radius:10px;transition:all var(--transition-base);position:relative}.bottom-nav a.active{color:var(--accent)}.bottom-nav a .nav-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;background:var(--accent-light);opacity:0;transition:opacity var(--transition-base)}.bottom-nav a.active .nav-bg{opacity:1}.bottom-nav a svg{width:20px;height:20px;position:relative;z-index:1;transition:transform var(--transition-bounce)}.bottom-nav a.active svg{transform:scale(1.08)}.bottom-nav a span{font-size:9px;font-weight:600;position:relative;z-index:1}.el-overlay{background-color:var(--el-mask-color);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.el-dialog{--el-dialog-bg-color: var(--bg-card);--el-dialog-border-color: var(--border);border-radius:var(--radius-xl)!important;box-shadow:var(--elevation-4);padding:0!important;overflow:hidden;animation:fade-scale .2s cubic-bezier(.4,0,.2,1)}.el-dialog__header{border-bottom:1px solid var(--border);padding:16px 20px;margin:0!important}.el-dialog__headerbtn{top:16px;right:16px}.el-dialog__title{font-weight:700;font-size:16px;color:var(--text)}.el-dialog__body{padding:20px;color:var(--text);font-size:14px}.el-dialog__body img{width:100%;max-height:65vh;object-fit:contain;border-radius:var(--radius-sm);display:block}.el-dialog__footer{border-top:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;justify-content:flex-end;gap:8px}.el-button{border-radius:var(--radius-sm)!important;font-weight:600!important;transition:all var(--transition-base)!important}.el-button:hover{transform:translateY(-1px)}.el-button:active{transform:scale(.97)!important}.el-button--primary{--el-button-bg-color: var(--accent);--el-button-border-color: var(--accent);--el-button-hover-bg-color: var(--accent-hover);--el-button-hover-border-color: var(--accent-hover) }.byte-btn.el-button--primary{border:none;background:var(--accent-gradient);color:#fff;box-shadow:0 2px 10px #40a9ff40}.byte-btn.el-button--primary:hover{box-shadow:0 8px 24px #40a9ff59;transform:translateY(-2px)!important}.byte-btn.ant-btn-primary{border:none;background:var(--accent-gradient);color:#fff;box-shadow:0 2px 10px #40a9ff40}.byte-btn.ant-btn-primary:hover{box-shadow:0 8px 24px #40a9ff59;transform:translateY(-2px)}.admin-form-card .ant-input,.admin-form-card .ant-input-password,.admin-form-card .ant-input-number{border-radius:var(--radius-sm)}.el-button--primary:not(.byte-btn){box-shadow:0 2px 8px #40a9ff33}.el-button--primary:not(.byte-btn):hover{box-shadow:0 6px 20px #40a9ff4d}.el-input__wrapper{background:var(--bg-card)!important;border:1.5px solid var(--border)!important;box-shadow:none!important;border-radius:var(--radius-sm)!important;transition:all var(--transition-base)!important}.el-input__wrapper:hover{border-color:var(--border-hover)!important}.el-input__wrapper.is-focus{border-color:var(--accent)!important;box-shadow:0 0 0 4px var(--accent-light)!important}.el-input__inner{color:var(--text)!important}.el-input__inner::placeholder{color:var(--text-tertiary)!important}.el-switch.is-checked .el-switch__core{border-color:var(--accent);background-color:var(--accent)}.el-progress-bar__outer{background:var(--bg-glass)!important;border-radius:999px!important;overflow:hidden}.el-progress-bar__inner{background:var(--accent-gradient)!important;border-radius:999px!important;transition:width .4s cubic-bezier(.4,0,.2,1)!important}.el-progress__text{color:var(--text-secondary)!important;font-size:12px!important;font-weight:600!important}.el-collapse-item__header{color:var(--text-secondary)!important;font-size:13px;font-weight:600;border-bottom:1px solid var(--border)!important;padding:8px 0}.el-collapse-item__content{color:var(--text-secondary);font-size:13px;line-height:1.7;padding-bottom:12px}.el-alert{border-radius:var(--radius-sm)!important}.el-alert--error{background:#ef44440f!important;border:1px solid rgba(239,68,68,.12)}.el-alert__title{color:#ef4444!important}.el-alert--info{background:var(--accent-light)!important;border:1px solid rgba(64,169,255,.15)}.el-alert--info .el-alert__title{color:var(--accent)!important}.el-empty__description p{color:var(--text-tertiary)!important}.el-empty__image svg{opacity:.2}.el-message{border-radius:var(--radius-sm)!important;border:1px solid var(--border)!important;background:var(--bg-card)!important;box-shadow:var(--elevation-3)!important;padding:12px 16px!important}.el-message .el-message__content{color:var(--text)!important;font-size:13px!important}.el-notification{background:var(--bg-card)!important;border:1px solid var(--border)!important;border-radius:var(--radius-md)!important;box-shadow:var(--elevation-3)!important}.el-notification__title{color:var(--text)!important}.el-notification__content{color:var(--text-secondary)!important}.el-card{background:var(--bg-card)!important;border:1px solid var(--border)!important;border-radius:var(--radius-md)!important;overflow:hidden}.el-step__head.is-finish{color:var(--accent)!important;border-color:var(--accent)!important}.el-step__title.is-finish{color:var(--accent)!important}.el-step__head.is-process{color:var(--accent)!important;border-color:var(--accent)!important}.el-step__head.is-wait{color:var(--text-tertiary)!important;border-color:var(--border)!important}.el-select{width:100%}.el-select .el-input__wrapper{padding-right:4px}.el-select-dropdown{background:var(--bg-elevated)!important;border:1px solid var(--border)!important;border-radius:var(--radius-sm)!important;box-shadow:var(--elevation-3)!important;padding:4px!important}.el-select-dropdown__item{border-radius:6px!important;font-size:13px!important;padding:8px 12px!important;margin:2px 0!important;color:var(--text)!important}.el-select-dropdown__item.hover{background:var(--bg-glass)!important}.el-select-dropdown__item.selected{background:var(--accent-light)!important;color:var(--accent)!important;font-weight:600!important}.el-select-dropdown__wrap{max-height:260px}.el-popper.is-light{border:1px solid var(--border)!important}.el-popper__arrow:before{background:var(--bg-elevated)!important;border-color:var(--border)!important}.el-pagination{padding:8px 0!important;font-weight:500!important}.el-pagination button{border-radius:8px!important;min-width:28px!important;height:28px!important;margin:0 2px!important}.el-pagination .el-pager li{border-radius:8px!important;min-width:28px!important;height:28px!important;margin:0 2px!important;font-size:12px!important;font-weight:600!important;color:var(--text-secondary)!important;background:transparent!important;border:none!important}.el-pagination .el-pager li.active{background:var(--accent-gradient)!important;color:#fff!important;box-shadow:0 2px 8px #40a9ff4d!important}.el-pagination .el-pager li:hover,.el-pagination button:hover{color:var(--accent)!important}.el-pagination .el-select .el-input__wrapper{box-shadow:none!important;border:1px solid var(--border)!important}.el-tag{border-radius:999px!important;padding:0 12px!important;height:24px!important;font-size:11px!important;font-weight:600!important;border:none!important}.el-tag.el-tag--success{background:#10b9811a!important;color:#10b981!important}.el-tag.el-tag--danger{background:#ef44441a!important;color:#ef4444!important}.el-tag.el-tag--warning{background:#f59e0b1a!important;color:#f59e0b!important}.el-tag.el-tag--info{background:var(--bg-glass)!important;color:var(--text-secondary)!important}.el-tabs__header{margin:0 0 16px!important;border-bottom:1px solid var(--border)!important}.el-tabs__nav-wrap:after{height:1px!important;background:var(--border)!important}.el-tabs__active-bar{background:var(--accent-gradient)!important;height:2.5px!important;border-radius:2px!important}.el-tabs__item{font-size:13px!important;font-weight:600!important;color:var(--text-secondary)!important;padding:0 16px!important;height:40px!important;line-height:40px!important;transition:color var(--transition-fast)!important}.el-tabs__item:hover{color:var(--accent)!important}.el-tabs__item.is-active{color:var(--accent)!important;font-weight:700!important}.el-upload{display:inline-flex!important}.el-upload-list{margin-top:8px}.el-upload-list__item{border-radius:var(--radius-sm)!important;transition:all var(--transition-fast)!important;font-size:12px!important}.el-upload--text{margin-right:8px}.el-input-number{width:140px!important}.el-input-number .el-input__wrapper{padding:0 40px!important}.el-input-number__decrease,.el-input-number__increase{border:none!important;background:var(--bg-glass)!important;color:var(--text-secondary)!important;border-radius:6px!important;margin:2px!important;width:22px!important;height:calc(100% - 4px)!important;right:2px!important}.el-input-number__decrease{left:2px!important;right:auto!important}.el-input-number__decrease:hover,.el-input-number__increase:hover{background:var(--accent-light)!important;color:var(--accent)!important}.el-message-box{border-radius:var(--radius-lg)!important;border:1px solid var(--border)!important;background:var(--bg-card)!important;box-shadow:var(--elevation-4)!important;padding:0!important;overflow:hidden}.el-message-box__header{padding:16px 20px!important;border-bottom:1px solid var(--border)!important}.el-message-box__title{font-size:15px!important;font-weight:700!important;color:var(--text)!important}.el-message-box__content{padding:20px!important;color:var(--text-secondary)!important;font-size:13px!important}.el-message-box__btns{padding:12px 20px!important;border-top:1px solid var(--border)!important;display:flex!important;justify-content:flex-end!important;gap:8px!important}.el-message-box__btns .el-button{padding:8px 18px!important}.el-row{margin-bottom:0!important}.el-loading-mask{background:#00000008!important;border-radius:var(--radius-md)!important}@media(prefers-color-scheme:dark){:root{background:#00000080!important}}.el-loading-spinner .path{stroke:var(--accent)!important}.el-button.is-link{font-weight:600!important;padding:4px 8px!important;border-radius:6px!important;transition:all var(--transition-fast)!important}.el-button.is-link:hover{background:var(--accent-light)!important;color:var(--accent)!important}.el-button.is-link.el-button--danger:hover{background:#ef44441a!important;color:#ef4444!important}.el-dialog__footer .el-button+.el-button{margin-left:8px}.admin-layout{display:grid;grid-template-columns:240px 1fr;height:100vh;overflow:hidden}.sidebar{background:var(--bg-card);padding:0;display:flex;flex-direction:column;border-right:1px solid var(--border);overflow-y:auto;position:relative}.sidebar:after{content:"";position:absolute;top:0;right:-1px;width:1px;height:100%;background:var(--border)}.sidebar-head{display:flex;align-items:center;gap:12px;padding:22px 18px 20px;border-bottom:1px solid var(--border);margin-bottom:6px}.sidebar-head .logo{width:38px;height:38px;border-radius:11px;background:var(--accent-gradient);color:#fff;font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 3px 10px #40a9ff40}.sidebar-head .head-text h3{margin:0;font-size:15px;font-weight:700;color:var(--text)}.sidebar-head .head-text p{margin:2px 0 0;font-size:11px;color:var(--text-tertiary)}.sidebar-nav{flex:1;padding:0 10px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:all var(--transition-base);position:relative;overflow:hidden}.nav-item:hover{background:var(--bg-glass);color:var(--text)}.nav-item.router-link-active{background:var(--accent-light);color:var(--accent);font-weight:600}.nav-indicator{position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:20px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#40a9ff,#69b1ff);transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.nav-item.router-link-active .nav-indicator{transform:translateY(-50%) scaleY(1)}.nav-item .nav-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg-glass);color:var(--text-tertiary);transition:all var(--transition-base)}.nav-item:hover .nav-icon{background:var(--bg-glass-hover);color:var(--text-secondary)}.nav-item.router-link-active .nav-icon{background:var(--accent-light);color:var(--accent)}.nav-item:hover .nav-icon svg{transform:scale(1.1)}.nav-item .nav-icon svg{width:16px;height:16px;display:block;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.nav-item .nav-label{flex:1}.nav-item .nav-badge{padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;background:var(--accent-light);color:var(--accent)}.sidebar-footer{padding:14px 16px;border-top:1px solid var(--border);margin-top:6px;display:flex;align-items:center;gap:10px}.sidebar-footer .avatar{width:32px;height:32px;border-radius:9px;background:var(--accent-gradient);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-footer .user-info{flex:1;min-width:0}.sidebar-footer .user-info .name{font-size:13px;font-weight:600;color:var(--text)}.sidebar-footer .user-info .role{font-size:11px;color:var(--text-tertiary)}.sidebar-footer .logout-btn{width:30px;height:30px;border-radius:8px;border:none;background:var(--bg-glass);color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);padding:0}.sidebar-footer .logout-btn:hover{background:#ef44441a;color:#ef4444}.sidebar-footer .logout-btn svg{width:15px;height:15px}.content{height:100vh;overflow:hidden}.content-shell{height:100vh;overflow:hidden;display:flex;flex-direction:column}.admin-top-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:var(--border);border-bottom:1px solid var(--border)}.top-metric{background:var(--bg-card);padding:14px 18px;display:flex;flex-direction:column;gap:3px;transition:background var(--transition-fast)}.top-metric:hover{background:var(--bg-glass)}.top-metric .k{font-size:11px;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.3px}.top-metric .v{font-size:22px;font-weight:800;color:var(--text);line-height:1.2;letter-spacing:-.3px}.top-metric .v.small{font-size:18px}.admin-view-port{flex:1;overflow:hidden;padding:20px 24px;display:flex;flex-direction:column;min-height:0}.mobile-menu-btn{display:none;position:fixed;top:10px;left:10px;z-index:201;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;align-items:center;justify-content:center;padding:0;box-shadow:var(--elevation-2);transition:all var(--transition-fast)}.mobile-menu-btn:hover{border-color:var(--accent);color:var(--accent)}.mobile-menu-btn svg{width:20px;height:20px}.sidebar-overlay{display:none}.admin-page{display:flex;flex-direction:column;gap:16px;flex:1;min-height:0}.page-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--elevation-1);animation:fade-in .2s ease}.page-head h2{margin:0;font-size:18px;font-weight:700;color:var(--text)}.page-sub{margin:4px 0 0;font-size:12px;color:var(--text-secondary)}.admin-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md)}.admin-toolbar .spacer{flex:1}.admin-scroll{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:16px}.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.metric-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 20px;transition:all var(--transition-base);box-shadow:var(--elevation-1)}.metric-card:hover{box-shadow:var(--elevation-2);transform:translateY(-1px)}.metric-card .metric-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.metric-card .metric-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--accent-light);color:var(--accent)}.metric-card .metric-icon svg{width:18px;height:18px}.metric-card .metric-title{font-size:11px;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.3px}.metric-card .metric-value{font-size:26px;font-weight:800;color:var(--text);line-height:1.2;letter-spacing:-.5px}.dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.dash-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.dash-title{font-weight:700;font-size:15px;color:var(--text)}.dash-sub{margin-top:3px;font-size:11px;color:var(--text-tertiary)}.dash-kpi{font-weight:800;font-size:20px;color:var(--text)}.ring-wrap{position:relative;display:grid;place-items:center;padding:12px 0}.ring-center{position:absolute;display:grid;place-items:center;text-align:center}.ring-big{font-size:20px;font-weight:800;color:var(--text)}.ring-small{font-size:11px;color:var(--text-tertiary)}.wave-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.wave-box svg{display:block;width:100%;height:100px}.wave-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px}.mini-row{border:1px solid var(--border);border-radius:9px;padding:10px 12px;background:var(--bg-glass)}.mini-k{font-size:11px;color:var(--text-tertiary);font-weight:500}.mini-v{margin-top:5px;font-size:16px;font-weight:800;color:var(--text)}.mini-v.ok{color:#22c55e}.mini-v.info{color:var(--accent)}.mini-v.warn{color:#f59e0b}.spark{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px}.spark-line{height:60px;border-radius:8px;background:linear-gradient(90deg,transparent,rgba(64,169,255,.06),transparent)}.spark-hint{margin-top:10px;font-size:11px;color:var(--text-tertiary)}.mini-table{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.mini-tr{display:grid;grid-template-columns:1fr 100px}.mini-th,.mini-td{padding:10px 16px;font-size:12px}.mini-th{background:var(--bg-glass);font-weight:700;color:var(--text-secondary);border-bottom:1px solid var(--border)}.mini-td{border-bottom:1px solid var(--border);color:var(--text)}.mini-tr:last-child .mini-td{border-bottom:none}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.admin-form-card .ant-form-item{margin-bottom:18px}.admin-form-card .ant-form-item:last-child{margin-bottom:0}.panel-card{border-radius:var(--radius-md)!important}.table-shell,.table-shell .ant-card-body{padding:0!important}.upload-preview{width:84px;height:84px;border-radius:8px;object-fit:cover;border:1px solid var(--border);margin-top:8px;display:block}.result-image{width:100%;border-radius:var(--radius-sm);margin-top:8px;border:1px solid var(--border);display:block}.stack{display:flex;flex-direction:column;gap:16px}.el-table{--el-table-bg-color: var(--bg-card);--el-table-tr-bg-color: var(--bg-card);--el-table-header-bg-color: var(--bg-glass);--el-table-row-hover-bg-color: var(--accent-light);--el-table-border-color: var(--border);--el-table-text-color: var(--text);--el-table-header-text-color: var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.el-table th.el-table__cell{background:var(--bg-glass)!important;color:var(--text-secondary)!important;font-weight:600}.el-table td.el-table__cell{color:var(--text)!important}.el-table tr:hover>td.el-table__cell{background:var(--accent-light)!important}.log-waterfall{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:980px){.log-waterfall{grid-template-columns:1fr}}.log-col{display:grid;gap:10px}.log-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;transition:all var(--transition-fast)}.log-card:hover{box-shadow:var(--elevation-1)}.log-meta{display:flex;align-items:center;gap:8px;margin-bottom:8px}.log-title{font-weight:600;font-size:12px;color:var(--text);line-height:1.5;word-break:break-word}.log-foot{display:flex;justify-content:space-between;margin-top:8px}.pill{display:inline-flex;align-items:center;height:22px;padding:0 10px;border-radius:999px;font-size:10px;font-weight:600;border:1px solid var(--border);background:var(--bg-glass);color:var(--text-secondary)}.pill.code.ok{border-color:#22c55e33;background:#22c55e14;color:#22c55e}.pill.code.bad,.pill.level.error{border-color:#ef444433;background:#ef444414;color:#ef4444}.pill.level.warn{border-color:#f59e0b33;background:#f59e0b14;color:#f59e0b}.pill.level.info{border-color:#7c5cfc33;background:var(--accent-light);color:var(--accent)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(64,169,255,.08) 0%,transparent 70%);top:-150px;right:-100px;pointer-events:none}.login-page:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(64,169,255,.06) 0%,transparent 70%);bottom:-120px;left:-80px;pointer-events:none}.login-card{width:400px;max-width:90vw;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px 36px 32px;box-shadow:var(--elevation-3);position:relative;z-index:1;animation:fade-up .4s cubic-bezier(.4,0,.2,1)}.login-card[data-vue-ssr]{animation:none}.login-card:not([data-vue-ssr]){animation:login-enter .4s cubic-bezier(.34,1.56,.64,1)}@keyframes login-enter{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card .login-logo{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:28px}.login-card .login-logo .logo-box{width:48px;height:48px;border-radius:14px;background:var(--accent-gradient);color:#fff;font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #40a9ff4d}.login-card .login-logo .logo-text{font-size:20px;font-weight:700;color:var(--text)}.login-card .login-sub{text-align:center;font-size:13px;color:var(--text-tertiary);margin-bottom:28px}.login-card .ant-form-item{margin-bottom:20px}.login-card .login-btn{width:100%;padding:13px;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:700;font-family:inherit;background:var(--accent-gradient);color:#fff;cursor:pointer;transition:all var(--transition-base);box-shadow:0 2px 10px #40a9ff40;display:inline-flex;align-items:center;justify-content:center;gap:8px}.login-card .login-btn:hover:not(:disabled){box-shadow:0 8px 24px #40a9ff59;transform:translateY(-2px)}.login-card .login-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.login-card .login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.install-shell{min-height:100vh;padding:32px 16px;animation:fade-in .3s ease}.install-top{max-width:720px;margin:0 auto 20px}.brand{display:flex;align-items:center;gap:14px}.brand .logo{width:42px;height:42px;border-radius:12px;background:var(--accent-gradient);color:#fff;font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px #40a9ff4d}.brand .title{font-size:17px;font-weight:700;color:var(--text)}.brand .subtitle{font-size:12px;color:var(--text-tertiary);margin-top:2px}.install-card{width:100%;max-width:720px;margin:0 auto}.step-body{padding:24px 0 16px}.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.panel h3{margin:0 0 10px;font-size:15px;color:var(--text);font-weight:700}.hint{font-size:12px;color:var(--text-tertiary);margin-bottom:10px;line-height:1.6}.form-grid{margin-top:12px}.check-list{display:grid;gap:10px;margin-top:10px}.check-item{display:grid;grid-template-columns:100px 1fr;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-glass)}.check-item .k{font-size:12px;font-weight:600;color:var(--text)}.check-item .v{font-size:12px;color:var(--text-secondary);word-break:break-all}.actions{display:flex;align-items:center;margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}.actions .spacer{flex:1}.center-page{min-height:100vh;display:flex;justify-content:center;align-items:center}.mt16{margin-top:16px}.muted{font-size:11px;color:var(--text-tertiary)}.uploaded-tip{margin-top:6px;font-size:11px;color:var(--text-tertiary);word-break:break-all}@media(max-width:700px){.tpl-cards{column-count:2;column-gap:8px}.tpl-card .tpl-img-wrap img{height:140px}.tpl-body{padding:8px 10px 10px}.tpl-title{font-size:12px}.admin-layout{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:300;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:var(--elevation-4)}.sidebar-open .sidebar{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:299;background:#00000059;opacity:0;pointer-events:none;transition:opacity .25s ease}.sidebar-open .sidebar-overlay{opacity:1;pointer-events:auto}.mobile-menu-btn{display:flex}.admin-view-port{padding:14px 12px}.card-grid,.dash-grid{grid-template-columns:1fr}.admin-top-strip{grid-template-columns:repeat(2,1fr)}.stats{grid-template-columns:1fr}.actions{flex-direction:column;gap:10px}.actions .spacer{display:none}}@media(max-width:480px){.hp-header-inner{padding:16px 12px 10px}.hp-top-row{flex-direction:column;gap:10px}.hp-brand,.hp-search-box{width:100%}.hp-search-input{font-size:13px;padding:9px 14px 9px 38px}.hp-cat{font-size:12px;padding:6px 12px}.hp-grid{gap:10px}.hp-gcard-foot{padding:8px 10px}.hp-gcard-title{font-size:12px}.hp-featured-scroll{grid-template-columns:repeat(2,1fr);gap:10px}.hp-fcard-body{padding:8px 10px}.hp-section-label{padding:0 12px;font-size:14px}.hp-main,.hp-featured{padding:0 12px}.gp-view{padding:0 10px 20px}.gp-upload{padding:40px 16px}.gp-upload-icon{width:44px;height:44px}.gp-upload-icon svg{width:20px;height:20px}.gp-body{gap:14px}.gp-img,.gp-result-img{max-height:40vh;object-fit:contain}}.hp-scroll-top,.glass,.card-glass{backdrop-filter:none;-webkit-backdrop-filter:none}.bottom-nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--bg-card);border-top:1px solid var(--border)}.bottom-nav a{padding:5px 14px}.bottom-nav a svg{width:18px;height:18px}.el-overlay{backdrop-filter:none;-webkit-backdrop-filter:none}.hp-gcard-hot{animation:none}.hp-brand-icon{transition:none}.hp-scroll-top:hover{transform:none}.skeleton-shimmer,.hp-sk-img,.hp-sk-line,.skeleton-img,.skeleton-line,.skeleton-body,.gp-progress-fill{animation-duration:2.5s}.gp-view:before,.gp-view:after{display:none}body:before{display:none}.hp-header-glow:before,.hp-header-glow:after{display:none}.app-footer{padding:24px 16px 80px;text-align:center;border-top:1px solid var(--border);margin-top:20px}.footer-inner{max-width:640px;margin:0 auto}.footer-text{font-size:12px;color:var(--text-tertiary);margin:0 0 8px}.footer-links{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;margin:0}.footer-links a{font-size:11px;color:var(--text-tertiary);text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--text-secondary)}.footer-links .gongan{display:inline-flex;align-items:center;gap:4px}.anno-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;display:flex;align-items:center;justify-content:center;background:#00000073;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:anno-fade-in .25s ease}.anno-dialog{width:400px;max-width:88vw;max-height:80vh;background:var(--bg-card);border-radius:16px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;animation:anno-scale-in .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.anno-dialog:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent-gradient)}.anno-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:50%;border:none;background:var(--bg-glass);color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:1}.anno-close svg{width:14px;height:14px}.anno-close:hover{background:var(--border);color:var(--text)}.anno-head{padding:32px 28px 0;text-align:center}.anno-head-icon{width:48px;height:48px;margin:0 auto 12px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-secondary, var(--accent)));color:#fff;display:flex;align-items:center;justify-content:center}.anno-head-icon svg{width:22px;height:22px}.anno-title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 4px;line-height:1.4}.anno-body{padding:16px 28px 8px;font-size:14px;line-height:1.7;color:var(--text-secondary);overflow-y:auto;flex:1}.anno-body p{margin:0 0 10px}.anno-body a{color:var(--accent);text-decoration:underline}.anno-body ul,.anno-body ol{padding-left:18px;margin:0 0 10px}.anno-body li{margin-bottom:4px}.anno-foot{padding:12px 28px 24px;text-align:center}.anno-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 36px;border-radius:24px;border:none;background:var(--accent-gradient);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 14px rgba(var(--accent-rgb, 99,102,241),.3)}.anno-btn:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px rgba(var(--accent-rgb, 99,102,241),.4)}.anno-btn:active{transform:scale(.97)}@keyframes anno-fade-in{0%{opacity:0}to{opacity:1}}@keyframes anno-scale-in{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.anno-fade-enter-active{animation:anno-fade-in .25s ease}.anno-fade-leave-active{animation:anno-fade-in .2s ease reverse}@keyframes ripple-burst{0%{transform:scale(2.5);opacity:0}}.card-lift{transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease;will-change:transform}.card-lift:hover{transform:translateY(-4px);box-shadow:0 12px 40px #40a9ff1f}@keyframes glow-pulse{0%{box-shadow:0 0 8px #40a9ff33}50%{box-shadow:0 0 20px #40a9ff66}}.glow-pulse{animation:glow-pulse 2s ease-in-out infinite}@media(prefers-reduced-motion:reduce){:root{animation:none!important;transition:none!important}}.notify-pop{min-width:200px!important;padding:14px 24px!important;border-radius:var(--radius-sm)!important;font-size:14px!important;font-weight:600!important;box-shadow:0 8px 32px #0000001f!important;border:1px solid var(--border)!important}.notify-pop .el-message__content{font-size:14px!important;font-weight:600!important}.notify-pop .el-message__icon{font-size:18px!important}.notify-save{background:var(--bg-card)!important;border:1px solid rgba(16,185,129,.3)!important}.notify-save .el-message__content{color:#10b981!important}.admin-img-list{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.admin-img-item{position:relative;width:72px;height:72px;border-radius:8px;overflow:hidden;border:1.5px solid var(--border);flex-shrink:0}.admin-img-thumb{width:100%;height:100%;object-fit:cover;display:block}.admin-img-del{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:#0000008c;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;padding:0}.admin-img-item:hover .admin-img-del{opacity:1}.admin-img-del svg{width:12px;height:12px}.admin-img-empty{font-size:12px;color:var(--text-tertiary);padding:8px 0}.admin-cell-imgs{position:relative;display:inline-block}.admin-img-badge{position:absolute;bottom:2px;right:2px;background:#0000008c;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:6px;line-height:1.4}.img-carousel{position:relative;width:100%;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-glass);-webkit-user-select:none;user-select:none}.img-carousel-track{display:flex;transition:transform .35s cubic-bezier(.4,0,.2,1);will-change:transform}.img-carousel-slide{flex:0 0 100%;min-width:0}.img-carousel-slide img{display:block;width:100%;height:100%;object-fit:cover}.img-carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:#00000073;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2;opacity:0}.img-carousel:hover .img-carousel-btn{opacity:1}.img-carousel-btn:hover{background:#000000a6;transform:translateY(-50%) scale(1.1)}.img-carousel-btn:active{transform:translateY(-50%) scale(.95)}.img-carousel-btn.prev{left:10px}.img-carousel-btn.next{right:10px}.img-carousel-btn svg{width:18px;height:18px}.img-carousel-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:2}.img-carousel-dot{width:6px;height:6px;border-radius:50%;background:#ffffff80;border:none;cursor:pointer;padding:0;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.img-carousel-dot.active{width:20px;border-radius:3px;background:#fff}.img-carousel-count{position:absolute;bottom:10px;right:12px;font-size:11px;font-weight:600;color:#fff;background:#0006;padding:2px 10px;border-radius:10px;z-index:2}.hp-banner-wrap{margin:0 -16px 24px;overflow:hidden;position:relative}.hp-banner{position:relative;height:200px;overflow:hidden}.hp-banner-track{display:flex;height:100%;transition:transform .5s cubic-bezier(.4,0,.2,1);will-change:transform}.hp-banner-slide{flex:0 0 100%;min-width:0;height:100%;position:relative;cursor:pointer;text-decoration:none}.hp-banner-slide-inner{height:100%;display:flex;align-items:center;justify-content:center;padding:0 40px;position:relative}.hp-banner-bg{position:absolute;top:0;right:0;bottom:0;left:0}.hp-banner-bg .gradient-1{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#40a9ff,#6366f1)}.hp-banner-bg .gradient-2{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#7ec1ff,#ec4899)}.hp-banner-bg .gradient-3{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#06b6d4,#3b82f6)}.hp-banner-content{position:relative;z-index:1;text-align:center;color:#fff}.hp-banner-content h2{margin:0 0 6px;font-size:24px;font-weight:800;letter-spacing:-.5px;text-shadow:0 2px 8px rgba(0,0,0,.15)}.hp-banner-content p{margin:0 0 14px;font-size:13px;opacity:.9;text-shadow:0 1px 4px rgba(0,0,0,.1)}.hp-banner-cta{display:inline-flex;align-items:center;gap:6px;padding:8px 20px;border-radius:999px;background:#fff3;color:#fff;font-size:13px;font-weight:700;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .2s;text-decoration:none}.hp-banner-cta:hover{background:#ffffff4d;transform:translateY(-1px)}.hp-banner-dots{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:2}.hp-banner-dot{width:6px;height:6px;border-radius:50%;background:#fff6;border:none;cursor:pointer;padding:0;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.hp-banner-dot.active{width:22px;border-radius:3px;background:#fff}@media(min-width:640px){.hp-banner{height:260px}.hp-banner-content h2{font-size:28px}.hp-banner-content p{font-size:15px}}.xh-header{padding:12px 12px 0;background:var(--bg)}@media(min-width:1024px){.xh-header,.xh-section,.xh-announce{max-width:1200px;margin-left:auto;margin-right:auto}.xh-header{padding:20px 24px 0}.xh-section{padding:0 24px 16px}.xh-announce{padding:0 24px}}.xh-header-row{display:flex;align-items:center;gap:10px}.xh-brand{display:flex;align-items:center;gap:6px;flex-shrink:0}.xh-brand svg{width:28px;height:28px;color:var(--accent)}.xh-brand span{font-size:17px;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.3px}.xh-search{flex:1;position:relative;min-width:0}.xh-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--text-tertiary);pointer-events:none}.xh-search-input{width:100%;padding:9px 12px 9px 34px;border:none;border-radius:999px;background:var(--bg-card);color:var(--text);font-size:13px;font-family:inherit;outline:none;box-shadow:var(--elevation-1);transition:box-shadow .2s;-webkit-appearance:none}.xh-search-input:focus{box-shadow:0 0 0 2px var(--accent-light)}.xh-search-input::placeholder{color:var(--text-tertiary)}.xh-cat-strip{display:flex;gap:8px;overflow-x:auto;padding:4px 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.xh-cat-strip::-webkit-scrollbar{display:none}.xh-cat-btn{flex-shrink:0;padding:6px 16px;border-radius:999px;border:none;background:var(--bg-glass);color:var(--text-secondary);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.xh-cat-btn:hover{background:var(--bg-glass-hover);color:var(--text)}.xh-cat-btn.active{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 8px rgba(var(--accent-rgb,99,102,241),.3)}.xh-banner{margin:12px 12px 16px;border-radius:var(--radius-md);overflow:hidden;position:relative;height:100px}.xh-banner-track{display:flex;height:100%;transition:transform .4s cubic-bezier(.4,0,.2,1)}.xh-banner-slide{flex:0 0 100%;min-width:0;height:100%;display:flex;align-items:center;text-decoration:none;position:relative}.xh-banner-bg{position:absolute;top:0;right:0;bottom:0;left:0}.xh-banner-text{position:relative;z-index:1;padding:0 20px;color:#fff;display:flex;flex-direction:column;gap:4px}.xh-banner-text strong{font-size:16px;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.12)}.xh-banner-text span{font-size:12px;opacity:.9}.xh-banner-dots{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:5px;z-index:2}.xh-banner-dots button{width:5px;height:5px;border-radius:50%;background:#ffffff80;border:none;cursor:pointer;padding:0;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.xh-banner-dots button.active{width:18px;border-radius:3px;background:#fff}.xh-section{padding:0 12px 8px}.xh-section-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.xh-section-label{font-size:15px;font-weight:700;color:var(--text)}.xh-section-more{margin-left:auto;font-size:12px;color:var(--text-tertiary);text-decoration:none;font-weight:500}.xh-announce{display:flex;flex-direction:column;gap:8px}.xh-announce-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);transition:all var(--transition-fast)}.xh-announce-primary{background:linear-gradient(135deg,#40a9ff0f,#7ec1ff0a);border-color:#40a9ff26}.xh-announce-secondary{background:var(--bg-card)}.xh-announce-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent);background:var(--accent-light)}.xh-announce-icon svg{width:19px;height:19px}.xh-announce-body{flex:1;min-width:0}.xh-announce-title{font-size:14px;font-weight:600;color:var(--text)}.xh-announce-desc{font-size:12px;color:var(--text-secondary);margin-top:2px;line-height:1.5}.xh-announce-btn{display:inline-flex;align-items:center;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;background:var(--accent-gradient);color:#fff;text-decoration:none;flex-shrink:0;transition:all var(--transition-fast)}.xh-announce-btn:hover{box-shadow:0 4px 12px #40a9ff40;transform:translateY(-1px)}.xh-welcome{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent-light),rgba(99,102,241,.04));border:1px solid rgba(64,169,255,.12)}.xh-welcome-text{font-size:14px;font-weight:500;color:var(--text)}.xh-welcome-link{font-size:13px;font-weight:600;color:var(--accent);text-decoration:none;flex-shrink:0}.xh-welcome-link:hover{text-decoration:underline}.xh-section-count{margin-left:auto;font-size:11px;font-weight:500;color:var(--text-tertiary);background:var(--bg-glass);padding:2px 10px;border-radius:999px}.xh-inspire-scroll{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:4px;margin-bottom:4px}.xh-inspire-scroll::-webkit-scrollbar{display:none}.xh-inspire-card{flex:0 0 110px;border-radius:var(--radius-sm);overflow:hidden;position:relative;aspect-ratio:3/4;text-decoration:none;background:var(--bg-card);box-shadow:var(--elevation-1);transition:transform .2s,box-shadow .2s}.xh-inspire-card:active{transform:scale(.96)}.xh-inspire-card img{width:100%;height:100%;object-fit:cover;display:block}.xh-inspire-over{position:absolute;bottom:0;left:0;right:0;padding:20px 8px 8px;background:linear-gradient(transparent,#0009);color:#fff;font-size:11px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.xh-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}@media(min-width:640px){.xh-grid{grid-template-columns:repeat(3,1fr);gap:10px}}@media(min-width:1024px){.xh-grid{grid-template-columns:repeat(4,1fr);gap:14px}}.xh-card{border-radius:var(--radius-sm);overflow:hidden;text-decoration:none;color:inherit;background:var(--bg-card);box-shadow:var(--elevation-1);transition:transform .2s,box-shadow .2s;-webkit-tap-highlight-color:transparent;display:flex;flex-direction:column;break-inside:avoid}.xh-card:active{transform:scale(.97)}.xh-card-img{position:relative;overflow:hidden;background:var(--bg-glass);line-height:0}.xh-card-img img{width:100%;display:block}.xh-card:nth-child(7n+1) .xh-card-img img{aspect-ratio:3/4}.xh-card:nth-child(7n+2) .xh-card-img img{aspect-ratio:1/1}.xh-card:nth-child(7n+3) .xh-card-img img{aspect-ratio:4/5}.xh-card:nth-child(7n+4) .xh-card-img img{aspect-ratio:3/4}.xh-card:nth-child(7n+5) .xh-card-img img{aspect-ratio:4/3}.xh-card:nth-child(7n+6) .xh-card-img img{aspect-ratio:2/3}.xh-card:nth-child(7n+7) .xh-card-img img{aspect-ratio:1/1}.xh-card:nth-child(7n) .xh-card-img img{aspect-ratio:3/4}.xh-card-title{position:absolute;bottom:0;left:0;right:0;padding:24px 8px 7px;background:linear-gradient(transparent,#0009);color:#fff;font-size:12px;font-weight:600;line-height:1.3;text-shadow:0 1px 3px rgba(0,0,0,.2);pointer-events:none}.xh-card-title span{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.xh-card-badge{position:absolute;top:6px;right:6px;padding:2px 7px;border-radius:999px;font-size:10px;font-weight:700;background:#00000080;color:#fff;pointer-events:none;line-height:1.3}.xh-sk{border-radius:var(--radius-sm);overflow:hidden}.xh-sk-img{background:linear-gradient(90deg,var(--bg-glass) 25%,var(--bg-glass-hover) 50%,var(--bg-glass) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;width:100%}.xh-loading-more{display:flex;justify-content:center;padding:16px 0}.xh-loading-dot{width:24px;height:24px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.xh-empty{text-align:center;padding:40px 20px 60px;color:var(--text-tertiary)}.xh-empty p{font-size:14px;margin:0 0 16px}.xh-empty-btn{padding:8px 24px;border-radius:999px;border:1.5px solid var(--accent);background:transparent;color:var(--accent);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer}.xh-end{text-align:center;padding:20px 0 10px;font-size:12px;color:var(--text-tertiary)}.xh-scroll-top{position:fixed;bottom:72px;right:14px;z-index:90;width:38px;height:38px;border-radius:50%;border:none;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--elevation-2);transition:all .2s}.xh-scroll-top svg{width:18px;height:18px}.anno-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center;padding:24px}.anno-modal{width:100%;max-width:380px;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000026;overflow:hidden;animation:anno-in .3s ease}@keyframes anno-in{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.anno-hd{display:flex;align-items:center;gap:8px;padding:16px 16px 0;font-size:15px;font-weight:700;color:var(--text)}.anno-hd svg{color:var(--accent);flex-shrink:0}.anno-close{margin-left:auto;width:28px;height:28px;border:none;background:var(--bg-glass);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:all .2s}.anno-close:hover{background:var(--bg-glass-hover);color:var(--text)}.anno-bd{padding:16px;font-size:14px;line-height:1.7;color:var(--text-secondary)}.anno-bd p{margin:0 0 8px}.anno-bd p:last-child{margin-bottom:0}.anno-ft{padding:0 16px 16px}.anno-btn{width:100%;padding:10px;border:none;border-radius:var(--radius-sm);background:var(--accent-gradient);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.anno-btn:hover{opacity:.9}.inspire-header{padding:20px 16px 4px}.inspire-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.inspire-title{margin:0;font-size:22px;font-weight:800;color:var(--text)}.inspire-sub{margin:4px 0 0;font-size:13px;color:var(--text-tertiary)}.inspire-pay-link{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;background:var(--accent-light);color:var(--accent);text-decoration:none;white-space:nowrap;flex-shrink:0}.inspire-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:12px 12px 20px}@media(min-width:480px){.inspire-grid{grid-template-columns:repeat(3,1fr)}}.in-card{border-radius:var(--radius-sm);overflow:hidden;text-decoration:none;color:inherit;background:var(--bg-card);box-shadow:var(--elevation-1);transition:transform .2s;-webkit-tap-highlight-color:transparent}.in-card:active{transform:scale(.97)}.in-card-img{position:relative;overflow:hidden;background:var(--bg-glass);line-height:0}.in-card-img img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.in-card-count{position:absolute;bottom:6px;right:6px;padding:2px 7px;border-radius:999px;font-size:10px;font-weight:700;background:#00000080;color:#fff}.in-card-body{padding:8px 10px 10px}.in-card-title{display:block;font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.in-card-usage{display:block;margin-top:2px;font-size:11px;color:var(--text-tertiary)}.inspire-empty{text-align:center;padding:60px 20px;color:var(--text-tertiary);font-size:14px}.my-header{padding:20px 16px 4px}.my-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.my-balance-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;background:var(--accent-light);color:var(--accent);text-decoration:none;white-space:nowrap;flex-shrink:0}.my-title{margin:0;font-size:22px;font-weight:800;color:var(--text)}.my-sub{margin:4px 0 0;font-size:13px;color:var(--text-tertiary)}.my-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 12px 20px}.my-card{border-radius:var(--radius-sm);overflow:hidden;position:relative;background:var(--bg-card);box-shadow:var(--elevation-1);aspect-ratio:1;-webkit-tap-highlight-color:transparent}.my-card img{width:100%;height:100%;object-fit:cover;display:block}.my-card-over{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.my-card:active .my-card-over{opacity:1}.my-card-btn{padding:6px 16px;border-radius:999px;font-size:12px;font-weight:600;background:#fff;color:var(--accent);text-decoration:none}.my-empty{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.my-empty-icon{margin-bottom:12px}.my-empty-icon svg{width:48px;height:48px;opacity:.4}.my-empty p{font-size:14px;margin:0 0 16px}.my-empty-btn{display:inline-block;padding:8px 24px;border-radius:999px;border:1.5px solid var(--accent);color:var(--accent);font-size:13px;font-weight:600;text-decoration:none}.sk-card{border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-card);box-shadow:var(--elevation-1)}.sk-img{width:100%;aspect-ratio:1;background:linear-gradient(90deg,var(--bg-glass) 25%,var(--bg-glass-hover) 50%,var(--bg-glass) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.sk-body{padding:10px 12px}.sk-line{height:12px;border-radius:6px;background:linear-gradient(90deg,var(--bg-glass) 25%,var(--bg-glass-hover) 50%,var(--bg-glass) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;margin-bottom:8px}.sk-line.short{width:55%}@media(max-width:768px){html,body{overflow:hidden!important;height:100%!important;width:100%!important}.client-layout{height:100vh!important;min-height:100vh!important;overflow:hidden!important;padding-bottom:0!important}.page,.gp-view{height:100%!important;min-height:0!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch;box-sizing:border-box;padding-bottom:calc(var(--nav-height) + 24px)}}
