@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--tokio-dark: #3C3C3B;--tokio-yellow: #FFEA00;--tokio-red: #FF2C0C;--tokio-paper: #F6F4EF;--tokio-white: #FFFFFF;--tokio-black: #0A0A0A;--neutral-50: #F6F6F5;--neutral-100: #ECECEB;--neutral-200: #D9D9D8;--neutral-300: #BDBDBC;--neutral-400: #8E8E8D;--neutral-500: #6F6F6E;--neutral-600: #555554;--neutral-700: #454544;--neutral-800: #3C3C3B;--neutral-900: #232322;--neutral-950: #131312;--yellow-50: #FFFEEB;--yellow-100: #FFFBC2;--yellow-200: #FFF694;--yellow-300: #FFF15C;--yellow-400: #FFEC2A;--yellow-500: #FFEA00;--yellow-600: #D6C400;--yellow-700: #A89800;--yellow-800: #7A6D00;--yellow-900: #4A4200;--yellow-950: #2A2500;--red-50: #FFEFEB;--red-100: #FFDAD1;--red-200: #FFB09F;--red-300: #FF8770;--red-400: #FF5E40;--red-500: #FF2C0C;--red-600: #D62106;--red-700: #A81804;--red-800: #7A0F02;--red-900: #4A0801;--red-950: #2A0400;--success: #1F8A5B;--success-bg: #E4F4ED;--warning: #C58A00;--warning-bg: #FFF6DC;--error: #FF2C0C;--error-bg: #FFE6E0;--info: #2A6FDB;--info-bg: #E5EEFB;--bg-canvas: var(--tokio-paper);--bg-surface: var(--tokio-white);--bg-elevated: var(--tokio-white);--bg-inverse: var(--tokio-dark);--bg-yellow: var(--tokio-yellow);--bg-red: var(--tokio-red);--fg-default: var(--tokio-dark);--fg-muted: var(--neutral-600);--fg-subtle: var(--neutral-500);--fg-inverse: var(--tokio-paper);--fg-accent-y: var(--tokio-dark);--fg-accent-r: var(--tokio-paper);--border-default: var(--neutral-200);--border-strong: var(--neutral-300);--border-inverse: var(--neutral-700);--font-display: "Space Grotesk", "Helvetica Neue", Arial, sans-serif;--font-body: "Inter", "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-32: 2rem;--fs-40: 2.5rem;--fs-56: 3.5rem;--fs-80: 5rem;--fs-120: 7.5rem;--fs-180: 11.25rem;--lh-tight: 1.05;--lh-display: .95;--lh-snug: 1.2;--lh-normal: 1.45;--lh-relaxed: 1.6;--tracking-display: -.02em;--tracking-tight: -.01em;--tracking-normal: 0;--tracking-wide: .04em;--tracking-mono: .02em;--tracking-eyebrow: .14em;--fw-light: 300;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--sp-0: 0;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--sp-20: 80px;--sp-24: 96px;--sp-32: 128px;--sp-40: 160px;--sp-48: 192px;--sp-64: 256px;--radius-none: 0;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 20px;--radius-pill: 999px;--shadow-xs: 0 1px 2px rgba(60,60,59,.06);--shadow-sm: 0 2px 8px rgba(60,60,59,.08);--shadow-md: 0 8px 24px rgba(60,60,59,.1);--shadow-lg: 0 20px 48px rgba(60,60,59,.14);--shadow-xl: 0 40px 80px rgba(60,60,59,.18);--shadow-inset: inset 0 0 0 1px rgba(60,60,59,.08);--ease-standard: cubic-bezier(.2, 0, 0, 1);--ease-emphasized: cubic-bezier(.2, .8, .2, 1);--ease-cut: cubic-bezier(.7, 0, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--dur-instant: 80ms;--dur-fast: .16s;--dur-base: .24s;--dur-medium: .4s;--dur-slow: .64s;--dur-cinema: .9s;--container-sm: 640px;--container-md: 960px;--container-lg: 1200px;--container-xl: 1440px;--container-max: 1600px;--gutter-mobile: 16px;--gutter-tablet: 24px;--gutter-desktop: 32px;--ig-w: 1080px;--ig-h: 1920px;--ig-safe-top: 250px;--ig-safe-bottom: 250px;--ig-safe-x: 72px}.t-poster,.t-display,.t-h1,.t-h2,.t-h3{font-family:var(--font-display);font-weight:var(--fw-medium);letter-spacing:var(--tracking-display);line-height:var(--lh-display);color:var(--fg-default);text-wrap:balance}.t-poster{font-size:clamp(72px,12vw,var(--fs-180));font-weight:var(--fw-medium)}.t-display{font-size:clamp(56px,9vw,var(--fs-120))}.t-h1{font-size:clamp(40px,6vw,var(--fs-80));line-height:var(--lh-tight)}.t-h2{font-size:var(--fs-56);line-height:var(--lh-tight)}.t-h3{font-size:var(--fs-40);line-height:var(--lh-snug)}.t-h4{font-family:var(--font-display);font-weight:var(--fw-medium);font-size:var(--fs-32);line-height:var(--lh-snug);letter-spacing:var(--tracking-tight)}.t-h5{font-family:var(--font-display);font-weight:var(--fw-medium);font-size:var(--fs-24);line-height:var(--lh-snug)}.t-lead{font-family:var(--font-body);font-weight:var(--fw-regular);font-size:var(--fs-20);line-height:var(--lh-relaxed);color:var(--fg-default)}.t-body{font-family:var(--font-body);font-weight:var(--fw-regular);font-size:var(--fs-16);line-height:var(--lh-relaxed);color:var(--fg-default)}.t-body-sm{font-family:var(--font-body);font-weight:var(--fw-regular);font-size:var(--fs-14);line-height:var(--lh-relaxed);color:var(--fg-muted)}.t-caption{font-family:var(--font-body);font-weight:var(--fw-regular);font-size:var(--fs-13);line-height:var(--lh-normal);color:var(--fg-muted)}.t-eyebrow{font-family:var(--font-mono);font-size:var(--fs-12);font-weight:var(--fw-medium);letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--fg-muted)}.t-mono{font-family:var(--font-mono);font-size:var(--fs-13);letter-spacing:var(--tracking-mono);color:var(--fg-default)}.t-code{font-family:var(--font-mono);font-size:var(--fs-13);background:var(--neutral-100);padding:2px 6px;border-radius:var(--radius-xs)}.t-link{color:inherit;text-decoration:none;background-image:linear-gradient(currentColor,currentColor);background-size:100% 1px;background-repeat:no-repeat;background-position:0 100%;transition:background-size var(--dur-base) var(--ease-emphasized)}.t-link:hover{background-size:0% 1px;background-position:100% 100%}html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}body{margin:0;background:var(--bg-canvas);color:var(--fg-default);font-family:var(--font-body);font-size:var(--fs-16);line-height:var(--lh-relaxed);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}:root{--c-canvas: #121211;--c-surface: #1b1b1a;--c-surface-2: #262624;--c-surface-3: #2f2f2c;--c-border: #34332f;--c-border-strong: #474640;--c-text: #F4F2EC;--c-muted: #9b9b94;--c-subtle: #6f6f6e;--shadow-dark-sm: 0 2px 10px rgba(0,0,0,.35);--shadow-dark-md: 0 10px 30px rgba(0,0,0,.45);--shadow-dark-lg: 0 24px 60px rgba(0,0,0,.55);--ok: #4ED38F;--ok-bg: rgba(31,138,91,.18);--run: #E8B53A;--run-bg: rgba(197,138,0,.2);--bad: #FF6B50;--bad-bg: rgba(255,44,12,.16);--tint-yellow: rgba(255,234,0,.12);--bg: var(--c-canvas);--panel: var(--c-surface);--panel-2: var(--c-surface-2);--border: var(--c-border);--text: var(--c-text);--muted: var(--c-muted);--accent: var(--tokio-yellow);--accent-2: var(--yellow-400);--radius: var(--radius-lg)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:var(--fs-14);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:var(--font-body);cursor:pointer}input,select,textarea{font-family:var(--font-body);color:var(--text);background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:10px 12px;font-size:var(--fs-14);width:100%;outline:none;transition:border-color var(--dur-fast) var(--ease-standard),box-shadow var(--dur-fast) var(--ease-standard)}input::placeholder,textarea::placeholder{color:var(--c-subtle)}input:focus,select:focus,textarea:focus{border-color:var(--tokio-yellow);box-shadow:inset 0 -2px 0 var(--tokio-yellow)}select option{background:var(--c-surface-2);color:var(--text)}textarea{resize:vertical;min-height:84px}label{display:block;font-family:var(--font-mono);font-size:var(--fs-12);letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--muted);margin:0 0 6px}.field{margin-bottom:14px}.app{display:flex;flex-direction:column;height:100%}.topbar{display:flex;align-items:center;gap:18px;padding:0 20px;height:60px;border-bottom:1px solid var(--border);background:var(--panel)}.brand{display:flex;align-items:center;gap:10px}.brand-mark{width:26px;height:26px;display:block}.logo{font-family:var(--font-display);font-weight:var(--fw-semibold);letter-spacing:-.01em;font-size:var(--fs-18);color:var(--c-text)}.logo span{color:var(--c-subtle);font-weight:var(--fw-regular)}.ai-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;font-weight:var(--fw-medium);letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:#e7e2c8;background:var(--tint-yellow);border:1px solid rgba(255,234,0,.32);padding:4px 9px;border-radius:var(--radius-pill)}.ai-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--tokio-yellow)}.tabs{display:flex;gap:4px}.tab{background:transparent;border:none;color:var(--muted);font-family:var(--font-display);font-weight:var(--fw-medium);padding:8px 14px;border-radius:var(--radius-sm);position:relative;transition:color var(--dur-fast) var(--ease-standard)}.tab:hover,.tab.active{color:var(--text)}.tab.active:after{content:"";position:absolute;left:14px;right:14px;bottom:2px;height:2px;background:var(--tokio-yellow);border-radius:2px}.spacer{flex:1}.identity{display:flex;align-items:center;gap:10px}.identity input{width:150px}.identity-select{width:180px}.icon-btn{background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--text);width:38px;height:38px;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;transition:border-color var(--dur-fast),background var(--dur-fast)}.icon-btn:hover{border-color:var(--c-border-strong)}.body{display:flex;flex:1;min-height:0}.panel{width:384px;min-width:384px;border-right:1px solid var(--border);background:var(--panel);padding:20px;overflow-y:auto}.history{flex:1;overflow-y:auto;padding:20px 24px}.btn{background:var(--tokio-yellow);color:var(--tokio-dark);border:none;font-family:var(--font-display);font-weight:var(--fw-semibold);padding:13px;border-radius:var(--radius-pill);width:100%;font-size:var(--fs-16);display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background var(--dur-fast) var(--ease-standard),transform var(--dur-instant)}.btn:hover{background:var(--yellow-400)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn .arr{transition:transform var(--dur-base) var(--ease-emphasized)}.btn:hover .arr{transform:translate(2px,-2px)}.btn.secondary{background:transparent;border:1px solid var(--c-border-strong);color:var(--c-text);font-weight:var(--fw-medium)}.btn.secondary:hover{background:var(--c-surface-2);border-color:var(--tokio-yellow)}.row{display:flex;gap:10px}.row>*{flex:1}.seg{display:flex;gap:6px;flex-wrap:wrap}.seg button{flex:1;min-width:56px;background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--muted);border-radius:var(--radius-sm);padding:8px;font-family:var(--font-display);font-weight:var(--fw-medium);transition:all var(--dur-fast) var(--ease-standard)}.seg button:hover{color:var(--text);border-color:var(--c-border-strong)}.seg button.active{color:var(--tokio-yellow);border-color:var(--tokio-yellow);background:var(--tint-yellow)}.panel-title,.section-title,.stat-block-title,.block-head{font-family:var(--font-mono);font-size:var(--fs-12);text-transform:uppercase;letter-spacing:var(--tracking-eyebrow);color:var(--muted);font-weight:var(--fw-medium)}.panel-title{margin:4px 0 14px}.section-title{margin:18px 0 10px;color:var(--text)}.hint{font-size:var(--fs-12);color:var(--muted);margin-top:6px;line-height:var(--lh-normal)}.mode-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;font-weight:var(--fw-medium);padding:4px 10px;letter-spacing:var(--tracking-mono);border-radius:var(--radius-pill);background:var(--tint-yellow);color:#e7e2c8;margin-bottom:12px;text-transform:uppercase}.dropzone{border:1.5px dashed var(--c-border-strong);border-radius:var(--radius-lg);padding:22px 14px;text-align:center;color:var(--muted);transition:all var(--dur-fast);margin-bottom:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px}.dropzone:hover{border-color:var(--tokio-yellow);background:var(--c-surface-2)}.dropzone.over{border-color:var(--tokio-yellow);background:#ffea000f;color:var(--text)}.dz-plus{width:42px;height:42px;border-radius:50%;background:var(--c-surface-3);border:1px solid var(--c-border);display:flex;align-items:center;justify-content:center;color:var(--text)}.dropzone:hover .dz-plus,.dropzone.over .dz-plus{border-color:var(--tokio-yellow)}.dz-text{font-size:var(--fs-13);color:var(--text)}.dz-text span{color:var(--muted)}.dz-sub{font-size:11px;color:var(--muted)}.refs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.ref{position:relative;width:78px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--c-border);background:var(--c-surface-2)}.ref img{width:100%;height:64px;object-fit:cover;display:block}.ref .role-sel{font-size:10px;padding:3px;border-radius:0;border:none;border-top:1px solid var(--c-border)}.ref .x{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:#000000b3;color:#fff;border:none;font-size:11px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.hist-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}.hist-head h2{margin:0;font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-20)}.count{color:var(--muted);font-size:var(--fs-13)}.cards{display:flex;flex-direction:column;gap:16px}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;gap:14px;cursor:pointer;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.card:hover{border-color:var(--c-border-strong);box-shadow:var(--shadow-dark-sm)}.card .outs{display:flex;gap:10px;flex-wrap:wrap}.thumb{width:150px;height:150px;border-radius:var(--radius-md);overflow:hidden;background:var(--c-surface-2);border:1px solid var(--c-border);position:relative}.thumb img,.thumb video{width:100%;height:100%;object-fit:cover;display:block}.thumb[draggable=true]{cursor:grab}.thumb .drag-tag{position:absolute;bottom:6px;left:6px;font-size:10px;background:#0009;padding:2px 7px;border-radius:var(--radius-sm);color:#fff;font-family:var(--font-mono)}.placeholder{width:150px;height:150px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--muted);font-size:var(--fs-13);text-align:center;padding:8px;gap:6px}.card .meta{flex:1;min-width:0}.card .top{display:flex;align-items:center;gap:8px;margin-bottom:8px}.status{font-family:var(--font-mono);font-size:11px;font-weight:var(--fw-medium);padding:3px 9px;border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:var(--tracking-mono);display:inline-flex;align-items:center;gap:5px}.status.queued{background:var(--c-surface-3);color:var(--muted)}.status.running{background:var(--run-bg);color:var(--run)}.status.succeeded{background:var(--ok-bg);color:var(--ok)}.status.failed{background:var(--bad-bg);color:var(--bad)}.model-tag{font-family:var(--font-display);font-size:var(--fs-13);color:var(--c-text);font-weight:var(--fw-medium)}.by{font-size:var(--fs-12);color:var(--muted)}.prompt{color:var(--text);font-size:var(--fs-14);line-height:var(--lh-normal);margin:6px 0 10px;white-space:pre-wrap;word-break:break-word}.params{font-family:var(--font-mono);font-size:11px;color:var(--muted);margin-bottom:10px;letter-spacing:var(--tracking-mono)}.actions{display:flex;gap:8px;flex-wrap:wrap}.actions button{background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--text);padding:7px 12px;border-radius:var(--radius-sm);font-size:var(--fs-13);font-weight:var(--fw-medium);display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display)}.actions button:hover{border-color:var(--c-border-strong)}.actions button.danger:hover{border-color:var(--bad);color:var(--bad)}.err{color:var(--bad);font-size:var(--fs-12);margin-top:8px;word-break:break-word}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-xl);width:560px;max-width:92vw;max-height:88vh;overflow-y:auto;padding:26px;box-shadow:var(--shadow-dark-lg)}.modal h2{margin:0 0 4px;font-family:var(--font-display);font-weight:var(--fw-semibold)}.modal .sub{color:var(--muted);margin:0 0 18px;font-size:var(--fs-13)}.confirm-gen-modal{width:440px}.confirm-sub{color:var(--muted);margin:4px 0 16px;font-size:var(--fs-14)}.confirm-summary{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:4px 0;margin-bottom:20px}.confirm-row{display:flex;justify-content:space-between;gap:12px;padding:9px 16px;font-size:var(--fs-13);border-bottom:1px solid var(--c-border)}.confirm-row:last-child{border-bottom:none}.confirm-k{color:var(--muted);white-space:nowrap;flex-shrink:0}.confirm-v{font-weight:var(--fw-medium);text-align:right;word-break:break-word;min-width:0}.confirm-actions{display:flex;justify-content:flex-end;gap:10px}.ghost-btn{background:transparent;color:var(--text);border:1px solid var(--c-border)}.ghost-btn:hover{border-color:var(--c-border-strong);background:var(--c-surface-2)}.ok-pill{font-family:var(--font-mono);font-size:10px;color:var(--ok);letter-spacing:var(--tracking-mono);text-transform:none}.empty{color:var(--muted);text-align:center;padding:60px 20px}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--c-surface-3);color:var(--c-text);border:1px solid var(--c-border-strong);padding:12px 18px;border-radius:var(--radius-md);z-index:60;box-shadow:var(--shadow-dark-md);font-size:var(--fs-14)}.toast.err{background:var(--bad-bg);border-color:var(--bad);color:#ff8f78}.prompt.clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.viewer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:35;background:#070706f0;display:flex;align-items:center;justify-content:center;padding:48px 420px 48px 48px;animation:fade var(--dur-fast) var(--ease-standard)}@keyframes fade{0%{opacity:0}to{opacity:1}}.viewer-close{position:fixed;top:16px;left:18px;z-index:36;width:40px;height:40px;border-radius:var(--radius-md);background:#ffffff1a;border:1px solid rgba(255,255,255,.18);color:#fff;display:inline-flex;align-items:center;justify-content:center}.viewer-close:hover{background:#fff3}.viewer-inner{display:flex;flex-direction:column;align-items:center;gap:16px;max-height:100%;max-width:100%}.viewer-media{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.viewer-media img,.viewer-media video{max-width:100%;max-height:84vh;border-radius:var(--radius-lg);object-fit:contain;box-shadow:var(--shadow-dark-lg);background:#000}.viewer-media img{cursor:grab}.viewer-thumbs{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.vthumb{width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden;border:2px solid transparent;padding:0;background:var(--c-surface-2)}.vthumb.active{border-color:var(--tokio-yellow)}.vthumb img,.vthumb video{width:100%;height:100%;object-fit:cover;display:block}.detail{position:fixed;top:0;right:0;height:100%;width:380px;max-width:92vw;background:var(--panel);border-left:1px solid var(--border);z-index:40;display:flex;flex-direction:column;box-shadow:var(--shadow-dark-lg);animation:slidein var(--dur-fast) var(--ease-emphasized)}@keyframes slidein{0%{transform:translate(20px);opacity:.4}to{transform:none;opacity:1}}.detail-head{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 10px}.author{display:flex;align-items:center;gap:10px}.avatar{width:38px;height:38px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--tokio-yellow),var(--yellow-700) 75%)}.author-name{font-family:var(--font-display);font-weight:var(--fw-semibold)}.author-role{font-size:var(--fs-12);color:var(--muted)}.icon-btn.ghost{background:transparent;border:none;color:var(--muted);width:32px;height:32px}.icon-btn.ghost:hover{color:var(--text)}.detail-tabs{display:flex;gap:8px;padding:0 16px 12px;border-bottom:1px solid var(--border)}.dt{flex:1;background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--muted);border-radius:var(--radius-md);padding:9px;font-weight:var(--fw-medium);font-family:var(--font-display);display:inline-flex;align-items:center;justify-content:center;gap:6px}.dt.active{color:var(--text);background:var(--c-surface-3);border-color:var(--c-border-strong)}.dt:disabled{opacity:.5}.detail-scroll{flex:1;overflow-y:auto;padding:14px 16px}.block{background:var(--c-surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:14px}.block-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.block-head span{display:inline-flex;align-items:center;gap:6px}.mini{background:var(--c-surface-3);border:1px solid var(--c-border);color:var(--text);border-radius:var(--radius-sm);padding:5px 12px;font-size:var(--fs-12);font-weight:var(--fw-medium);font-family:var(--font-display)}.mini:hover{border-color:var(--tokio-yellow)}.ref-row{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.ref-thumb{width:58px;height:58px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--c-border)}.ref-thumb img{width:100%;height:100%;object-fit:cover;cursor:grab}.prompt-text{font-size:var(--fs-14);line-height:var(--lh-normal);color:var(--c-muted);white-space:pre-wrap;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.prompt-text.open{-webkit-line-clamp:unset;display:block;color:var(--c-text)}.see-all{background:transparent;border:none;color:var(--muted);font-size:var(--fs-13);margin-top:8px;padding:0;display:inline-flex;align-items:center;gap:4px}.see-all:hover{color:var(--text)}.info-row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border);font-size:var(--fs-14)}.info-row:last-child{border-bottom:none}.info-k{color:var(--muted)}.info-v{font-weight:var(--fw-semibold);font-family:var(--font-mono);font-size:var(--fs-13)}.detail-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 16px;border-top:1px solid var(--border)}.act{background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--text);border-radius:var(--radius-md);padding:13px;font-weight:var(--fw-medium);font-size:var(--fs-13);font-family:var(--font-display);display:inline-flex;align-items:center;justify-content:center;gap:7px}.act:hover{border-color:var(--c-border-strong)}.act.primary{background:var(--tokio-yellow);color:var(--tokio-dark);border-color:var(--tokio-yellow);grid-column:1 / -1}.act.primary:hover{background:var(--yellow-400)}.act.danger:hover{border-color:var(--bad);color:var(--bad)}.act.active-toggle{border-color:var(--tokio-yellow);color:var(--tokio-yellow)}.move-picker{margin-top:4px}.move-search{display:flex;align-items:center;gap:8px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:8px 12px;color:var(--muted)}.move-search input{flex:1;background:none;border:none;color:var(--text);font-size:var(--fs-14);font-family:var(--font-body);outline:none}.move-search input::placeholder{color:var(--muted)}.move-list{margin-top:6px;max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.move-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);border:1px solid transparent;background:none;color:var(--text);font-size:var(--fs-13);font-family:var(--font-display);text-align:left;cursor:pointer;transition:background var(--dur-fast),border-color var(--dur-fast)}.move-item:hover{background:var(--c-surface-2);border-color:var(--c-border)}.move-item.current{background:var(--tint-yellow);border-color:var(--tokio-yellow);color:var(--tokio-yellow);cursor:default}.move-item.create{color:var(--tokio-yellow)}.move-item.create:hover{background:var(--tint-yellow);border-color:var(--tokio-yellow)}.move-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.move-badge{font-size:var(--fs-11);text-transform:uppercase;letter-spacing:.05em;background:var(--tokio-yellow);color:var(--tokio-dark);padding:2px 8px;border-radius:var(--radius-pill);font-weight:var(--fw-semibold)}.move-arrow{opacity:0;transition:opacity var(--dur-fast);flex-shrink:0}.move-item:hover .move-arrow{opacity:1}.move-empty{color:var(--muted);font-size:var(--fs-13);padding:12px;text-align:center}.toggle{display:flex;align-items:center;gap:10px;width:100%;background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--text);border-radius:var(--radius-md);padding:11px 13px;font-weight:var(--fw-medium);font-size:var(--fs-13)}.toggle .knob{width:38px;height:22px;border-radius:var(--radius-pill);background:var(--c-border-strong);position:relative;transition:background var(--dur-fast);flex:0 0 auto}.toggle .knob:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform var(--dur-fast)}.toggle.on{border-color:var(--tokio-yellow)}.toggle.on .knob{background:var(--tokio-yellow)}.toggle.on .knob:after{transform:translate(16px);background:var(--tokio-dark)}.projects-view{max-width:1100px}.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}.proj-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:0;text-align:left;overflow:hidden;transition:border-color var(--dur-fast),transform var(--dur-instant),box-shadow var(--dur-fast)}.proj-card:hover{border-color:var(--c-border-strong);transform:translateY(-2px);box-shadow:var(--shadow-dark-md)}.proj-cover{height:140px;background:var(--c-surface-2);display:flex;align-items:center;justify-content:center;position:relative;color:var(--c-subtle)}.proj-cover img{width:100%;height:100%;object-fit:cover;display:block}.folder-ico{opacity:.8}.proj-cover-title{position:absolute;left:0;right:0;bottom:0;padding:18px 12px 9px;font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-14);color:#fff;text-align:left;background:linear-gradient(to top,#000000d9,#0000);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-meta{color:var(--muted);font-size:var(--fs-13);padding:10px 14px 14px;font-family:var(--font-mono);letter-spacing:var(--tracking-mono)}.proj-detail-head{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.proj-detail-head h2{margin:0;font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-24)}.back,.act-sm{background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--text);border-radius:var(--radius-md);padding:8px 14px;font-weight:var(--fw-medium);font-family:var(--font-display);font-size:var(--fs-13);display:inline-flex;align-items:center;gap:6px}.back:hover,.act-sm:hover{border-color:var(--c-border-strong)}.act-sm.danger:hover{border-color:var(--bad);color:var(--bad)}.viewmode{display:flex;gap:4px;background:var(--c-surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:3px}.viewmode button{background:transparent;border:none;color:var(--muted);width:32px;height:30px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center}.viewmode button.active{background:var(--tokio-yellow);color:var(--tokio-dark)}.gen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.gen-tile{position:relative;aspect-ratio:1 / 1;padding:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--c-surface-2);cursor:pointer;transition:border-color var(--dur-fast)}.gen-tile:hover{border-color:var(--tokio-yellow)}.gen-tile img,.gen-tile video{width:100%;height:100%;object-fit:cover;display:block}.gen-tile-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:var(--fs-12)}.gen-tile-badge{position:absolute;top:7px;left:7px;min-width:22px;height:22px;padding:0 5px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:#0009;color:#fff}.stats-view{max-width:980px}.stats-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}.stats-head h2{margin:0;font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-24)}.period-seg{width:auto;flex:0 0 auto}.period-seg button{min-width:86px}.project-filter{width:auto;min-width:180px}.total-card{background:linear-gradient(135deg,#26261d,var(--c-surface));color:var(--c-text);border:1px solid var(--c-border);border-radius:var(--radius-xl);padding:24px 26px;margin-bottom:20px}.total-label{color:var(--muted);font-family:var(--font-mono);font-size:var(--fs-13);text-transform:uppercase;letter-spacing:var(--tracking-eyebrow)}.total-value{font-family:var(--font-display);font-size:var(--fs-40);font-weight:var(--fw-semibold);letter-spacing:-.02em;margin:6px 0;color:var(--tokio-yellow)}.total-sub{color:var(--muted);font-size:var(--fs-13)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.stat-block{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.stat-block-title{margin-bottom:14px}.muted-row{color:var(--muted);font-size:var(--fs-13)}.bar-row{margin-bottom:13px}.bar-head{display:flex;justify-content:space-between;font-size:var(--fs-13);margin-bottom:5px;gap:8px}.bar-name{color:var(--text);word-break:break-word;flex:1;min-width:0}.bar-val{font-weight:var(--fw-semibold);font-family:var(--font-mono);white-space:nowrap;flex-shrink:0}.bar-cnt{color:var(--muted);font-weight:var(--fw-regular)}.bar-track{height:7px;background:var(--c-surface-2);border-radius:var(--radius-pill);overflow:hidden}.bar-fill{height:100%;background:var(--tokio-yellow);border-radius:var(--radius-pill)}code{font-family:var(--font-mono);background:var(--c-surface-2);padding:1px 6px;border-radius:var(--radius-xs);font-size:var(--fs-12);color:var(--c-text)}.login-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,#1f1f1c,var(--c-canvas))}.login-card{width:360px;max-width:92vw;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-xl);padding:32px 28px;box-shadow:var(--shadow-dark-lg);display:flex;flex-direction:column}.login-mark{width:40px;height:40px;margin-bottom:18px}.login-title{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--fs-32);letter-spacing:-.01em}.login-sub{color:var(--muted);font-size:var(--fs-14);margin:4px 0 22px}.login-card label{margin-top:12px}.login-card .btn{margin-top:20px}.login-err{background:var(--bad-bg);color:#ff8f78;border:1px solid var(--bad);border-radius:var(--radius-md);padding:9px 12px;font-size:var(--fs-13);margin-top:14px}.login-foot{color:var(--c-subtle);font-size:var(--fs-12);margin-top:18px;text-align:center;line-height:var(--lh-normal)}.user-chip{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:var(--radius-pill);background:var(--c-surface-2);border:1px solid var(--c-border)}.user-name{font-family:var(--font-display);font-weight:var(--fw-medium);font-size:var(--fs-13);color:var(--c-text)}.role-badge{font-family:var(--font-mono);font-size:9px;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:var(--tracking-eyebrow);color:var(--tokio-dark);background:var(--tokio-yellow);padding:2px 6px;border-radius:var(--radius-pill)}.modal-head{display:flex;align-items:center;justify-content:space-between}.user-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.user-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:10px 14px}.user-row-name{font-family:var(--font-display);font-weight:var(--fw-medium);display:flex;align-items:center;gap:8px}.user-row-email{font-family:var(--font-mono);font-size:var(--fs-12);color:var(--muted);letter-spacing:var(--tracking-mono)}.model-seg{display:grid;grid-template-columns:1fr 1fr;gap:6px}.model-seg button{background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--muted);border-radius:var(--radius-md);padding:9px 12px;font-family:var(--font-display);font-weight:var(--fw-medium);font-size:var(--fs-13);text-align:left;line-height:1.25;min-width:0;transition:all var(--dur-fast) var(--ease-standard)}.model-seg button:hover{color:var(--text);border-color:var(--c-border-strong)}.model-seg button.active{color:var(--tokio-yellow);border-color:var(--tokio-yellow);background:var(--tint-yellow)}.balances{display:flex;align-items:center;gap:8px}.bchip{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:var(--radius-pill);background:var(--c-surface-2);border:1px solid var(--c-border);font-family:var(--font-mono);font-size:11px;letter-spacing:var(--tracking-mono);white-space:nowrap}.bchip-k{color:var(--muted);text-transform:uppercase}.bchip-v{color:var(--c-text);font-weight:var(--fw-medium)}.bchip.ok{border-color:#4ed38f66}.bchip.ok .bchip-v{color:var(--ok)}.bchip.mid{border-color:#e8b53a73}.bchip.mid .bchip-v{color:var(--run)}.bchip.low{border-color:#ff6b5080}.bchip.low .bchip-v{color:var(--bad)}.btn.danger-btn{background:var(--tokio-red);color:#fff}.btn.danger-btn:hover{background:var(--red-600)}.btn.danger-btn:disabled{opacity:.4;cursor:not-allowed}.stars{display:flex;gap:6px}.star{background:transparent;border:none;color:var(--neutral-600);padding:2px;line-height:0;transition:color var(--dur-fast)}.star:hover{color:var(--yellow-400)}.star.on{color:var(--tokio-yellow)}.rating-filter{display:inline-flex;gap:2px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:4px 6px}.star-f{background:transparent;border:none;color:var(--neutral-600);padding:1px;line-height:0}.star-f.on,.star-f:hover{color:var(--tokio-yellow)}.card-stars{color:var(--tokio-yellow);font-size:var(--fs-13);letter-spacing:1px}.gen-tile-stars{position:absolute;bottom:6px;left:7px;font-size:11px;color:var(--tokio-yellow);background:#0009;padding:1px 6px;border-radius:var(--radius-sm);letter-spacing:1px}.act-sm.active-toggle,.icon-btn.active-icon{border-color:var(--tokio-yellow);color:var(--tokio-yellow)}.comments{display:flex;flex-direction:column;gap:10px}.comment{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:8px 10px}.comment-head{display:flex;justify-content:space-between;gap:8px;font-size:var(--fs-12);color:var(--muted);margin-bottom:4px}.comment-head b{color:var(--c-text);font-family:var(--font-display)}.comment-text{font-size:var(--fs-14);line-height:var(--lh-normal);white-space:pre-wrap;word-break:break-word}.chat-panel{width:360px;min-width:360px;border-left:1px solid var(--border);background:var(--panel);display:flex;flex-direction:column;min-height:0}.chat-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border)}.chat-title{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:var(--fw-semibold);color:var(--tokio-yellow)}.chat-empty{color:var(--muted);font-size:var(--fs-13);line-height:var(--lh-relaxed);padding:18px}.chat-scroll{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.chat-msg{display:flex;flex-direction:column;gap:4px;max-width:100%}.chat-msg.user{align-items:flex-end}.chat-bubble{max-width:92%;padding:9px 12px;border-radius:var(--radius-lg);font-size:var(--fs-14);line-height:var(--lh-normal);white-space:pre-wrap;word-break:break-word}.chat-msg.user .chat-bubble{background:var(--tokio-yellow);color:var(--tokio-dark);border-bottom-right-radius:var(--radius-xs)}.chat-msg.assistant .chat-bubble{background:var(--c-surface-2);color:var(--c-text);border:1px solid var(--c-border);border-bottom-left-radius:var(--radius-xs)}.chat-bubble.thinking{color:var(--muted);font-style:italic}.chat-paste{align-self:flex-start;background:transparent;border:1px solid var(--c-border);color:var(--muted);border-radius:var(--radius-pill);padding:4px 10px;font-size:var(--fs-12);font-family:var(--font-display);display:inline-flex;align-items:center;gap:5px}.chat-paste:hover{border-color:var(--tokio-yellow);color:var(--tokio-yellow)}.chat-input{border-top:1px solid var(--border);padding:12px;display:flex;flex-direction:column;gap:8px}.chat-input textarea{min-height:64px}
