:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#fbf6ea;--surface:#fff;--surface-2:#fff9ee;--surface-canvas:#f4ecd9;--text:#1f1608;--text-dim:#6e5d49;--muted:#a89682;--border:#1f160814;--border-strong:#1f160824;--brand:#ff7a2e;--brand-hover:#ef5a0a;--brand-pale:#fff4e8;--brand-soft:#ffe3c8;--brand-fg:#fff;--wechat:#07c160;--icon-bg:#fff4e8;--icon-fg:#ef5a0a;--shadow-card:0 1px 2px #1f160808, 0 4px 14px -6px #1f16080f;--shadow-pop:0 6px 24px -8px #1f16081f;--shadow-mode-hover:0 2px 8px -4px #1f160814;--halo:#ffc14d66;--primary-bg:#1f1608;--primary-fg:#fff9ee;--r-sm:10px;--r:14px;--r-lg:20px;--r-pill:999px;--ease:cubic-bezier(.2, .8, .2, 1);--ease-soft:cubic-bezier(.4, 0, .2, 1);--topbar-h:60px}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#14100a;--surface:#1d1810;--surface-2:#221c13;--surface-canvas:#0e0a06;--text:#f4ecd9;--text-dim:#b8a98e;--muted:#7d6f57;--border:#ffecc314;--border-strong:#ffecc329;--brand:#ff8a44;--brand-hover:#ffa063;--brand-pale:#ff8a441f;--brand-soft:#ff8a4438;--brand-fg:#1a0f08;--icon-bg:#ff8a4424;--icon-fg:#ffa063;--shadow-card:0 1px 2px #0000004d, 0 6px 16px -6px #00000059;--shadow-pop:0 8px 28px -8px #00000080;--shadow-mode-hover:0 2px 10px -4px #00000073;--halo:#ff8a4424;--primary-bg:#ff8a44;--primary-fg:#1a0f08}}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#14100a;--surface:#1d1810;--surface-2:#221c13;--surface-canvas:#0e0a06;--text:#f4ecd9;--text-dim:#b8a98e;--muted:#7d6f57;--border:#ffecc314;--border-strong:#ffecc329;--brand:#ff8a44;--brand-hover:#ffa063;--brand-pale:#ff8a441f;--brand-soft:#ff8a4438;--brand-fg:#1a0f08;--icon-bg:#ff8a4424;--icon-fg:#ffa063;--shadow-card:0 1px 2px #0000004d, 0 6px 16px -6px #00000059;--shadow-pop:0 8px 28px -8px #00000080;--shadow-mode-hover:0 2px 10px -4px #00000073;--halo:#ff8a4424;--primary-bg:#ff8a44;--primary-fg:#1a0f08}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-feature-settings:"ss01", "cv11";-webkit-font-smoothing:antialiased;min-height:100dvh;transition:background-color .18s var(--ease-soft), color .18s var(--ease-soft);font-family:Inter,PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:15.5px;line-height:1.55;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(ellipse at center, var(--halo), transparent 65%);filter:blur(80px);width:1000px;height:600px;position:fixed;top:-280px;left:50%;transform:translate(-50%)}body[data-view=workspace]:before{opacity:.35}a{color:inherit;text-decoration:none}.shell{z-index:1;grid-template-rows:auto 1fr auto;min-height:100vh;display:grid;position:relative}.topbar{padding:16px 28px;padding-top:max(16px, env(safe-area-inset-top));padding-left:max(28px, env(safe-area-inset-left));padding-right:max(28px, env(safe-area-inset-right));justify-content:space-between;align-items:center;gap:16px;width:100%;max-width:1280px;margin:0 auto;display:flex}.topbar-brand{align-items:center;gap:12px;min-width:0;display:flex}.topbar-logo{object-fit:contain;width:40px;height:40px;transition:transform .18s var(--ease)}.topbar-brand-clickable{cursor:pointer;border-radius:var(--r-pill);transition:background .16s var(--ease);margin:-4px -6px;padding:4px 6px}.topbar-brand-clickable:hover{background:var(--surface-2)}.topbar-brand-clickable:hover .topbar-logo{transform:scale(1.06)rotate(-3deg)}.topbar-brand-clickable:hover .topbar-name{color:var(--brand-hover)}.topbar-brand-clickable:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.topbar-name{transition:color .16s var(--ease);letter-spacing:-.01em;color:var(--text);font-size:16px;font-weight:800}.topbar-divider{background:var(--border-strong);width:1px;height:18px}.topbar-file{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:360px;font-family:ui-monospace,SF Mono,monospace;font-size:13px;overflow:hidden}.topbar-mode-info{border:1px solid var(--brand-soft);background:var(--brand-pale);color:var(--brand-hover);letter-spacing:.01em;text-overflow:ellipsis;white-space:nowrap;border-radius:999px;align-items:center;gap:8px;max-width:280px;padding:5px 12px;font-size:13px;font-weight:600;display:inline-flex;overflow:hidden}.topbar-mode-name{font-weight:700}.topbar-mode-sep{opacity:.55;font-weight:400}.topbar-mode-strength{font-variant-numeric:tabular-nums}@media (max-width:640px){.topbar-mode-info{gap:6px;max-width:180px;padding:5px 10px;font-size:12.5px}}.topbar-actions{align-items:center;gap:6px;display:flex}.topbar-version{border:1px solid var(--brand-soft);background:var(--brand-pale);color:var(--brand-hover);white-space:nowrap;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:6px;padding:5px 10px;font-size:12px;line-height:1.2;display:inline-flex}.topbar-version-tag{letter-spacing:.02em;font-weight:700}.topbar-version-date{color:var(--brand-hover);opacity:.78;font-variant-numeric:tabular-nums;font-size:11.5px;font-weight:500}@media (max-width:640px){.topbar-version{gap:5px;padding:4px 8px;font-size:11px}.topbar-version-date{display:none}}body[data-view=landing] .topbar{background:0 0;border:0;justify-content:flex-end;padding:22px 32px 0}body[data-view=landing] .topbar-brand,body[data-view=landing] .back-btn{display:none}body[data-view=workspace] .topbar{background:var(--surface);border-bottom:1px solid var(--border);height:var(--topbar-h);max-width:none;margin:0;padding:0 24px}.btn{border-radius:var(--r-pill);color:var(--text);cursor:pointer;transition:all .18s var(--ease);white-space:nowrap;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;gap:7px;padding:10px 18px;font-size:14.5px;font-weight:600;list-style:none;display:inline-flex}.btn::-webkit-details-marker{display:none}.btn::marker{content:""}.btn-quiet{color:var(--text-dim)}.btn-quiet:hover{background:var(--surface-2);color:var(--text)}body[data-view=workspace] .btn-quiet:hover{background:var(--bg)}.btn-icon{width:38px;height:38px;color:var(--text-dim);border-radius:50%;padding:0}.btn-icon:hover{background:var(--surface-2);color:var(--text)}body[data-view=workspace] .btn-icon:hover{background:var(--bg)}.btn-primary{background:var(--primary-bg);color:var(--primary-fg);padding:12px 24px;font-size:14.5px;font-weight:700}.btn-primary:hover{background:var(--brand);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px -4px #ff7a2e52}.btn-lg{padding:14px 32px;font-size:15px}.theme-toggle .icon-light{display:none}.theme-toggle .icon-dark{display:block}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .theme-toggle .icon-light{display:block}:root:not([data-theme=light]) .theme-toggle .icon-dark{display:none}}:root[data-theme=dark] .theme-toggle .icon-light{display:block}:root[data-theme=dark] .theme-toggle .icon-dark{display:none}.share{position:relative}.share>summary{cursor:pointer;-webkit-user-select:none;user-select:none}.share-menu{z-index:40;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);min-width:260px;box-shadow:var(--shadow-pop);animation:pop .18s var(--ease);gap:1px;padding:6px;display:grid;position:absolute;top:calc(100% + 8px);right:0}@keyframes pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.share-item{cursor:pointer;text-align:left;width:100%;color:var(--text);transition:background .15s var(--ease);background:0 0;border:0;border-radius:12px;align-items:center;gap:12px;padding:10px 12px;display:flex}.share-item:hover{background:var(--brand-pale)}.share-icon{background:var(--surface-2);border:1px solid var(--border);width:36px;height:36px;color:var(--text-dim);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.share-icon.wechat{background:var(--wechat);color:#fff;border-color:var(--wechat)}.share-item strong{color:var(--text);margin-bottom:1px;font-size:14px;font-weight:700;display:block}.share-item small{color:var(--muted);font-size:12px;display:block}body[data-view=landing] .view-workspace,body[data-view=landing] .view-review,body[data-view=workspace] .view-landing,body[data-view=workspace] .view-review,body[data-view=review] .view-landing,body[data-view=review] .view-workspace{display:none}.main{place-items:start center;padding:16px 0 80px;display:grid}.stage{text-align:center;justify-items:center;gap:36px;width:100%;max-width:760px;padding:1vh 28px 0;display:grid}.hero-logo{object-fit:contain;filter:drop-shadow(0 4px 16px #ff7a2e2e);width:96px;height:96px;margin-bottom:-8px}.hero-text{justify-items:center;gap:20px;display:grid}.headline{letter-spacing:-.035em;color:var(--text);margin:0;font-size:clamp(40px,6.4vw,72px);font-weight:700;line-height:1.04}.lede{max-width:560px;color:var(--text-dim);margin:0;font-size:17px;font-weight:400;line-height:1.7}.uploader{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;box-shadow:var(--shadow-card);text-align:center;transition:all .22s var(--ease);position:relative;overflow:hidden}.uploader:hover{border-color:var(--border-strong);transform:translateY(-1px)}.upload-body{cursor:pointer;transition:background-color .16s var(--ease-soft);place-items:center;gap:14px;padding:56px 32px 40px;display:grid}.upload-body-dragging{background:var(--brand-pale)}.upload-body-dragging .upload-icon{background:var(--brand);color:#fff;transform:scale(1.05)}.upload-body-dragging .upload-title{color:var(--brand-hover)}.upload-body-dragging *,.upload-body-loading{pointer-events:none}.upload-loading-overlay{background:color-mix(in srgb, var(--surface) 88%, transparent);-webkit-backdrop-filter:blur(8px)saturate(120%);border-radius:inherit;z-index:4;animation:canvasLoadingFade .2s var(--ease-soft);place-items:center;gap:14px;display:grid;position:absolute;inset:0}.upload-loading-ring{width:52px;height:52px}.upload-loading-ring svg{width:100%;height:100%;display:block}.upload-loading-ring circle{fill:none;stroke:var(--border-strong);stroke-width:3px}.upload-loading-ring .canvas-loading-ring-spin{stroke:var(--brand);stroke-linecap:round;stroke-dasharray:40 90;transform-origin:50%;animation:1.1s linear infinite canvasRingSpin}.upload-loading-overlay p{color:var(--text);text-align:center;max-width:280px;margin:0;font-size:13.5px;font-weight:600;line-height:1.55}.upload-body{position:relative}.upload-icon{background:var(--icon-bg);width:64px;height:64px;color:var(--icon-fg);border-radius:18px;place-items:center;margin-bottom:6px;display:grid}.upload-title{letter-spacing:-.015em;color:var(--text);margin:0;font-size:22px;font-weight:800}.upload-hint{color:var(--muted);margin:0 0 10px;font-size:14px;font-weight:500}.upload-foot{border-top:1px solid var(--border);background:var(--surface-2);padding:20px}.highlight-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.highlight-card{border:1px solid var(--border);background:var(--surface);text-align:left;border-radius:14px;align-items:flex-start;gap:12px;min-height:104px;padding:14px 16px;display:flex}.highlight-icon{background:var(--icon-bg);width:34px;height:34px;color:var(--icon-fg);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.highlight-text{grid-template-rows:auto 1fr;gap:6px;min-width:0;display:grid}.highlight-title{color:var(--text);letter-spacing:-.01em;font-size:14px;font-weight:700}.highlight-desc{color:var(--text-dim);font-size:12.5px;font-weight:500;line-height:1.48}@media (max-width:640px){.highlight-grid{grid-template-columns:1fr;gap:8px}.highlight-card{min-height:auto;padding:12px 14px}}.mode-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.mode-card{border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;text-align:left;transition:all .2s var(--ease);border-radius:20px;gap:14px;padding:22px 20px;font-family:inherit;display:grid;position:relative}.mode-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-mode-hover);transform:translateY(-1px)}.mode-card.active{border-color:var(--brand);background:var(--brand-pale)}.mode-card .mode-icon{background:var(--icon-bg);width:44px;height:44px;color:var(--icon-fg);transition:all .2s var(--ease);border-radius:14px;place-items:center;display:grid}.mode-card.active .mode-icon{background:var(--brand);color:#fff}.mode-card .mode-text{gap:6px;display:grid}.mode-card .mode-name{letter-spacing:-.015em;color:var(--text);font-size:18px;font-weight:800}.mode-card .mode-desc{color:var(--text-dim);font-size:14px;font-weight:500;line-height:1.55}.workspace{grid-template-columns:minmax(0,1fr) 380px;align-items:stretch;gap:18px;width:100%;max-width:1440px;margin:0 auto;padding:20px 32px 40px;display:grid}.preset-section{position:relative}.preset-list{gap:8px;display:grid}.preset-card{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);color:var(--text);text-align:left;cursor:pointer;font:inherit;transition:background .15s var(--ease-soft), border-color .15s var(--ease-soft), transform .1s var(--ease-soft);grid-template-columns:56px minmax(0,1fr);align-items:center;gap:12px;width:100%;min-width:0;padding:10px 14px 10px 10px;display:grid;position:relative}.preset-card-text{word-break:break-word;min-width:0}.preset-card-thumb{background:var(--surface);border:1px solid var(--border);cursor:zoom-in;width:56px;height:56px;font:inherit;color:inherit;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border-radius:8px;flex-shrink:0;padding:0;display:flex;overflow:hidden}.preset-card-thumb:hover{border-color:var(--brand)}.preset-card-thumb:active{transform:scale(.96)}.preset-card-text{text-align:left;cursor:pointer;min-width:0;color:inherit;font:inherit;-webkit-tap-highlight-color:transparent;background:0 0;border:0;flex-direction:column;gap:2px;padding:0;display:flex}.preset-card-thumb img{object-fit:cover;width:100%;height:100%;display:block}.preset-card-text{flex-direction:column;gap:2px;min-width:0;display:flex}.preset-hover-preview{z-index:250;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);pointer-events:auto;cursor:pointer;width:min(360px,32vw);animation:fadeIn .14s var(--ease-soft);padding:12px;position:fixed;top:50%;right:24px;transform:translateY(-50%);box-shadow:0 24px 60px -16px #00000052}.preset-hover-preview-close-hint{color:var(--muted);text-align:center;margin-top:4px;font-size:11.5px;display:none}@media (hover:none) and (pointer:coarse){.preset-hover-preview-close-hint{display:block}}.preset-hover-preview img{border-radius:var(--r-sm);width:100%;margin-bottom:8px;display:block}.preset-hover-preview-label{text-align:center;color:var(--text);font-size:13px;font-weight:700;display:block}@media (max-width:900px){.preset-hover-preview{width:auto;max-height:60vh;inset:auto 12px 12px;overflow-y:auto;transform:none}}.preset-empty-hint{color:var(--text-dim);border:1px dashed var(--border);border-radius:var(--r-sm);text-align:center;margin:0;padding:12px;font-size:13px}.preset-tip-hint{color:var(--muted);text-align:center;margin:8px 0 0;font-size:12px}.preset-card:hover{background:var(--bg);border-color:var(--border-strong)}.preset-card.active{background:var(--brand-pale);border-color:var(--brand);color:var(--brand-hover)}.preset-card-name{letter-spacing:.01em;font-size:14px;font-weight:700}.preset-card-desc{color:var(--text-dim);font-size:12px;line-height:1.5}.preset-card.active .preset-card-desc{color:var(--brand-hover);opacity:.85}.preset-card-ratio{background:var(--surface);border:1px solid var(--border);color:var(--muted);font-variant-numeric:tabular-nums;letter-spacing:.04em;border-radius:999px;padding:2px 7px;font-size:11px;position:absolute;top:10px;right:12px}.preset-card.active .preset-card-ratio{background:var(--surface);border-color:var(--brand-soft);color:var(--brand)}.preset-active-hint{color:var(--brand-hover);background:var(--brand-pale);border:1px dashed var(--brand-soft);border-radius:var(--r-sm);margin:8px 0 0;padding:8px 12px;font-size:12.5px;line-height:1.5}.quality-tier-section{gap:8px}.quality-tier-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.quality-tier-card{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);color:var(--text);text-align:left;cursor:pointer;transition:background .15s var(--ease-soft), border-color .15s var(--ease-soft), transform .1s var(--ease-soft);font:inherit;-webkit-tap-highlight-color:transparent;gap:4px;padding:12px;display:grid;position:relative}.quality-tier-card:hover{background:var(--bg);border-color:var(--border-strong)}.quality-tier-card.active{background:var(--brand-pale);border-color:var(--brand);color:var(--brand-hover)}.quality-tier-card.active .quality-tier-name{color:var(--brand-hover);font-weight:800}.quality-tier-head-row{justify-content:space-between;align-items:center;gap:6px;display:flex}.quality-tier-name{letter-spacing:.01em;font-size:14.5px;font-weight:700}.quality-tier-eta{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:12.5px}.quality-tier-card.active .quality-tier-eta{color:var(--brand-hover)}.quality-tier-cost{border:1px solid var(--brand-soft);background:var(--brand-pale);color:var(--brand-hover);font-variant-numeric:tabular-nums;border-radius:999px;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px 4px 8px;line-height:1;display:inline-flex}.quality-tier-cost-icon{font-size:18px;line-height:1}.quality-tier-cost-num{font-size:17px;font-weight:800;line-height:1}.quality-tier-card.active .quality-tier-cost{background:var(--brand);border-color:var(--brand);color:#fff}.quality-tier-hint{opacity:0;max-height:0;color:var(--text-dim);transition:max-height .2s var(--ease-soft), opacity .15s var(--ease-soft), margin-top .2s var(--ease-soft);margin-top:0;font-size:12px;line-height:1.5;overflow:hidden}.quality-tier-card.active .quality-tier-hint{color:var(--brand-hover)}.quality-tier-card:hover .quality-tier-hint,.quality-tier-card:focus-visible .quality-tier-hint,.quality-tier-card.active .quality-tier-hint{opacity:1;max-height:80px;margin-top:4px}@media (max-width:640px){.quality-tier-card{padding:14px 12px}.quality-tier-name{font-size:15px}.quality-tier-meta,.quality-tier-hint{font-size:12.5px}}.canvas-area{background:var(--surface-canvas);border:1px solid var(--border);border-radius:var(--r-lg);height:calc(100dvh - var(--topbar-h) - 120px);min-height:420px;display:flex;position:relative;overflow:hidden}.canvas-wrap{flex:1;place-items:center;min-height:0;padding:32px 40px;display:grid;position:relative}.preview-canvas{border-radius:var(--r);width:auto;max-width:min(640px,100%);height:auto;max-height:min(72vh,100%);box-shadow:var(--shadow-card);background:var(--surface);display:block}.compare-canvas,.compare-canvas .compare-sizer{max-width:min(680px,100%);max-height:min(74vh,100%)}.param-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);height:calc(100dvh - var(--topbar-h) - 120px);overscroll-behavior:contain;scrollbar-gutter:stable;flex-direction:column;gap:22px;min-width:0;min-height:420px;padding:22px;display:flex;overflow:hidden auto}.param-panel>.panel-section:not(.panel-history){flex-shrink:0;min-width:0}.param-panel .panel-action{margin-top:auto}.panel-section{gap:12px;display:grid}.panel-title{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0;font-size:12.5px;font-weight:800}.mode-list{gap:8px;display:grid}.mode-list .mode-card{border-radius:16px;grid-template-columns:auto 1fr;align-items:center;gap:14px;padding:14px}.mode-list .mode-card .mode-icon{width:40px;height:40px}.mode-list .mode-card .mode-name{font-size:15.5px}.mode-list .mode-card .mode-desc{font-size:13px}.style-module-list{gap:8px;display:grid}.style-module-group{border:1.5px solid var(--border);background:var(--surface);transition:background .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease);border-radius:16px;gap:10px;padding:12px;display:grid}.style-module-group.active{border-color:color-mix(in srgb, var(--brand) 58%, var(--border));background:color-mix(in srgb, var(--brand-pale) 62%, var(--surface))}.style-module-group-head{min-height:26px;color:var(--text);letter-spacing:0;align-items:center;gap:8px;padding:0 1px;font-size:14px;font-weight:800;display:flex}.style-module-group-icon{background:var(--icon-bg);width:24px;height:24px;color:var(--icon-fg);border-radius:8px;place-items:center;display:grid}.style-branch-list,.style-branch-stack{gap:8px;display:grid}.style-module-group .style-branch-card{background:color-mix(in srgb, var(--surface) 72%, var(--surface-2));padding:12px}.style-module-group .style-branch-card.active{background:var(--surface)}.style-module-card{border:1.5px solid var(--border);background:var(--surface);width:100%;min-width:0;color:var(--text);cursor:pointer;text-align:left;font:inherit;transition:background .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease);border-radius:16px;grid-template-columns:40px minmax(0,1fr);align-items:center;gap:14px;padding:14px;display:grid}.style-module-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-mode-hover);transform:translateY(-1px)}.style-module-card.active{border-color:var(--brand);background:var(--brand-pale);box-shadow:0 0 0 1px color-mix(in srgb, var(--brand) 18%, transparent)}.style-module-icon{background:var(--icon-bg);width:40px;height:40px;color:var(--icon-fg);transition:background .2s var(--ease), color .2s var(--ease);border-radius:12px;place-items:center;display:grid}.style-module-card.active .style-module-icon{background:var(--brand);color:#fff}.style-module-text{gap:5px;min-width:0;display:grid}.style-module-name{color:var(--text);letter-spacing:0;font-size:15.5px;font-weight:800;line-height:1.25}.style-module-desc{color:var(--text-dim);letter-spacing:0;font-size:13px;font-weight:600;line-height:1.45}.style-strength-picker{border:1px solid color-mix(in srgb, var(--brand) 22%, var(--border));background:color-mix(in srgb, var(--surface) 78%, var(--brand-pale));border-radius:14px;gap:8px;padding:10px;display:grid}.style-strength-head{min-width:0;color:var(--text);justify-content:space-between;align-items:baseline;gap:10px;font-size:13px;font-weight:800;display:flex}.style-strength-head strong{color:var(--brand-hover);white-space:nowrap;font-size:13.5px;font-weight:850}.style-strength-options{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;display:grid}.style-strength-option{border:1px solid var(--border);background:var(--surface);min-width:0;min-height:48px;color:var(--text-dim);cursor:pointer;font:inherit;transition:background .16s var(--ease), border-color .16s var(--ease), color .16s var(--ease), box-shadow .16s var(--ease);border-radius:12px;place-items:center;gap:2px;padding:7px 4px;display:grid}.style-strength-option:hover{border-color:var(--border-strong);background:var(--surface-2)}.style-strength-option.active{border-color:var(--brand);background:var(--brand);color:#fff;box-shadow:0 6px 16px #ff6f2d3d}.style-strength-percent{font-size:13px;font-weight:850;line-height:1.1}.style-strength-label{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:11.5px;font-weight:750;line-height:1.15;overflow:hidden}.strength-row{color:var(--text);justify-content:space-between;align-items:baseline;font-size:14px;font-weight:700;display:flex}.strength-row .strength-value{color:var(--brand-hover);letter-spacing:0;font-size:17px;font-weight:800}.strength-picker-section{--strength-thumb:24px}.strength-slider{--pct:100%;appearance:none;background:linear-gradient(to right, var(--brand) 0%, var(--brand) var(--pct), var(--border-strong) var(--pct), var(--border-strong) 100%);cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:999px;outline:0;width:100%;height:8px;margin:8px 0 2px}.strength-slider::-webkit-slider-thumb{appearance:none;background:var(--surface);cursor:pointer;border:3px solid var(--brand);width:24px;height:24px;transition:box-shadow .18s var(--ease), transform .18s var(--ease);border-radius:50%;box-shadow:0 3px 8px #1f160840,0 0 #ff7a2e00}.strength-slider::-webkit-slider-thumb:hover{transform:scale(1.04);box-shadow:0 3px 10px #1f160847,0 0 0 7px #ff7a2e29}.strength-slider::-moz-range-thumb{background:var(--surface);cursor:pointer;border:3px solid var(--brand);border-radius:50%;width:24px;height:24px;box-shadow:0 3px 8px #1f160840}.strength-marks{height:34px;margin-top:6px;position:relative}.strength-mark-button{top:0;left:var(--mark-left,0%);min-width:52px;color:var(--muted);font:inherit;cursor:pointer;background:0 0;border:0;justify-items:center;gap:5px;padding:0;display:grid;position:absolute;transform:translate(-50%)}.strength-mark-button:first-child{--mark-left:0%}.strength-mark-button:nth-child(2){--mark-left:33.333%}.strength-mark-button:nth-child(3){--mark-left:66.667%}.strength-mark-button:nth-child(4){--mark-left:100%}.strength-mark-dot{background:var(--border-strong);width:6px;height:6px;transition:background .16s var(--ease), transform .16s var(--ease);border-radius:50%}.strength-mark-label{letter-spacing:0;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:12px;font-weight:750;line-height:1.15;overflow:hidden}.strength-mark-button.active{color:var(--brand-hover)}.strength-mark-button.active .strength-mark-dot{background:var(--brand);transform:scale(1.25)}.panel-action{gap:10px}.download-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.download-options-single{grid-template-columns:1fr}.review-secondary-actions{grid-template-columns:1fr;gap:10px;display:grid}.review-secondary-btn{justify-content:center;align-items:center;gap:8px;min-height:52px;font-weight:750;display:inline-flex}.submit-btn{background:var(--brand);color:#fff;width:100%;padding:16px;font-size:15px}.submit-btn[data-cooldown=true],.submit-btn[data-cooldown=true]:disabled,.submit-btn[data-busy=true],.submit-btn[data-busy=true]:disabled{color:#71717a;box-shadow:none;background:#f4f4f5;border-color:#d4d4d8}.submit-btn:hover{background:var(--brand-hover);transform:translateY(-1px);box-shadow:0 6px 14px -6px #ff7a2e66}.submit-btn[data-cooldown=true]:hover,.submit-btn[data-cooldown=true]:disabled:hover,.submit-btn[data-busy=true]:hover,.submit-btn[data-busy=true]:disabled:hover{color:#71717a;box-shadow:none;background:#f4f4f5;border-color:#d4d4d8;transform:none}.generate-confirm-overlay{animation:confirmModalFadeIn .18s var(--ease-soft);padding:24px}.generate-confirm-dialog{text-align:center;background:var(--surface);border:1px solid var(--border);width:min(360px,100%);animation:confirmModalPop .22s var(--ease-soft);border-radius:20px;flex-direction:column;align-items:center;padding:28px 24px 18px;display:flex;box-shadow:0 24px 60px -20px #1f160859,0 8px 16px -8px #1f16082e}@keyframes confirmModalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes confirmModalPop{0%{opacity:0;transform:translateY(8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.generate-confirm-icon{background:var(--brand-pale);width:56px;height:56px;color:var(--brand);border-radius:50%;place-items:center;margin-bottom:14px;display:grid}.generate-confirm-title{color:var(--text);letter-spacing:-.01em;margin:0 0 12px;font-size:18px;font-weight:800}.generate-confirm-description{max-width:280px;color:var(--muted);margin:-2px 0 18px;font-size:14px;line-height:1.6}.generate-confirm-chip{border:1px solid var(--brand-soft);background:var(--brand-pale);color:var(--brand-hover);border-radius:999px;align-items:center;gap:6px;max-width:100%;margin-bottom:18px;padding:7px 14px;font-size:13.5px;font-weight:600;display:inline-flex}.generate-confirm-chip-sep{opacity:.55;font-weight:400}.generate-confirm-cost-row{justify-content:center;align-items:center;gap:18px;width:100%;margin-bottom:20px;display:flex}.generate-confirm-cost-item{flex-direction:column;align-items:center;gap:3px;display:flex}.generate-confirm-cost-label{color:var(--muted);letter-spacing:.02em;font-size:12px}.generate-confirm-cost-value{color:var(--text);font-variant-numeric:tabular-nums;font-size:16px;font-weight:800}.generate-confirm-cost-balance{color:var(--brand-hover)}.insufficient-chicken-icon{background:var(--brand-pale);color:var(--brand-hover)}.generate-confirm-cost-divider{background:var(--border);width:1px;height:28px}.generate-confirm-go{border-radius:var(--r-pill);width:100%;margin-bottom:6px;padding:14px 18px;font-size:16px;font-weight:700}.generate-confirm-cancel{width:100%;color:var(--muted);cursor:pointer;border-radius:var(--r-pill);transition:color .16s var(--ease), background .16s var(--ease);background:0 0;border:0;padding:12px;font-size:14.5px;font-weight:500}.generate-confirm-cancel:hover{color:var(--text);background:var(--surface-2)}.action-note{color:var(--muted);text-align:center;margin:0;font-size:12.5px}.history-only-hint{border:1px solid var(--brand-soft);background:var(--brand-pale);color:var(--text-dim);border-radius:12px;align-items:flex-start;gap:10px;padding:12px 14px;display:flex}.history-only-hint svg{color:var(--brand-hover);flex-shrink:0;margin-top:2px}.history-only-hint p{color:var(--text);margin:0;font-size:12.5px;line-height:1.6}.footer{border-top:1px solid var(--border);background:var(--surface-2);margin-top:40px}.footer-inner{max-width:1200px;padding:28px 32px 24px;padding-bottom:max(24px, env(safe-area-inset-bottom));gap:14px;margin:0 auto;display:grid}body[data-view=workspace] .footer-inner,body[data-view=review] .footer-inner{padding:24px 32px 20px}.disclaimer{color:var(--text-dim);max-width:720px;margin:0;font-size:12.5px;line-height:1.6}.footer-bottom{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.copyright{color:var(--muted);font-size:12px}.footer-links{flex-wrap:wrap;gap:22px;display:flex}.footer-links a{color:var(--text-dim);transition:color .15s var(--ease);font-size:12.5px}.footer-links a:hover{color:var(--brand-hover)}@media (max-width:900px){.workspace{grid-template-columns:1fr;align-items:start;gap:12px;padding:12px 14px 24px}.canvas-area{height:auto;min-height:0}.canvas-wrap{min-height:0;padding:10px}.preview-canvas,.compare-canvas,.compare-canvas .compare-sizer{max-width:100%;max-height:none}.view-review .canvas-wrap{padding:10px}.review-stage{align-content:start;gap:10px;height:auto}.param-panel{box-sizing:border-box;gap:16px;width:100%;min-width:0;max-width:100%;height:auto;min-height:0;max-height:none;padding:16px;font-size:14.5px;overflow:visible}.param-panel .panel-title{font-size:13px}.param-panel .style-module-card{gap:12px;padding:14px}.param-panel .style-module-icon{width:38px;height:38px}.param-panel .style-module-name{font-size:15.5px}.param-panel .style-module-desc{font-size:13px}.param-panel .mode-card .mode-name{font-size:16px}.param-panel .mode-card .mode-desc{font-size:13.5px}.param-panel .submit-btn{padding:16px;font-size:16px}.param-panel .submit-btn-secondary{padding:14px;font-size:14.5px}.param-panel .submit-btn-reupload{padding:15px;font-size:16px}.param-panel .download-options .submit-btn-secondary{font-size:14.5px}.view-review .param-panel .panel-action{order:1;margin-top:0}.view-review .guest-login-lead{order:2;margin-bottom:0}.view-review .guest-community-cta{order:3}.view-review .panel-history{order:4}.view-review .review-secondary-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.view-review .review-secondary-btn{border-color:var(--border-strong);background:var(--surface);min-height:56px;color:var(--text);padding:12px 8px;font-size:14.5px}.strength-row .strength-label{font-size:14px}.strength-row .strength-value{font-size:17px}.param-panel>*,.history-list,.history-item,.history-pick,.history-download,.download-options{min-width:0;max-width:100%}.download-options{grid-template-columns:repeat(2,minmax(0,1fr))}.view-review .review-stage{max-height:none;overflow:visible}.view-review .compare-canvas-wrap{justify-content:center;align-items:center;width:100%;max-width:100%;height:auto;min-height:0;max-height:60dvh;display:flex;overflow:visible}.view-review .compare-canvas{width:auto;max-width:100%;height:auto;max-height:60dvh;display:block}.view-review .compare-canvas .compare-sizer{width:auto;max-width:100%;height:auto;max-height:60dvh}.panel-history{flex:none}.history-list{flex:none;max-height:none;overflow:visible}.history-toggle{padding:16px 18px}.history-toggle .panel-title{font-size:16px}.history-toggle-icon{width:24px;height:24px}.style-module-card{grid-template-columns:38px minmax(0,1fr);padding:13px}.style-module-icon{border-radius:11px;width:38px;height:38px}.style-module-name{font-size:15px}.style-module-desc{font-size:12.5px;line-height:1.45}.mode-card{gap:12px;padding:18px 16px}.mode-card .mode-name{font-size:16.5px}.mode-card .mode-desc{font-size:13px}}@media (max-width:640px){.shell{padding:0}.topbar{height:auto;min-height:56px;padding:14px 18px 0}body[data-view=landing] .topbar{padding:14px 18px 0}body[data-view=workspace] .topbar,body[data-view=review] .topbar{height:auto;min-height:56px;padding:14px 18px 0}.topbar-file,.topbar-divider{display:none}.topbar-actions{gap:6px}.topbar-actions .btn{padding:10px 14px;font-size:14.5px;font-weight:600}.btn-icon{width:44px;height:44px;padding:0}.topbar-actions .btn-icon svg,.topbar-actions .theme-toggle svg{width:22px;height:22px}.topbar-name{font-size:17px;font-weight:800}.user-pill{height:auto;min-height:44px;padding:0 6px}.user-pill .user-pill-main{height:auto;padding:8px 12px;font-size:14.5px}.user-pill .user-pill-main strong{max-width:92px;font-size:14.5px}.user-pill .user-pill-main span{font-size:14.5px}.user-pill .btn-icon-sm{width:36px;height:36px}.user-pill .btn-icon-sm svg{width:16px;height:16px}.back-btn span{display:none}.stage{gap:28px;padding:1vh 18px 0}.hero-logo{width:76px;height:76px}.lede{font-size:15.5px}.upload-body{padding:40px 22px 28px}.upload-icon{width:56px;height:56px}.upload-title{font-size:19px}.upload-foot{padding:14px}.mode-grid{grid-template-columns:1fr;gap:10px}.mode-grid .mode-card{grid-template-columns:auto 1fr;align-items:center;gap:14px;padding:14px 16px}.mode-grid .mode-card .mode-icon{width:40px;height:40px}.canvas-wrap{min-height:0;padding:2px}.canvas-area{border:0;border-radius:0;min-height:0}.view-review .canvas-wrap{padding:2px}.view-review .canvas-area{background:0 0;border:0;border-radius:0}.upload-area{border-radius:14px}.footer-inner{padding:22px 18px 20px}.footer-bottom{flex-direction:column;align-items:flex-start;gap:10px}.footer-links{gap:14px}.share-menu{min-width:240px;right:-10px}:root{--topbar-h:56px}}.front-bootshell{background:var(--bg);min-height:100vh}.view-landing,.view-workspace,.view-review{animation:viewFadeIn .18s var(--ease-soft)}@keyframes viewFadeIn{0%{opacity:0}to{opacity:1}}.consent-overlay{z-index:80;-webkit-backdrop-filter:blur(8px);background:#1f160873;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.consent-dialog{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:min(420px,100%);box-shadow:var(--shadow-pop);gap:16px;padding:28px;display:grid}.consent-dialog h2{letter-spacing:-.015em;margin:0;font-size:20px;font-weight:800}.consent-dialog p{color:var(--text-dim);margin:0;font-size:14.5px;line-height:1.7}.auth-dropdown{position:relative}.auth-dropdown>summary{cursor:pointer;-webkit-user-select:none;user-select:none}.auth-dropdown>summary::-webkit-details-marker{display:none}.auth-dropdown>summary::marker{content:""}.auth-popover{z-index:40;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);width:min(340px,100vw - 28px);box-shadow:var(--shadow-pop);animation:pop .18s var(--ease);padding:18px;position:absolute;top:calc(100% + 8px);right:0}.auth-box{gap:10px;display:grid}.auth-switch{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface-2);gap:4px;margin-bottom:6px;padding:3px;display:flex}.auth-switch button{border-radius:var(--r-pill);min-height:30px;color:var(--muted);cursor:pointer;transition:all .16s var(--ease);background:0 0;border:0;flex:1;padding:0 14px;font-size:13px;font-weight:700}.auth-switch button.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px #1f160814}.auth-switch button:disabled{opacity:.4;cursor:not-allowed}.generation-wait-ad,.guest-history-cta{border:1px solid var(--border);border-radius:var(--r);background:var(--surface-2);grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:12px;display:grid}.generation-wait-ad img{object-fit:cover;border:1px solid var(--border);border-radius:8px;width:72px;height:72px}.generation-wait-ad strong,.guest-history-cta strong{color:var(--text);margin-bottom:4px;font-size:14px;display:block}.generation-wait-ad p,.guest-history-cta p{color:var(--muted);margin:0;font-size:13px;line-height:1.5}.generation-wait-ad span,.generation-wait-ad small{color:var(--text);margin-top:5px;font-size:12px;display:block}.guest-community-cta{text-align:center;border:1px solid color-mix(in srgb, var(--brand) 18%, var(--border-strong));background:color-mix(in srgb, var(--surface) 86%, var(--brand-pale));box-shadow:var(--shadow-card);border-radius:18px;justify-items:center;gap:14px;padding:18px;display:grid}.guest-community-cta p{color:var(--text);margin:0;font-size:14px;font-weight:750;line-height:1.45}.guest-community-cta img{object-fit:cover;border:1px solid var(--border);background:var(--surface);border-radius:14px;width:min(190px,58vw);height:min(190px,58vw)}.guest-login-lead{border:1px solid color-mix(in srgb, var(--brand) 22%, var(--border-strong));background:color-mix(in srgb, var(--surface) 88%, var(--brand-pale));box-shadow:var(--shadow-card);border-radius:18px;grid-template-columns:auto 1fr;align-items:start;gap:12px;margin-bottom:12px;padding:15px;display:grid}.guest-login-lead strong{color:var(--text);margin-bottom:5px;font-size:15px;display:block}.guest-login-lead p{color:var(--muted);margin:0;font-size:13px;line-height:1.55}.guest-history-actions{grid-column:1/-1;gap:8px;display:flex}.guest-history-actions .btn-quiet{border:1px solid var(--border-strong);background:var(--surface);color:var(--text)}.text-input{border:1px solid var(--border-strong);background:var(--surface-2);width:100%;min-height:40px;color:var(--text);font:inherit;transition:all .16s var(--ease);border-radius:10px;padding:0 14px;font-size:14px;display:block}.text-input:focus{border-color:var(--brand);background:var(--surface);outline:none;box-shadow:0 0 0 3px #ff7a2e24}.text-input::placeholder{color:var(--muted)}.text-input:disabled{opacity:.55;cursor:not-allowed}@media (max-width:900px){.text-input,.textarea,input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],textarea,select{font-size:16px}}.user-pill{border:1px solid var(--border-strong);border-radius:var(--r-pill);background:var(--surface);white-space:nowrap;align-items:center;gap:8px;height:38px;padding:0 6px 0 4px;display:inline-flex}.user-pill-main{border-radius:var(--r-pill);min-width:0;height:30px;color:inherit;cursor:pointer;font:inherit;transition:background .16s var(--ease);background:0 0;border:0;align-items:center;gap:8px;padding:0 8px 0 10px;display:inline-flex}.user-pill-main:hover{background:var(--surface-2)}.user-pill-main strong{text-overflow:ellipsis;max-width:120px;color:var(--text);font-size:13px;font-weight:700;overflow:hidden}.user-pill-main span{color:var(--brand-hover);font-size:13px;font-weight:700}.btn-icon-sm{width:28px;height:28px;color:var(--muted);cursor:pointer;transition:all .16s var(--ease);background:0 0;border:0;border-radius:50%;place-items:center;padding:0;display:grid}.btn-icon-sm:hover{background:var(--surface-2);color:var(--text)}.profile-overlay{z-index:75;-webkit-backdrop-filter:blur(10px);background:#1f160861;place-items:center;padding:22px;display:grid;position:fixed;inset:0}.profile-dialog{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:min(920px,100%);max-height:min(820px,100vh - 44px);box-shadow:var(--shadow-pop);gap:18px;padding:24px;display:grid;overflow:auto}.profile-head{justify-content:space-between;align-items:center;gap:14px;display:flex}.profile-head h2{letter-spacing:-.02em;margin:0;font-size:24px;font-weight:850}.profile-stats{grid-template-columns:1.3fr 1fr 1fr;gap:10px;display:grid}.profile-stat{border:1px solid var(--border);background:var(--surface-2);border-radius:16px;gap:6px;padding:16px;display:grid}.profile-stat span{color:var(--muted);font-size:12px;font-weight:700}.profile-stat strong{color:var(--text);font-size:24px;line-height:1.1}.profile-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.profile-card{border:1px solid var(--border);background:var(--surface);border-radius:18px;align-content:start;gap:12px;padding:18px;display:grid}.profile-card-title{color:var(--brand-hover);align-items:center;gap:8px;display:flex}.profile-card-title h3{color:var(--text);margin:0;font-size:15px;font-weight:850}.field-label{color:var(--text-dim);gap:6px;font-size:12px;font-weight:750;display:grid}.profile-meta{color:var(--muted);gap:4px;margin-top:2px;font-size:12px;display:grid}.profile-save{justify-self:start;margin-top:2px}.ledger-card{gap:14px}.ledger-list{gap:8px;max-height:260px;padding-right:4px;display:grid;overflow:auto}.ledger-row{border:1px solid var(--border);background:var(--surface-2);border-radius:14px;grid-template-columns:1fr auto;align-items:center;gap:14px;padding:12px 14px;display:grid}.ledger-row strong{text-overflow:ellipsis;white-space:nowrap;max-width:560px;color:var(--text);font-size:13.5px;display:block;overflow:hidden}.ledger-row span{color:var(--muted);margin-top:2px;font-size:11.5px;display:block}.ledger-amount{justify-items:end;gap:2px;min-width:84px;font-size:14px;font-weight:850;display:grid}.ledger-amount small{color:var(--muted);font-size:11px;font-weight:650}.empty-ledger,.profile-loading,.profile-message{color:var(--text-dim);margin:0;font-size:13px;line-height:1.6}.profile-loading{text-align:center;border:1px solid var(--border);background:var(--surface-2);border-radius:16px;padding:36px 18px}.profile-message{border:1px solid var(--border);background:var(--surface-2);border-radius:12px;padding:10px 12px}@media (max-width:640px){.user-pill-main strong{max-width:76px}.profile-overlay{place-items:stretch stretch;padding:10px}.profile-dialog{border-radius:22px;width:100%;max-height:calc(100vh - 20px);padding:18px}.profile-head h2{font-size:20px}.profile-stats,.profile-grid{grid-template-columns:1fr}.ledger-row{grid-template-columns:1fr;align-items:start}.ledger-amount{justify-items:start;min-width:0}.ledger-row strong{white-space:normal;max-width:100%}}.progress-card{border:1px solid var(--border);background:var(--surface-2);border-radius:10px;padding:10px 12px}.progress-row{color:var(--text-dim);justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;font-size:12px;font-weight:600;display:flex}.progress-row strong{color:var(--brand-hover);font-variant-numeric:tabular-nums;font-size:13px;font-weight:700}.progress-track{background:var(--border-strong);border-radius:999px;height:3px;overflow:hidden}.progress-fill{background:var(--brand);height:100%;transition:width .4s var(--ease);border-radius:999px}.progress-note{color:var(--muted);margin-top:5px;font-size:11.5px}.canvas-loading{z-index:5;box-sizing:border-box;background:color-mix(in srgb, var(--surface-canvas) 78%, transparent);-webkit-backdrop-filter:blur(10px)saturate(120%);animation:canvasLoadingFade .25s var(--ease);place-items:center;padding:16px;display:grid;position:absolute;inset:0}@keyframes canvasLoadingFade{0%{opacity:0}to{opacity:1}}.canvas-loading-inner{box-sizing:border-box;text-align:center;justify-items:center;gap:18px;width:min(430px,100%);max-width:100%;padding:24px 0;display:grid}.canvas-loading-ring{width:64px;height:64px}.canvas-loading-ring svg{width:100%;height:100%;display:block}.canvas-loading-ring circle{fill:none;stroke:var(--border-strong);stroke-width:3px}.canvas-loading-ring .canvas-loading-ring-spin{stroke:var(--brand);stroke-linecap:round;stroke-dasharray:40 90;transform-origin:50%;animation:1.1s linear infinite canvasRingSpin}@keyframes canvasRingSpin{to{transform:rotate(360deg)}}.canvas-loading-count{letter-spacing:-.04em;color:var(--text);font-variant-numeric:tabular-nums;font-size:clamp(48px,6vw,72px);font-weight:800;line-height:1}.canvas-loading-label{color:var(--text-dim);letter-spacing:.01em;font-size:13.5px;font-weight:500}.canvas-loading-track{background:var(--border-strong);border-radius:999px;width:100%;max-width:220px;height:3px;overflow:hidden}.canvas-loading-ad{box-sizing:border-box;-webkit-backdrop-filter:blur(8px)saturate(110%);background:#ffffff6b;border:1px solid #78716c38;border-radius:16px;justify-self:center;justify-items:center;gap:10px;width:min(340px,100%);padding:12px;animation:2.8s ease-in-out infinite loadingAdFloat;display:grid;position:relative;overflow:hidden;box-shadow:0 10px 26px #1f160814}.canvas-loading-ad:after{display:none}.canvas-loading-ad img{z-index:1;object-fit:cover;background:var(--surface);border:1px solid #1f16081f;border-radius:14px;width:min(180px,52vw);height:min(180px,52vw);position:relative}.canvas-loading-ad p{z-index:1;color:var(--text);margin:0;font-size:13px;font-weight:700;line-height:1.45;position:relative}@keyframes loadingAdFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes loadingAdSweep{0%,36%{transform:translate(-120%)}68%,to{transform:translate(120%)}}.canvas-loading-cancel{letter-spacing:.02em;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text-dim);cursor:pointer;transition:background .15s var(--ease-soft), color .15s var(--ease-soft), border-color .15s var(--ease-soft);border-radius:999px;margin-top:14px;padding:10px 22px;font-size:14px;font-weight:700}.canvas-loading-cancel:hover{color:#dc2626;background:#fff5f5;border-color:#dc2626}@media (max-width:900px){.canvas-loading-cancel{padding:12px 24px;font-size:15px}}.canvas-loading-fill{background:var(--brand);height:100%;transition:width .4s var(--ease);border-radius:999px}@media (max-width:640px){.canvas-loading{padding:12px}.canvas-loading-inner{gap:12px;width:min(360px,100%);padding:16px 0}.canvas-loading-ring{width:52px;height:52px}.canvas-loading-count{font-size:clamp(40px,9vw,56px)}.canvas-loading-ad{background:#ffffff57;border-color:#78716c2e;gap:8px;width:min(300px,88vw);padding:10px;display:grid;box-shadow:0 8px 20px #1f16080f}.canvas-loading-ad img{width:min(156px,48vw);height:min(156px,48vw)}.canvas-loading-ad p{font-size:12.5px}.guest-community-cta img{width:min(184px,56vw);height:min(184px,56vw)}}.message{color:var(--text-dim);text-align:center;margin:0;font-size:12.5px;line-height:1.55}.message.error{letter-spacing:.01em;color:#c53030;text-align:center;white-space:pre-wrap;word-break:break-word;animation:errorPulse .4s var(--ease-soft);background:#fff5f5;border:2px solid #fc8181;border-left-width:6px;border-radius:12px;margin:12px 0 0;padding:14px 18px;font-size:15px;font-weight:700;line-height:1.55;box-shadow:0 2px 10px -4px #e53e3e33}@keyframes errorPulse{0%{opacity:0;transform:scale(.97)}60%{opacity:1;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}@media (max-width:640px){.message.error{border-left-width:8px;padding:16px 18px;font-size:16.5px}}:root[data-theme=dark] .message.error{color:#fed7d7;background:#e53e3e24;border-color:#fc81818c;box-shadow:0 2px 12px -4px #e53e3e59}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .message.error{color:#fed7d7;background:#e53e3e24;border-color:#fc81818c;box-shadow:0 2px 12px -4px #e53e3e59}}.submit-btn-secondary{border:1px solid var(--border-strong);background:var(--surface);width:100%;color:var(--text);padding:14px;font-size:14.5px}.submit-btn-secondary:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-pale);transform:translateY(-1px)}.submit-btn-reupload{letter-spacing:.02em;border:2px solid var(--brand);background:var(--brand-pale);width:100%;color:var(--brand-hover);border-radius:var(--r-sm);cursor:pointer;transition:background .15s var(--ease-soft), color .15s var(--ease-soft), transform .1s var(--ease-soft), box-shadow .15s var(--ease-soft);justify-content:center;align-items:center;gap:8px;padding:14px;font-size:15px;font-weight:700;display:inline-flex}.submit-btn-reupload:hover{background:var(--brand);color:#fff;transform:translateY(-1px);box-shadow:0 6px 16px -6px #ff7a2e80}.submit-btn-reupload:active{transform:translateY(0)}.submit-btn-reupload:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}@media (max-width:640px){.submit-btn-reupload{padding:15px;font-size:16px}}@media (max-width:420px){.download-options{grid-template-columns:1fr}}.view-review .canvas-area{background:var(--surface-canvas)}.view-review .canvas-wrap{padding:20px 32px}.review-stage{grid-template-rows:minmax(0,1fr) auto auto auto;align-content:stretch;justify-items:center;gap:14px;width:100%;max-width:100%;height:100%;min-height:0;display:grid}.compare-canvas{border-radius:var(--r);background:var(--surface);width:auto;max-width:100%;height:100%;max-height:100%;box-shadow:var(--shadow-card);cursor:pointer;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:0;margin:0;padding:0;line-height:0;display:inline-block;position:relative;overflow:hidden}.compare-canvas .compare-sizer{object-fit:contain;visibility:hidden;pointer-events:none;-webkit-touch-callout:none;-webkit-user-drag:none;width:auto;max-width:100%;height:100%;max-height:100%;display:block}.compare-canvas .compare-base{object-fit:contain;pointer-events:none;-webkit-touch-callout:none;-webkit-user-drag:none;width:100%;height:100%;position:absolute;inset:0}.compare-canvas .compare-overlay{object-fit:contain;opacity:0;width:100%;height:100%;transition:opacity .15s var(--ease);pointer-events:none;-webkit-touch-callout:none;-webkit-user-drag:none;position:absolute;inset:0}.compare-canvas .compare-overlay.active{opacity:1}.compare-badge{border-radius:var(--r-pill);background:var(--brand);color:#fff;letter-spacing:.02em;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:800;line-height:1;display:inline-flex;position:absolute;top:14px;left:14px;box-shadow:0 4px 14px -4px #ff7a2e8c,0 1px 2px #0000002e}.compare-badge:before{content:"";background:#fff;border-radius:50%;width:6px;height:6px;box-shadow:0 0 0 3px #ffffff59}.compare-canvas-wrap{justify-content:center;align-items:center;width:100%;max-width:100%;height:100%;min-height:0;max-height:100%;display:flex;position:relative}.compare-fullscreen-trigger{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(6px);width:36px;height:36px;transition:background .15s var(--ease-soft), transform .1s var(--ease-soft);z-index:4;background:#0000008c;border:0;border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:12px;right:12px}.compare-fullscreen-trigger:hover{background:#000000b8}.compare-fullscreen-trigger:active{transform:scale(.94)}.compare-loading-overlay{color:#fff;border-radius:inherit;z-index:5;letter-spacing:.02em;background:#0000008c;flex-direction:column;justify-content:center;align-items:center;gap:10px;font-size:13.5px;font-weight:600;display:flex;position:absolute;inset:0}.compare-loading-spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.fullscreen-compare-overlay{z-index:200;animation:fadeIn .18s var(--ease-soft);background:#000000eb;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:24px 18px 36px;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fullscreen-close-btn{top:max(env(safe-area-inset-top,0px), 18px);color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2;background:#ffffff24;border:1px solid #ffffff38;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex;position:absolute;right:18px}.fullscreen-close-btn:hover{background:#ffffff38}.fullscreen-compare-canvas{cursor:pointer;touch-action:pinch-zoom;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;border-radius:8px;max-width:100%;max-height:calc(100dvh - 120px);display:inline-flex;position:relative;overflow:hidden;box-shadow:0 24px 60px -20px #0009}.fullscreen-compare-base,.fullscreen-compare-overlay-img{pointer-events:none;-webkit-user-drag:none;width:auto;max-width:100%;height:auto;max-height:calc(100vh - 120px);display:block}.fullscreen-compare-overlay-img{object-fit:contain;opacity:0;width:100%;height:100%;transition:opacity .12s var(--ease-soft);position:absolute;inset:0}.fullscreen-compare-overlay-img.active{opacity:1}.fullscreen-compare-badge{border-radius:var(--r-pill);background:var(--brand);color:#fff;letter-spacing:.02em;align-items:center;gap:6px;padding:6px 12px;font-size:12.5px;font-weight:800;line-height:1;display:inline-flex;position:absolute;top:12px;left:12px}.fullscreen-compare-badge:before{content:"";background:#fff;border-radius:50%;width:5px;height:5px}.fullscreen-compare-hint{color:#ffffffb8;text-align:center;margin:0;font-size:13px}@media (max-width:640px){.compare-fullscreen-trigger{width:38px;height:38px;top:10px;right:10px}.fullscreen-close-btn{width:40px;height:40px;top:max(env(safe-area-inset-top,0px), 12px);right:14px}.fullscreen-compare-hint{padding:0 10px;font-size:12.5px}}.compare-canvas:has(.compare-overlay.active) .compare-badge{color:#fff;background:#14100ad9;box-shadow:0 4px 14px -4px #00000080}.compare-canvas:has(.compare-overlay.active) .compare-badge:before{background:var(--brand);box-shadow:0 0 0 3px #ff7a2e66}.compare-toggle{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface);flex-shrink:0;gap:4px;padding:4px;display:inline-flex;box-shadow:0 2px 8px -4px #1f16081a}.compare-toggle button{border-radius:var(--r-pill);min-height:36px;color:var(--text-dim);cursor:pointer;transition:background .15s var(--ease-soft), color .15s var(--ease-soft);touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:0 0;border:0;padding:0 22px;font-size:13.5px;font-weight:700}.compare-toggle button:hover:not(.active){color:var(--text)}.compare-toggle button.active{background:var(--text);color:var(--bg)}.compare-hint{color:var(--muted);flex-shrink:0;margin:0;font-size:12px}.photo-meta-bar{flex-wrap:wrap;flex-shrink:0;justify-content:center;align-items:center;gap:8px;max-width:100%;margin-top:4px;display:inline-flex}.meta-chip{border:1px solid var(--border);background:var(--surface);color:var(--text-dim);white-space:nowrap;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:6px;padding:5px 12px;font-size:12.5px;line-height:1.2;display:inline-flex}.meta-chip-mode{border-color:var(--brand-soft);background:var(--brand-pale);max-width:min(72vw,520px);color:var(--brand-hover);font-weight:600}.meta-chip-mode .meta-chip-label{text-overflow:ellipsis;min-width:0;overflow:hidden}.meta-chip-mode .meta-chip-sep{opacity:.55;font-weight:400}.meta-chip-mode .meta-chip-val{font-variant-numeric:tabular-nums;font-weight:700}.meta-chip-model{font-variant-numeric:tabular-nums}.meta-chip-date{color:var(--muted);font-variant-numeric:tabular-nums}@media (max-width:900px){.meta-chip-model{display:none}}@media (max-width:640px){.photo-meta-bar{grid-template-columns:minmax(0,1fr) auto;gap:6px;width:100%;margin-top:6px;padding:0 2px;display:grid}.meta-chip{white-space:nowrap;text-align:center;justify-content:center;min-width:0;min-height:32px;padding:4px 8px;font-size:11.5px}.meta-chip-mode{width:100%;max-width:none}.meta-chip-date{text-overflow:ellipsis;width:max-content;max-width:none;overflow:hidden}}@media (max-width:390px){.photo-meta-bar{grid-template-columns:1fr}.meta-chip-date{width:100%}}.saved-only-stage{border-radius:var(--r);max-width:100%;max-height:calc(100dvh - var(--topbar-h) - 240px);place-items:center;display:grid;position:relative;overflow:hidden}.saved-only-stage img{width:auto;max-width:100%;height:auto;max-height:calc(100dvh - var(--topbar-h) - 240px);object-fit:contain;border-radius:var(--r);box-shadow:var(--shadow-card);display:block}@media (max-width:900px){.view-review .saved-only-stage,.view-review .saved-only-stage img{max-height:60dvh}}.version-card{border:1px solid var(--border);background:var(--surface-2);border-radius:16px;gap:10px;padding:14px;display:grid}.version-thumb{object-fit:cover;border-radius:12px;width:100%;max-height:220px;display:block}.version-meta{gap:6px;display:grid}.version-meta strong{color:var(--text);font-size:14.5px;font-weight:800}.version-meta-badge{border-radius:var(--r-pill);background:var(--brand-pale);border:1px solid var(--brand-soft);color:var(--brand-hover);letter-spacing:-.005em;align-items:center;gap:8px;width:fit-content;max-width:100%;padding:6px 12px;font-size:13.5px;font-weight:800;display:inline-flex}.version-meta-badge .meta-mode{color:var(--brand-hover)}.version-meta-badge .meta-dot{background:var(--brand);opacity:.6;border-radius:50%;flex-shrink:0;width:4px;height:4px}.version-meta-badge .meta-strength{color:var(--text);font-variant-numeric:tabular-nums}.panel-history{flex-direction:column;flex:auto;gap:10px;min-height:0;display:flex}.history-toggle{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);color:var(--text);cursor:pointer;font:inherit;text-align:left;width:100%;transition:background .15s var(--ease-soft), border-color .15s var(--ease-soft);touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:14px 16px;list-style:none;display:flex}summary.history-toggle::-webkit-details-marker{display:none}summary.history-toggle::marker{content:""}.history-toggle:hover{background:var(--bg);border-color:var(--border-strong)}.history-toggle:active{background:var(--brand-pale);border-color:var(--brand-soft)}details.panel-history[open]>.history-toggle{background:var(--brand-pale);border-color:var(--brand-soft);color:var(--brand-hover)}details.panel-history[open] .history-toggle-icon{opacity:1;color:var(--brand-hover);transform:rotate(180deg)}.history-toggle .panel-title{letter-spacing:-.01em;text-transform:none;color:inherit;align-items:center;gap:8px;margin:0;font-size:15px;font-weight:800;display:inline-flex}.history-toggle-icon{width:22px;height:22px;transition:transform .2s var(--ease-soft), color .15s var(--ease-soft);opacity:.9;color:inherit;flex-shrink:0}.history-toggle-icon.open{opacity:1;transform:rotate(180deg)}.history-list{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;min-height:0;max-height:clamp(280px,48vh,560px);animation:historyExpand .18s var(--ease-soft);isolation:isolate;z-index:1;background:var(--surface);flex:1 1 0;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:max-content;align-content:start;align-items:start;gap:10px;margin-top:6px;padding-right:6px;display:grid;position:relative;overflow-y:auto}.history-list::-webkit-scrollbar{width:5px}.history-list::-webkit-scrollbar-track{background:0 0}.history-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.history-list::-webkit-scrollbar-thumb:hover{background:var(--muted)}@media (max-width:900px){.history-list{-webkit-overflow-scrolling:auto;flex:none;max-height:none;padding-right:0;overflow:visible}}@keyframes historyExpand{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.history-item{border:1.5px solid var(--border);background:var(--surface);transition:border-color .16s var(--ease-soft);border-radius:12px;flex-direction:column;min-width:0;height:max-content;display:flex;position:relative;overflow:hidden}.history-item:hover{border-color:var(--border-strong)}.history-item.active{border-color:var(--brand)}.history-pick{cursor:pointer;color:inherit;font:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;background:0 0;border:0;flex-direction:column;width:100%;min-width:0;padding:0;display:flex}.history-pick img{background:var(--surface-2);pointer-events:none;-webkit-touch-callout:none;-webkit-user-drag:none;width:100%;height:auto;min-height:100px;display:block}.history-pick span{color:var(--text-dim);text-align:center;padding:8px 4px;font-size:13px;font-weight:600}@media (max-width:900px){.history-pick span{padding:10px 4px;font-size:13.5px}}.history-item.active .history-pick span{color:var(--brand-hover);font-weight:700}.history-download{color:#fff;cursor:pointer;opacity:0;width:26px;height:26px;transition:all .16s var(--ease);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;border:0;border-radius:50%;place-items:center;padding:0;display:grid;position:absolute;top:6px;right:6px;transform:translateY(-1px)}.history-item:hover .history-download,.history-item:focus-within .history-download{opacity:1;transform:translateY(0)}.history-download:hover{background:var(--brand)}.canvas-frame canvas{border-radius:var(--r);max-width:100%;max-height:100%;box-shadow:var(--shadow-card);background:var(--surface);display:block}@media (max-width:900px){.compare-canvas{max-height:50vh}.history-list{grid-template-columns:repeat(2,minmax(0,1fr))}}.admin-shell{background:#f6f7fa;grid-template-columns:252px 1fr;min-height:100vh;display:grid}:root[data-theme=dark] .admin-shell{background:#0f1115}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .admin-shell{background:#0f1115}}.admin-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;gap:0;height:100vh;padding:0;display:flex;position:sticky;top:0;overflow-y:auto}.admin-brand{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:14px;padding:22px 20px 20px;display:flex}.admin-brand .brand-logo{object-fit:contain;flex-shrink:0;width:42px;height:42px}.admin-brand-text{flex-direction:column;flex:auto;gap:1px;min-width:0;line-height:1.2;display:flex}.admin-brand-text strong{letter-spacing:-.01em;color:var(--text);font-size:18px;font-weight:800}.admin-brand-text span{color:var(--muted);letter-spacing:.05em;font-size:12.5px}.admin-nav-close{width:32px;height:32px;color:var(--text-dim);cursor:pointer;background:0 0;border:0;border-radius:50%;justify-content:center;align-items:center;display:none}.admin-nav{flex-direction:column;flex:auto;gap:0;padding:14px 12px 28px;display:flex}.admin-nav-group{flex-direction:column;gap:2px;padding-bottom:18px;display:flex}.admin-nav-group-label{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:14px 14px 8px;font-size:12px;font-weight:700}.admin-nav button{width:100%;color:var(--text-dim);text-align:left;cursor:pointer;transition:background .12s var(--ease-soft), color .12s var(--ease-soft);background:0 0;border:0;border-radius:9px;align-items:center;gap:12px;padding:11px 14px;font-size:14.5px;font-weight:500;display:flex;position:relative}.admin-nav button svg{width:18px;height:18px;color:var(--muted);flex-shrink:0}.admin-nav button:hover{background:var(--surface-2);color:var(--text)}.admin-nav button:hover svg{color:var(--text-dim)}.admin-nav button.active{background:var(--brand-pale);color:var(--brand-hover);font-weight:700}.admin-nav button.active svg{color:var(--brand)}.admin-nav button.active:before{content:"";background:var(--brand);border-radius:0 3px 3px 0;width:3px;height:22px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.admin-nav-overlay{z-index:80;animation:fadeIn .15s var(--ease-soft);background:#0f172a5c;display:none;position:fixed;inset:0}.admin-nav-toggle{border:1px solid var(--border);background:var(--surface);width:38px;height:38px;color:var(--text);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:none}.admin-top-title{flex:auto;align-items:center;gap:12px;min-width:0;display:flex}.admin-main{background:0 0;max-width:100%;padding:0 36px 48px;font-size:14.5px;position:relative;overflow-y:auto}.admin-card{background:var(--surface)}.admin-toast-layer{z-index:120;-webkit-backdrop-filter:blur(4px)saturate(120%);pointer-events:none;animation:adminToastLayerIn .18s var(--ease-soft);background:#fffaf26b;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.admin-toast{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 94%, transparent);color:var(--text);box-shadow:0 24px 70px #19120a2e, var(--shadow-pop);animation:adminToastIn .2s var(--ease-soft);text-align:left;border-radius:18px;align-items:center;gap:12px;max-width:min(360px,100vw - 56px);padding:18px 22px;font-size:15px;font-weight:850;display:flex}.admin-toast-icon{background:var(--surface-2);border-radius:999px;flex:none;place-items:center;width:38px;height:38px;display:grid}.admin-toast.success{background:color-mix(in srgb, var(--surface) 88%, #5fbf7d29);color:#2f9e63;border-color:#5fbf7d66}.admin-toast.error{background:color-mix(in srgb, var(--surface) 88%, #d94a4a29);color:#d94a4a;border-color:#d94a4a66}:root[data-theme=dark] .admin-toast-layer{background:#0807056b}:root[data-theme=dark] .admin-toast.success{background:color-mix(in srgb, var(--surface) 88%, #69d6922e);color:#69d692}:root[data-theme=dark] .admin-toast.error{background:color-mix(in srgb, var(--surface) 88%, #ff8a8a2e);color:#ff8a8a}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .admin-toast-layer{background:#0807056b}:root:not([data-theme=light]) .admin-toast.success{background:color-mix(in srgb, var(--surface) 88%, #69d6922e);color:#69d692}:root:not([data-theme=light]) .admin-toast.error{background:color-mix(in srgb, var(--surface) 88%, #ff8a8a2e);color:#ff8a8a}}@keyframes adminToastLayerIn{0%{opacity:0}to{opacity:1}}@keyframes adminToastIn{0%{opacity:0;transform:translateY(10px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.admin-main-refreshing .admin-card{opacity:.82;transition:opacity .16s var(--ease), transform .16s var(--ease);transform:translateY(1px)}.admin-top{z-index:40;-webkit-backdrop-filter:blur(10px)saturate(140%);border-bottom:1px solid var(--border);background:#f6f7fae0;justify-content:space-between;align-items:center;gap:16px;margin:0 0 22px;padding:22px 0;display:flex;position:sticky;top:0}:root[data-theme=dark] .admin-top{background:#0f1115e0}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .admin-top{background:#0f1115e0}}.admin-top h1{letter-spacing:-.015em;color:var(--text);margin:0;font-size:24px;font-weight:800}.admin-muted{font-size:13.5px}.admin-top .admin-muted{margin-top:4px}.admin-muted{color:var(--muted);font-size:13px}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px;display:grid}.metric-card{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);transition:all .18s var(--ease);padding:14px 16px}.metric-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-card);transform:translateY(-1px)}.metric-card span{color:var(--muted);letter-spacing:.02em;font-size:11.5px;font-weight:700;display:block}.metric-card strong{color:var(--text);letter-spacing:-.02em;margin-top:2px;font-size:22px;font-weight:800;display:block}.metric-grid-6{grid-template-columns:repeat(6,minmax(0,1fr))}@media (max-width:1100px){.metric-grid-6{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width:760px){.metric-grid-6{grid-template-columns:repeat(2,minmax(0,1fr))}}.metric-card-accent{background:var(--surface);border-color:var(--border)}.metric-card-accent:before{content:none}.metric-card-accent span{color:var(--muted)}.metric-card-accent strong{color:var(--text)}.dashboard-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.dashboard-summary-card{flex-direction:column;gap:16px;min-width:0;display:flex}.dashboard-summary-card-featured{grid-column:1/-1;gap:18px}.dashboard-summary-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.dashboard-summary-head h2{color:var(--text);letter-spacing:0;margin:0;font-size:18px;font-weight:850}.dashboard-summary-card-featured .dashboard-summary-head h2{font-size:21px}.dashboard-summary-head span{color:var(--muted);margin-top:4px;font-size:12.5px;font-weight:700;display:block}.dashboard-summary-head-side{justify-content:flex-end;align-items:center;gap:12px;margin-left:auto;display:flex}.dashboard-summary-head-side>strong{color:var(--brand-hover);font-variant-numeric:tabular-nums;font-size:30px;font-weight:900;line-height:1}.dashboard-summary-card-featured .dashboard-summary-head-side>strong{font-size:42px}.dashboard-range-switch{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface-2);align-items:center;gap:4px;padding:4px;display:inline-flex}.dashboard-range-switch button{border-radius:var(--r-pill);color:var(--muted);cursor:pointer;transition:background .16s var(--ease), color .16s var(--ease), box-shadow .16s var(--ease);background:0 0;border:0;padding:7px 10px;font-size:12.5px;font-weight:800}.dashboard-range-switch button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-soft)}.dashboard-summary-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.dashboard-summary-card-featured .dashboard-summary-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.dashboard-total-detail-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;display:grid}.dashboard-summary-metrics .metric-card{padding:11px 12px}.dashboard-summary-metrics .metric-card strong{font-size:19px}.dashboard-style-stats{gap:8px;min-width:0;display:grid}.dashboard-summary-card-featured .dashboard-style-stats .bar-list{grid-template-columns:1fr}.dashboard-style-title{color:var(--text);font-size:13px;font-weight:800}.dashboard-style-stats .bar-row{grid-template-columns:minmax(220px,.52fr) minmax(160px,1fr) 60px;align-items:center}.dashboard-style-label{white-space:normal;text-overflow:clip;word-break:break-word;line-height:1.35;overflow:visible}.dashboard-style-other{color:var(--muted);padding-top:2px;font-size:12.5px;font-weight:700}.dashboard-empty{color:var(--muted);margin:0;font-size:13px}.dashboard-mini-list{gap:8px;padding-top:2px;display:grid}.dashboard-inline-metrics{grid-template-columns:minmax(0,1fr);display:grid}.dashboard-mini-row{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:9px 10px;display:grid}.dashboard-mini-row span{gap:2px;min-width:0;display:grid}.dashboard-mini-row strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text);font-size:12.5px;overflow:hidden}.dashboard-mini-row small,.dashboard-mini-row em{color:var(--muted);font-size:11.5px;font-style:normal;font-weight:700}.dashboard-mini-row b{color:var(--brand-hover);font-variant-numeric:tabular-nums;font-size:16px;font-weight:850}@media (max-width:1200px){.dashboard-summary-grid{grid-template-columns:1fr}.dashboard-total-detail-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width:760px){.dashboard-summary-head-side{justify-content:space-between;width:100%;margin-left:0}.dashboard-range-switch{flex-wrap:wrap}.dashboard-summary-metrics,.dashboard-summary-card-featured .dashboard-summary-metrics,.dashboard-summary-card-featured .dashboard-style-stats .bar-list,.dashboard-total-detail-grid{grid-template-columns:1fr}.dashboard-style-stats .bar-row{grid-template-columns:1fr;gap:6px}.dashboard-style-stats .bar-value{flex-direction:row;align-items:flex-start;gap:6px}}.dashboard-v2-kpi-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.dashboard-v2-kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:4px;padding:14px 16px;display:flex;box-shadow:0 1px 2px #0000000a}.dashboard-v2-kpi-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:10.5px;font-weight:750}.dashboard-v2-kpi-value{font-variant-numeric:tabular-nums;color:var(--text);font-size:30px;font-weight:900;line-height:1}.dashboard-v2-kpi-value-accent{color:var(--brand-hover)}.dashboard-v2-kpi-sub{color:var(--muted);font-size:10px;font-weight:700}.dashboard-v2-compare{grid-template-columns:1fr 1fr;gap:8px;display:grid}.dashboard-v2-panel{border:1px solid var(--border);background:var(--surface);border-radius:10px;overflow:hidden;box-shadow:0 1px 2px #0000000a}.dashboard-v2-panel-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.dashboard-v2-panel-head-guest{background:#6366f10a}.dashboard-v2-panel-head-member{background:#d977060a}.dashboard-v2-panel-head h2{align-items:center;gap:6px;font-size:14px;font-weight:850;display:flex}.dashboard-v2-dot{border-radius:999px;flex-shrink:0;width:8px;height:8px}.dashboard-v2-dot-guest{background:#6366f1}.dashboard-v2-dot-member{background:var(--brand-hover)}.dashboard-v2-panel-total{font-variant-numeric:tabular-nums;align-items:baseline;gap:5px;font-size:26px;font-weight:900;line-height:1;display:flex}.dashboard-v2-panel-total-guest{color:#6366f1}.dashboard-v2-panel-total-member{color:var(--brand-hover)}.dashboard-v2-panel-total .dash-pct{color:var(--muted);align-self:flex-end;margin-bottom:2px;font-size:12px;font-weight:800}.dashboard-v2-panel-body{padding:10px 16px}.dashboard-v2-panel-metrics{grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:10px;display:grid}.dashboard-v2-mini-metric{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:3px;padding:10px 12px;display:flex}.dashboard-v2-mini-label{color:var(--muted);font-size:10px;font-weight:750}.dashboard-v2-mini-value{font-variant-numeric:tabular-nums;font-size:19px;font-weight:900}.dashboard-v2-mini-sub{color:var(--muted);font-size:9.5px;font-weight:700}.dashboard-v2-rank-title{color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px;font-size:10px;font-weight:800}.dashboard-v2-rank-list{flex-direction:column;gap:2px;display:flex}.dashboard-v2-rank-row{border:1px solid #0000;border-radius:6px;grid-template-columns:18px 1fr 72px auto;align-items:center;gap:5px;padding:4px 8px;display:grid}.dashboard-v2-rank-row:nth-child(odd){background:var(--surface-2)}.dashboard-v2-rank-num{color:var(--muted);text-align:center;font-variant-numeric:tabular-nums;font-size:10px;font-weight:900}.dashboard-v2-rank-num-top{color:var(--brand-hover)}.dashboard-v2-rank-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:11.5px;font-weight:750;overflow:hidden}.dashboard-v2-rank-loc{color:var(--muted);text-align:left;white-space:nowrap;font-size:9.5px;font-weight:700}.dashboard-v2-rank-stat{color:var(--brand-hover);font-variant-numeric:tabular-nums;text-align:right;font-size:12.5px;font-weight:850}.dashboard-v2-platform-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.dashboard-v2-platform-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;align-items:center;gap:18px;padding:14px 16px;display:flex;box-shadow:0 1px 2px #0000000a}.dashboard-v2-pie-wrap{flex-shrink:0;place-items:center;width:110px;height:110px;display:grid}.dashboard-v2-pie-wrap svg{width:100%;height:100%;transform:rotate(-90deg)}.dashboard-v2-legend{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.dashboard-v2-legend-title{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:10.5px;font-weight:800}.dashboard-v2-legend-row{align-items:center;gap:5px;display:flex}.dashboard-v2-legend-dot{border-radius:2px;flex-shrink:0;width:7px;height:7px}.dashboard-v2-legend-name{white-space:nowrap;text-overflow:ellipsis;min-width:55px;font-size:11px;font-weight:750;overflow:hidden}.dashboard-v2-legend-pct{font-variant-numeric:tabular-nums;text-align:right;min-width:28px;font-size:11px;font-weight:800}.dashboard-v2-legend-count{color:var(--muted);text-align:right;min-width:24px;font-size:9.5px;font-weight:700}.dashboard-v2-style-bar-list{flex-direction:column;gap:5px;display:flex}.dashboard-v2-style-bar-row{grid-template-columns:110px 1fr 64px;align-items:center;gap:8px;display:grid}.dashboard-v2-style-bar-label{white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;font-weight:750;overflow:hidden}.dashboard-v2-style-bar-track{background:var(--surface-2);border-radius:999px;height:6px;overflow:hidden}.dashboard-v2-style-bar-fill{background:linear-gradient(90deg,#f59e0b,#d97706);border-radius:999px;height:100%}.dashboard-v2-style-bar-fill-alt{background:linear-gradient(90deg,#6366f1,#818cf8)}.dashboard-v2-style-bar-value{font-variant-numeric:tabular-nums;text-align:right;color:var(--text);font-size:11px;font-weight:800}.dashboard-v2-style-bar-value small{color:var(--muted);margin-left:3px;font-size:9.5px}.dashboard-v2-style-bar-other{color:var(--muted);border-top:1px dashed var(--border);margin-top:3px;padding-top:4px;font-size:10.5px;font-weight:700}@media (max-width:860px){.dashboard-v2-kpi-grid{grid-template-columns:repeat(2,1fr)}.dashboard-v2-compare,.dashboard-v2-platform-grid{grid-template-columns:1fr}}@media (max-width:560px){.dashboard-v2-kpi-grid{grid-template-columns:repeat(2,1fr);gap:6px}.dashboard-v2-kpi-card{gap:3px;padding:12px 13px}.dashboard-v2-kpi-value{font-size:24px}.dashboard-v2-compare,.dashboard-v2-platform-grid{grid-template-columns:1fr;gap:6px}.dashboard-v2-panel-head{padding:10px 14px}.dashboard-v2-panel-head h2{font-size:13px}.dashboard-v2-panel-total{font-size:22px}.dashboard-v2-panel-body{padding:8px 14px}.dashboard-v2-panel-metrics{gap:4px;margin-bottom:8px}.dashboard-v2-mini-metric{padding:8px 10px}.dashboard-v2-mini-value{font-size:16px}.dashboard-v2-rank-row{grid-template-columns:18px 1fr auto;gap:4px}.dashboard-v2-rank-loc{display:none}.dashboard-v2-platform-card{flex-direction:row;gap:14px;padding:12px 14px}.dashboard-v2-pie-wrap{width:90px;height:90px}.dashboard-v2-legend-name{min-width:48px;font-size:10.5px}.dashboard-v2-style-bar-row{grid-template-columns:90px 1fr 56px;gap:6px}}.admin-log-block{gap:10px;margin-top:18px;display:grid}.admin-log-block-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.admin-log-block-head h3{color:var(--text);margin:0;font-size:15px}.chart-row{grid-template-columns:2fr 1fr;gap:10px;margin-bottom:10px;display:grid}.chart-row-3{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width:1100px){.chart-row,.chart-row-3{grid-template-columns:1fr}}.chart-period-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.chart-period-label{letter-spacing:.04em;color:var(--muted);text-transform:uppercase;font-size:12.5px;font-weight:800}.chart-period-switch{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface-2);gap:4px;padding:4px;display:inline-flex}.chart-period-switch button{border-radius:var(--r-pill);min-height:32px;color:var(--text-dim);cursor:pointer;transition:all .16s var(--ease);background:0 0;border:0;padding:0 16px;font-family:inherit;font-size:13px;font-weight:700}.chart-period-switch button:hover{color:var(--text)}.chart-period-switch button.active{background:var(--surface);color:var(--brand-hover);box-shadow:0 1px 2px #1f160814}.chart-head-num{letter-spacing:-.02em;color:var(--brand-hover);font-variant-numeric:tabular-nums;font-size:18px;font-weight:800}.admin-bootshell{background:var(--bg);min-height:100vh}.admin-shell,.admin-login-shell{animation:viewFadeIn .18s var(--ease-soft)}.keys-page{gap:14px;display:grid}.key-status-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}@media (max-width:1100px){.key-status-grid{grid-template-columns:1fr 1fr}}@media (max-width:700px){.key-status-grid{grid-template-columns:1fr}}.key-status{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);flex-direction:column;gap:10px;padding:16px;display:flex;position:relative}.key-status-analysis,.key-status-image{background:var(--surface);border-color:var(--border)}.key-status-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.key-status-head-actions{flex-wrap:wrap;gap:6px;display:flex}.key-status-badge{border-radius:var(--r-pill);background:var(--surface);border:1px solid var(--border);letter-spacing:.02em;color:var(--text);align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:800;display:inline-flex}.key-status-analysis .key-status-badge{color:#2f9e63;border-color:#5fbf7d4d}.key-status-image .key-status-badge{color:var(--brand-hover);border-color:#ff7a2e4d}:root[data-theme=dark] .key-status-analysis .key-status-badge{color:#69d692}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .key-status-analysis .key-status-badge{color:#69d692}}.key-status-name{letter-spacing:-.015em;color:var(--text);font-size:17px;font-weight:800}.key-status-meta{color:var(--text-dim);flex-wrap:wrap;align-items:center;gap:10px;font-size:12.5px;display:flex}.key-status-meta code{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:3px 8px;font-family:ui-monospace,SF Mono,monospace;font-size:12px}.key-status-url{color:var(--muted);font-family:ui-monospace,SF Mono,monospace;font-size:11.5px}.key-status-empty{color:var(--muted);margin:0;font-size:13px;font-style:italic}.key-purpose-pills{flex-wrap:wrap;gap:8px;margin-bottom:4px;display:flex}.key-purpose-pill{border:1.5px solid var(--border-strong);border-radius:var(--r-pill);background:var(--surface);color:var(--text-dim);cursor:pointer;transition:all .16s var(--ease);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:9px 16px;font-size:13.5px;font-weight:700;display:inline-flex}.key-purpose-pill:hover{border-color:var(--brand);color:var(--brand-hover)}.key-purpose-pill input{display:none}.key-purpose-pill.active{border-color:var(--brand);background:var(--brand-pale);color:var(--brand-hover)}.key-form-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.key-form-actions .admin-save{margin-left:auto}.key-list-v2{gap:10px;display:grid}.key-card{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);transition:all .18s var(--ease);flex-direction:column;gap:12px;padding:16px 18px;display:flex}.key-card:hover{border-color:var(--border-strong)}.key-card-active{background:var(--surface);box-shadow:inset 3px 0 0 var(--brand);border-color:#ff7a2e66}.key-card-head{flex-direction:column;gap:6px;display:flex}.key-card-title{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.key-card-title strong{color:var(--text);letter-spacing:-.01em;font-size:15px;font-weight:800}.key-card-badges{flex-wrap:wrap;gap:6px;display:flex}.key-badge{border-radius:var(--r-pill);letter-spacing:.02em;align-items:center;gap:3px;padding:3px 8px;font-size:11px;font-weight:800;display:inline-flex}.key-badge-analysis{color:#2f9e63;background:#5fbf7d24}.key-badge-image{background:var(--brand-pale);color:var(--brand-hover);border:1px solid #ff7a2e33}.key-badge-fallback{color:#5c6cb8;background:#7878c81f;border:1px dashed #7878c866}:root[data-theme=dark] .key-badge-fallback{color:#9aa6ff;background:#7878c829}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .key-badge-fallback{color:#9aa6ff;background:#7878c829}}.key-status-fallback{border-style:dashed;border-color:var(--border-strong)}.key-status-fallback .key-status-badge{color:#5c6cb8}:root[data-theme=dark] .key-status-fallback .key-status-badge{color:#9aa6ff}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .key-status-fallback .key-status-badge{color:#9aa6ff}}:root[data-theme=dark] .key-badge-analysis{color:#69d692;background:#69d69229}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .key-badge-analysis{color:#69d692;background:#69d69229}}.key-card-meta{color:var(--text-dim);flex-wrap:wrap;align-items:center;gap:10px;font-size:12.5px;display:flex}.key-card-meta code{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:2px 8px;font-family:ui-monospace,SF Mono,monospace;font-size:12px}.key-card-url{color:var(--muted);font-family:ui-monospace,SF Mono,monospace;font-size:11.5px}.key-card-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.key-card-divider{letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-left:4px;font-size:11.5px;font-weight:700}.key-card-delete{margin-left:auto}@media (max-width:760px){.key-status-head-actions{width:100%}.key-card-actions{gap:4px}}.key-test-line{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.test-status{border-radius:var(--r-pill);letter-spacing:.02em;cursor:help;animation:pop .16s var(--ease);border:1px solid #0000;align-items:center;gap:4px;padding:4px 10px;font-family:ui-monospace,SF Mono,monospace;font-size:11.5px;font-weight:700;display:inline-flex}.test-status svg{flex-shrink:0}.test-status-time{letter-spacing:0}.test-status-success{color:#2f9e63;background:#5fbf7d1f;border-color:#5fbf7d47}.test-status-error{color:#d94a4a;background:#d94a4a1a;border-color:#d94a4a47}:root[data-theme=dark] .test-status-success{color:#69d692;background:#69d69224;border-color:#69d6924d}:root[data-theme=dark] .test-status-error{color:#ff8a8a;background:#ff8a8a1f;border-color:#ff8a8a4d}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .test-status-success{color:#69d692;background:#69d69224;border-color:#69d6924d}:root:not([data-theme=light]) .test-status-error{color:#ff8a8a;background:#ff8a8a1f;border-color:#ff8a8a4d}}.chart-card{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);flex-direction:column;gap:10px;padding:16px 18px;display:flex}.chart-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.chart-head h2{letter-spacing:-.015em;margin:0;font-size:14px;font-weight:800}.line-chart-wrap{flex-direction:column;gap:4px;min-height:0;display:flex;position:relative}.line-chart{width:100%;height:130px;display:block}.line-chart-hover{pointer-events:none;height:130px;display:flex;position:absolute;top:0}.line-chart-hover-col{pointer-events:auto;cursor:crosshair;flex:1 1 0;height:100%}.line-chart-tooltip{z-index:5;pointer-events:none;background:var(--text);color:var(--bg);white-space:nowrap;animation:tooltipPop .12s var(--ease);border-radius:8px;flex-direction:column;align-items:center;gap:1px;padding:6px 10px;display:flex;position:absolute;transform:translate(-50%,calc(-100% - 10px));box-shadow:0 8px 20px -6px #00000059}.line-chart-tooltip:after{content:"";border:5px solid #0000;border-top-color:var(--text);width:0;height:0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.line-chart-tooltip .tooltip-label{opacity:.75;letter-spacing:0;font-family:ui-monospace,SF Mono,monospace;font-size:10.5px;font-weight:600}.line-chart-tooltip .tooltip-value{letter-spacing:-.01em;font-variant-numeric:tabular-nums;font-size:14px;font-weight:800}@keyframes tooltipPop{0%{opacity:0;transform:translate(-50%,calc(-100% - 4px))}to{opacity:1;transform:translate(-50%,calc(-100% - 10px))}}.line-chart-labels{color:var(--muted);justify-content:space-between;font-family:ui-monospace,SF Mono,monospace;font-size:10.5px;font-weight:700;display:flex}.line-chart-labels span{text-align:center;flex:1}.donut-wrap{flex-direction:column;align-items:center;gap:8px;padding:4px 0;display:flex}.donut{width:110px;height:110px}.donut-meta{text-align:center;flex-direction:column;align-items:center;gap:1px;display:flex}.donut-meta span{font-size:12.5px;font-weight:600}.donut-meta small{font-size:11px}.bar-list{gap:14px;padding:4px 0;display:grid}.bar-row{grid-template-columns:90px 1fr 40px;align-items:center;gap:12px;display:grid}.bar-label{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:700;overflow:hidden}.bar-track{background:var(--surface-2);border-radius:999px;height:10px;position:relative;overflow:hidden}.bar-fill{background:linear-gradient(90deg, var(--brand), var(--brand-hover));height:100%;transition:width .45s var(--ease);border-radius:999px;min-width:2px;position:absolute;inset:0 auto 0 0}.bar-value{text-align:right;color:var(--text);font-variant-numeric:tabular-nums;flex-direction:column;align-items:flex-end;font-size:13.5px;font-weight:800;line-height:1.15;display:flex}.bar-value small{color:var(--brand-hover);margin-top:1px;font-size:11px;font-weight:700}.bar-row{grid-template-columns:90px 1fr 56px}.settings-head{justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;display:flex}.settings-head h2{letter-spacing:-.015em;margin:0;font-size:21px;font-weight:800}.settings-tabs{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface-2);flex-wrap:wrap;gap:4px;padding:4px;display:flex}.settings-tabs button{border-radius:var(--r-pill);min-height:32px;color:var(--text-dim);cursor:pointer;transition:all .16s var(--ease);background:0 0;border:0;align-items:center;gap:6px;padding:0 16px;font-size:12.5px;font-weight:700;display:inline-flex}.settings-tabs button.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px #1f160814}.settings-tabs button:hover:not(.active){color:var(--text)}.settings-panel,.setting-fields{gap:14px;display:grid}.setting-block{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);grid-template-columns:minmax(220px,.7fr) minmax(0,1.3fr);gap:20px;padding:20px;display:grid}.setting-block h3,.setting-block p{margin:0}.setting-block h3{letter-spacing:-.01em;font-size:17px;font-weight:800}.setting-block p,.setting-fields small{color:var(--muted);font-size:12.5px;line-height:1.65}.setting-fields label{gap:6px;display:grid}.setting-fields label span{color:var(--text-dim);font-size:12.5px;font-weight:700}.readonly-setting,.setting-placeholder{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);gap:5px;padding:12px 14px;display:grid}.readonly-setting span{color:var(--muted);font-size:12px}.readonly-setting strong{color:var(--text);font-size:13.5px}.setting-placeholder{color:var(--muted);font-size:12.5px;line-height:1.65}.admin-card{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);padding:22px}.admin-form{gap:14px;display:grid}.system-settings-card{gap:18px;display:grid}.admin-table,.data-table,.key-list{gap:8px;display:grid}.admin-table,.data-table{overflow-x:auto}.admin-row,.data-row{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);align-items:center;gap:12px;padding:14px 16px;font-size:13.5px;display:grid}.admin-row{grid-template-columns:1.45fr 1fr 100px 95px 90px 1fr 1fr 80px 250px;min-width:1250px}.admin-row-head,.data-head{background:var(--surface-2);color:var(--muted);letter-spacing:.02em;font-weight:700}.data-row{min-width:920px}.data-row span{overflow-wrap:anywhere;min-width:0}.key-item{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.key-item strong,.key-item span{display:block}.key-item strong{color:var(--text);font-size:14px;font-weight:700}.key-item span{color:var(--muted);margin-top:2px;font-size:11.5px}.key-item-wrap{gap:8px;display:grid}.key-test-result{animation:pop .18s var(--ease);border:1px solid #0000;border-radius:10px;align-items:flex-start;gap:8px;padding:10px 14px;font-size:13px;font-weight:600;line-height:1.5;display:flex}.key-test-result svg{flex-shrink:0;margin-top:1px}.key-test-result.success{color:#2f9e63;background:#5fbf7d1a;border-color:#5fbf7d4d}.key-test-result.error{color:#d94a4a;background:#d94a4a14;border-color:#d94a4a40}:root[data-theme=dark] .key-test-result.success{color:#69d692}:root[data-theme=dark] .key-test-result.error{color:#ff8a8a}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .key-test-result.success{color:#69d692}:root:not([data-theme=light]) .key-test-result.error{color:#ff8a8a}}.proxy-page{gap:14px;padding:0;display:grid}.proxy-settings-card{gap:16px;padding:22px 20px}.proxy-settings-card .settings-head{border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:12px}.proxy-settings-card .settings-head h2{font-size:21px}.proxy-settings-card .settings-head p{margin-top:4px;font-size:13px}.proxy-global-control{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:inline-flex}.proxy-global-pill{border-radius:var(--r-pill);align-items:center;min-height:30px;padding:0 12px;font-size:12px;font-weight:800;display:inline-flex}.proxy-global-pill.active{color:#0f9688;background:#14b8a61f}.proxy-global-pill.inactive{color:#d94a4a;background:#d94a4a14}.proxy-global-switch{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface);min-height:34px;color:var(--text-dim);cursor:pointer;transition:background .16s var(--ease), border-color .16s var(--ease), color .16s var(--ease);align-items:center;gap:9px;padding:0 12px 0 4px;font-size:13px;font-weight:800;display:inline-flex;box-shadow:0 8px 18px -18px #0f172a4d}.proxy-global-switch span{border-radius:var(--r-pill);width:48px;height:26px;transition:background .16s var(--ease);background:#94a3b847;position:relative}.proxy-global-switch span:after{content:"";width:20px;height:20px;transition:transform .16s var(--ease);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 4px 10px -6px #0f172abf}.proxy-global-switch.active{color:#0f9688;border-color:#14b8a647}.proxy-global-switch.active span{background:#14b8a6cc}.proxy-global-switch.active span:after{transform:translate(22px)}.proxy-action-bar{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;padding:2px 0 0;display:grid}.proxy-filters,.proxy-toolbar-actions{flex-wrap:wrap;align-items:center;gap:8px;min-width:0;display:flex}.proxy-filters{justify-content:flex-start}.proxy-toolbar-actions{justify-content:flex-end;max-width:100%}.proxy-filter-select{border:1px solid var(--border);background:var(--surface);width:136px;min-height:40px;color:var(--text);font:inherit;border-radius:10px;padding:0 34px 0 13px;font-size:14px;font-weight:700;box-shadow:0 6px 18px -18px #0f172a40}.proxy-icon-button{border:1px solid var(--border);background:var(--surface);width:40px;height:40px;color:var(--text-dim);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 6px 18px -18px #0f172a40}.proxy-toolbar-actions .secondary-button,.proxy-toolbar-actions .primary-button{border-radius:10px;gap:6px;min-height:40px;padding-inline:13px;font-size:14px;font-weight:750;box-shadow:0 6px 18px -18px #0f172a40}.proxy-delete-button{color:#d94a4a;background:#d94a4a0f;border-color:#d94a4a38}.proxy-add-button{color:#fff;background:#0ea998}.proxy-table-card{border:1px solid var(--border);background:var(--surface);border-radius:12px;overflow:auto hidden;box-shadow:0 10px 24px -24px #0f172a47}.proxy-table{min-width:930px;display:grid}.proxy-row{border-top:1px solid var(--border);min-height:72px;color:var(--text);background:var(--surface);grid-template-columns:34px minmax(96px,.68fr) 56px minmax(172px,1fr) minmax(140px,.8fr) minmax(100px,.55fr) minmax(260px,1.1fr);align-items:center;gap:8px;padding:0 14px;font-size:14px;display:grid}.proxy-row:first-child{border-top:0}.proxy-row-head{min-height:54px;color:var(--text-dim);background:#fff9efbd;font-size:14px;font-weight:800}.proxy-check-cell,.proxy-name-cell,.proxy-row-actions{background:inherit}.proxy-check-cell{z-index:2;position:sticky;left:0}.proxy-check-cell input{width:16px;height:16px}.proxy-name-cell,.proxy-location-cell{gap:5px;min-width:0;display:grid}.proxy-name-cell{z-index:2;position:sticky;left:34px}.proxy-name-cell strong{overflow-wrap:anywhere;font-size:14px;font-weight:800}.proxy-name-cell em{color:#0f9688;background:#14b8a624;border-radius:999px;align-items:center;width:fit-content;min-height:20px;padding:0 7px;font-size:10.5px;font-style:normal;font-weight:800;display:inline-flex}.proxy-address-cell{align-items:center;gap:6px;min-width:0;display:inline-flex}.proxy-address-cell code{background:var(--surface-2);color:#008b8b;white-space:nowrap;text-overflow:ellipsis;border-radius:6px;min-width:0;max-width:calc(100% - 30px);padding:4px 7px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:13px;display:block;overflow:hidden}.proxy-mini-icon{width:24px;height:24px;color:var(--muted);cursor:pointer;background:0 0;border:0;flex:0 0 24px;justify-content:center;align-items:center;display:inline-flex}.proxy-location-cell strong{overflow-wrap:anywhere;min-width:0;font-size:14px;font-weight:700;line-height:1.45}.proxy-protocol-pill,.proxy-status-pill{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;width:fit-content;min-height:22px;padding:0 8px;font-size:11px;font-weight:800;display:inline-flex}.proxy-protocol-pill{background:var(--surface-2);color:var(--text-dim)}.proxy-status-pill.success{color:#0f9688;background:#14b8a624}.proxy-status-pill.unknown{background:var(--surface-2);color:var(--muted)}.proxy-status-pill.error{color:#d94a4a;background:#d94a4a1a}.proxy-check-result-cell{flex-wrap:wrap;align-items:center;gap:6px;min-width:0;display:flex}.proxy-check-result-cell>strong{color:#0f9688;background:#14b8a62e;border-radius:999px;justify-content:center;align-items:center;min-width:66px;min-height:22px;font-size:11px;font-weight:800;display:inline-flex}.proxy-row-actions{z-index:2;flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:4px;display:flex;position:sticky;right:0;box-shadow:-18px 0 18px -22px #0f172a73}.proxy-row-actions button{width:62px;min-width:62px;height:48px;color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:4px 3px;font-size:12px;line-height:1.25;display:inline-flex}.proxy-row-actions button:hover:not(:disabled){color:#0f9688;background:#14b8a614;border-color:#14b8a62e}.proxy-row-actions button:disabled{opacity:.45;cursor:not-allowed}.proxy-action-label{max-width:100%;color:inherit;text-align:center;white-space:nowrap;font-size:12px;font-weight:650;line-height:1.2;display:block;overflow:hidden}.proxy-row-head .proxy-check-cell,.proxy-row-head .proxy-name-cell,.proxy-row-head .proxy-row-actions{z-index:4}.proxy-empty-state{color:var(--muted);padding:28px 20px;font-size:13px}.proxy-modal{border-radius:16px;width:min(640px,94vw);overflow:hidden}.proxy-modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.proxy-modal-head h2{letter-spacing:-.01em;margin:0;font-size:22px;font-weight:850}.proxy-modal-close{width:34px;height:34px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.proxy-modal-close:hover{background:var(--surface-2);color:var(--text)}.proxy-modal-tabs{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;gap:0;margin:18px 22px 0;display:grid}.proxy-modal-tabs button{min-height:42px;color:var(--text-dim);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;align-items:center;gap:8px;font-size:14px;font-weight:800;display:inline-flex}.proxy-modal-tabs button.active{color:#0f9688;border-bottom-color:#0ea998}.proxy-modal-body{gap:14px;padding:20px 22px;display:grid}.proxy-modal-body label{gap:7px;display:grid}.proxy-modal-body label span{color:var(--text-dim);font-size:13px;font-weight:800}.proxy-modal-input{border-radius:10px;min-height:42px;font-size:14px}.proxy-modal-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.proxy-password-field{position:relative}.proxy-password-field button{width:32px;height:32px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.proxy-quick-textarea{border-radius:10px;min-height:240px;padding:14px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.5}.proxy-quick-parse{flex-wrap:wrap;align-items:center;gap:10px;margin-top:-8px;display:flex}.proxy-quick-parse span{background:var(--surface-2);min-height:28px;color:var(--text-dim);border-radius:999px;align-items:center;padding:0 10px;font-size:13px;font-weight:800;display:inline-flex}.proxy-quick-parse span.success{color:#0f9688;background:#14b8a624}.proxy-quick-parse span.warning{color:#d94a4a;background:#d94a4a1a}.proxy-modal-hint{color:var(--muted);margin:-4px 0 0;font-size:12.5px}.proxy-modal-foot{border-top:1px solid var(--border);padding:16px 22px}.proxy-modal-foot .secondary-button,.proxy-modal-foot .primary-button{border-radius:10px;min-height:42px;padding-inline:20px;font-size:14px;font-weight:800}@media (max-width:760px){.proxy-action-bar{grid-template-columns:1fr;display:grid}.proxy-filters,.proxy-toolbar-actions,.proxy-filter-select{width:100%}.proxy-table{min-width:920px}.proxy-toolbar-actions .secondary-button,.proxy-toolbar-actions .primary-button{flex:132px}.proxy-modal-grid{grid-template-columns:1fr}}.admin-theme-toggle{background:var(--surface-2);border:1px solid var(--border)}.admin-theme-toggle:hover{background:var(--brand-pale);color:var(--brand-hover);border-color:var(--brand-pale)}.admin-theme-toggle .icon-light{display:none}.admin-theme-toggle .icon-dark{display:block}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .admin-theme-toggle .icon-light{display:block}:root:not([data-theme=light]) .admin-theme-toggle .icon-dark{display:none}}:root[data-theme=dark] .admin-theme-toggle .icon-light{display:block}:root[data-theme=dark] .admin-theme-toggle .icon-dark{display:none}.key-actions,.key-form-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.key-form-actions{justify-content:flex-start}.admin-login-shell{background:var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.admin-login-card{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:min(100%,400px);max-width:calc(100vw - 32px);box-shadow:var(--shadow-card);gap:16px;padding:32px 28px;display:grid;overflow:hidden}.admin-login-card .brand-logo{object-fit:contain;justify-self:center;width:min(132px,42vw);height:auto;max-height:132px}.admin-login-card h1,.admin-login-card p{margin:0}.admin-login-card h1{letter-spacing:-.015em;color:var(--text);font-size:22px;font-weight:800}.admin-login-card p{color:var(--text-dim);font-size:14px;line-height:1.65}.admin-login-card .text-input,.admin-login-card .primary-button{width:100%;min-width:0}.admin-top-actions,.row-actions,.create-user-bar,.inline-action{align-items:center;gap:8px;display:flex}.row-actions{flex-wrap:wrap}.admin-row-users{justify-content:start;min-width:1180px;grid-template-columns:50px minmax(180px,240px) minmax(90px,130px) 78px 72px 72px 90px 78px 90px 90px 78px!important;align-items:center!important}.user-cell-date{color:var(--text-dim);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:13px}.user-cell-email{word-break:break-all;font-size:14px;font-weight:600}.user-cell-username{color:var(--text-dim);font-size:14px}.user-cell-id{color:var(--muted);font-family:ui-monospace,SF Mono,monospace;font-size:13px}.user-cell-num{font-variant-numeric:tabular-nums;font-size:14px}.user-cell-num strong{color:var(--text);font-weight:700}.user-cell-credit-warning{color:#b45309;align-items:center;gap:6px;display:inline-flex}.user-cell-credit-warning strong{color:#b45309}.user-cell-credit-warning small{background:#f59e0b1f;border:1px solid #f59e0b47;border-radius:999px;padding:1px 5px;font-size:10px;font-weight:700}.user-cell-success{color:#059669;font-weight:600}.user-cell-dim{color:var(--muted)}.admin-row-users .role-pill{padding:2px 8px;font-size:11px}.admin-row-users.admin-row-head{font-size:11.5px}.role-pill{letter-spacing:.04em;border-radius:999px;align-items:center;padding:3px 10px;font-size:11.5px;font-weight:700;display:inline-flex}.role-user{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border)}.role-admin{background:var(--brand-pale);color:var(--brand-hover);border:1px solid var(--brand-soft)}.admin-section-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-modal-overlay{z-index:350;animation:fadeIn .16s var(--ease-soft);background:#0f172a6b;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.admin-modal{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);width:min(460px,96vw);max-height:92vh;animation:slideInRight .18s var(--ease-soft);flex-direction:column;display:flex;overflow-y:auto;box-shadow:0 24px 50px -16px #00000052}.admin-modal-wide{width:min(680px,96vw)}.preset-order-status{min-height:34px;color:var(--text-dim);white-space:nowrap;align-items:center;font-size:12px;display:inline-flex}.preset-admin-list{flex-direction:column;gap:12px;margin-top:14px;display:flex}.preset-admin-item{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);transition:border-color .16s var(--ease-soft), box-shadow .16s var(--ease-soft), opacity .16s var(--ease-soft), transform .16s var(--ease-soft);padding:14px 16px}.preset-admin-item-disabled{opacity:.55}.preset-admin-item-dragging{opacity:.58;transform:scale(.995)}.preset-admin-item-drop-target{border-color:var(--brand);box-shadow:inset 3px 0 0 var(--brand), 0 12px 30px -24px #ff7a2ea6}.preset-admin-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.preset-admin-head-main{align-items:center;gap:14px;min-width:0;display:flex}.preset-drag-handle{border:1px solid var(--border);border-radius:var(--r-sm);width:34px;height:70px;color:var(--muted);background:var(--surface-2);cursor:grab;-webkit-user-select:none;user-select:none;flex-direction:column;flex:none;justify-content:center;align-items:center;gap:3px;display:inline-flex}.preset-drag-handle:active{cursor:grabbing}.preset-drag-handle:hover,.preset-drag-handle:focus-visible{border-color:var(--brand-soft);color:var(--brand);outline:none}.preset-drag-handle[aria-disabled=true]{cursor:wait;opacity:.55}.preset-drag-handle span{font-size:11px;font-weight:800;line-height:1}.preset-admin-thumb{border-radius:var(--r-sm);background:var(--surface-2);border:1px solid var(--border);width:70px;height:70px;color:var(--muted);cursor:zoom-in;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;display:flex;position:relative}.preset-admin-thumb>img:not(.preset-admin-thumb-zoom img){object-fit:cover;border-radius:inherit;width:100%;height:100%;display:block}.preset-admin-thumb-empty{color:var(--muted)}.preset-admin-thumb-zoom{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);opacity:0;pointer-events:none;transform-origin:0 0;width:360px;max-width:60vw;transition:opacity .16s var(--ease-soft), transform .16s var(--ease-soft);z-index:60;padding:8px;position:absolute;top:0;left:calc(100% + 12px);transform:translateY(-6px)scale(.96);box-shadow:0 24px 60px -12px #0000004d}.preset-admin-thumb-zoom img{border-radius:var(--r-sm);width:100%;display:block}.preset-admin-thumb:hover .preset-admin-thumb-zoom,.preset-admin-thumb:focus-within .preset-admin-thumb-zoom{opacity:1;transform:translateY(0)scale(1)}.preset-admin-item:last-child .preset-admin-thumb-zoom{transform-origin:0 100%;top:auto;bottom:0;transform:translateY(6px)scale(.96)}.preset-admin-item:last-child .preset-admin-thumb:hover .preset-admin-thumb-zoom{transform:translateY(0)scale(1)}@media (max-width:760px){.preset-admin-thumb-zoom{width:min(86vw,380px);max-width:86vw;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)scale(.96)}.preset-admin-thumb:hover .preset-admin-thumb-zoom{transform:translate(-50%,-50%)scale(1)}.preset-admin-item:last-child .preset-admin-thumb-zoom{top:50%;bottom:auto;transform:translate(-50%,-50%)scale(.96)}}.preset-admin-head h3{margin:0 0 4px;font-size:16px;font-weight:800}.preset-preview-upload{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.preset-preview-thumb{border-radius:var(--r-sm);background:var(--surface-2);border:1px solid var(--border);cursor:zoom-in;flex-shrink:0;width:80px;height:80px;display:flex;position:relative}.preset-preview-thumb>img:not(.preset-admin-thumb-zoom img){object-fit:cover;border-radius:inherit;width:100%;height:100%;display:block}.preset-preview-thumb:hover .preset-admin-thumb-zoom,.preset-preview-thumb:focus-within .preset-admin-thumb-zoom{opacity:1;transform:translateY(0)scale(1)}.preset-preview-empty{border-radius:var(--r-sm);background:var(--surface-2);border:1px dashed var(--border);width:80px;height:80px;color:var(--muted);flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.preset-preview-upload .text-input{flex:200px;min-width:160px}.preset-admin-meta{color:var(--muted);flex-wrap:wrap;gap:4px;font-size:12px;display:inline-flex}.preset-admin-actions{flex-wrap:wrap;gap:8px;display:flex}.preset-admin-desc{color:var(--text-dim);margin:8px 0 0;font-size:13px;line-height:1.55}.preset-admin-item details summary{cursor:pointer;color:var(--muted);margin-top:8px;font-size:12.5px}.preset-admin-prompt{background:var(--surface-2);border-radius:var(--r-sm);white-space:pre-wrap;max-height:320px;margin:8px 0 0;padding:12px;font-family:ui-monospace,SF Mono,monospace;font-size:12px;line-height:1.6;overflow-y:auto}.preset-edit-row{grid-template-columns:1fr 1fr;gap:12px 14px;display:grid}@media (max-width:640px){.preset-edit-row{grid-template-columns:1fr}}.admin-modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.admin-modal-head h2{margin:0;font-size:17px;font-weight:800}.admin-modal-body{gap:12px;padding:18px 22px;display:grid}.admin-modal-body label{flex-direction:column;gap:5px;display:flex}.admin-modal-body label>span{color:var(--text-dim);letter-spacing:.02em;font-size:12.5px;font-weight:700}.admin-modal-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:14px 22px 18px;display:flex}.user-edit-grid{grid-template-columns:1fr 1fr;gap:12px 16px;margin-bottom:16px;display:grid}.user-edit-grid label{flex-direction:column;gap:5px;display:flex}.user-edit-grid label>span{letter-spacing:.02em;color:var(--text-dim);font-size:12px;font-weight:700}.user-detail-readonly{background:var(--surface-2);border-radius:var(--r-sm);margin-top:6px;padding:12px 14px}.user-detail-readonly dt{color:var(--muted);font-size:11.5px}.user-detail-readonly dd{font-size:12.5px;font-weight:500}.user-detail-danger{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:16px;padding-top:14px;display:flex}@media (max-width:640px){.user-edit-grid{grid-template-columns:1fr}}.inline-action .text-input{flex:auto}.create-user-bar{margin-bottom:14px}.create-user-bar .primary-button{flex:none}.user-detail-overlay{z-index:300;animation:fadeIn .18s var(--ease-soft);background:#0f172a6b;justify-content:flex-end;display:flex;position:fixed;inset:0}.user-detail-drawer{background:var(--surface);width:min(640px,96vw);height:100%;animation:slideInRight .22s var(--ease-soft);flex-direction:column;display:flex;overflow-y:auto;box-shadow:-12px 0 36px -12px #00000040}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.user-detail-head{z-index:2;background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:20px 24px;display:flex;position:sticky;top:0}.user-detail-title{flex-direction:column;gap:2px;min-width:0;display:flex}.user-detail-title h2{letter-spacing:-.01em;margin:0;font-size:19px;font-weight:800}.user-detail-email{color:var(--text-dim);font-family:ui-monospace,SF Mono,monospace;font-size:13px}.user-detail-close{background:var(--surface-2);border:1px solid var(--border);width:36px;height:36px;color:var(--text-dim);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.user-detail-close:hover{background:var(--border);color:var(--text)}.user-detail-section{border-bottom:1px solid var(--border);padding:18px 24px}.user-detail-section:last-child{border-bottom:0}.user-detail-section h3{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:0 0 12px;font-size:13px;font-weight:800}.user-detail-grid{grid-template-columns:1fr 1fr;gap:12px 18px;margin:0;display:grid}.user-detail-grid>div{flex-direction:column;gap:2px;min-width:0;display:flex}.user-detail-grid dt{color:var(--muted);font-size:12px}.user-detail-grid dd{color:var(--text);margin:0;font-size:13.5px;font-weight:600}.user-detail-grid dd.mono{font-family:ui-monospace,SF Mono,monospace}.user-detail-stats{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.user-stat-card{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);flex-direction:column;gap:4px;padding:12px 14px;display:flex}.user-stat-label{color:var(--muted);letter-spacing:.02em;font-size:11.5px}.user-stat-value{color:var(--text);font-variant-numeric:tabular-nums;font-size:19px;font-weight:800}.user-stat-grant{background:#10b98114;border-color:#10b9814d}.user-stat-grant .user-stat-value{color:#047857}.user-stat-purchase{background:#3b82f614;border-color:#3b82f64d}.user-stat-purchase .user-stat-value{color:#1d4ed8}.user-stat-consume{background:#f4725b14;border-color:#f4725b4d}.user-stat-consume .user-stat-value{color:#c2410c}.user-stat-adjust{background:#6b728014;border-color:#6b72804d}.user-stat-success .user-stat-value{color:#047857}.user-stat-fail .user-stat-value{color:#dc2626}.user-stat-rate{background:var(--brand-pale);border-color:var(--brand-soft)}.user-stat-rate .user-stat-value{color:var(--brand-hover)}.user-credit-warning-panel{border-radius:var(--r-sm);color:#92400e;background:#f59e0b1a;border:1px solid #f59e0b59;margin-top:10px;padding:10px 12px;font-size:13px;line-height:1.5}.user-ledger-table{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);flex-direction:column;display:flex;overflow:hidden}.user-ledger-row{border-bottom:1px solid var(--border);color:var(--text);font-variant-numeric:tabular-nums;grid-template-columns:1.4fr .9fr .7fr .7fr 2fr;gap:10px;padding:10px 14px;font-size:12.5px;display:grid}.user-ledger-row:last-child{border-bottom:0}.user-ledger-head{background:var(--surface-2);letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-size:11.5px;font-weight:700}.ledger-type-grant{color:#047857;font-weight:600}.ledger-type-purchase{color:#1d4ed8;font-weight:600}.ledger-type-generate{color:var(--text-dim)}.ledger-type-refund{color:#c2410c;font-weight:600}.ledger-type-admin_adjustment{color:#6b7280;font-weight:600}.ledger-amount-positive{color:#047857;font-weight:700}.ledger-amount-negative{color:#dc2626;font-weight:700}.user-log-list{flex-direction:column;gap:8px;display:flex}.user-log-item{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);flex-direction:column;gap:4px;padding:10px 14px;display:flex}.user-log-row1{color:var(--text);justify-content:space-between;font-size:12.5px;display:flex}.user-log-time{font-variant-numeric:tabular-nums}.user-log-status{letter-spacing:.04em;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700}.user-log-status.status-success{color:#047857;background:#10b9811f}.user-log-status.status-error{color:#b91c1c;background:#dc26261f}.user-log-row2{color:var(--text-dim);gap:6px;font-size:12px;display:flex}.user-log-error{color:#b91c1c;word-break:break-word;font-size:12px}@media (max-width:640px){.user-detail-drawer{width:100%}.user-detail-grid{grid-template-columns:1fr}.user-detail-stats,.user-ledger-row{grid-template-columns:1fr 1fr}.user-ledger-row>span:nth-child(n+3){display:none}}.billing-mode-cards{grid-template-columns:1fr 1fr;gap:12px;display:grid}.billing-mode-card{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);cursor:pointer;text-align:left;font:inherit;transition:border-color .15s var(--ease-soft), background .15s var(--ease-soft), transform .1s var(--ease-soft);flex-direction:column;align-items:stretch;gap:8px;padding:16px 16px 14px;display:flex}.billing-mode-card:hover{border-color:var(--border-strong);background:var(--surface-2)}.billing-mode-card.active{border-color:var(--brand);background:var(--brand-pale);box-shadow:0 0 0 3px #ff7a2e1f}.billing-mode-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.billing-mode-name{letter-spacing:-.005em;font-size:15.5px;font-weight:800}.billing-mode-card.active .billing-mode-name{color:var(--brand-hover)}.billing-mode-active-tag{background:var(--brand);color:#fff;letter-spacing:.04em;border-radius:999px;padding:3px 8px;font-size:10.5px;font-weight:700}.billing-mode-desc{color:var(--text-dim);margin:0;font-size:13px;line-height:1.55}.billing-mode-traits{color:var(--text-dim);margin:4px 0 0;padding:0 0 0 18px;font-size:12.5px;line-height:1.6}.billing-mode-traits li{margin:0}.billing-cost-row{margin-top:14px}.billing-cost-input{max-width:120px;width:120px!important}.billing-tier-summary{border:1px dashed var(--brand-soft);border-radius:var(--r-sm);background:var(--brand-pale);flex-wrap:wrap;align-items:center;gap:10px;margin-top:14px;padding:12px 14px;display:flex}.billing-tier-pill{background:var(--surface);border:1px solid var(--brand-soft);color:var(--brand-hover);border-radius:999px;align-items:center;padding:5px 12px;font-size:13px;font-weight:700;display:inline-flex}.billing-tier-summary small{color:var(--text-dim);font-size:12px}@media (max-width:640px){.billing-mode-cards{grid-template-columns:1fr}}.admin-two-col{grid-template-columns:1fr 1fr;gap:14px;display:grid}.admin-form small,.setting-fields small{color:var(--muted);font-size:12px;line-height:1.5}.mode-prompt-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.prompt-page{gap:14px;display:grid}.prompt-page-head{align-items:flex-start}.prompt-tree-card{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);overflow:hidden}.prompt-tree-card+.prompt-tree-card{margin-top:10px}.prompt-tree-summary{cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--surface-2);border-bottom:1px solid var(--border);align-items:baseline;gap:12px;padding:14px 18px;list-style:none;display:flex}.prompt-tree-summary::-webkit-details-marker{display:none}.prompt-tree-summary h3{color:var(--text);white-space:nowrap;margin:0;font-size:15px;font-weight:600}.prompt-tree-summary small{color:var(--muted);font-size:12px}.prompt-tree-body{gap:12px;padding:16px 18px;display:grid}.prompt-tree-card[open]>.prompt-tree-summary{border-bottom-color:var(--brand-soft)}.prompt-control-card{border:1px solid var(--border);background:var(--surface);border-radius:16px;gap:14px;padding:18px;display:grid}.prompt-section-head{justify-content:space-between;align-items:center;gap:14px;min-width:0;display:flex}.prompt-section-head h3{letter-spacing:0;color:var(--text);margin:0;font-size:18px;font-weight:850}.prompt-section-head small{color:var(--text-dim);margin-top:4px;font-size:12.5px;line-height:1.5;display:block}.prompt-compact-grid{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;gap:12px;display:grid}.prompt-compact-grid label,.prompt-default-tier,.prompt-editor-block{gap:7px;min-width:0;display:grid}.prompt-compact-grid label>span,.prompt-default-tier>span,.prompt-editor-block>span{color:var(--text-dim);font-size:13px;font-weight:800}.prompt-compact-grid small,.prompt-default-tier small{color:var(--muted);margin:0;font-size:12px;line-height:1.45}.prompt-compact-grid .text-input{height:38px;min-height:38px}.prompt-compact-wide{grid-column:span 2}.muscle-model-card{gap:16px}.prompt-compact-tabs{border:1px solid var(--border);background:var(--surface-2);border-radius:14px;flex-shrink:0;align-items:center;gap:4px;padding:4px;display:inline-flex}.prompt-compact-tabs button{min-height:34px;color:var(--text-dim);font:inherit;cursor:pointer;transition:color .16s var(--ease), background .16s var(--ease), box-shadow .16s var(--ease);background:0 0;border:0;border-radius:11px;padding:0 14px;font-size:13px;font-weight:800}.prompt-compact-tabs button.active{background:var(--surface);color:var(--brand-hover);box-shadow:0 5px 14px #1f160814}.prompt-textarea{background:var(--surface-2);border-radius:10px;min-height:150px;font-size:13px;line-height:1.62}.prompt-textarea-large{min-height:360px}.prompt-tier-layout{gap:14px;display:grid}.prompt-default-tier{max-width:280px}.prompt-strength-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.prompt-tier-card{border:1px solid var(--border);background:var(--surface-2);border-radius:12px;gap:9px;padding:12px;display:grid}.prompt-tier-card header{justify-content:space-between;align-items:baseline;gap:10px;display:flex}.prompt-tier-card strong{color:var(--text);font-size:14px;font-weight:850}.prompt-tier-card header span{color:var(--brand-hover);font-size:12px;font-weight:800}.prompt-tier-card small{color:var(--muted);margin:0;font-size:12px;line-height:1.45}.prompt-tier-card .prompt-textarea{min-height:132px}.prompt-mode-compact-list{gap:12px;display:grid}.prompt-mode-compact-row{border:1px solid var(--border);background:var(--surface-2);border-radius:12px;padding:12px}.prompt-mode-compact-row .prompt-textarea{min-height:150px}@media (max-width:1100px){.prompt-compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:760px){.prompt-section-head{flex-direction:column;align-items:stretch}.prompt-compact-tabs{width:100%;overflow-x:auto}.prompt-compact-tabs button{flex:1 0 auto}.prompt-strength-grid,.prompt-compact-grid{grid-template-columns:1fr}.prompt-compact-wide{grid-column:auto}.prompt-textarea-large{min-height:300px}}.prompt-output-section{gap:16px;display:grid}.prompt-group{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);gap:12px;padding:16px 18px;display:grid}.prompt-group-head{flex-direction:column;gap:2px;display:flex}.prompt-group-head h3{letter-spacing:-.01em;color:var(--text);margin:0;font-size:14.5px;font-weight:800}.prompt-group-head small{color:var(--text-dim);font-size:12px;line-height:1.55}.prompt-group-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px 14px;display:grid}.prompt-group-grid-single{grid-template-columns:1fr}.prompt-group-grid label{flex-direction:column;gap:6px;min-width:0;display:flex}.prompt-group-grid label>span{letter-spacing:.02em;color:var(--text-dim);font-size:12.5px;font-weight:700}.prompt-group-grid label>small{color:var(--muted);margin:0;font-size:11.5px;line-height:1.55}.prompt-group-grid label>small strong{color:var(--text-dim);margin-right:4px;font-weight:700;display:inline-block}.prompt-group-grid .text-input{height:36px;min-height:36px}@media (max-width:900px){.prompt-group-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.prompt-group-grid{grid-template-columns:1fr}}.prompt-output-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:12px;display:flex}.prompt-output-head h3{letter-spacing:-.01em;color:var(--text);margin:0;font-size:14px;font-weight:800}.prompt-output-head small{color:var(--muted);font-size:12px;line-height:1.5}.prompt-output-grid{grid-template-columns:repeat(6,minmax(0,1fr));align-items:start;gap:10px 12px;display:grid}.prompt-output-grid label{grid-template-rows:16px 36px 22px;gap:4px;min-width:0;display:grid}.prompt-output-grid label>span{letter-spacing:.02em;color:var(--text-dim);font-size:12px;font-weight:700;line-height:16px}.prompt-output-grid label>small{color:var(--muted);margin:0;font-size:11px;line-height:1.5}.prompt-output-grid .text-input{height:36px;min-height:36px}.prompt-updated-at{color:var(--text-dim);margin:8px 0 0;font-size:12.5px;font-weight:700}.prompt-page-version-banner{border:1px solid var(--brand-soft);background:var(--brand-pale);color:var(--brand-hover);border-radius:999px;align-items:center;gap:10px;margin:0 0 12px;padding:7px 14px;font-size:13px;line-height:1.2;display:inline-flex}.prompt-page-version-tag{letter-spacing:.02em;font-weight:800}.prompt-page-version-date{opacity:.78;font-variant-numeric:tabular-nums;font-size:12.5px;font-weight:500}.prompt-history-panel{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);overflow:hidden}.prompt-history-panel summary{cursor:pointer;color:var(--text);justify-content:space-between;align-items:center;gap:12px;padding:13px 16px;font-size:13px;font-weight:800;list-style:none;display:flex}.prompt-history-panel summary::-webkit-details-marker{display:none}.prompt-history-panel summary small{color:var(--muted);font-size:12px;font-weight:700}.prompt-history-list{gap:10px;padding:0 16px 16px;display:grid}.prompt-history-item{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2)}.prompt-history-item>summary{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--r-sm);flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:10px;padding:10px 12px;list-style:none;display:flex}.prompt-history-item>summary::-webkit-details-marker{display:none}.prompt-history-item>summary::marker{content:""}.prompt-history-item>summary:hover{background:var(--surface)}.prompt-history-item strong{color:var(--text);font-size:12.5px;font-weight:700}.prompt-history-meta{color:var(--text-dim);font-family:ui-monospace,SF Mono,monospace;font-size:11.5px}.prompt-history-changes{color:var(--brand-hover);font-size:11.5px;font-weight:700}.prompt-history-empty{color:var(--muted);margin:0;padding:0 16px 16px;font-size:12px;line-height:1.55}.prompt-history-body{gap:10px;padding:0 12px 12px;display:grid}.prompt-history-tags{flex-wrap:wrap;gap:6px;display:flex}.prompt-history-tags span{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface);color:var(--text-dim);padding:4px 7px;font-size:11.5px;font-weight:700}.prompt-snapshot{gap:10px;display:grid}.prompt-snapshot-params{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin:0;padding:10px 12px;display:grid}.prompt-snapshot-params>div{gap:2px;display:grid}.prompt-snapshot-params dt{color:var(--muted);letter-spacing:.02em;text-transform:uppercase;font-size:11px;font-weight:700}.prompt-snapshot-params dd{color:var(--text);text-overflow:ellipsis;margin:0;font-family:ui-monospace,SF Mono,monospace;font-size:12.5px;font-weight:600;overflow:hidden}.prompt-snapshot-section{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface)}.prompt-snapshot-section>summary{cursor:pointer;color:var(--text-dim);-webkit-user-select:none;user-select:none;padding:8px 12px;font-size:12px;font-weight:700;list-style:none}.prompt-snapshot-section>summary::-webkit-details-marker{display:none}.prompt-snapshot-section>summary::marker{content:""}.prompt-snapshot-section>summary:hover{color:var(--text);background:var(--surface-2)}.prompt-snapshot-section pre{border-top:1px solid var(--border);background:var(--surface-2);color:var(--text);white-space:pre-wrap;word-break:break-word;max-height:320px;margin:0;padding:10px 12px;font-family:ui-monospace,SF Mono,monospace;font-size:12px;line-height:1.55;overflow-y:auto}@media (max-width:1280px){.prompt-output-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width:760px){.prompt-output-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:460px){.prompt-output-grid{grid-template-columns:1fr}}.prompt-bilingual-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.prompt-bilingual-grid label{gap:6px;min-width:0;display:grid}.prompt-lang-bar{justify-content:space-between;align-items:center;gap:10px;min-height:28px;display:flex}.prompt-lang-label{letter-spacing:.04em;text-transform:uppercase;color:var(--brand-hover);align-items:center;gap:6px;font-size:12px;font-weight:800;display:inline-flex}.prompt-translate-btn{gap:5px;min-height:28px;padding:0 12px;font-size:12px}@media (max-width:900px){.prompt-bilingual-grid{grid-template-columns:1fr}}.prompt-mode-list{gap:18px;display:grid}.prompt-mode-row{border:1px solid var(--border);border-radius:var(--r);background:var(--surface-2);gap:10px;padding:14px 16px;display:grid}.prompt-mode-title{letter-spacing:0;color:var(--text);margin:0;font-size:14px;font-weight:800}.prompt-mode-subtitle{color:var(--muted);margin-left:8px;font-size:12px;font-weight:700}.prompt-default-strength-select{gap:8px;max-width:360px;display:grid}.prompt-mode-row .textarea{min-height:180px}.textarea,textarea.text-input{border:1px solid var(--border-strong);background:var(--surface-2);width:100%;min-height:140px;color:var(--text);font:inherit;resize:vertical;transition:all .16s var(--ease);border-radius:12px;padding:14px 16px;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:14px;line-height:1.65;display:block}.textarea:focus,textarea.text-input:focus{border-color:var(--brand);background:var(--surface);outline:none;box-shadow:0 0 0 3px #ff7a2e24}.admin-textarea-large{min-height:280px}.mode-prompt-grid .textarea{min-height:200px}.mode-prompt-grid label{gap:6px;display:grid}.mode-prompt-grid label>span{color:var(--text-dim);font-size:13px;font-weight:800}.admin-full-span{grid-column:1/-1}.admin-two-col label{gap:6px;display:grid}.admin-two-col label>span{color:var(--text-dim);font-size:13px;font-weight:800}.admin-two-col label>small{color:var(--muted);font-size:11.5px;font-weight:500;line-height:1.6}.primary-button{border-radius:var(--r-pill);background:var(--brand);color:#fff;cursor:pointer;min-height:38px;transition:all .18s var(--ease);white-space:nowrap;border:0;justify-content:center;align-items:center;gap:7px;padding:0 18px;font-size:14px;font-weight:700;display:inline-flex}.primary-button:hover:not(:disabled){background:var(--brand-hover);box-shadow:0 3px 10px -3px #ff7a2e52}.primary-button:disabled{opacity:.4;cursor:not-allowed}.secondary-button{border:1px solid var(--border-strong);border-radius:var(--r-pill);background:var(--surface);min-height:38px;color:var(--text);cursor:pointer;transition:all .18s var(--ease);white-space:nowrap;justify-content:center;align-items:center;gap:7px;padding:0 16px;font-size:13.5px;font-weight:600;display:inline-flex}.secondary-button:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-pale)}.secondary-button.danger-button{color:#d94a4a;border-color:#d94a4a4d}.secondary-button.danger-button:hover{color:#d94a4a;background:#d94a4a14;border-color:#d94a4a}.secondary-button:disabled,.secondary-button[disabled],.primary-button:disabled,.primary-button[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-spinner-icon{flex-shrink:0;animation:.7s linear infinite spin}.admin-save{margin-top:6px}.admin-section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.admin-section-head h2{letter-spacing:-.015em;margin:0;font-size:17px;font-weight:800}.category-copy-card{border:1px solid var(--border);background:var(--surface-2);border-radius:14px;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:12px;margin:-2px 0 16px;padding:14px;display:grid}.category-copy-card label{gap:7px;min-width:0;display:grid}.category-copy-card label>span{color:var(--text-dim);font-size:12.5px;font-weight:800}.category-copy-card .category-copy-textarea{min-height:74px;padding:10px 12px;font-family:inherit;font-size:13.5px;line-height:1.55}.category-copy-card .secondary-button{white-space:nowrap;min-height:40px}.label-edit-btn{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);width:22px;height:22px;color:var(--muted);cursor:pointer;vertical-align:middle;place-items:center;margin-left:6px;transition:border-color .15s,color .15s;display:inline-grid}.label-edit-btn:hover{border-color:var(--brand);color:var(--brand)}.admin-search{border:1px solid var(--border-strong);border-radius:var(--r-pill);background:var(--surface-2);min-width:280px;min-height:38px;color:var(--text-dim);transition:all .16s var(--ease);align-items:center;gap:8px;padding:0 12px 0 14px;display:flex}.admin-search:focus-within{border-color:var(--brand);background:var(--surface);color:var(--brand-hover);box-shadow:0 0 0 3px #ff7a2e24}.admin-search-input{color:var(--text);font:inherit;background:0 0;border:0;outline:0;flex:1;min-width:0;padding:6px 0;font-size:13.5px}.admin-search-input::placeholder{color:var(--muted)}.admin-search-input::-webkit-search-cancel-button{appearance:none}.admin-search-clear{background:var(--border-strong);width:22px;height:22px;color:var(--text-dim);cursor:pointer;transition:all .15s var(--ease);border:0;border-radius:50%;place-items:center;font-size:16px;line-height:1;display:grid}.admin-search-clear:hover{background:var(--brand);color:#fff}.admin-search-count{color:var(--muted);border-left:1px solid var(--border-strong);flex-shrink:0;padding-left:6px;font-family:ui-monospace,SF Mono,monospace;font-size:11.5px;font-weight:700}.admin-empty{text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:var(--r-sm);background:var(--surface-2);padding:40px 16px;font-size:13.5px}@media (max-width:1100px){.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-shell{grid-template-columns:1fr!important}.admin-main{padding:0 16px 32px}.admin-sidebar{width:260px;height:100vh;transition:transform .22s var(--ease-soft);z-index:90;top:0;left:0;transform:translate(-100%);box-shadow:8px 0 32px -8px #0000002e;position:fixed!important}.admin-shell-nav-open .admin-sidebar{transform:translate(0)}.admin-shell-nav-open .admin-nav-overlay{display:block}.admin-nav-toggle{display:inline-flex}.admin-nav-close{margin-left:auto;display:inline-flex}}@media (max-width:760px){.admin-main{padding:16px 12px 28px}.admin-card{padding:14px 12px}.metric-grid,.admin-two-col,.mode-prompt-grid,.setting-block{grid-template-columns:1fr}.settings-head{flex-direction:column;align-items:stretch}.admin-top{flex-direction:column;align-items:stretch;gap:10px}.admin-top h1{font-size:18px}.admin-top-actions{flex-wrap:wrap;gap:6px;flex-direction:row!important;align-items:center!important;display:flex!important}.admin-top-actions .btn-icon{width:38px;height:38px}.admin-top-actions .secondary-button,.admin-top-actions .btn{flex:none;padding:8px 14px;font-size:13.5px;width:auto!important}.admin-section-head{flex-direction:column;align-items:stretch;gap:10px}.category-copy-card{grid-template-columns:1fr;align-items:stretch}.category-copy-card .secondary-button{width:100%}.admin-section-actions{flex-wrap:wrap;align-items:center;gap:8px;flex-direction:row!important}.admin-section-actions .admin-search{flex:auto;min-width:0}.admin-section-actions .primary-button{flex:none;padding:8px 14px;width:auto!important}.admin-row:not(.admin-row-users){grid-template-columns:1fr;min-width:0}.admin-table{-webkit-overflow-scrolling:touch;overflow-x:auto}.row-actions,.create-user-bar,.inline-action{flex-direction:column;align-items:stretch}.admin-row-users{min-width:1180px!important}}.user-edit-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:4px;padding-top:14px;display:flex}.user-edit-actions .primary-button:disabled,.user-edit-actions .secondary-button:disabled{opacity:.4;cursor:not-allowed}.password-edit-row{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:12px;padding-top:12px;display:flex}.password-edit-row .text-input{flex:auto;min-width:0}.password-edit-row .secondary-button,.password-edit-row .primary-button{flex-shrink:0}.user-detail-section h3{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.user-detail-balance-pill{background:var(--brand-pale);color:var(--brand-hover);border:1px solid var(--brand-soft);letter-spacing:.02em;text-transform:none;border-radius:999px;align-items:center;gap:4px;padding:4px 12px;font-size:13px;font-weight:700;display:inline-flex}.user-detail-collapse>summary{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;gap:10px;padding:0;list-style:none;display:flex}.user-detail-collapse>summary::-webkit-details-marker{display:none}.user-detail-collapse>summary::marker{content:""}.user-detail-collapse>summary:after{content:"▶";color:var(--muted);transition:transform .18s var(--ease-soft);margin-left:auto;font-size:10px}.user-detail-collapse[open]>summary:after{transform:rotate(90deg)}.user-detail-collapse>summary h3{text-transform:uppercase;margin:0}.user-detail-collapse>summary small{color:var(--text-dim);letter-spacing:.02em;font-size:12px}.user-detail-collapse>:not(summary){animation:fadeIn .18s var(--ease-soft);margin-top:12px}.profile-overlay{z-index:90;-webkit-backdrop-filter:blur(10px)saturate(120%);animation:profileFade .16s var(--ease-soft);background:#1f16086b;place-items:center;padding:24px;display:grid;position:fixed;inset:0}:root[data-theme=dark] .profile-overlay{background:#000000b3}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .profile-overlay{background:#000000b3}}@keyframes profileFade{0%{opacity:0}to{opacity:1}}@keyframes profileSlide{0%{opacity:0;transform:translateY(6px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}.profile-dialog{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:min(720px,100%);max-height:86vh;box-shadow:var(--shadow-pop);animation:profileSlide .18s var(--ease-soft);scrollbar-width:thin;scrollbar-color:#1f160829 transparent;padding:0;display:block;overflow:hidden auto}:root[data-theme=dark] .profile-dialog{scrollbar-color:#ffecc333 transparent}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .profile-dialog{scrollbar-color:#ffecc333 transparent}}.profile-dialog::-webkit-scrollbar{width:6px}.profile-dialog::-webkit-scrollbar-track{background:0 0}.profile-dialog::-webkit-scrollbar-thumb{background:var(--border-strong);border:1.5px solid var(--surface);background-clip:padding-box;border-radius:999px}.profile-dialog::-webkit-scrollbar-thumb:hover{background:var(--muted);background-clip:padding-box}.profile-head{z-index:2;border-bottom:1px solid var(--border);background:var(--surface);border-top-left-radius:calc(var(--r-lg) - 1px);border-top-right-radius:calc(var(--r-lg) - 1px);justify-content:space-between;align-items:center;gap:16px;margin:0;padding:22px 28px 18px;display:flex;position:sticky;top:0}.profile-head>div{gap:4px;min-width:0;display:grid}.profile-head h2{letter-spacing:-.02em;color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:22px;font-weight:800;line-height:1.2;overflow:hidden}.profile-kicker{letter-spacing:.14em;text-transform:uppercase;color:var(--brand);margin:0;font-size:11px;font-weight:800}.profile-head .btn-icon{color:var(--text-dim);width:32px;height:32px;transition:background .15s var(--ease-soft), color .15s var(--ease-soft), border-color .15s var(--ease-soft);background:0 0;border:1px solid #0000;flex-shrink:0}.profile-head .btn-icon:hover{background:var(--surface-2);border-color:var(--border);color:var(--text)}.profile-head .btn-icon:active{background:var(--border)}.profile-stats{grid-template-columns:repeat(2,1fr);gap:12px;padding:20px 28px 8px;display:grid}.profile-stat{border:1px solid var(--border);border-radius:var(--r);background:var(--surface-2);transition:all .18s var(--ease);gap:4px;padding:16px 18px;display:grid}.profile-stat:hover{border-color:var(--border-strong);box-shadow:var(--shadow-mode-hover);transform:translateY(-1px)}.profile-stat span{letter-spacing:.04em;color:var(--muted);text-transform:uppercase;font-size:11.5px;font-weight:700}.profile-stat strong{letter-spacing:-.02em;color:var(--text);font-size:22px;font-weight:800;line-height:1.15}.profile-stat.primary{background:linear-gradient(135deg, var(--brand-pale), var(--brand-soft));border-color:#ff7a2e4d}.profile-stat.primary span,.profile-stat.primary strong{color:var(--brand-hover)}.profile-grid{grid-template-columns:1fr 1fr;gap:14px;padding:12px 28px;display:grid}.profile-card{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);flex-direction:column;gap:12px;padding:20px;display:flex}.profile-card-title{color:var(--brand-hover);align-items:center;gap:8px;margin-bottom:4px;display:flex}.profile-card-title h3{letter-spacing:-.01em;color:var(--text);margin:0;font-size:14.5px;font-weight:800}.profile-card-note{color:var(--muted);margin-left:auto;font-size:11.5px;font-weight:750}.profile-history-card{margin:12px 28px 0}.profile-history-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;display:grid}.profile-history-item{border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);cursor:pointer;transition:border-color .16s var(--ease), transform .16s var(--ease), box-shadow .16s var(--ease);border-radius:12px;gap:6px;padding:0 0 8px;display:grid;overflow:hidden}.profile-history-item:hover{border-color:var(--brand-soft);box-shadow:var(--shadow-mode-hover);transform:translateY(-1px)}.profile-history-item img{aspect-ratio:1;object-fit:cover;background:var(--surface-canvas);width:100%}.profile-history-item span{white-space:nowrap;text-overflow:ellipsis;padding:0 6px;font-size:10.5px;font-weight:650;overflow:hidden}.profile-card .field-label{gap:6px;display:grid}.profile-card .field-label>span{color:var(--text-dim);font-size:12px;font-weight:700}.profile-meta{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);color:var(--muted);gap:4px;padding:12px 14px;font-size:11.5px;line-height:1.65;display:grid}.profile-save{width:100%;margin-top:auto}.ledger-card{margin:12px 28px 24px}.ledger-list{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;gap:2px;max-height:320px;margin:0 -4px;padding:0 4px;display:grid;overflow-y:auto}.ledger-list::-webkit-scrollbar{width:6px}.ledger-list::-webkit-scrollbar-track{background:0 0}.ledger-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.ledger-list::-webkit-scrollbar-thumb:hover{background:var(--muted)}.ledger-row{border-radius:var(--r-sm);transition:background .16s var(--ease);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.ledger-row:hover{background:var(--surface-2)}.ledger-row>div:first-child{gap:2px;min-width:0;display:grid}.ledger-row strong{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.ledger-row span{color:var(--muted);font-size:11.5px}.ledger-amount{text-align:right;letter-spacing:-.01em;flex-shrink:0;gap:2px;font-size:14px;font-weight:800;display:grid}.ledger-amount.plus{color:#2f9e63}.ledger-amount.minus{color:#d94a4a}:root[data-theme=dark] .ledger-amount.plus{color:#69d692}:root[data-theme=dark] .ledger-amount.minus{color:#ff8a8a}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .ledger-amount.plus{color:#69d692}:root:not([data-theme=light]) .ledger-amount.minus{color:#ff8a8a}}.ledger-amount small{color:var(--muted);letter-spacing:0;font-size:11px;font-weight:600}.empty-ledger{text-align:center;color:var(--muted);margin:0;padding:28px 12px;font-size:13px}.profile-loading{text-align:center;color:var(--muted);padding:60px 24px;font-size:14px}.profile-message{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--brand-pale);color:var(--brand-hover);border-color:#ff7a2e40;margin:8px 28px 24px;padding:12px 16px;font-size:13px}@media (max-width:640px){.profile-overlay{align-items:stretch;padding:0}.profile-dialog{border:0;border-radius:0;width:100%;height:100vh;max-height:100vh}.profile-head{padding:18px 18px 14px}.profile-head h2{font-size:19px}.profile-stats{grid-template-columns:1fr;padding:16px 18px 0}.profile-grid{grid-template-columns:1fr;padding:10px 18px}.profile-history-card{margin:10px 18px 0}.profile-history-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.ledger-card{margin:10px 18px 20px;padding:16px}.profile-message{margin:8px 18px 18px}}
