:root{--primary: #2563EB;--primary-soft: #DBE7FE;--primary-ink: #1d4ed8;--accent: #D97757;--accent-soft: #FBE8DD;--bg-app: #F5F3EE;--surface: #FDFCF8;--surface-2: #F8F6F0;--surface-3: #EFEDE6;--side-bg: #1F1E1B;--side-bg-2: #2A2825;--side-fg: #D8D5CC;--side-fg-mute: #8A857A;--side-fg-soft: #6E695E;--ink: #1F1E1B;--ink-2: #3A3833;--ink-soft: #5C584F;--ink-mute: #8A857A;--ink-faint: #B0AB9F;--rule: rgba(31, 30, 27, .1);--rule-soft: rgba(31, 30, 27, .06);--rule-strong: rgba(31, 30, 27, .18);--success: #4A7F4F;--success-soft: #E1ECDC;--warn: #C18A2E;--warn-soft: #F4E8D0;--danger: #B5443A;--danger-soft: #F4DDD9;--side-w: 248px;--header-h: 56px;--row-h: 44px;--r-sm: 4px;--r-md: 6px;--r-lg: 8px;--r-xl: 12px;--shadow-sm: 0 1px 2px rgba(31,30,27,.04);--shadow-md: 0 6px 16px rgba(31,30,27,.08), 0 1px 2px rgba(31,30,27,.04);--shadow-lg: 0 24px 48px rgba(31,30,27,.18), 0 4px 12px rgba(31,30,27,.08);--sans: "Inter", system-ui, -apple-system, sans-serif;--mono: "IBM Plex Mono", ui-monospace, "SFMono-Regular", monospace;--pad-y: 14px;--pad-x: 18px;--gap: 16px}:root[data-theme=dark]{--bg-app: #161513;--surface: #1F1E1B;--surface-2: #25231F;--surface-3: #2A2825;--side-bg: #131210;--side-bg-2: #1B1A17;--ink: #E8E4DA;--ink-2: #C9C4B7;--ink-soft: #9A9588;--ink-mute: #6E695E;--ink-faint: #4F4B43;--rule: rgba(232, 228, 218, .1);--rule-soft: rgba(232, 228, 218, .06);--rule-strong: rgba(232, 228, 218, .18);--primary-soft: #1B2D52;--accent-soft: #3E2A20;--success-soft: #1E2D1F;--warn-soft: #2D261A;--danger-soft: #2E1A18}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:var(--sans);background:var(--bg-app);color:var(--ink);font-size:13.5px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::selection{background:var(--primary);color:#fff}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}input,select,textarea{font:inherit;color:inherit}.app{display:grid;grid-template-columns:var(--side-w) 1fr;min-height:100vh}aside.sidebar{background:var(--side-bg);color:var(--side-fg);display:flex;flex-direction:column;border-right:1px solid rgba(0,0,0,.4);position:sticky;top:0;height:100vh;overflow-y:auto}.side-brand{padding:18px 20px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:12px}.side-brand svg{height:18px;width:auto;flex-shrink:0}.side-brand .gw,.side-brand .gp{fill:#faf9f5}.side-brand .gs{fill:var(--primary)}.side-brand-text{display:flex;flex-direction:column;gap:2px;overflow:hidden}.side-brand-text strong{font-size:11.5px;font-weight:600;color:#faf9f5;letter-spacing:.01em}.side-brand-text span{font-size:10.5px;color:var(--side-fg-soft);letter-spacing:.04em;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.side-search{padding:14px 16px 8px;position:relative}.side-search input{width:100%;height:30px;padding:0 10px 0 30px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--r-md);color:var(--side-fg);font-size:12.5px;outline:none;transition:border-color .15s,background .15s}.side-search input::placeholder{color:var(--side-fg-soft)}.side-search input:focus{border-color:#fff3;background:#ffffff12}.side-search:before{content:"";position:absolute;left:26px;top:50%;width:12px;height:12px;transform:translateY(-50%);background:var(--side-fg-soft);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><circle cx='7' cy='7' r='5' fill='none' stroke='black' stroke-width='1.5'/><line x1='11' y1='11' x2='14' y2='14' stroke='black' stroke-width='1.5' stroke-linecap='round'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><circle cx='7' cy='7' r='5' fill='none' stroke='black' stroke-width='1.5'/><line x1='11' y1='11' x2='14' y2='14' stroke='black' stroke-width='1.5' stroke-linecap='round'/></svg>") center/contain no-repeat}.side-search kbd{position:absolute;right:22px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:10px;color:var(--side-fg-soft);border:1px solid rgba(255,255,255,.08);padding:1px 4px;border-radius:3px}.side-nav{flex:1;padding:8px 0 16px;overflow-y:auto}.side-group{padding:12px 0 4px}.side-group-label{padding:4px 20px 6px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--side-fg-mute);font-weight:500}.side-item{display:flex;align-items:center;gap:10px;padding:7px 20px;color:var(--side-fg);font-size:13px;line-height:1.3;border-left:2px solid transparent;cursor:pointer;transition:background .12s,color .12s;position:relative}.side-item:hover{background:#ffffff08;color:#faf9f5}.side-item.active{background:var(--side-bg-2);color:#faf9f5;border-left-color:var(--accent);font-weight:500}.side-item-icon{width:14px;height:14px;background:currentColor;opacity:.7;flex-shrink:0;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}.side-item.active .side-item-icon{opacity:1}.side-item-badge{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--side-fg-mute);padding:1px 5px;border:1px solid rgba(255,255,255,.1);border-radius:3px;line-height:1.4}.side-item.active .side-item-badge{color:#faf9f5;border-color:#ffffff2e}.side-foot{padding:12px 16px;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px}.side-avatar{width:28px;height:28px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--primary),var(--primary-ink));color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}.side-foot-text{flex:1;overflow:hidden}.side-foot-text strong{display:block;font-size:12px;color:#faf9f5;font-weight:500;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.side-foot-text span{font-size:10.5px;color:var(--side-fg-soft)}.side-foot-action{width:24px;height:24px;border-radius:var(--r-sm);color:var(--side-fg-soft);display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.side-foot-action:hover{background:#ffffff0f;color:var(--side-fg)}main.main{display:flex;flex-direction:column;min-width:0}header.top{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--rule);position:sticky;top:0;z-index:20;display:flex;align-items:center;padding:0 24px;gap:18px}.top-crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft)}.top-crumb a{color:var(--ink-soft);cursor:pointer}.top-crumb a:hover{color:var(--ink)}.top-crumb .sep{color:var(--ink-faint)}.top-title{font-size:14.5px;font-weight:600;color:var(--ink);letter-spacing:-.005em}.top-spacer{flex:1}.top-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:32px;height:32px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:background .12s,color .12s;position:relative}.icon-btn:hover{background:var(--surface-3);color:var(--ink)}.icon-btn .dot{position:absolute;top:6px;right:7px;width:6px;height:6px;border-radius:50%;background:var(--accent);border:1.5px solid var(--surface)}.top-divider{width:1px;height:20px;background:var(--rule);margin:0 4px}.top-user{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 4px;border-radius:var(--r-md);cursor:pointer;transition:background .12s}.top-user:hover{background:var(--surface-3)}.top-user .av{width:26px;height:26px;border-radius:5px;background:linear-gradient(135deg,var(--primary),var(--primary-ink));color:#fff;display:flex;align-items:center;justify-content:center;font-size:10.5px;font-weight:600}.top-user-text{display:flex;flex-direction:column;line-height:1.15}.top-user-text strong{font-size:12px;font-weight:500;color:var(--ink)}.top-user-text span{font-size:10.5px;color:var(--ink-mute)}.page{flex:1;padding:28px 32px 60px;background:var(--bg-app);min-width:0}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px}.page-title{display:flex;flex-direction:column;gap:4px}.page-title h1{font-size:22px;font-weight:600;letter-spacing:-.015em;color:var(--ink)}.page-title p{font-size:13px;color:var(--ink-soft)}.page-actions{display:flex;gap:8px;align-items:center}body[data-density=compact]{--row-h: 36px}body[data-density=compact] table.tbl tbody td{padding:8px 14px}body[data-density=compact] .kpi{padding:12px 14px}body[data-density=compact] .kpi-value{font-size:22px}body[data-density=compact] .page{padding:20px 24px 40px}body[data-density=comfy]{--row-h: 52px}body[data-density=comfy] table.tbl tbody td{padding:16px 18px}body[data-density=comfy] .kpi{padding:20px 22px}body[data-density=comfy] .kpi-value{font-size:30px}body[data-density=comfy] .page{padding:36px 40px 60px}@media (max-width: 1100px){.kpis{grid-template-columns:repeat(2,1fr)!important}.chart-row{grid-template-columns:1fr!important}}@media (max-width: 760px){:root{--side-w: 0px}aside.sidebar{display:none}.page{padding:16px}.kpis{grid-template-columns:1fr!important}}.badge{display:inline-flex;align-items:center;gap:6px;height:24px;padding:0 10px;border-radius:var(--r-sm);font-size:11.5px;font-weight:500;line-height:1;letter-spacing:.005em;border:1px solid transparent}.badge-primary{background:var(--primary-soft);color:var(--primary)}.badge-accent{background:var(--accent-soft);color:var(--accent)}.badge-green{background:var(--success-soft);color:var(--success)}.badge-warn{background:var(--warn-soft);color:var(--warn)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-neutral{background:var(--surface-3);color:var(--ink-soft)}.badge-outline{background:transparent;color:var(--ink-soft);border-color:var(--rule)}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--r-md);font-size:12.5px;font-weight:500;line-height:1;transition:background .12s,color .12s,border-color .12s,box-shadow .12s;border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:color-mix(in srgb,var(--primary) 88%,#000)}.btn-outline{background:var(--surface);color:var(--ink);border-color:var(--rule)}.btn-outline:hover{border-color:var(--ink);background:var(--surface-2)}.btn-ghost{color:var(--ink-soft)}.btn-ghost:hover{background:var(--surface-3);color:var(--ink)}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:color-mix(in srgb,var(--accent) 90%,#000)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{height:26px;padding:0 10px;font-size:11.5px}.btn-lg{height:40px;padding:0 18px;font-size:13.5px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:11.5px;font-weight:500;color:var(--ink-soft);letter-spacing:.02em}.field label .req{color:var(--danger);margin-left:2px}.input,.select,.textarea{height:36px;padding:0 12px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-md);font-size:13px;color:var(--ink);outline:none;transition:border-color .12s,box-shadow .12s}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 15%,transparent)}.textarea{height:auto;padding:10px 12px;resize:vertical;min-height:80px}.input::placeholder,.textarea::placeholder{color:var(--ink-mute)}.field-hint{font-size:11.5px;color:var(--ink-mute)}.field-error{font-size:11.5px;color:var(--danger)}.field.error .input,.field.error .select,.field.error .textarea{border-color:var(--danger)}.checkbox,.radio{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);cursor:pointer}.checkbox input,.radio input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border:1.5px solid var(--rule-strong);border-radius:3px;background:var(--surface);display:grid;place-items:center;transition:background .12s,border-color .12s}.radio input{border-radius:50%}.checkbox input:checked,.radio input:checked{background:var(--primary);border-color:var(--primary)}.checkbox input:checked:after{content:"";width:9px;height:5px;border:1.5px solid #fff;border-top:0;border-right:0;transform:translateY(-1px) rotate(-45deg)}.radio input:checked:after{content:"";width:6px;height:6px;border-radius:50%;background:#fff}.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}.kpi{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-lg);padding:16px 18px;display:flex;flex-direction:column;gap:8px;position:relative;transition:border-color .15s}.kpi:hover{border-color:var(--rule-strong)}.kpi-head{display:flex;align-items:center;justify-content:space-between}.kpi-label{font-size:11.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.kpi-info{width:14px;height:14px;border-radius:50%;border:1px solid var(--rule);color:var(--ink-mute);font-size:9px;display:flex;align-items:center;justify-content:center}.kpi-value{font-family:var(--mono);font-size:26px;font-weight:500;color:var(--ink);line-height:1.05;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi-value .unit{font-size:13px;color:var(--ink-mute);font-weight:400;margin-left:4px}.kpi-foot{display:flex;align-items:center;justify-content:space-between;font-size:11.5px}.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-family:var(--mono);font-weight:500;font-variant-numeric:tabular-nums}.kpi-delta.up{color:var(--success)}.kpi-delta.down{color:var(--danger)}.kpi-delta.flat,.kpi-vs{color:var(--ink-mute)}.kpi-spark{position:absolute;right:0;bottom:0;width:80px;height:32px;opacity:.5;pointer-events:none}.filters{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.seg{display:inline-flex;background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-md);padding:2px;height:32px}.seg button{height:26px;padding:0 12px;font-size:12px;font-weight:500;color:var(--ink-soft);border-radius:var(--r-sm);line-height:1;transition:background .12s,color .12s}.seg button:hover{color:var(--ink)}.seg button.on{background:var(--surface-3);color:var(--ink)}.filter-search{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-md);height:32px;padding:0 10px 0 30px;width:240px;position:relative}.filter-search:before{content:"";position:absolute;left:10px;top:50%;width:12px;height:12px;transform:translateY(-50%);background:var(--ink-mute);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><circle cx='7' cy='7' r='5' fill='none' stroke='black' stroke-width='1.5'/><line x1='11' y1='11' x2='14' y2='14' stroke='black' stroke-width='1.5' stroke-linecap='round'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><circle cx='7' cy='7' r='5' fill='none' stroke='black' stroke-width='1.5'/><line x1='11' y1='11' x2='14' y2='14' stroke='black' stroke-width='1.5' stroke-linecap='round'/></svg>") center/contain no-repeat}.filter-search input{flex:1;height:100%;background:transparent;border:0;outline:none;font-size:12.5px;min-width:0}.filter-search input::placeholder{color:var(--ink-mute)}.filter-pill{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-md);height:32px;padding:0 12px;font-size:12px;color:var(--ink-soft);transition:border-color .12s,color .12s}.filter-pill:hover{border-color:var(--ink);color:var(--ink)}.filter-pill .x{width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface-3);font-size:10px;line-height:1;color:var(--ink-mute)}.table-card{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-lg);overflow:hidden}table.tbl{width:100%;border-collapse:collapse;font-size:13px}table.tbl thead th{text-align:left;padding:10px 14px;font-weight:500;font-size:11.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;background:var(--surface-2);border-bottom:1px solid var(--rule);white-space:nowrap}table.tbl thead th .sort{margin-left:4px;color:var(--ink-faint)}table.tbl thead th.num{text-align:right}table.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--rule-soft);vertical-align:middle;color:var(--ink-2)}table.tbl tbody tr:last-child td{border-bottom:0}table.tbl tbody tr{transition:background .1s;cursor:pointer}table.tbl tbody tr:hover{background:var(--surface-2)}table.tbl tbody tr.selected{background:var(--primary-soft)}table.tbl tbody td.num{font-family:var(--mono);text-align:right;font-variant-numeric:tabular-nums;color:var(--ink)}table.tbl tbody td.muted{color:var(--ink-mute)}table.tbl td .ck-cell{display:inline-flex;align-items:center}.ent-cell{display:flex;align-items:center;gap:10px;min-width:0}.ent-mark{width:28px;height:28px;border-radius:5px;background:var(--surface-3);color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10.5px;font-weight:600;flex-shrink:0;border:1px solid var(--rule)}.ent-mark.b{background:var(--primary-soft);color:var(--primary);border-color:transparent}.ent-mark.c{background:var(--accent-soft);color:var(--accent);border-color:transparent}.ent-mark.g{background:var(--success-soft);color:var(--success);border-color:transparent}.ent-name{display:flex;flex-direction:column;gap:1px;min-width:0}.ent-name strong{font-size:13px;font-weight:500;color:var(--ink);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.ent-name span{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);letter-spacing:.02em}.progress{display:flex;align-items:center;gap:8px}.progress-track{flex:1;max-width:80px;height:4px;background:var(--surface-3);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--ink-2);border-radius:999px;transition:width .4s}.progress-fill.primary{background:var(--primary)}.progress-fill.accent{background:var(--accent)}.progress-fill.green{background:var(--success)}.progress span{font-family:var(--mono);font-size:11px;color:var(--ink-soft);font-variant-numeric:tabular-nums;min-width:32px}.row-actions{display:flex;gap:2px;justify-content:flex-end}.row-actions .icon-btn{width:26px;height:26px}.table-foot{padding:10px 14px;border-top:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;background:var(--surface-2);font-size:12px;color:var(--ink-soft)}.pager{display:flex;gap:4px;align-items:center}.pager button{width:26px;height:26px;border:1px solid var(--rule);border-radius:var(--r-sm);background:var(--surface);color:var(--ink-soft);font-size:12px;font-family:var(--mono);transition:background .12s,color .12s}.pager button:hover{background:var(--surface-3);color:var(--ink)}.pager button.on{background:var(--ink);color:var(--surface);border-color:var(--ink)}.bulk-bar{display:flex;align-items:center;gap:12px;padding:8px 14px;background:var(--ink);color:#fff;border-radius:var(--r-md);margin-bottom:12px;font-size:12.5px}.bulk-bar .bulk-count{font-family:var(--mono);padding:2px 8px;background:#ffffff1a;border-radius:var(--r-sm)}.bulk-bar .bulk-actions{margin-left:auto;display:flex;gap:6px}.bulk-bar .btn{background:#ffffff1a;color:#fff;border-color:transparent}.bulk-bar .btn:hover{background:#fff3}.chart-row{display:grid;grid-template-columns:2fr 1fr;gap:12px;margin-bottom:28px}.chart-card{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-lg);padding:18px 20px;display:flex;flex-direction:column;gap:14px;min-height:240px}.chart-head{display:flex;align-items:flex-start;justify-content:space-between}.chart-title{display:flex;flex-direction:column;gap:2px}.chart-title h3{font-size:13px;font-weight:600;color:var(--ink)}.chart-title p{font-size:11.5px;color:var(--ink-mute)}.chart-body{flex:1;position:relative}.chart-legend{display:flex;gap:14px;font-size:11.5px;color:var(--ink-soft);flex-wrap:wrap}.chart-legend span{display:inline-flex;align-items:center;gap:6px}.chart-legend i{width:10px;height:2px;background:currentColor;border-radius:1px}.detail-head{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-lg);padding:22px 24px;margin-bottom:16px}.detail-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:16px}.detail-id-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.detail-id-row .id{font-family:var(--mono);font-size:11.5px;color:var(--ink-mute);letter-spacing:.04em}.detail-title{font-size:24px;font-weight:600;color:var(--ink);letter-spacing:-.015em;margin-bottom:4px}.detail-sub{font-size:13px;color:var(--ink-soft)}.detail-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding-top:16px;border-top:1px solid var(--rule-soft)}.detail-meta-item{display:flex;flex-direction:column;gap:4px}.detail-meta-item .l{font-size:10.5px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.detail-meta-item .v{font-size:13.5px;color:var(--ink);font-weight:500;font-variant-numeric:tabular-nums}.tabs{display:flex;gap:0;border-bottom:1px solid var(--rule);margin-bottom:20px}.tabs button{padding:10px 14px;font-size:13px;font-weight:500;color:var(--ink-soft);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s}.tabs button:hover{color:var(--ink)}.tabs button.on{color:var(--ink);border-bottom-color:var(--accent)}.tabs .count{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);margin-left:6px;padding:1px 5px;background:var(--surface-3);border-radius:3px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f1e1b66;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;opacity:0;pointer-events:none;transition:opacity .2s}.drawer-overlay.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:92vw;background:var(--surface);border-left:1px solid var(--rule);z-index:101;transform:translate(100%);transition:transform .25s ease;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.drawer.open{transform:translate(0)}.drawer-head{padding:18px 22px;border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between}.drawer-head h3{font-size:15px;font-weight:600;color:var(--ink)}.drawer-body{flex:1;padding:22px;overflow-y:auto}.drawer-foot{padding:14px 22px;border-top:1px solid var(--rule);display:flex;gap:8px;justify-content:flex-end}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f1e1b80;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .15s}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{width:480px;max-width:92vw;background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);transform:scale(.97);transition:transform .2s}.modal-overlay.open .modal{transform:scale(1)}.modal-head{padding:18px 22px 8px}.modal-head h3{font-size:16px;font-weight:600;color:var(--ink);margin-bottom:4px}.modal-head p{font-size:13px;color:var(--ink-soft)}.modal-body{padding:14px 22px}.modal-foot{padding:14px 22px 18px;display:flex;gap:8px;justify-content:flex-end}.stepper{display:flex;gap:0;margin-bottom:24px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-lg);padding:4px}.stepper-item{flex:1;display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-md);font-size:12.5px;color:var(--ink-mute);cursor:pointer;transition:background .12s,color .12s;position:relative}.stepper-item:hover{color:var(--ink-soft)}.stepper-item.on{background:var(--surface-3);color:var(--ink)}.stepper-item.done{color:var(--success)}.step-num{width:22px;height:22px;border-radius:50%;background:var(--surface-3);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;font-weight:600;flex-shrink:0}.stepper-item.on .step-num{background:var(--ink);color:var(--surface);border-color:var(--ink)}.stepper-item.done .step-num{background:var(--success);color:#fff;border-color:var(--success)}.step-label{display:flex;flex-direction:column;gap:1px;min-width:0}.step-label strong{font-weight:500}.step-label span{font-size:10.5px;color:var(--ink-mute)}.form-card{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-lg);padding:24px;margin-bottom:16px}.form-card h3{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:4px}.form-card .desc{font-size:12.5px;color:var(--ink-soft);margin-bottom:18px}.form-grid{display:grid;gap:14px;grid-template-columns:repeat(2,1fr)}.form-grid .full{grid-column:1 / -1}.upload{border:2px dashed var(--rule-strong);border-radius:var(--r-lg);padding:28px;text-align:center;background:var(--surface-2);cursor:pointer;transition:border-color .15s,background .15s}.upload:hover{border-color:var(--primary);background:var(--primary-soft)}.upload .upload-icon{width:36px;height:36px;margin:0 auto 10px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;color:var(--ink-soft)}.upload strong{font-size:13px;color:var(--ink);display:block;margin-bottom:2px}.upload span{font-size:11.5px;color:var(--ink-mute)}.upload-files{margin-top:14px;display:flex;flex-direction:column;gap:6px}.upload-file{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-md);font-size:12.5px}.upload-file .name{flex:1;color:var(--ink)}.upload-file .size{font-family:var(--mono);font-size:11px;color:var(--ink-mute)}.empty{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-lg);padding:64px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}.empty-art{width:96px;height:96px;border-radius:var(--r-lg);background:var(--surface-2);border:1px dashed var(--rule-strong);display:flex;align-items:center;justify-content:center;color:var(--ink-mute);margin-bottom:14px}.empty h2{font-size:17px;font-weight:600;color:var(--ink)}.empty p{font-size:13px;color:var(--ink-soft);max-width:380px;line-height:1.55}.empty-actions{display:flex;gap:8px;margin-top:14px}.skeleton{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:sk 1.4s ease-in-out infinite;border-radius:var(--r-sm)}@keyframes sk{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{width:22px;height:22px;border:2.5px solid var(--rule);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--r-md);font-size:12.5px;border:1px solid transparent}.alert .alert-dot{width:6px;height:6px;border-radius:50%;background:currentColor;margin-top:6px;flex-shrink:0}.alert-info{background:var(--primary-soft);color:var(--primary);border-color:color-mix(in srgb,var(--primary) 25%,transparent)}.alert-success{background:var(--success-soft);color:var(--success);border-color:color-mix(in srgb,var(--success) 25%,transparent)}.alert-warn{background:var(--warn-soft);color:var(--warn);border-color:color-mix(in srgb,var(--warn) 25%,transparent)}.alert-danger{background:var(--danger-soft);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 25%,transparent)}.alert strong{font-weight:600}.alert .alert-body{flex:1;color:var(--ink-2)}.alert .alert-body strong{color:var(--ink);display:block;margin-bottom:2px}.app-grid{display:grid;grid-template-columns:var(--side-w) 1fr;min-height:100vh}.center-fill{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-app)}.app-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-top:16px}.app-card{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r-md);padding:18px;display:flex;flex-direction:column;gap:10px;cursor:pointer;transition:border-color .12s,transform .12s,box-shadow .12s}.app-card:hover{border-color:var(--rule-strong);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.app-card-head{display:flex;align-items:center;gap:10px}.app-card-icon{width:32px;height:32px;border-radius:var(--r-sm);background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-card-title{font-size:14px;font-weight:600;color:var(--ink)}.app-card-desc{font-size:12.5px;color:var(--ink-soft);line-height:1.5;flex:1}.app-card-tag{font-family:var(--mono);font-size:10px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.06em}
