:root{--bg-0: #f7f7f9;--bg-1: #ffffff;--bg-2: #f0f0f3;--bg-3: #e6e6ec;--bg-hover: #f4f4f7;--border-subtle: #ededf1;--border: #e3e3e9;--border-strong: #cfcfd6;--text-1: #15151a;--text-2: #54565f;--text-3: #8b8d97;--text-inverse: #ffffff;--accent: #5b5bd6;--accent-hover: #4e4ec9;--accent-soft: rgba(91, 91, 214, .08);--accent-ring: rgba(91, 91, 214, .22);--ok: #16a34a;--ok-soft: rgba(22, 163, 74, .1);--warn: #d97706;--warn-soft: rgba(217, 119, 6, .1);--err: #dc2626;--err-soft: rgba(220, 38, 38, .1);--danger: var(--err);--mono: "JetBrains Mono", "Fira Code", ui-monospace, Consolas, monospace;--ui: "Inter", -apple-system, "Segoe UI", system-ui, sans-serif;--fs-xs: 12px;--fs-sm: 13px;--fs-md: 14px;--fs-lg: 16px;--fs-xl: 20px;--fs-2xl: 26px;--fs-3xl: 32px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-full: 999px;--shadow-sm: 0 1px 2px rgba(20, 20, 30, .04);--shadow-md: 0 4px 12px rgba(20, 20, 30, .06), 0 1px 3px rgba(20, 20, 30, .04);--shadow-lg: 0 12px 28px rgba(20, 20, 30, .1), 0 4px 12px rgba(20, 20, 30, .06);--shadow-popover: 0 16px 40px rgba(20, 20, 30, .14), 0 2px 6px rgba(20, 20, 30, .06);--shadow-focus: 0 0 0 3px var(--accent-ring);--nav-w: 224px;--header-h: 52px;--footer-h: 30px;--rail-left: 264px;--rail-right: 320px;--ease: cubic-bezier(.2, .7, .2, 1);--t-fast: .1s;--t-med: .18s;--canvas-bg: #fbfbfd;--canvas-grid: #eef0f4;--canvas-grid-major: #e2e5ec;--canvas-ruler-bg: #f0f0f3;--canvas-ruler-text: #8b8d97;--canvas-ruler-tick: #cfcfd6;--canvas-axis: #c5c8d0;--canvas-edge: rgba(15, 15, 22, .1)}:root[data-theme=dark]{--bg-0: #0b0e16;--bg-1: #141925;--bg-2: #1c2230;--bg-3: #262d3e;--bg-hover: #1e2535;--border-subtle: #1f2535;--border: #2a3145;--border-strong: #3a4360;--text-1: #ecedf2;--text-2: #aab2c5;--text-3: #6d748a;--text-inverse: #15151a;--accent: #818cf8;--accent-hover: #9aa3fa;--accent-soft: rgba(129, 140, 248, .14);--accent-ring: rgba(129, 140, 248, .32);--ok: #34d399;--ok-soft: rgba(52, 211, 153, .14);--warn: #fbbf24;--warn-soft: rgba(251, 191, 36, .14);--err: #f87171;--err-soft: rgba(248, 113, 113, .14);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .25);--shadow-md: 0 6px 16px rgba(0, 0, 0, .32), 0 1px 3px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 36px rgba(0, 0, 0, .42), 0 4px 12px rgba(0, 0, 0, .3);--shadow-popover: 0 22px 48px rgba(0, 0, 0, .58), 0 2px 8px rgba(0, 0, 0, .4);--canvas-bg: #0f1422;--canvas-grid: #1a2032;--canvas-grid-major: #232a3e;--canvas-ruler-bg: #0a0d18;--canvas-ruler-text: #6d748a;--canvas-ruler-tick: #2a3145;--canvas-axis: #3a4360;--canvas-edge: rgba(255, 255, 255, .1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-0);color:var(--text-1);font-family:var(--ui);font-size:var(--fs-md);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden;font-feature-settings:"cv11","ss01"}::selection{background:var(--accent-soft);color:var(--text-1)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-full);border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--text-3);background-clip:padding-box;border:2px solid transparent}::-webkit-scrollbar-corner{background:transparent}h1{font-size:var(--fs-2xl);font-weight:600;letter-spacing:-.015em;margin:0 0 var(--sp-3);color:var(--text-1)}h2{font-size:var(--fs-xl);font-weight:600;letter-spacing:-.01em;margin:0 0 var(--sp-3);color:var(--text-1)}h3{font-size:var(--fs-lg);font-weight:600;margin:0 0 var(--sp-2);color:var(--text-1)}h4{font-size:var(--fs-md);font-weight:600;margin:0 0 var(--sp-2);color:var(--text-1)}p{margin:0 0 var(--sp-2);color:var(--text-2)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}hr{border:0;border-top:1px solid var(--border-subtle);margin:var(--sp-4) 0}code,kbd{font-family:var(--mono);font-size:.92em;background:var(--bg-2);padding:1px 6px;border-radius:var(--r-sm);border:1px solid var(--border-subtle);color:var(--text-2)}button{font-family:var(--ui);background:var(--bg-1);color:var(--text-1);border:1px solid var(--border);padding:7px 14px;border-radius:var(--r-md);cursor:pointer;font-size:var(--fs-sm);font-weight:500;line-height:1.3;transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease),color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease);display:inline-flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0;letter-spacing:-.005em}button.btn-truncate{overflow:hidden;text-overflow:ellipsis;min-width:0}button:hover:not(:disabled){background:var(--bg-2);border-color:var(--border-strong)}button:active:not(:disabled){background:var(--bg-3)}button:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-color:var(--accent)}button:disabled{opacity:.45;cursor:not-allowed}button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}button.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}button.primary:active:not(:disabled){background:var(--accent-hover);filter:brightness(.95)}button.danger{background:var(--bg-1);color:var(--err);border-color:var(--border)}button.danger:hover:not(:disabled){background:var(--err-soft);border-color:var(--err)}button.ghost{background:transparent;border-color:transparent;color:var(--text-2)}button.ghost:hover:not(:disabled){background:var(--bg-2);color:var(--text-1);border-color:transparent}button.ok{background:var(--ok);color:#fff;border-color:var(--ok)}button.sm{padding:4px 10px;font-size:var(--fs-xs)}button.xs{padding:2px 8px;font-size:var(--fs-xs)}button.lg{padding:10px 18px;font-size:var(--fs-md)}button.block{display:flex;width:100%;justify-content:center}input,select,textarea{background:var(--bg-1);color:var(--text-1);border:1px solid var(--border);padding:8px 12px;border-radius:var(--r-md);font-family:var(--ui);font-size:var(--fs-sm);width:100%;transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),background var(--t-fast) var(--ease)}input:hover:not(:disabled):not(:focus),select:hover:not(:disabled):not(:focus),textarea:hover:not(:disabled):not(:focus){border-color:var(--border-strong)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus)}input:disabled,select:disabled,textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-2)}input::placeholder,textarea::placeholder{color:var(--text-3)}input[type=number]{font-variant-numeric:tabular-nums;font-family:var(--mono);font-size:var(--fs-xs);padding-right:10px}input[type=color]{padding:2px;height:34px;cursor:pointer}input[type=range]{padding:0;background:transparent;border:0}input[type=checkbox],input[type=radio]{width:auto;accent-color:var(--accent);cursor:pointer}select{background-image:linear-gradient(45deg,transparent 50%,var(--text-3) 50%),linear-gradient(135deg,var(--text-3) 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:28px;-webkit-appearance:none;-moz-appearance:none;appearance:none}label{display:flex;align-items:center;gap:4px;font-size:var(--fs-xs);color:var(--text-2);margin-bottom:6px;font-weight:500;letter-spacing:0}fieldset{border:1px solid var(--border-subtle);border-radius:var(--r-md);padding:var(--sp-4);margin:0 0 var(--sp-4)}legend{font-size:var(--fs-xs);color:var(--text-3);padding:0 var(--sp-2);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.row{display:flex;gap:var(--sp-2);align-items:flex-start;min-width:0}.row>*{flex:1 1 0;min-width:0}.row.row-auto>*{flex:0 0 auto}.col{display:flex;flex-direction:column;gap:var(--sp-2)}.stack-sm{display:flex;flex-direction:column;gap:4px}.stack-md{display:flex;flex-direction:column;gap:var(--sp-3)}.stack-lg{display:flex;flex-direction:column;gap:var(--sp-5)}.shell-v2{display:grid;grid-template-columns:var(--nav-w) 1fr;grid-template-rows:var(--header-h) 1fr auto var(--footer-h);height:100vh;background:var(--bg-0);transition:grid-template-columns var(--t-med) var(--ease)}.shell-v2>.shell-header-v2{grid-column:1 / 3;grid-row:1}.shell-v2>.shell-nav-v2{grid-column:1;grid-row:2 / 4}.shell-v2>.shell-main-v2{grid-column:2;grid-row:2}.shell-v2>.shell-nextstep{grid-column:2;grid-row:3}.shell-v2>.shell-footer-v2{grid-column:1 / 3;grid-row:4}.shell-v2.nav-collapsed{grid-template-columns:52px 1fr}.shell-v2.nav-collapsed .shell-nav-v2{padding:var(--sp-3) 4px}.shell-v2.nav-collapsed .nav-phase{display:none}.shell-v2.nav-collapsed .nav-icon{justify-content:center;padding:8px 4px;gap:0}.shell-v2.nav-collapsed .nav-label{display:none}.shell-v2.nav-collapsed .nav-step{width:auto;text-align:center}.shell-v2.nav-collapsed .brand .word{display:none}.shell-v2.nav-collapsed .brand{width:auto}.shell-header-v2{display:flex;align-items:center;padding:0 var(--sp-5);gap:var(--sp-3);background:var(--bg-1);border-bottom:1px solid var(--border-subtle);position:relative;z-index:10}.shell-header-v2 .brand{font-weight:600;font-size:var(--fs-md);letter-spacing:-.01em;color:var(--text-1);display:flex;align-items:center;gap:10px;width:calc(var(--nav-w) - var(--sp-5) - var(--sp-3))}.shell-header-v2 .brand .mark{width:24px;height:24px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:var(--r-sm);font-size:13px;font-weight:700}.shell-header-v2 .spacer{flex:1}.shell-header-v2 .save-status{color:var(--text-3);font-size:var(--fs-xs);font-family:var(--mono);padding:2px 8px;background:var(--bg-2);border-radius:var(--r-sm)}.shell-header-v2 button{padding:5px 11px;font-size:var(--fs-sm)}.shell-header-v2 .divider{width:1px;align-self:stretch;background:var(--border-subtle);margin:12px 4px}.shell-nav-v2{background:var(--bg-1);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;padding:var(--sp-3) var(--sp-2);overflow-y:auto;overflow-x:hidden}.shell-nav-v2::-webkit-scrollbar{width:0}.shell-nav-v2 .nav-phase{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);padding:14px 12px 6px}.shell-nav-v2 .nav-icon{display:flex;flex-direction:row;align-items:center;gap:10px;margin:1px 0;min-height:34px;padding:6px 10px;color:var(--text-2);text-decoration:none;border-radius:var(--r-sm);cursor:pointer;transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease);position:relative}.shell-nav-v2 .nav-icon:hover{background:var(--bg-2);color:var(--text-1)}.shell-nav-v2 .nav-icon.active{color:var(--text-1);background:var(--accent-soft);font-weight:600}.shell-nav-v2 .nav-icon.active:before{content:"";position:absolute;left:-2px;top:50%;transform:translateY(-50%);width:3px;height:16px;border-radius:var(--r-full);background:var(--accent)}.shell-nav-v2 .nav-step{font-size:11px;font-weight:500;line-height:1;color:var(--text-3);width:14px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}.shell-nav-v2 .nav-icon.active .nav-step{color:var(--accent);font-weight:700}.shell-nav-v2 .nav-glyph{display:none}.shell-nav-v2 .nav-label{flex:1;font-size:var(--fs-sm);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shell-nav-v2 .nav-sep{height:1px;background:var(--border-subtle);margin:10px 8px}.shell-main-v2{overflow:hidden;display:flex;min-width:0;min-height:0;background:var(--bg-0)}.shell-footer-v2{display:flex;align-items:center;padding:0 var(--sp-5);gap:var(--sp-4);background:var(--bg-1);border-top:1px solid var(--border-subtle);font-size:var(--fs-xs);color:var(--text-2);font-family:var(--mono)}.shell-footer-v2 span{display:inline-flex;align-items:center;gap:4px}.shell-footer-v2 b{color:var(--text-1);font-weight:600}.panel{background:var(--bg-1);border-right:1px solid var(--border-subtle);overflow:auto;padding:var(--sp-4);min-width:0}.panel-right{border-right:0;border-left:1px solid var(--border-subtle)}.panel h3{margin:0 0 var(--sp-3);font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.panel h4{margin:var(--sp-4) 0 var(--sp-2);font-size:var(--fs-sm);color:var(--text-1);font-weight:600}.panel h4:first-child{margin-top:0}.card{background:var(--bg-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:var(--sp-5)}.card.elevated{box-shadow:var(--shadow-md)}.card .card-header{display:flex;align-items:center;gap:var(--sp-2);margin:calc(-1 * var(--sp-5)) calc(-1 * var(--sp-5)) var(--sp-4);padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--border-subtle)}.card .card-header h3,.card .card-header h4{margin:0}.list-item{padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;gap:10px;margin-bottom:2px;border:1px solid transparent;transition:background var(--t-fast) var(--ease);min-width:0}.list-item:hover{background:var(--bg-2)}.list-item.active{background:var(--accent-soft);color:var(--text-1);position:relative}.list-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:var(--r-full);background:var(--accent)}.list-item.active .name{font-weight:600}.list-item .name{flex:1;font-size:var(--fs-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-1)}.list-item .meta{font-size:var(--fs-xs);color:var(--text-3);font-family:var(--mono);font-variant-numeric:tabular-nums;flex-shrink:0}.list-item .swatch{width:14px;height:14px;border-radius:3px;border:1px solid var(--border);flex-shrink:0}.canvas-host{flex:1;position:relative;overflow:hidden;background:var(--canvas-bg);min-width:0}canvas{display:block}.empty{text-align:center;padding:var(--sp-8) var(--sp-5);color:var(--text-3);font-size:var(--fs-sm)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--r-sm);font-size:10px;font-family:var(--mono);font-weight:600;letter-spacing:.03em;border:1px solid transparent}.badge.err{background:var(--err-soft);color:var(--err);border-color:#dc26264d}.badge.ok{background:var(--ok-soft);color:var(--ok);border-color:#16a34a4d}.badge.warn{background:var(--warn-soft);color:var(--warn);border-color:#d977064d}.badge.info{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-ring)}.badge.solid.err{background:var(--err);color:#fff}.badge.solid.ok{background:var(--ok);color:#fff}.badge.solid.warn{background:var(--warn);color:#fff}.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--r-full);background:var(--bg-2);border:1px solid var(--border);font-size:var(--fs-xs);color:var(--text-2)}.chip.active{background:var(--accent-soft);border-color:var(--accent-ring);color:var(--accent)}.kbd{display:inline-block;padding:1px 6px;border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border);border-bottom-width:2px;font-family:var(--mono);font-size:11px;color:var(--text-2)}.toolbar{display:flex;flex-wrap:wrap;gap:6px;padding:var(--sp-2) var(--sp-3);background:var(--bg-1);border-bottom:1px solid var(--border-subtle);align-items:center;min-height:44px}.toolbar button{padding:5px 11px;font-size:var(--fs-xs)}.toolbar .sep{width:1px;background:var(--border-subtle);align-self:stretch;margin:0 6px}.toolbar .title{font-weight:600;font-size:var(--fs-sm);color:var(--text-1);padding-right:6px}.segmented{display:inline-flex;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);padding:2px;gap:2px}.segmented button{background:transparent;border:0;padding:4px 10px;color:var(--text-2);font-size:var(--fs-xs);border-radius:var(--r-sm)}.segmented button.active,.segmented button[aria-pressed=true]{background:var(--bg-1);color:var(--text-1);box-shadow:var(--shadow-sm)}.icon-btn{width:30px;height:30px;padding:0!important;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1;background:transparent;border:1px solid transparent;color:var(--text-2);border-radius:var(--r-sm)}.icon-btn:hover:not(:disabled){background:var(--bg-2);color:var(--text-1);border-color:transparent}.btn-group{display:inline-flex;align-items:center;gap:2px;background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:var(--r-md);padding:2px}.btn-group .icon-btn{width:28px;height:28px}.cmd-search{display:flex!important;align-items:center;gap:8px;padding:5px 12px!important;font-size:var(--fs-xs)!important;color:var(--text-3);background:var(--bg-2)!important;border:1px solid var(--border-subtle)!important;border-radius:var(--r-md)!important;white-space:nowrap;min-width:220px}.cmd-search:hover{background:var(--bg-3)!important;color:var(--text-2)}.cmd-search kbd{margin-left:auto;font-size:10px;padding:1px 6px;border-radius:var(--r-sm);background:var(--bg-1);border:1px solid var(--border);color:var(--text-3)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0f1666;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .12s var(--ease)}.modal{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-6);min-width:420px;max-width:90vw;max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg);animation:popIn .18s var(--ease)}.modal h2{margin:0 0 var(--sp-4);font-size:var(--fs-xl)}.modal-actions{display:flex;gap:var(--sp-2);justify-content:flex-end;margin-top:var(--sp-5)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.97) translateY(4px)}to{opacity:1;transform:none}}@keyframes slideInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}@keyframes save-flash{0%{background:var(--ok-soft)}60%{background:#16a34a0a}to{background:transparent}}.save-just-completed{animation:save-flash .6s ease-out}[data-toast]{animation:slideInUp .18s var(--ease)}table{border-collapse:collapse;width:100%;font-size:var(--fs-sm)}th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border-subtle)}th{color:var(--text-3);font-weight:600;font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-0)}tr:hover td{background:var(--bg-2)}.progress{height:6px;background:var(--bg-2);border-radius:var(--r-full);overflow:hidden}.progress>div{height:100%;background:var(--accent);transition:width var(--t-med) var(--ease)}input[type=range]{-webkit-appearance:none;width:100%;height:24px;background:transparent}input[type=range]::-webkit-slider-runnable-track{height:4px;background:var(--bg-3);border-radius:var(--r-full)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-1);margin-top:-6px;cursor:pointer;transition:transform var(--t-fast) var(--ease);box-shadow:var(--shadow-sm)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}details>summary{cursor:pointer;padding:8px 10px;border-radius:var(--r-sm);list-style:none;display:flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none;transition:background var(--t-fast)}details>summary::-webkit-details-marker{display:none}details>summary:before{content:"›";display:inline-block;font-family:var(--mono);color:var(--text-3);transition:transform var(--t-fast) var(--ease)}details[open]>summary:before{transform:rotate(90deg)}details>summary:hover{background:var(--bg-2)}:focus-visible{outline:none}a:focus-visible{box-shadow:var(--shadow-focus);border-radius:var(--r-sm)}.text-muted{color:var(--text-2)}.text-subtle{color:var(--text-3)}.text-mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.text-center{text-align:center}.nowrap{white-space:nowrap}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.mt-1{margin-top:var(--sp-1)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mb-1{margin-bottom:var(--sp-1)}.mb-2{margin-bottom:var(--sp-2)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.p-2{padding:var(--sp-2)}.p-3{padding:var(--sp-3)}.p-4{padding:var(--sp-4)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1 1 0;min-width:0}.hidden{display:none!important}.page-head{display:flex;align-items:baseline;gap:var(--sp-3);padding-bottom:var(--sp-3);margin-bottom:var(--sp-4);border-bottom:1px solid var(--border-subtle)}.page-head .page-title{font-size:var(--fs-xl);font-weight:600;margin:0;letter-spacing:-.01em}.page-head .page-subtitle{color:var(--text-3);font-size:var(--fs-sm)}.page-head .spacer{flex:1}.dots:after{content:"";display:inline-block;width:1em;animation:dots 1.4s infinite step-end}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.pulse{animation:pulse 2s infinite ease-in-out}.list-item:focus-visible{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(700px 400px at 25% 0%,rgba(91,91,214,.06),transparent 70%),radial-gradient(600px 380px at 90% 100%,rgba(91,91,214,.05),transparent 70%),var(--bg-0);padding:var(--sp-5);z-index:100}.login-card{width:100%;max-width:380px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:36px 32px;box-shadow:var(--shadow-lg)}.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:28px}.login-brand .mark{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:var(--r-md);font-size:16px;font-weight:700}.login-brand .word{font-size:var(--fs-md);font-weight:600;letter-spacing:-.01em}.login-title{font-size:var(--fs-xl);font-weight:600;margin:0 0 6px;letter-spacing:-.015em}.login-subtitle{font-size:var(--fs-sm);color:var(--text-3);margin:0 0 24px}.login-form{display:flex;flex-direction:column;gap:14px}.login-form label{margin-bottom:4px}.login-error{font-size:var(--fs-xs);color:var(--err);background:var(--err-soft);border:1px solid rgba(220,38,38,.2);border-radius:var(--r-sm);padding:8px 10px;margin-top:2px}.login-hint{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle);font-size:var(--fs-xs);color:var(--text-3);line-height:1.6}.login-hint code{font-size:11px}.user-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 8px 4px 4px;border-radius:var(--r-full);background:var(--bg-2);border:1px solid var(--border-subtle);font-size:var(--fs-xs);color:var(--text-2);cursor:pointer;transition:background var(--t-fast) var(--ease)}.user-chip:hover{background:var(--bg-3)}.user-chip .avatar{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.user-chip .role{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}
