:root{--font-display:"Cormorant",Georgia,serif;--font-ui:"Syne",sans-serif;--font-mono:"JetBrains Mono",monospace;--text-xs:12px;--text-sm:14px;--text-base:16px;--text-md:18px;--text-lg:22px;--text-xl:30px;--text-2xl:36px;--text-3xl:48px;--text-4xl:64px;--text-5xl:88px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;--space-10:128px;--radius-sm:2px;--radius-md:4px;--radius-lg:8px;--radius-xl:12px;--radius-full:9999px;--leading-tight:1.1;--leading-snug:1.3;--leading-normal:1.5;--leading-relaxed:1.7;--tracking-wide:0.06em;--tracking-wider:0.12em;--duration-fast:100ms;--duration-base:150ms;--duration-slow:250ms;--duration-slower:400ms;--ease-default:cubic-bezier(0.16,1,0.3,1);--ease-in:cubic-bezier(0.4,0,1,1);--ease-out:cubic-bezier(0,0,0.2,1);--ease-bounce:cubic-bezier(0.34,1.56,0.64,1);--shadow-xs:0 1px 2px rgba(0,0,0,0.08);--shadow-sm:0 1px 4px rgba(0,0,0,0.10),0 0 0 1px rgba(0,0,0,0.04);--shadow-md:0 4px 12px rgba(0,0,0,0.12),0 0 0 1px rgba(0,0,0,0.06);--shadow-lg:0 8px 24px rgba(0,0,0,0.16),0 0 0 1px rgba(0,0,0,0.06);--shadow-xl:0 16px 48px rgba(0,0,0,0.20),0 0 0 1px rgba(0,0,0,0.06);--shadow-focus:0 0 0 3px rgba(77,212,204,0.28);--z-base:0;--z-raised:10;--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-popover:500;--z-toast:600;--z-tooltip:700;--border-width-default:1px;--border-width-strong:2px;--tracking-tighter:-0.04em;--tracking-tight:-0.02em;--tracking-normal:0em;--tracking-wide:0.04em;--tracking-wider:0.08em;--tracking-widest:0.14em}[data-theme=dark]{--bg-base:#0A0A09;--bg-surface:#111110;--bg-elevated:#1A1A18;--bg-subtle:#222220;--bg-hover:#2A2A28;--border-faint:rgba(255,255,252,0.05);--border-default:rgba(255,255,252,0.08);--border-muted:rgba(255,255,252,0.13);--border-strong:rgba(255,255,252,0.22);--text-primary:#EDE9DF;--text-secondary:#7C7A72;--text-tertiary:#3A3A36;--text-disabled:#252522;--accent:#4DD4CC;--accent-muted:rgba(77,212,204,0.10);--accent-hover:#62DDD6;--error:#C45454;--error-muted:rgba(196,84,84,0.10);--success:#54946A;--success-muted:rgba(84,148,106,0.10);--warning:#B8882A;--warning-muted:rgba(184,136,42,0.10);--info:#5480B8;--info-muted:rgba(84,128,184,0.10)}[data-theme=light]{--bg-base:#F5F7FA;--bg-surface:#FFFFFF;--bg-elevated:#FFFFFF;--bg-subtle:#EAECF0;--bg-hover:#DEE1E7;--border-faint:rgba(13,15,18,0.05);--border-default:rgba(13,15,18,0.09);--border-muted:rgba(13,15,18,0.14);--border-strong:rgba(13,15,18,0.24);--text-primary:#0D0F12;--text-secondary:#5A5E66;--text-tertiary:#9BA0A9;--text-disabled:#C8CBD2;--accent:#0FA89F;--accent-muted:rgba(15,168,159,0.08);--accent-hover:#0B9890;--error:#C04040;--error-muted:rgba(192,64,64,0.08);--success:#3A7850;--success-muted:rgba(58,120,80,0.08);--warning:#9A7020;--warning-muted:rgba(154,112,32,0.08);--info:#3A60A0;--info-muted:rgba(58,96,160,0.08)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-ui);background:var(--bg-base);color:var(--text-primary);font-size:var(--text-base);line-height:var(--leading-normal);min-height:100vh;transition:background .25s ease,color .25s ease}::selection{background:var(--accent-muted)}.t-display-xl{font-size:var(--text-5xl)}.t-display-lg,.t-display-xl{font-family:var(--font-display);font-weight:300;line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.t-display-lg{font-size:var(--text-4xl)}.t-display-md{font-size:var(--text-3xl);font-weight:300}.t-display-md,.t-display-sm{font-family:var(--font-display);line-height:var(--leading-snug)}.t-display-sm{font-size:var(--text-2xl);font-weight:400}.t-heading{font-size:var(--text-xl)}.t-heading,.t-subheading{font-family:var(--font-ui);font-weight:500;line-height:var(--leading-snug)}.t-subheading{font-size:var(--text-lg)}.t-body{font-size:var(--text-base)}.t-body,.t-body-sm{font-family:var(--font-ui);font-weight:400;line-height:var(--leading-relaxed)}.t-body-sm{font-size:var(--text-sm)}.t-label{font-weight:600;letter-spacing:var(--tracking-wider);text-transform:uppercase}.t-caption,.t-label{font-family:var(--font-ui);font-size:var(--text-xs)}.t-caption{font-weight:400;line-height:var(--leading-normal)}.t-mono{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:400}.t-primary{color:var(--text-primary)}.t-secondary{color:var(--text-secondary)}.t-tertiary{color:var(--text-tertiary)}.t-accent{color:var(--accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.btn:focus-visible,.nav-link:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:var(--shadow-focus)}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:var(--shadow-focus)}::selection{background:rgba(77,212,204,.2);color:var(--text-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}@media print{.ds-nav,.theme-toggle{display:none!important}.ds-section{break-inside:avoid}body{background:white!important;color:black!important}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.ds-container{max-width:1280px;margin:0 auto;padding:0 var(--space-6)}.ds-header{padding:var(--space-8) 0 var(--space-7);border-bottom:1px solid var(--border-default);display:flex;align-items:flex-end;justify-content:space-between}.ds-nav{display:flex;align-items:center;flex-wrap:nowrap;gap:2px;padding:var(--space-2) 0;border-top:1px solid var(--border-faint);position:sticky;top:0;background:var(--bg-base);z-index:100;backdrop-filter:blur(8px)}.ds-nav,.ds-section{border-bottom:1px solid var(--border-faint)}.ds-section{padding-top:var(--space-10);padding-bottom:var(--space-9)}.ds-section:last-of-type{border-bottom:none}.section-number{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-tertiary);display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.section-number:before{content:"";width:20px;height:1px;background:var(--accent);display:block;opacity:.5}.section-title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:300;color:var(--text-primary);line-height:var(--leading-snug);letter-spacing:-.02em;margin-bottom:var(--space-3)}.section-desc{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:520px;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-faint)}.subsection-label{font-family:var(--font-mono);font-size:10px;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);margin-top:var(--space-7)}.subsection-label:after{content:"";flex:1;height:1px;background:var(--border-faint);max-width:100px}.subsection-label:first-of-type{margin-top:0}.specimen-grid{display:grid;grid-template-columns:150px 1fr}.specimen-label{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);letter-spacing:.04em;padding:var(--space-5) var(--space-4) var(--space-5) 0;border-right:1px solid var(--border-default);line-height:1.6}.specimen-value{padding:var(--space-4) 0 var(--space-4) var(--space-5);display:flex;align-items:center}.specimen-row{display:contents}.specimen-row:not(:last-child) .specimen-label,.specimen-row:not(:last-child) .specimen-value{border-bottom:1px solid var(--border-faint)}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:var(--space-3);margin-bottom:var(--space-7)}.color-swatch{display:flex;flex-direction:column;gap:var(--space-2)}.color-swatch-block{height:72px;border-radius:var(--radius-md);border:1px solid var(--border-default);transition:transform .15s ease}.color-swatch-block:hover{transform:scale(1.02)}.color-swatch-name{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:500;color:var(--text-secondary)}.color-swatch-var{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary)}.demo-row{gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-6)}.demo-row,.space-bar{display:flex;align-items:center}.space-bar{gap:var(--space-4);padding:var(--space-3) 0}.space-block{background:var(--accent-muted);border:1px solid var(--accent);height:8px;border-radius:1px;flex-shrink:0;opacity:.7}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-ui);font-weight:500;letter-spacing:.01em;cursor:pointer;transition:all var(--duration-base) var(--ease-out);border:none;outline:none;text-decoration:none;white-space:nowrap;user-select:none}.btn-sm{height:30px;padding:0 var(--space-3);font-size:var(--text-xs)}.btn-md,.btn-sm{border-radius:var(--radius-md)}.btn-md{height:36px;padding:0 var(--space-4);font-size:var(--text-sm)}.btn-lg{height:44px;padding:0 var(--space-5);border-radius:var(--radius-md);font-size:var(--text-base)}.btn-primary{background:var(--text-primary);color:var(--bg-base)}.btn-primary:hover{opacity:.88}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-muted)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-subtle);color:var(--text-primary)}.btn-accent{color:var(--accent);border:1px solid transparent}.btn-accent,.btn-accent:hover{background:var(--accent-muted)}.btn-accent:hover{border-color:var(--accent)}.btn-destructive{background:transparent;color:var(--error);border:1px solid var(--error-muted)}.btn-destructive:hover{background:var(--error-muted)}.btn:active{transform:scale(.97)}.btn-icon{width:36px;height:36px;padding:0;background:transparent;color:var(--text-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:16px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--duration-base) var(--ease-out);font-family:var(--font-ui);outline:none}.btn-icon:hover{background:var(--bg-subtle);border-color:var(--border-muted)}.btn-icon:hover,.input{color:var(--text-primary)}.input{display:block;width:100%;height:36px;padding:0 var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);outline:none;transition:border-color var(--duration-base) var(--ease-out),background .15s ease;appearance:none}.input::placeholder{color:var(--text-tertiary)}.input:hover{border-color:var(--border-muted)}.input:focus{border-color:var(--border-strong);background:var(--bg-elevated)}.input-sm{height:30px;font-size:var(--text-xs);padding:0 var(--space-2)}.input-lg{height:44px;font-size:var(--text-base);padding:0 var(--space-4)}textarea.input{height:auto;padding:var(--space-3);resize:vertical;line-height:var(--leading-relaxed)}select.input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--text-secondary)}.input-hint{font-size:var(--text-xs);color:var(--text-tertiary);line-height:var(--leading-normal)}.input.is-error{border-color:var(--error)}.input-hint.is-error{color:var(--error)}.input-addon-wrap{display:flex;align-items:stretch;border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-elevated);transition:border-color .15s}.input-addon-wrap:focus-within{border-color:var(--border-strong)}.input-addon{display:flex;align-items:center;padding:0 var(--space-3);background:var(--bg-subtle);border-right:1px solid var(--border-default);font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.input-addon-right{border-right:none;border-left:1px solid var(--border-default)}.input-addon-wrap .input{border:none;background:transparent;border-radius:0}.input-addon-wrap .input:focus{border:none}.input-with-icon{position:relative}.input-with-icon .fi{position:absolute;left:10px;top:50%;transform:translateY(-50%);pointer-events:none}.input-with-icon .input{padding-left:32px}.input-with-icon-right .fi{left:auto;right:10px}.input-with-icon-right .input{padding-right:32px}.search-field{display:flex;align-items:center;gap:var(--space-2);height:36px;padding:0 var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:border-color var(--duration-base) var(--ease-out)}.search-field:focus-within{border-color:var(--border-strong)}.search-field:hover{border-color:var(--border-muted)}.search-field input{flex:1;background:none;border:none;outline:none;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary)}.search-field input::placeholder{color:var(--text-tertiary)}.search-field-lg{height:44px;border-radius:var(--radius-lg);padding:0 var(--space-4);gap:var(--space-3)}.search-field-lg input{font-size:var(--text-base)}.card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--duration-base) var(--ease-out)}.card:hover{border-color:var(--border-muted)}.card-elevated{background:var(--bg-elevated)}.card-elevated,.card-ghost{border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5)}.card-ghost{background:transparent}.card-subtle{background:var(--bg-subtle);border:1px solid transparent;border-radius:var(--radius-lg);padding:var(--space-5)}.card-feature{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);transition:border-color var(--duration-base) var(--ease-out),background .15s ease}.card-feature:hover{border-color:var(--border-muted);background:var(--bg-elevated)}.card-feature-icon{width:40px;height:40px;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.card-feature-title{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.card-feature-desc{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.card-metric{background:var(--bg-subtle);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-1)}.card-metric-label{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.04em}.card-metric-value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);letter-spacing:-.02em;line-height:1.1}.card-metric-delta{font-family:var(--font-mono);font-size:var(--text-xs)}.card-metric-delta-up{color:var(--success)}.card-metric-delta-down{color:var(--error)}.card-metric-delta-flat{color:var(--text-tertiary)}.card-media{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out)}.card-media:hover{border-color:var(--border-muted)}.card-media-thumb{height:140px;background:var(--bg-subtle);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-default)}.card-media-body{padding:var(--space-4)}.card-media-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);margin-bottom:4px}.card-media-desc{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.card-media-footer{border-top:1px solid var(--border-faint);justify-content:space-between}.card-media-footer,.card-row{padding:var(--space-3) var(--space-4);display:flex;align-items:center}.card-row{gap:var(--space-3);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:border-color var(--duration-base) var(--ease-out),background .15s ease}.card-row:hover{border-color:var(--border-muted);background:var(--bg-elevated)}.card-row-body{flex:1;min-width:0}.card-row-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-row-sub{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.card-row-meta{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.expand-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:border-color .2s ease;cursor:pointer}.expand-card:hover{border-color:var(--border-muted)}.expand-card.is-open{border-color:var(--accent)}.expand-card-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);user-select:none}.expand-card-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);flex:1}.expand-card-meta{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono)}.expand-card-arrow{color:var(--text-tertiary);transition:transform .25s ease,color .15s ease;flex-shrink:0;display:flex;align-items:center}.expand-card.is-open .expand-card-arrow{transform:rotate(180deg);color:var(--accent)}.expand-card-body{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .25s ease;padding:0 var(--space-5);border-top:0 solid var(--border-default)}.expand-card.is-open .expand-card-body{max-height:600px;padding:var(--space-4) var(--space-5);border-top-width:1px}.expand-card-content{display:flex;flex-direction:column;gap:var(--space-3)}.empty-icon{width:48px;height:48px;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-2)}.empty-title{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.empty-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:280px}.toast-title{margin-bottom:2px}.badge{display:inline-flex;align-items:center;gap:var(--space-1);font-family:var(--font-ui);font-size:var(--text-xs);font-weight:500;letter-spacing:.03em;padding:3px var(--space-2);border-radius:var(--radius-sm);white-space:nowrap}.badge-default{background:var(--bg-subtle);color:var(--text-secondary)}.badge-accent{background:var(--accent-muted);color:var(--accent)}.badge-error{background:var(--error-muted);color:var(--error)}.badge-success{background:var(--success-muted);color:var(--success)}.badge-warning{background:var(--warning-muted);color:var(--warning)}.badge-info{background:var(--info-muted);color:var(--info)}.badge-outline{background:transparent;border:1px solid var(--border-muted)}.badge-outline,.tag{color:var(--text-secondary)}.tag{display:inline-flex;align-items:center;font-family:var(--font-ui);font-size:var(--text-xs);font-weight:400;padding:var(--space-1) var(--space-3);background:var(--bg-subtle);border-radius:var(--radius-full);border:1px solid var(--border-default);cursor:pointer;transition:all var(--duration-base) var(--ease-out);user-select:none}.tag:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-muted)}.tag.is-active{background:var(--text-primary);color:var(--bg-base);border-color:transparent}.chip{gap:var(--space-1);font-family:var(--font-ui);font-size:var(--text-xs);font-weight:400;padding:3px var(--space-2) 3px var(--space-3);background:var(--bg-subtle);color:var(--text-secondary);border:1px solid var(--border-default);border-radius:var(--radius-full)}.chip,.chip-remove{display:inline-flex;align-items:center}.chip-remove{width:14px;height:14px;border-radius:50%;justify-content:center;background:var(--bg-hover);color:var(--text-tertiary);cursor:pointer;border:none;outline:none;font-size:9px;line-height:1;transition:all var(--duration-fast) var(--ease-out)}.chip-remove:hover{background:var(--error-muted);color:var(--error)}.plan-badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;font-weight:500;padding:3px var(--space-3);border-radius:var(--radius-full);border:1px solid transparent}.pb-free{background:var(--bg-subtle);color:var(--text-tertiary);border-color:var(--border-default)}.pb-starter{background:var(--info-muted);color:var(--info)}.pb-pro{background:var(--accent-muted);color:var(--accent)}.pb-team{background:var(--warning-muted);color:var(--warning)}.pb-enterprise{background:var(--bg-subtle);color:var(--text-primary);border-color:var(--border-muted)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);border:1px solid;position:relative;overflow:hidden}.alert:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.alert-info{background:var(--info-muted);border-color:rgba(84,128,184,.2)}.alert-info:before{background:var(--info)}.alert-success{background:var(--success-muted);border-color:rgba(84,148,106,.2)}.alert-success:before{background:var(--success)}.alert-warning{background:var(--warning-muted);border-color:rgba(184,136,42,.2)}.alert-warning:before{background:var(--warning)}.alert-error{background:var(--error-muted);border-color:rgba(196,84,84,.2)}.alert-error:before{background:var(--error)}.alert-accent{background:var(--accent-muted);border-color:rgba(77,212,204,.2)}.alert-accent:before{background:var(--accent)}.alert-neutral{background:var(--bg-surface);border-color:var(--border-muted)}.alert-neutral:before{background:var(--text-tertiary)}.alert-icon{flex-shrink:0;margin-top:1px}.alert-body{flex:1;min-width:0}.alert-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);margin-bottom:3px}.alert-msg{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.alert-actions{gap:var(--space-2);margin-top:var(--space-3)}.alert-actions,.alert-close{display:flex;align-items:center}.alert-close{position:absolute;top:var(--space-3);right:var(--space-3);background:none;border:none;cursor:pointer;outline:none;color:var(--text-tertiary);padding:2px;border-radius:var(--radius-sm);transition:color .12s;line-height:1}.alert-close:hover{color:var(--text-secondary)}.alert-inline{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;border:1px solid transparent}.callout{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid}.callout-info{background:var(--info-muted);border-color:rgba(84,128,184,.25)}.callout-success{background:var(--success-muted);border-color:rgba(84,148,106,.25)}.callout-warning{background:var(--warning-muted);border-color:rgba(184,136,42,.25)}.callout-error{background:var(--error-muted);border-color:rgba(196,84,84,.25)}.callout-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);margin-bottom:2px}.callout-body{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.snackbar-demo{position:relative;min-height:140px;background:var(--bg-subtle);border-radius:var(--radius-lg);display:flex;align-items:flex-end;justify-content:center;padding:var(--space-4);overflow:hidden}.snackbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-primary);max-width:360px;width:100%}.snackbar-success{border-color:var(--success);background:var(--success-muted)}.snackbar-error{border-color:var(--error);background:var(--error-muted)}.snackbar-accent{border-color:var(--accent);background:var(--accent-muted)}.snackbar-action{margin-left:auto;flex-shrink:0;font-size:var(--text-xs);font-weight:500;color:var(--accent);cursor:pointer;background:none;border:none;outline:none;padding:0;font-family:var(--font-ui);transition:opacity .12s}.snackbar-action:hover{opacity:.75}.notif-stack{display:flex;flex-direction:column;gap:var(--space-2);max-width:380px}.notif{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--duration-base) var(--ease-out),background .15s ease;position:relative}.notif:hover{border-color:var(--border-strong);background:var(--bg-hover)}.notif-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px;background:var(--text-disabled)}.notif-dot.unread{background:var(--accent)}.notif-body{flex:1;min-width:0}.notif-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.notif-msg{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-top:2px}.notif-time{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);white-space:nowrap;margin-top:3px}.notif-icon-wrap{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.overlay-backdrop{background:rgba(0,0,0,.42);border-radius:var(--radius-lg);position:relative;overflow:hidden;min-height:280px;display:flex;align-items:stretch}.drawer{position:absolute;top:0;right:0;height:100%;width:280px;background:var(--bg-elevated);border-left:1px solid var(--border-muted);display:flex;flex-direction:column;z-index:10}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default)}.drawer-title{font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.drawer-body{flex:1;padding:var(--space-5);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-4)}.drawer-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-default);display:flex;gap:var(--space-2)}.bottom-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--bg-elevated);border-top:1px solid var(--border-muted);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-5);z-index:10}.bottom-sheet-handle{width:36px;height:4px;background:var(--border-strong);border-radius:var(--radius-full);margin:0 auto var(--space-4)}.alert-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-xl);padding:var(--space-6);width:320px;z-index:10;display:flex;flex-direction:column;gap:var(--space-3)}.alert-dialog-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-1)}.alert-dialog-title{font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.alert-dialog-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.alert-dialog-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.modal-wrap{background:rgba(0,0,0,.4);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;padding:var(--space-6);min-height:280px}.modal{background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-xl);width:100%;max-width:400px;overflow:hidden}.modal-hd{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default)}.modal-title{font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.modal-bd{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.modal-ft{padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-default);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2)}.popover-wrap{position:relative;display:inline-block}.popover-box{border:1px solid var(--border-muted);border-radius:var(--radius-lg);padding:var(--space-4);min-width:220px;z-index:20;filter:drop-shadow(0 4px 16px rgba(0,0,0,.18))}.popover-box,.popover-box:before{position:absolute;background:var(--bg-elevated)}.popover-box:before{content:"";width:8px;height:8px;border:1px solid var(--border-muted);transform:rotate(45deg)}.popover-top{bottom:calc(100% + 10px);left:50%;transform:translateX(-50%)}.popover-top:before{bottom:-5px;left:50%;transform:translateX(-50%) rotate(45deg);border-top:none;border-left:none}.popover-bottom{top:calc(100% + 10px);left:50%;transform:translateX(-50%)}.popover-bottom:before{top:-5px;left:50%;transform:translateX(-50%) rotate(45deg);border-bottom:none;border-right:none}.popover-right{left:calc(100% + 10px);top:50%;transform:translateY(-50%)}.popover-right:before{left:-5px;top:50%;transform:translateY(-50%) rotate(45deg);border-right:none;border-top:none}.popover-left{right:calc(100% + 10px);top:50%;transform:translateY(-50%)}.popover-left:before{right:-5px;top:50%;transform:translateY(-50%) rotate(45deg);border-left:none;border-bottom:none}.popover-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);margin-bottom:var(--space-2)}.popover-body,.rtip{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.rtip{display:inline-block;background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);max-width:240px}.rtip-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2)}.rtip-dark{background:var(--text-primary);border-color:transparent;color:var(--bg-surface)}.rtip-dark .rtip-title{color:var(--bg-base)}.menu{position:relative;display:inline-block}.menu-content{position:absolute;top:calc(100% + 6px);left:0;min-width:200px;background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-lg);padding:var(--space-1) 0;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.18)}.menu-content.align-right{left:auto;right:0}.menu-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:background .1s ease,color .1s ease;user-select:none;white-space:nowrap;border:none;background:none;width:100%;text-align:left;outline:none}.menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.menu-item.is-active{color:var(--text-primary);background:var(--accent-muted)}.menu-item.is-danger{color:var(--error)}.menu-item.is-danger:hover{background:var(--error-muted);color:var(--error)}.menu-item.is-disabled{color:var(--text-disabled);cursor:not-allowed;pointer-events:none}.menu-item .fi{flex-shrink:0}.menu-item-suffix{margin-left:auto;font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);padding-left:var(--space-4)}.menu-separator{height:1px;background:var(--border-default);margin:var(--space-1) 0}.menu-label{padding:var(--space-2) var(--space-4) var(--space-1);font-family:var(--font-ui);font-size:10px;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.context-menu{display:inline-block;background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-lg);padding:var(--space-1) 0;min-width:180px}.command-palette{background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-xl);overflow:hidden;max-width:480px}.command-input-wrap{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-default)}.command-input{flex:1;background:none;border:none;outline:none;font-family:var(--font-ui);font-size:var(--text-base);color:var(--text-primary)}.command-input::placeholder{color:var(--text-tertiary)}.command-results{padding:var(--space-1) 0;max-height:280px;overflow-y:auto}.command-group-label{padding:var(--space-2) var(--space-4) var(--space-1);font-size:10px;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);font-family:var(--font-ui)}.command-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:background .1s}.command-item.is-focused,.command-item:hover{background:var(--bg-hover);color:var(--text-primary)}.command-item-icon{width:28px;height:28px;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.command-item-desc{font-size:var(--text-xs);color:var(--text-tertiary);margin-left:2px}.command-footer{padding:var(--space-2) var(--space-4);border-top:1px solid var(--border-default);display:flex;align-items:center;gap:var(--space-3)}.tabs{display:flex;flex-direction:column}.tab-list{display:flex;align-items:flex-end;gap:0;border-bottom:1px solid var(--border-default);overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.tab-list::-webkit-scrollbar{display:none}.tab-item{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:400;color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:none;outline:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--duration-base) var(--ease-out),border-color .15s ease;user-select:none}.tab-item.is-active,.tab-item:hover{color:var(--text-primary)}.tab-item.is-active{border-bottom-color:var(--text-primary);font-weight:500}.tab-item .fi{opacity:.6}.tab-item.is-active .fi{opacity:1}.tab-list-pill{gap:var(--space-1);background:var(--bg-subtle);border:1px solid var(--border-faint);border-radius:var(--radius-xl);padding:3px}.tab-item-pill,.tab-list-pill{display:inline-flex;align-items:center}.tab-item-pill{gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:400;color:var(--text-secondary);cursor:pointer;white-space:nowrap;border:none;background:none;outline:none;border-radius:calc(var(--radius-xl) - 2px);transition:all var(--duration-base) var(--ease-out);user-select:none}.tab-item-pill.is-active,.tab-item-pill:hover{color:var(--text-primary)}.tab-item-pill.is-active{background:var(--bg-elevated);font-weight:500;border:1px solid var(--border-muted)}.tab-list-underline{display:flex;align-items:center;gap:var(--space-5);border-bottom:1px solid var(--border-faint)}.tab-item-underline{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-tertiary);cursor:pointer;background:none;outline:none;border:none;border-bottom:1px solid transparent;margin-bottom:-1px;transition:color var(--duration-base) var(--ease-out),border-color .15s ease}.tab-item-underline:hover{color:var(--text-secondary)}.tab-item-underline.is-active{color:var(--text-primary);border-bottom-color:var(--accent)}.tab-panel{padding:var(--space-5) 0}.navbar{display:flex;align-items:center;height:52px;padding:0 var(--space-5);background:var(--bg-surface);border-bottom:1px solid var(--border-default);gap:var(--space-4)}.navbar-brand{font-family:var(--font-display);font-size:20px;font-weight:300;color:var(--text-primary);letter-spacing:-.01em;text-decoration:none;white-space:nowrap}.navbar-nav{display:flex;align-items:center;gap:var(--space-1)}.navbar-link{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;border:none;background:none;outline:none;font-family:var(--font-ui)}.navbar-link:hover{color:var(--text-primary);background:var(--bg-subtle)}.navbar-link.is-active{color:var(--text-primary);background:var(--bg-hover)}.navbar-spacer{flex:1}.breadcrumb,.navbar-actions{display:flex;align-items:center;gap:var(--space-2)}.breadcrumb{flex-wrap:wrap}.breadcrumb-item{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast) var(--ease-out);border:none;background:none;outline:none;padding:0;font-family:var(--font-ui)}.breadcrumb-item:hover{color:var(--text-primary)}.breadcrumb-item.is-current{color:var(--text-primary);cursor:default;font-weight:500}.breadcrumb-item.is-current:hover{color:var(--text-primary)}.breadcrumb-sep{color:var(--text-tertiary);font-size:12px;user-select:none}.step-nav{gap:0;overflow-x:auto}.step-nav,.step-nav-item{display:flex;align-items:center}.step-nav-item{flex:1;min-width:0}.step-nav-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;flex-shrink:0;background:var(--bg-subtle);border:1.5px solid var(--border-muted);color:var(--text-tertiary);transition:all .15s;z-index:1;position:relative}.step-nav-dot.done{background:var(--success-muted);border-color:var(--success);color:var(--success)}.step-nav-dot.active{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.step-nav-label{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:4px;white-space:nowrap;font-family:var(--font-ui)}.step-nav-label.done{color:var(--success)}.step-nav-label.active{color:var(--text-primary);font-weight:500}.step-nav-line{flex:1;height:1.5px;background:var(--border-default);margin:0 -1px;position:relative;top:-10px}.step-nav-line.done{background:var(--success)}.step-nav-item-inner{align-items:center;gap:4px}.nav-tabs-v,.step-nav-item-inner{display:flex;flex-direction:column}.nav-tabs-v{gap:2px;width:180px;border-right:1px solid var(--border-default);padding-right:var(--space-3)}.nav-tab-v{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .12s;border:none;background:none;outline:none;width:100%;text-align:left}.nav-tab-v:hover{background:var(--bg-subtle);color:var(--text-primary)}.nav-tab-v.is-active{background:var(--bg-hover);color:var(--text-primary);font-weight:500}.nav-tab-v.is-active .fi{color:var(--accent)}.nav-tab-v .nav-badge{margin-left:auto;font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary);background:var(--bg-subtle);padding:1px 5px;border-radius:var(--radius-full)}.pagination{display:flex;align-items:center;gap:var(--space-1)}.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 var(--space-2);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);background:transparent;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);user-select:none;outline:none}.page-btn:hover{background:var(--bg-subtle);color:var(--text-primary);border-color:var(--border-default)}.page-btn.is-active{background:var(--text-primary);color:var(--bg-base);border-color:transparent;font-weight:500}.page-btn.is-disabled{color:var(--text-disabled);pointer-events:none}.page-ellipsis{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--text-tertiary);font-size:var(--text-sm);user-select:none}.sidebar{width:220px;background:var(--bg-surface);border-right:1px solid var(--border-default);display:flex;flex-direction:column;padding:var(--space-3) 0;height:320px}.sidebar-header{padding:var(--space-2) var(--space-4) var(--space-3);font-family:var(--font-mono);font-size:10px;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);border-bottom:1px solid var(--border-faint);margin-bottom:var(--space-1)}.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;background:none;outline:none;width:100%;text-align:left;border-radius:0}.sidebar-item:hover{color:var(--text-primary);background:var(--bg-subtle)}.sidebar-item.is-active{color:var(--text-primary);background:var(--bg-hover);font-weight:500}.sidebar-item.is-active .fi{color:var(--accent)}.sidebar-item .sidebar-count{margin-left:auto;font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);background:var(--bg-hover);padding:1px 6px;border-radius:var(--radius-full)}.sidebar-section-label{padding:var(--space-4) var(--space-4) var(--space-1);font-family:var(--font-ui);font-size:10px;font-weight:600;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--text-tertiary)}.theme-toggle{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);transition:all var(--duration-base) var(--ease-out);outline:none}.theme-toggle:hover{color:var(--text-primary);border-color:var(--border-muted)}.nav-link{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);text-decoration:none;white-space:nowrap;transition:color var(--duration-fast) var(--ease-out),background .12s ease;cursor:pointer;background:none;border:none;outline:none;padding:5px var(--space-2);border-radius:var(--radius-sm)}.nav-link:hover{color:var(--text-secondary);background:var(--bg-subtle)}.nav-link.is-active{color:var(--text-primary);background:var(--bg-surface);font-weight:500}.nav-sep{font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--border-strong);padding:0 var(--space-2);white-space:nowrap;user-select:none;flex-shrink:0}.nav-sep:before{content:"\00B7";margin-right:6px;color:var(--border-muted)}.prop-strip{display:flex;align-items:stretch;gap:1px;background:var(--border-faint);border-top:1px solid var(--border-faint);border-bottom:1px solid var(--border-faint);overflow:hidden}.prop-item{flex:1;background:var(--bg-base);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);transition:background .15s ease}.prop-item:hover{background:var(--bg-surface)}.prop-item-word{font-family:var(--font-display);font-size:var(--text-xl);font-weight:300;color:var(--text-primary);letter-spacing:-.01em;line-height:1}.prop-item-word em{font-style:italic;color:var(--accent)}.prop-item-def{font-family:var(--font-ui);font-size:11px;color:var(--text-tertiary);line-height:var(--leading-relaxed);max-width:200px}.section-rule{height:1px;background:var(--border-faint);margin:0}.section-rule-accent{background:var(--accent);opacity:.3}.hero-eyebrow{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:var(--space-3)}.hero-eyebrow:before{content:"";width:24px;height:1px;background:var(--accent);display:block}.hero-headline{font-family:var(--font-display);font-size:76px;font-weight:300;line-height:.92;letter-spacing:-.04em;color:var(--text-primary);margin:var(--space-5) 0 var(--space-4)}.hero-sub{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:360px}.hero-meta{display:flex;align-items:center;gap:var(--space-5);margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border-faint)}.hero-meta-item{display:flex;flex-direction:column;gap:3px}.hero-meta-num{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);line-height:1;letter-spacing:-.02em}.hero-meta-label{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);letter-spacing:.06em}.hero-meta-sep{width:1px;height:32px;background:var(--border-default);align-self:center}.compare-table{width:100%;border-collapse:collapse}.compare-table .compare-header{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-default);text-align:left}.compare-table .compare-header:not(:first-child){text-align:right}.compare-table td{font-size:var(--text-sm);padding:var(--space-3);border-bottom:1px solid var(--border-faint);color:var(--text-primary);line-height:var(--leading-normal)}.compare-table td:not(:first-child){text-align:right;color:var(--text-secondary)}.compare-table td:first-child{color:var(--text-secondary);font-size:var(--text-xs);letter-spacing:.03em}.compare-table tr:last-child td{border-bottom:none}.compare-table tr:hover td{background:var(--bg-subtle)}.compare-highlight{color:var(--accent)!important;font-weight:500}.data-table{width:100%;border-collapse:collapse;font-family:var(--font-ui)}.data-table thead th{padding:var(--space-2) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);border-bottom:1px solid var(--border-default);white-space:nowrap;cursor:pointer;user-select:none}.data-table thead th:hover{color:var(--text-secondary)}.data-table tbody td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);border-bottom:1px solid var(--border-faint);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .1s ease}.data-table tbody tr:hover td{background:var(--bg-subtle)}.data-table tbody tr.is-selected td{background:var(--accent-muted)}.data-table-wrap{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.data-table-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default);gap:var(--space-3)}.data-table-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.data-table-actions{display:flex;align-items:center;gap:var(--space-2)}.dt-toolbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default);flex-wrap:wrap}.dt-toolbar-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);margin-right:auto}.dt-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-default);font-size:var(--text-xs);color:var(--text-secondary);font-family:var(--font-ui)}.dt-row-selected td{background:var(--accent-muted)!important}.dt-sort-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);padding:0;outline:none;transition:color .12s}.dt-sort-btn:hover{color:var(--text-secondary)}.dt-sort-btn.is-sorted{color:var(--text-primary)}.dt-checkbox{width:14px;height:14px;border:1.5px solid var(--border-muted);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}.dt-checkbox.is-checked{background:var(--accent);border-color:var(--accent)}.fct-wrap{border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto}.fct{width:100%;border-collapse:collapse;font-family:var(--font-ui);min-width:500px}.fct thead th{padding:var(--space-4) var(--space-4) var(--space-3);background:var(--bg-surface);border-bottom:1px solid var(--border-default);text-align:center;white-space:nowrap;vertical-align:bottom}.fct thead th:first-child{text-align:left;min-width:160px;background:var(--bg-subtle)}.fct-plan-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);display:block}.fct-plan-name.is-accent{color:var(--accent)}.fct-plan-cta{display:inline-flex;align-items:center;gap:4px;margin-top:var(--space-2);font-size:11px;color:var(--text-tertiary);background:none;border:1px solid var(--border-default);border-radius:var(--radius-full);padding:2px var(--space-3);cursor:pointer;outline:none;transition:all .12s;white-space:nowrap;font-family:var(--font-ui)}.fct-plan-cta:hover{color:var(--text-primary);border-color:var(--border-muted)}.fct-plan-cta.is-accent{background:var(--accent);border-color:transparent;color:var(--bg-base)}.fct-plan-cta.is-accent:hover{background:var(--accent-hover)}.fct-col-accent{border-left:1px solid var(--accent);border-right:1px solid var(--accent);background:rgba(77,212,204,.035)!important}.fct thead th.fct-col-accent{border-top:2px solid var(--accent)}[data-theme=light] .fct-col-accent{background:rgba(15,168,159,.04)!important}.fct-col-accent .fct-check{color:var(--accent)}.fct-col-accent .fct-val{color:var(--text-primary)!important}.fct-col-accent .fct-dash{color:var(--text-disabled)}.fct-section td{background:var(--bg-subtle);font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:400;padding:var(--space-2) var(--space-5);text-align:left;border-top:1px solid var(--border-default)}.fct-row td,.fct-section td{color:var(--text-secondary);border-bottom:1px solid var(--border-faint)}.fct-row td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);text-align:center;vertical-align:middle;line-height:var(--leading-normal)}.fct-row td:first-child{text-align:left;color:var(--text-primary);font-size:var(--text-sm);padding-left:var(--space-5)}.fct-row:last-child td{border-bottom:none}.fct-row:hover td{background:var(--bg-subtle)}.fct-row td.fct-col-accent{background:rgba(77,212,204,.04)}[data-theme=light] .fct-row td.fct-col-accent{background:rgba(15,168,159,.03)}.fct-row:hover td.fct-col-accent{background:rgba(77,212,204,.065)!important}.fct-check{color:var(--accent)}.fct-dash{color:var(--border-strong)}.fct-val{font-family:var(--font-mono);font-size:11px}.fct-pill,.fct-val{color:var(--text-secondary)}.fct-pill{display:inline-block;font-size:10px;font-weight:500;padding:2px 7px;border-radius:var(--radius-full);background:var(--bg-hover);font-family:var(--font-ui);border:1px solid var(--border-faint);white-space:nowrap}.fct-pill-accent{background:var(--accent-muted);color:var(--accent);border-color:transparent}.fct-pill-muted{color:var(--text-tertiary);background:transparent;border-color:var(--border-default)}.fct-pill-soon{padding:2px 7px;border-radius:var(--radius-full);background:var(--warning-muted);color:var(--warning);border:1px solid transparent}.fct-pill-soon,.fct-pill-special{display:inline-block;font-size:10px;font-family:var(--font-ui);font-weight:500;white-space:nowrap}.fct-pill-special{padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-muted)}.fct td,.fct th{text-align:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-faint);font-size:var(--text-sm)}.fct td:first-child{text-align:left;color:var(--text-primary);font-size:var(--text-sm);padding-left:var(--space-5)}.progress-group{gap:var(--space-3)}.progress-group,.progress-item{display:flex;flex-direction:column}.progress-item{gap:var(--space-1)}.progress-top{display:flex;align-items:center;justify-content:space-between}.progress-label{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);letter-spacing:.02em}.progress-value{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary)}.progress-track{height:3px;background:var(--bg-hover);overflow:hidden}.progress-fill,.progress-track{border-radius:var(--radius-full)}.progress-fill{height:100%;background:var(--text-secondary);transition:width .4s ease}.progress-fill-accent{background:var(--accent)}.progress-fill-info{background:var(--info)}.progress-fill-success{background:var(--success)}.progress-fill-warning{background:var(--warning)}.progress-fill-error{background:var(--error)}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;display:inline-block}.status-dot-active{background:var(--success);box-shadow:0 0 0 2px var(--success-muted)}.status-dot-pending{background:var(--warning)}.status-dot-idle{background:var(--text-tertiary)}.status-dot-error{background:var(--error)}.status-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary)}.spinner{display:inline-block;border-radius:50%;border:2px solid var(--bg-hover);border-top-color:var(--text-secondary);animation:spin .7s linear infinite;flex-shrink:0}.spinner-xs{width:12px;height:12px;border-width:1.5px}.spinner-sm{width:16px;height:16px}.spinner-md{width:22px;height:22px}.spinner-lg{width:32px;height:32px;border-width:3px}.spinner-xl{width:44px;height:44px;border-width:3px}.spinner-accent{border-top-color:var(--accent);border-color:var(--accent-muted)}.spinner-primary{border-top-color:var(--text-primary)}.spinner-success{border-top-color:var(--success);border-color:var(--success-muted)}.spinner-error{border-top-color:var(--error);border-color:var(--error-muted)}.skel-shimmer{background:linear-gradient(90deg,var(--bg-hover) 25%,var(--bg-subtle) 50%,var(--bg-hover) 75%);background-size:800px 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:var(--radius-md)}.loading-screen{background:var(--bg-base);gap:var(--space-4);padding:var(--space-9)}.loading-screen,.success-screen{border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.success-screen{background:var(--bg-surface);gap:var(--space-3);padding:var(--space-7)}.success-icon-wrap{width:56px;height:56px;border-radius:50%;background:var(--success-muted);border:1px solid var(--success);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-1)}.form-section{display:flex;flex-direction:column;gap:var(--space-5)}.form-row{display:grid;gap:var(--space-4)}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}.field-wrap{display:flex;flex-direction:column;gap:var(--space-2)}.field-label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--text-secondary)}.field-desc{font-size:var(--text-xs);color:var(--text-tertiary);line-height:var(--leading-normal)}.field-char-count{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);text-align:right}.field-char-warn{color:var(--warning)}.form-sep{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);letter-spacing:.06em;text-transform:uppercase}.form-sep:after,.form-sep:before{content:"";flex:1;height:1px;background:var(--border-default)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-family:var(--font-ui);font-weight:500;letter-spacing:.01em;flex-shrink:0;background:var(--bg-subtle);color:var(--text-secondary);border:1px solid var(--border-default);overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.avatar-xs{width:20px;height:20px;font-size:8px}.avatar-sm{width:28px;height:28px;font-size:10px}.avatar-md{width:36px;height:36px;font-size:13px}.avatar-lg{width:48px;height:48px;font-size:16px}.avatar-xl{width:64px;height:64px;font-size:20px}.avatar-accent{background:var(--accent-muted);color:var(--accent);border-color:transparent}.avatar-info{background:var(--info-muted);color:var(--info);border-color:transparent}.avatar-success{background:var(--success-muted);color:var(--success);border-color:transparent}.avatar-warning{background:var(--warning-muted);color:var(--warning);border-color:transparent}.avatar-group{display:flex;align-items:center}.avatar-group .avatar{margin-left:-8px;border:2px solid var(--bg-base)}.avatar-group .avatar:first-child{margin-left:0}.picon{display:inline-block;flex-shrink:0;overflow:hidden;background:var(--bg-subtle);border:1px solid var(--border-default)}.picon img{width:100%;height:100%;object-fit:cover;display:block}.picon-xs{width:24px;height:24px;border-radius:6px}.picon-sm{width:32px;height:32px;border-radius:8px}.picon-md{width:40px;height:40px;border-radius:9px}.picon-lg{width:52px;height:52px;border-radius:11px}.picon-xl{width:68px;height:68px;border-radius:14px}.picon-2xl{width:88px;height:88px;border-radius:18px}.picon-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-weight:500;color:var(--text-secondary);background:var(--bg-subtle)}.picon-xs .picon-placeholder{font-size:9px}.picon-sm .picon-placeholder{font-size:11px}.picon-md .picon-placeholder{font-size:13px}.picon-lg .picon-placeholder{font-size:16px}.picon-xl .picon-placeholder{font-size:20px}.picon-2xl .picon-placeholder{font-size:26px}.prof-card{display:inline-flex;align-items:center;gap:var(--space-3);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:border-color var(--duration-base) var(--ease-out),background .15s ease;cursor:pointer}.prof-card:hover{border-color:var(--border-muted);background:var(--bg-elevated)}.prof-sm{padding:var(--space-2) var(--space-3);gap:var(--space-2)}.prof-md{padding:var(--space-3) var(--space-4);gap:var(--space-3)}.prof-lg{padding:var(--space-4) var(--space-5);gap:var(--space-4)}.prof-classic{background:var(--bg-elevated);border-color:var(--border-muted)}.prof-ghost{background:transparent;border-color:transparent}.prof-ghost:hover{background:var(--bg-subtle);border-color:var(--border-default)}.prof-name{font-weight:500;color:var(--text-primary)}.prof-email,.prof-name{font-family:var(--font-ui);white-space:nowrap;line-height:var(--leading-snug)}.prof-email{color:var(--text-secondary)}.prof-sm .prof-name{font-size:var(--text-sm)}.prof-sm .prof-email{font-size:11px}.prof-md .prof-name{font-size:var(--text-base)}.prof-md .prof-email{font-size:var(--text-xs)}.prof-lg .prof-name{font-size:var(--text-lg)}.prof-lg .prof-email{font-size:var(--text-sm)}.auth-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-7) var(--space-7);display:flex;flex-direction:column;gap:var(--space-5)}.auth-title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:300;color:var(--text-primary);letter-spacing:-.02em;line-height:var(--leading-tight)}.auth-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1);line-height:var(--leading-relaxed)}.auth-fields{display:flex;flex-direction:column;gap:var(--space-4)}.auth-field-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.auth-label{font-weight:500;color:var(--text-primary)}.auth-label,.auth-link{font-family:var(--font-ui);font-size:var(--text-sm)}.auth-link{color:var(--accent);cursor:pointer;background:none;border:none;outline:none;padding:0;transition:opacity .15s}.auth-link:hover{opacity:.75}.auth-actions{justify-content:flex-end;padding-top:var(--space-2)}.auth-actions,.auth-divider{display:flex;align-items:center;gap:var(--space-3)}.auth-divider{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary)}.auth-divider:after,.auth-divider:before{content:"";flex:1;height:1px;background:var(--border-default)}.auth-oauth{display:flex;align-items:center;justify-content:center;gap:var(--space-2);height:40px;background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);cursor:pointer;transition:all var(--duration-base) var(--ease-out);outline:none;width:100%}.auth-oauth:hover{background:var(--bg-hover);border-color:var(--border-strong)}.auth-footer-note{font-size:var(--text-xs);color:var(--text-tertiary);text-align:center;line-height:var(--leading-relaxed)}.auth-footer-note a{color:var(--accent);cursor:pointer}.skel{background:var(--bg-hover);border-radius:var(--radius-md);animation:skel-pulse 1.6s ease-in-out infinite}.skel-input{height:36px}.billing-toggle{display:inline-flex;align-items:center;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-full);padding:3px;gap:2px}.billing-opt{padding:var(--space-2) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);background:none;border:1px solid transparent;border-radius:calc(var(--radius-full) - 2px);cursor:pointer;outline:none;transition:all var(--duration-base) var(--ease-out);display:flex;align-items:center;gap:var(--space-2);white-space:nowrap}.billing-opt.is-active{background:var(--bg-elevated);border-color:var(--border-muted);color:var(--text-primary);font-weight:500}.billing-save{font-size:10px;font-weight:500;padding:1px 6px;border-radius:var(--radius-full);background:var(--success-muted);color:var(--success)}.pricing-wrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1px;background:var(--border-default);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden}.pc{background:var(--bg-surface);padding:var(--space-6) var(--space-5);display:flex;flex-direction:column;gap:var(--space-5);position:relative;transition:background .15s ease}.pc.pc-featured,.pc:hover{background:var(--bg-elevated)}.pc-featured-bar{position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent)}.pc-name{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-secondary);margin-bottom:var(--space-2)}.pc-name.pc-name-featured{color:var(--accent)}.pc-tagline{font-size:var(--text-xs);color:var(--text-tertiary);line-height:var(--leading-relaxed)}.pc-price{display:flex;align-items:baseline;gap:3px}.pc-amount{font-size:52px;letter-spacing:-.03em}.pc-amount,.pc-amount-sm{font-family:var(--font-display);font-weight:300;color:var(--text-primary);line-height:1}.pc-amount-sm{font-size:var(--text-3xl);letter-spacing:-.02em}.pc-period{font-family:var(--font-ui);line-height:1;padding-bottom:4px}.pc-period,.pc-period-note{font-size:var(--text-xs);color:var(--text-tertiary)}.pc-period-note{margin-top:5px;font-family:var(--font-mono)}.pc-cta{width:100%;height:36px;display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-md);cursor:pointer;outline:none;transition:all var(--duration-base) var(--ease-out);border:1px solid var(--border-muted);background:transparent;color:var(--text-secondary)}.pc-cta:hover{color:var(--text-primary);border-color:var(--border-strong);background:var(--bg-subtle)}.pc-cta:active{transform:scale(.98)}.pc-cta-featured{background:var(--accent)}.pc-cta-featured,.pc-cta-featured:hover{border-color:transparent;color:var(--bg-base)}.pc-cta-featured:hover{background:var(--accent-hover)}.pc-divider{height:1px;background:var(--border-faint);margin:0}.pc-features{display:flex;flex-direction:column;gap:10px;flex:1}.pc-feat-head{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);letter-spacing:.06em;margin-bottom:2px}.pc-feat{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.pc-feat .fi{flex-shrink:0;margin-top:1px}.pc-feat-on{color:var(--text-secondary)}.pc-feat-off{color:var(--text-disabled)}.pc-feat-bold{color:var(--text-primary);font-weight:500}.usage{display:flex;flex-direction:column;gap:var(--space-2)}.usage-top{display:flex;align-items:baseline;justify-content:space-between}.usage-label{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary)}.usage-val{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}.usage-track{height:4px;background:var(--bg-hover);overflow:hidden}.usage-fill,.usage-track{border-radius:var(--radius-full)}.usage-fill{height:100%;background:var(--accent);transition:width .4s ease}.usage-fill-warn{background:var(--warning)}.usage-fill-crit{background:var(--error)}.usage-foot{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary)}.upgrade-banner{gap:var(--space-4);padding:var(--space-4) var(--space-5);border:1px solid var(--accent);border-radius:var(--radius-lg);background:var(--accent-muted);flex-wrap:wrap}.ub-icon,.upgrade-banner{display:flex;align-items:center}.ub-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--accent);justify-content:center;flex-shrink:0}.ub-body{flex:1;min-width:0}.ub-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.ub-desc{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.opt-group{display:flex;flex-direction:column;gap:var(--space-2)}.opt{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .12s ease,background .12s ease}.opt:hover{border-color:var(--border-muted)}.opt.is-on{border-color:var(--accent);background:var(--accent-muted)}.opt-radio{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--border-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;transition:border-color .12s,background .12s}.opt.is-on .opt-radio{border-color:var(--accent);background:var(--accent)}.opt-dot{width:6px;height:6px;border-radius:50%;background:var(--bg-base);opacity:0;transition:opacity .12s}.opt.is-on .opt-dot{opacity:1}.opt-body{flex:1}.opt-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.opt-desc{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px;line-height:var(--leading-relaxed)}.opt-right{margin-left:auto;flex-shrink:0}.onb{flex-direction:column}.onb,.onb-step{display:flex;position:relative}.onb-step{align-items:flex-start;gap:var(--space-4);padding-bottom:var(--space-5)}.onb-step:not(:last-child):before{content:"";position:absolute;left:15px;top:32px;bottom:0;width:1px;background:var(--border-default)}.onb-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;background:var(--bg-subtle);border:1px solid var(--border-muted);color:var(--text-tertiary);z-index:1;position:relative;transition:all var(--duration-base) var(--ease-out)}.onb-dot.is-done{background:var(--success-muted);border-color:var(--success);color:var(--success)}.onb-dot.is-active{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.onb-body{padding-top:4px;flex:1}.onb-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.onb-desc{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-top:3px}.onb-action{margin-top:var(--space-3)}.chart-container{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5)}.chart-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-4)}.chart-title{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.chart-subtitle{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.chart-value-large{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);letter-spacing:-.02em;line-height:1}.chart-delta{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-mono);font-size:var(--text-xs);margin-top:var(--space-1)}.chart-delta-up{color:var(--success)}.chart-delta-down{color:var(--error)}.bar-chart{display:flex;align-items:flex-end;gap:var(--space-2);height:120px}.bar-col{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);flex:1;height:100%;justify-content:flex-end}.bar-fill{width:100%;border-radius:2px 2px 0 0;background:var(--text-tertiary);transition:background .2s ease;cursor:pointer;min-height:2px}.bar-fill.is-accent,.bar-fill:hover{background:var(--accent)}.bar-label{font-family:var(--font-mono);font-size:9px;color:var(--text-tertiary);white-space:nowrap}.sparkline{display:block;overflow:visible}.donut-wrap{display:flex;align-items:center;gap:var(--space-5)}.donut-legend{display:flex;flex-direction:column;gap:var(--space-2)}.donut-legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary)}.donut-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.h-bar-list{gap:var(--space-3)}.h-bar-item,.h-bar-list{display:flex;flex-direction:column}.h-bar-item{gap:5px}.h-bar-top{display:flex;align-items:center;justify-content:space-between}.h-bar-label{color:var(--text-secondary);font-weight:500}.h-bar-label,.h-bar-val{font-size:var(--text-xs)}.h-bar-val{font-family:var(--font-mono);color:var(--text-tertiary)}.h-bar-track{height:4px;background:var(--bg-hover);overflow:hidden}.h-bar-fill,.h-bar-track{border-radius:var(--radius-full)}.h-bar-fill{height:100%;background:var(--text-tertiary);transition:width .4s ease}.chart-legend{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap;margin-top:var(--space-3)}.chart-legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:11px;color:var(--text-secondary)}.chart-legend-swatch{width:10px;height:3px;border-radius:2px}.heat-cell{width:22px;height:22px;border-radius:3px;cursor:pointer;transition:opacity .15s,transform .12s;flex-shrink:0}.heat-cell:hover{transform:scale(1.15)}.heat-cell[data-v="0"]{background:var(--bg-hover)}.heat-cell[data-v="1"]{background:var(--accent);opacity:.2}.heat-cell[data-v="2"]{background:var(--accent);opacity:.4}.heat-cell[data-v="3"]{background:var(--accent);opacity:.65}.heat-cell[data-v="4"]{background:var(--accent);opacity:.9}.stacked-bar-col{flex:1;display:flex;flex-direction:column-reverse;align-items:stretch;cursor:pointer;transition:opacity .15s;position:relative}.stacked-bar-col:hover{opacity:.85}.stacked-bar-col:after{content:attr(data-label);position:absolute;bottom:-18px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:9px;color:var(--text-tertiary);white-space:nowrap}.stacked-seg{width:100%;transition:height .6s ease}.treemap-cell{transition:opacity .15s,filter .15s}.treemap-cell:hover{filter:brightness(1.2)}.treemap-label{font-size:9px;line-height:1.4;padding:4px}.treemap-label strong{font-weight:600}.bubble{transition:fill-opacity .15s,r .15s;cursor:pointer}.bubble:hover{fill-opacity:.4}.map-chart-wrap{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.map-canvas{width:100%;background:var(--bg-subtle);display:block}.map-country{fill:var(--bg-hover);stroke:var(--bg-surface);stroke-width:.5;transition:fill .15s ease;cursor:pointer}.map-country:hover{fill:var(--border-muted)}.map-country.is-active{fill:var(--accent-muted);stroke:var(--accent);stroke-width:1}.map-pin{cursor:pointer;transition:transform .15s ease;transform-origin:center}.map-pin:hover{transform:scale(1.2)}.map-pin-dot{fill:var(--bg-base);stroke:var(--accent);stroke-width:2;filter:drop-shadow(0 1px 3px rgba(0,0,0,.3))}.map-pin-label{font-family:var(--font-mono);font-size:9px;fill:var(--accent);letter-spacing:.04em}.map-bars{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1) var(--space-6);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-default)}.map-bar-item{display:flex;flex-direction:column;gap:5px;padding:var(--space-2) 0}.map-bar-top{display:flex;align-items:center;justify-content:space-between}.map-bar-name{font-size:var(--text-sm);color:var(--text-primary);font-family:var(--font-ui)}.map-bar-pct{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary)}.map-bar-track{height:5px;background:var(--bg-hover);overflow:hidden}.map-bar-fill,.map-bar-track{border-radius:var(--radius-full)}.map-bar-fill{height:100%;background:var(--text-secondary);transition:width .8s ease}.map-bar-fill.c-accent{background:var(--accent)}.map-bar-fill.c-info{background:var(--info)}.map-bar-fill.c-success{background:var(--success)}.map-bar-fill.c-warning{background:var(--warning)}.list-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border-faint);font-size:var(--text-sm);color:var(--text-primary)}.list-item-action,.list-item:last-child{border-bottom:none}.list-item-action{cursor:pointer;padding:var(--space-3);margin:0 calc(-1 * var(--space-3));border-radius:var(--radius-md);transition:background .12s ease}.list-item-action:hover{background:var(--bg-subtle)}.code-block{background:var(--bg-surface);padding:var(--space-5) var(--space-6);font-size:12px;color:var(--text-secondary);line-height:1.8;white-space:pre;tab-size:2}.code-block,.log-block{border:1px solid var(--border-default);border-radius:var(--radius-md);font-family:var(--font-mono);overflow-x:auto}.log-block{background:var(--bg-base);padding:var(--space-4) var(--space-5);font-size:11px;line-height:1.9;color:var(--text-tertiary)}.log-line{display:flex;gap:var(--space-3)}.log-time{color:var(--text-tertiary);flex-shrink:0}.log-level-info{color:var(--info)}.log-level-success{color:var(--success)}.log-level-warning{color:var(--warning)}.log-level-error{color:var(--error)}.kbd,.log-msg{color:var(--text-secondary)}.kbd{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;background:var(--bg-subtle);border:1px solid var(--border-muted);border-radius:var(--radius-sm);padding:2px 6px;line-height:1.6;white-space:nowrap}.divider{height:1px;background:var(--border-default);border:none;margin:var(--space-5) 0}.divider-subtle{background:var(--border-faint)}.divider-strong{background:var(--border-strong)}.divider-labeled{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.08em}.divider-labeled:after,.divider-labeled:before{content:"";flex:1;height:1px;background:var(--border-default)}.fi{display:inline-block;width:16px;height:16px;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;fill:none;flex-shrink:0;vertical-align:middle}.fi-xs{width:12px;height:12px}.fi-sm{width:14px;height:14px}.fi-md{width:16px;height:16px}.fi-lg{width:20px;height:20px}.fi-xl{width:24px;height:24px}.fi-2xl{width:32px;height:32px}.fi-primary{color:var(--text-primary)}.fi-secondary{color:var(--text-secondary)}.fi-tertiary{color:var(--text-tertiary)}.fi-accent{color:var(--accent)}.fi-success{color:var(--success)}.fi-warning{color:var(--warning)}.fi-error{color:var(--error)}.fi-info{color:var(--info)}.btn .fi,.btn-icon .fi{pointer-events:none}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:1px;background:var(--border-faint);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.icon-cell{background:var(--bg-surface);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);cursor:pointer;transition:background .12s ease;user-select:none}.icon-cell:hover{background:var(--bg-elevated)}.icon-cell:hover .icon-cell-name{color:var(--text-secondary)}.icon-cell-name{font-family:var(--font-mono);font-size:9px;color:var(--text-tertiary);letter-spacing:.02em;text-align:center;line-height:1.3}.icon-grid-clean{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-2)}.icon-grid-clean .icon-cell{display:flex;flex-direction:column;align-items:center;gap:6px;padding:var(--space-3) var(--space-2);border-radius:var(--radius-md);cursor:default;transition:background .12s ease}.icon-grid-clean .icon-cell:hover{background:var(--bg-subtle)}.icon-grid-clean .icon-cell-name{font-family:var(--font-mono);font-size:9px;color:var(--text-tertiary);text-align:center;letter-spacing:.02em;line-height:1.2}.model-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4);transition:border-color var(--duration-base) var(--ease-out)}.model-card:hover{border-color:var(--border-muted)}.model-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.model-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:300;color:var(--text-primary);letter-spacing:-.01em}.model-sub{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);margin-top:3px;letter-spacing:.04em}.model-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.model-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-2)}.model-meta-item{background:var(--bg-subtle);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:2px}.model-meta-key{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);letter-spacing:.04em}.model-meta-value{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:500;color:var(--text-secondary)}.phase-section{margin-bottom:var(--space-6)}.phase-header{gap:var(--space-3);margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-faint)}.phase-header,.phase-num{display:flex;align-items:center}.phase-num{width:26px;height:26px;border-radius:50%;justify-content:center;font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;flex-shrink:0}.phase-num-info{background:var(--info-muted);color:var(--info)}.phase-num-success{background:var(--success-muted);color:var(--success)}.phase-num-warning{background:var(--warning-muted);color:var(--warning)}.phase-num-error{background:var(--error-muted);color:var(--error)}.phase-num-accent{background:var(--accent-muted);color:var(--accent)}.phase-title{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.phase-time{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);margin-left:auto}.steps-grid{display:grid;gap:var(--space-2);margin-left:var(--space-3)}.step-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);transition:border-color var(--duration-base) var(--ease-out),background .15s ease;cursor:default}.step-card:hover{border-color:var(--border-muted);background:var(--bg-elevated)}.step-card.is-clickable{cursor:pointer}.step-top{gap:var(--space-2)}.step-icon,.step-top{display:flex;align-items:center}.step-icon{width:22px;height:22px;border-radius:50%;justify-content:center;font-family:var(--font-ui);font-size:10px;font-weight:600;flex-shrink:0}.step-icon-info{background:var(--info-muted);color:var(--info)}.step-icon-success{background:var(--success-muted);color:var(--success)}.step-icon-warning{background:var(--warning-muted);color:var(--warning)}.step-icon-error{background:var(--error-muted);color:var(--error)}.step-icon-accent{background:var(--accent-muted);color:var(--accent)}.step-icon-default{background:var(--bg-hover);color:var(--text-secondary)}.step-name{font-family:var(--font-ui);font-weight:500;color:var(--text-primary)}.step-desc,.step-name{font-size:var(--text-sm)}.step-desc{color:var(--text-secondary);line-height:var(--leading-relaxed)}.step-meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-1)}.meta-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-family:var(--font-mono);font-size:10px;font-weight:400;padding:2px var(--space-2);border-radius:var(--radius-sm);white-space:nowrap}.meta-time{background:var(--info-muted);color:var(--info)}.meta-cost{background:var(--success-muted);color:var(--success)}.meta-key{background:var(--accent-muted);color:var(--accent)}.meta-warning{background:var(--warning-muted);color:var(--warning)}.meta-default{background:var(--bg-subtle);color:var(--text-tertiary)}.stats-row{display:flex;gap:1px;background:var(--border-default);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.stat-block{flex:1;background:var(--bg-surface);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-1)}.stat-num{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);line-height:1;letter-spacing:-.02em}.stat-label{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.04em;line-height:var(--leading-normal)}.imgtxt-card{display:flex;align-items:stretch;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out)}.imgtxt-card:hover{border-color:var(--border-muted)}.imgtxt-img{flex-shrink:0;background:var(--bg-subtle);display:flex;align-items:center;justify-content:center;overflow:hidden}.imgtxt-img img{width:100%;height:100%;object-fit:cover;display:block}.imgtxt-body{padding:var(--space-5);display:flex;flex-direction:column;justify-content:center;gap:var(--space-2);flex:1}.imgtxt-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--accent);text-transform:uppercase}.imgtxt-title{font-family:var(--font-display);font-weight:400;color:var(--text-primary);line-height:var(--leading-snug)}.imgtxt-body-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.imgtxt-body-text strong{color:var(--text-primary);font-weight:500}.imgtxt-meta{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);margin-top:var(--space-1)}.imgtxt-sm .imgtxt-img{width:100px;min-height:100px;align-self:stretch}.imgtxt-sm .imgtxt-img img{width:100px;height:100%;min-height:100px}.imgtxt-sm .imgtxt-title{font-size:var(--text-xl)}.imgtxt-sm .imgtxt-body{padding:var(--space-4);gap:var(--space-1)}.imgtxt-md .imgtxt-img{width:140px;min-height:140px;align-self:stretch}.imgtxt-md .imgtxt-img img{width:140px;height:100%;min-height:140px}.imgtxt-md .imgtxt-title{font-size:var(--text-2xl)}.imgtxt-lg .imgtxt-img{width:180px;min-height:180px;align-self:stretch}.imgtxt-lg .imgtxt-img img{width:180px;height:100%;min-height:180px}.imgtxt-lg .imgtxt-title{font-size:var(--text-3xl);font-weight:300}.imgtxt-stack{flex-direction:column;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out)}.imgtxt-stack:hover{border-color:var(--border-muted)}.imgtxt-stack .imgtxt-img{width:100%;height:180px;border-radius:0;border-bottom:1px solid var(--border-default)}.imgtxt-stack .imgtxt-body{padding:var(--space-5)}.imgtxt-stack .imgtxt-title{font-size:var(--text-xl);font-weight:400;font-family:var(--font-display)}.img-ph-1{background:linear-gradient(135deg,var(--bg-hover) 0,var(--bg-subtle) 100%)}.img-ph-2{background:linear-gradient(135deg,var(--bg-subtle) 0,var(--bg-hover) 100%)}.img-ph-warm{background:linear-gradient(135deg,#2A2416,#1A1A18)}.img-ph-cool{background:linear-gradient(135deg,#14202A,#111110)}.sw{display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;user-select:none}.sw-track{position:relative;width:32px;height:18px;flex-shrink:0}.sw-track input{position:absolute;opacity:0;width:0;height:0}.sw-bg{position:absolute;inset:0;border-radius:var(--radius-full);background:var(--bg-hover);border:1px solid var(--border-muted);transition:background .18s ease,border-color .18s ease}.sw-track input:checked~.sw-bg{background:var(--accent);border-color:var(--accent)}.sw-dot{position:absolute;top:3px;left:3px;width:10px;height:10px;border-radius:50%;background:var(--text-tertiary);transition:transform .18s ease,background .18s ease;pointer-events:none}.sw-track input:checked~.sw-dot{transform:translateX(14px);background:var(--bg-base)}.sw-label{font-size:var(--text-sm);color:var(--text-primary);font-family:var(--font-ui)}.sw-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:1px}.checkbox{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);user-select:none;position:relative}.checkbox input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.checkbox-box{width:18px;height:18px;border:var(--border-width-default) solid var(--border-muted);border-radius:var(--radius-sm);background:var(--bg-surface);display:flex;align-items:center;justify-content:center;flex-shrink:0}.checkbox-box,.checkbox-box svg{transition:all var(--duration-fast) var(--ease-default)}.checkbox-box svg{width:12px;height:12px;stroke:var(--bg-base);stroke-width:2.5;fill:none;opacity:0;transform:scale(.6)}.checkbox input:checked~.checkbox-box{background:var(--accent);border-color:var(--accent)}.checkbox input:checked~.checkbox-box svg{opacity:1;transform:scale(1)}.checkbox input:indeterminate~.checkbox-box{background:var(--accent);border-color:var(--accent)}.checkbox input:indeterminate~.checkbox-box svg{opacity:0}.checkbox input:indeterminate~.checkbox-box:after{content:"";width:10px;height:2px;background:var(--bg-base);border-radius:1px}.checkbox:hover .checkbox-box{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.checkbox input:focus-visible~.checkbox-box{outline:2px solid var(--accent);outline-offset:2px}.checkbox.is-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.checkbox-text{line-height:1.4}.checkbox-desc{display:block;font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.checkbox-group{display:flex;flex-direction:column;gap:var(--space-3)}.checkbox-group-label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:var(--space-1)}.checkbox-group-h{flex-direction:row;flex-wrap:wrap;gap:var(--space-4)}.checkbox-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:var(--border-width-default) solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.checkbox-card:hover{border-color:var(--accent);background:var(--accent-muted)}.checkbox-card input:checked~.checkbox-box{background:var(--accent);border-color:var(--accent)}.checkbox-card:has(input:checked){border-color:var(--accent);background:var(--accent-muted)}.radio{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);user-select:none;position:relative}.radio input[type=radio]{position:absolute;opacity:0;width:0;height:0}.radio-dot{width:18px;height:18px;border:var(--border-width-default) solid var(--border-muted);background:var(--bg-surface);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--duration-fast) var(--ease-default)}.radio-dot,.radio-dot:after{border-radius:var(--radius-full)}.radio-dot:after{content:"";width:8px;height:8px;background:var(--bg-base);transform:scale(0);transition:transform var(--duration-fast) var(--ease-bounce)}.radio input:checked~.radio-dot{background:var(--accent);border-color:var(--accent)}.radio input:checked~.radio-dot:after{transform:scale(1)}.radio:hover .radio-dot{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.radio input:focus-visible~.radio-dot{outline:2px solid var(--accent);outline-offset:2px}.radio.is-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.radio-text{line-height:1.4}.radio-desc{display:block;font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.radio-group{display:flex;flex-direction:column;gap:var(--space-3)}.radio-group-label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:var(--space-1)}.radio-group-h{flex-direction:row;flex-wrap:wrap;gap:var(--space-4)}.radio-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border:var(--border-width-default) solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.radio-card:hover{border-color:var(--accent);background:var(--accent-muted)}.radio-card:has(input:checked){border-color:var(--accent);background:var(--accent-muted)}.radio-card-body{flex:1}.radio-card-title{font-weight:500;font-size:var(--text-base);margin-bottom:2px}.radio-card-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.radio-card-price{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent);margin-top:var(--space-2)}.select-wrap{position:relative}.select,.select-wrap{font-family:var(--font-ui)}.select{width:100%;height:40px;padding:0 var(--space-7) 0 var(--space-3);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:var(--border-width-default) solid var(--border-default);border-radius:var(--radius-md);appearance:none;cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.select:hover{border-color:var(--border-muted)}.select:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:none}.select.is-error{border-color:var(--error)}.select-sm{height:32px;font-size:var(--text-xs);padding:0 var(--space-6) 0 var(--space-2)}.select-lg{height:48px;font-size:var(--text-base);padding:0 var(--space-8) 0 var(--space-4)}.select-wrap:after{content:"";position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--text-tertiary);pointer-events:none}.cselect{position:relative}.cselect,.cselect-trigger{font-family:var(--font-ui)}.cselect-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;height:40px;padding:0 var(--space-3);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:var(--border-width-default) solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.cselect-trigger:hover{border-color:var(--border-muted)}.cselect.is-open .cselect-trigger{border-color:var(--accent);box-shadow:var(--shadow-focus)}.cselect-arrow,.cselect-placeholder{color:var(--text-tertiary)}.cselect-arrow{width:16px;height:16px;transition:transform var(--duration-fast) var(--ease-default)}.cselect.is-open .cselect-arrow{transform:rotate(180deg)}.cselect-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-elevated);border:var(--border-width-default) solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);max-height:240px;overflow-y:auto;opacity:0;transform:translateY(-4px);pointer-events:none;transition:all var(--duration-fast) var(--ease-default)}.cselect.is-open .cselect-dropdown{opacity:1;transform:translateY(0);pointer-events:auto}.cselect-search{padding:var(--space-2);border-bottom:1px solid var(--border-faint);position:sticky;top:0;background:var(--bg-elevated)}.cselect-search input{width:100%;height:32px;padding:0 var(--space-2);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:var(--border-width-default) solid var(--border-faint);border-radius:var(--radius-sm);outline:none}.cselect-search input:focus{border-color:var(--accent)}.cselect-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;transition:background var(--duration-fast)}.cselect-option.is-focused,.cselect-option:hover{background:var(--bg-hover)}.cselect-option.is-selected{color:var(--accent);font-weight:500}.cselect-option.is-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.cselect-option-check{width:14px;height:14px;color:var(--accent);opacity:0}.cselect-option.is-selected .cselect-option-check{opacity:1}.cselect-group-label{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary)}.cselect-tags{display:flex;flex-wrap:wrap;gap:4px;flex:1}.cselect-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;font-size:var(--text-xs);background:var(--accent-muted);color:var(--accent);border-radius:var(--radius-sm)}.cselect-tag-remove{width:12px;height:12px;cursor:pointer;opacity:.6}.cselect-tag-remove:hover{opacity:1}.cselect-empty{padding:var(--space-4);text-align:center;font-size:var(--text-sm);color:var(--text-tertiary)}.range-wrap{position:relative;padding:var(--space-2) 0}.range-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:var(--border-default);border-radius:var(--radius-full);outline:none;cursor:pointer}.range-slider::-webkit-slider-runnable-track{height:4px;border-radius:var(--radius-full)}.range-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:var(--radius-full);background:var(--accent);border:2px solid var(--bg-base);box-shadow:var(--shadow-sm);cursor:grab;margin-top:-7px;transition:box-shadow var(--duration-fast) var(--ease-default)}.range-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 4px var(--accent-muted),var(--shadow-sm)}.range-slider::-webkit-slider-thumb:active{cursor:grabbing}.range-slider::-moz-range-thumb{width:18px;height:18px;border-radius:var(--radius-full);background:var(--accent);border:2px solid var(--bg-base);box-shadow:var(--shadow-sm);cursor:grab}.range-slider:focus-visible::-webkit-slider-thumb{outline:2px solid var(--accent);outline-offset:2px}.range-labels{display:flex;justify-content:space-between;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-tertiary)}.range-labels,.range-value{font-family:var(--font-mono)}.range-value{font-size:var(--text-sm);color:var(--accent);font-weight:500;text-align:center;margin-bottom:var(--space-1)}.range-marks{display:flex;justify-content:space-between;padding:0 8px;margin-top:var(--space-1)}.range-mark{width:2px;height:8px;background:var(--border-muted);border-radius:1px}.range-dual{position:relative;height:4px;background:var(--border-default);border-radius:var(--radius-full);margin:var(--space-4) 0}.range-dual-fill{height:100%}.range-dual-fill,.range-dual-thumb{position:absolute;background:var(--accent);border-radius:var(--radius-full)}.range-dual-thumb{top:50%;transform:translate(-50%,-50%);width:18px;height:18px;border:2px solid var(--bg-base);box-shadow:var(--shadow-sm);cursor:grab;z-index:2}.range-dual-thumb:hover{box-shadow:0 0 0 4px var(--accent-muted),var(--shadow-sm)}.range-dual-thumb:active{cursor:grabbing}.range-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);padding:2px 8px;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--bg-base);background:var(--text-primary);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none}.range-slider:disabled{opacity:.35;cursor:not-allowed}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-7) var(--space-5);border:2px dashed var(--border-muted);border-radius:var(--radius-lg);background:var(--bg-surface);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);text-align:center}.upload-zone.is-dragover,.upload-zone:hover{border-color:var(--accent);background:var(--accent-muted)}.upload-zone.is-dragover{border-style:solid}.upload-zone.is-error{border-color:var(--error);background:var(--error-muted)}.upload-zone-icon{width:40px;height:40px;color:var(--text-tertiary)}.upload-zone-title{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.upload-zone-title span{color:var(--accent);text-decoration:underline}.upload-zone-hint{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-tertiary)}.upload-zone input[type=file]{position:absolute;opacity:0;width:0;height:0}.upload-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);background:var(--bg-surface);border:var(--border-width-default) solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast)}.upload-btn:hover{border-color:var(--accent);color:var(--accent)}.upload-list{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}.upload-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-subtle);border-radius:var(--radius-md);font-size:var(--text-sm)}.upload-item-icon{width:20px;height:20px;color:var(--text-tertiary);flex-shrink:0}.upload-item-info{flex:1;min-width:0}.upload-item-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-item-size{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary)}.upload-item-remove{width:16px;height:16px;color:var(--text-tertiary);cursor:pointer;flex-shrink:0}.upload-item-remove:hover{color:var(--error)}.upload-item-progress{width:100%;height:3px;background:var(--border-faint);border-radius:var(--radius-full);overflow:hidden;margin-top:4px}.upload-item-progress-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width var(--duration-base) var(--ease-default)}.upload-item.is-success .upload-item-icon{color:var(--success)}.upload-item.is-error .upload-item-icon,.upload-item.is-error .upload-item-name{color:var(--error)}.upload-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-2);margin-top:var(--space-3)}.upload-preview-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-subtle)}.upload-preview-item img{width:100%;height:100%;object-fit:cover}.upload-preview-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;background:rgba(0,0,0,.6);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;color:white}.datepicker{position:relative;font-family:var(--font-ui)}.datepicker-trigger{display:flex;align-items:center;gap:var(--space-2);width:100%;height:40px;padding:0 var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:var(--border-width-default) solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast)}.datepicker-trigger:hover{border-color:var(--border-muted)}.datepicker.is-open .datepicker-trigger{border-color:var(--accent);box-shadow:var(--shadow-focus)}.datepicker-trigger-icon{width:16px;height:16px;color:var(--text-tertiary)}.datepicker-trigger-text{flex:1}.datepicker-trigger-placeholder{color:var(--text-tertiary)}.datepicker-cal{position:absolute;top:calc(100% + 4px);left:0;width:280px;background:var(--bg-elevated);border:var(--border-width-default) solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);padding:var(--space-3);opacity:0;transform:translateY(-4px);pointer-events:none;transition:all var(--duration-fast) var(--ease-default)}.datepicker.is-open .datepicker-cal{opacity:1;transform:translateY(0);pointer-events:auto}.datepicker-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 var(--space-2) 0}.datepicker-month{font-weight:500;font-size:var(--text-sm);color:var(--text-primary)}.datepicker-nav{display:flex;gap:var(--space-1)}.datepicker-nav-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer}.datepicker-nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.datepicker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:0;margin-bottom:var(--space-1)}.datepicker-weekday{text-align:center;font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);padding:var(--space-1) 0}.datepicker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.datepicker-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast);border:none;background:transparent}.datepicker-day:hover{background:var(--bg-hover)}.datepicker-day.is-today{color:var(--accent);font-weight:600}.datepicker-day.is-selected{background:var(--accent);color:var(--bg-base);font-weight:500}.datepicker-day.is-other-month{color:var(--text-disabled)}.datepicker-day.is-disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.datepicker-day.is-range-start{background:var(--accent);color:var(--bg-base);border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.datepicker-day.is-range-end{background:var(--accent);color:var(--bg-base);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.datepicker-day.is-in-range{background:var(--accent-muted);color:var(--accent);border-radius:0}.datepicker-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-2);border-top:1px solid var(--border-faint);margin-top:var(--space-2)}.datepicker-today-btn{font-size:var(--text-xs);color:var(--accent);cursor:pointer;background:none;border:none;font-family:var(--font-ui)}.datepicker-today-btn:hover{text-decoration:underline}.field-error .cselect-trigger,.field-error .input,.field-error .select{border-color:var(--error)}.field-error .input:focus,.field-error .select:focus{box-shadow:0 0 0 3px var(--error-muted)}.field-success .cselect-trigger,.field-success .input,.field-success .select{border-color:var(--success)}.field-success .input:focus{box-shadow:0 0 0 3px var(--success-muted)}.field-warning .input,.field-warning .select{border-color:var(--warning)}.field-warning .input:focus{box-shadow:0 0 0 3px var(--warning-muted)}.field-msg{display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-1);font-family:var(--font-ui);font-size:var(--text-xs);line-height:1.4}.field-msg-error{color:var(--error)}.field-msg-success{color:var(--success)}.field-msg-warning{color:var(--warning)}.field-msg-info{color:var(--info)}.field-msg-icon{width:14px;height:14px;flex-shrink:0}.field-required:after{content:"*";color:var(--error);margin-left:2px;font-weight:600}.field-counter{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);text-align:right;margin-top:var(--space-1)}.field-counter.is-warn{color:var(--warning)}.field-counter.is-over{color:var(--error);font-weight:500}.form-summary{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--error-muted);border-left:3px solid var(--error);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.form-summary-title{font-weight:600;font-size:var(--text-sm);color:var(--error);display:flex;align-items:center;gap:var(--space-2)}.form-summary-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-1)}.form-summary-list li{font-size:var(--text-sm);color:var(--text-secondary);padding-left:var(--space-3);position:relative}.form-summary-list li:before{content:"•";position:absolute;left:0;color:var(--error)}.form-summary-list li a{color:var(--error);text-decoration:underline;cursor:pointer}.form-summary-success{background:var(--success-muted);border-left-color:var(--success)}.form-summary-success .form-summary-title{color:var(--success)}.pw-strength{display:flex;gap:4px;margin-top:var(--space-2)}.pw-strength-bar{flex:1;height:3px;background:var(--border-default);border-radius:var(--radius-full);transition:background var(--duration-fast)}.pw-strength.pw-weak .pw-strength-bar:first-child{background:var(--error)}.pw-strength.pw-fair .pw-strength-bar:nth-child(-n+2){background:var(--warning)}.pw-strength.pw-good .pw-strength-bar:nth-child(-n+3){background:var(--info)}.pw-strength.pw-strong .pw-strength-bar{background:var(--success)}.pw-strength-label{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-1)}.wizard{display:flex;flex-direction:column;gap:var(--space-5)}.wizard-steps{display:flex;align-items:center;gap:0}.wizard-step-item{display:flex;align-items:center;gap:var(--space-2);flex:1}.wizard-step-dot{width:32px;height:32px;border-radius:var(--radius-full);border:2px solid var(--border-muted);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600;color:var(--text-tertiary);flex-shrink:0;transition:all var(--duration-base) var(--ease-default)}.wizard-step-item.is-active .wizard-step-dot{background:var(--accent);border-color:var(--accent);color:var(--bg-base)}.wizard-step-item.is-done .wizard-step-dot{background:var(--success-muted);border-color:var(--success);color:var(--success)}.wizard-step-info{min-width:0}.wizard-step-title{font-size:var(--text-sm);font-weight:500;color:var(--text-tertiary);white-space:nowrap}.wizard-step-item.is-active .wizard-step-title{color:var(--text-primary)}.wizard-step-item.is-done .wizard-step-title{color:var(--success)}.wizard-step-desc{font-size:var(--text-xs);color:var(--text-tertiary);display:none}.wizard-step-item.is-active .wizard-step-desc{display:block}.wizard-step-line{flex:1;height:2px;background:var(--border-default);margin:0 var(--space-2);min-width:20px}.wizard-step-line.is-done{background:var(--success)}.wizard-panel{display:none}.wizard-panel.is-active{display:block}.wizard-panel-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;color:var(--text-primary);margin-bottom:var(--space-2)}.wizard-panel-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-5)}.wizard-nav{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-4);border-top:1px solid var(--border-faint)}.wizard-nav-left,.wizard-nav-right{display:flex;gap:var(--space-2)}.wizard-compact{flex-direction:row;gap:var(--space-6)}.wizard-compact .wizard-steps{flex-direction:column;flex-shrink:0;width:200px;gap:0}.wizard-compact .wizard-step-item{flex:none}.wizard-compact .wizard-step-line{width:2px;height:24px;min-width:2px;margin:var(--space-1) 0 var(--space-1) 15px}.wizard-compact .wizard-content{flex:1;min-width:0}.wizard-progress{display:flex;flex-direction:column;gap:var(--space-1)}.wizard-progress-bar{width:100%;height:4px;background:var(--border-default);border-radius:var(--radius-full);overflow:hidden}.wizard-progress-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-default)}.wizard-progress-text{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);text-align:right}.timeline{display:flex;flex-direction:column;position:relative;padding-left:var(--space-5)}.timeline:before{content:"";position:absolute;left:5px;top:0;bottom:0;width:1px;background:var(--border-default)}.timeline-item{position:relative;padding-bottom:var(--space-5);display:flex;flex-direction:column;gap:var(--space-1)}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:calc(-1 * var(--space-5) - 1px);top:2px;width:12px;height:12px;border-radius:50%;background:var(--bg-subtle);border:2px solid var(--border-muted);z-index:1}.timeline-dot-accent{background:var(--accent-muted);border-color:var(--accent)}.timeline-dot-success{background:var(--success-muted);border-color:var(--success)}.timeline-dot-warning{background:var(--warning-muted);border-color:var(--warning)}.timeline-dot-error{background:var(--error-muted);border-color:var(--error)}.timeline-dot-info{background:var(--info-muted);border-color:var(--info)}.timeline-content{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);line-height:var(--leading-normal)}.timeline-time{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary)}.timeline-h{display:flex;flex-direction:row;align-items:flex-start;gap:var(--space-4);padding-left:0;overflow-x:auto}.timeline-h:before{content:"";position:absolute;left:0;right:0;top:5px;height:1px;width:100%;bottom:auto}.timeline-h .timeline-item{flex-direction:column;align-items:center;text-align:center;padding-bottom:0;padding-top:var(--space-5);min-width:100px;flex-shrink:0}.timeline-h .timeline-dot{left:50%;top:calc(-1 * var(--space-5) + 4px);transform:translateX(-50%)}.kanban-board{display:flex;gap:var(--space-4);overflow-x:auto;padding-bottom:var(--space-2);align-items:flex-start}.kanban-column{min-width:260px;max-width:320px;flex-shrink:0;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;flex-direction:column}.kanban-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-faint)}.kanban-header-title{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);letter-spacing:var(--tracking-wide);text-transform:uppercase}.kanban-count{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);background:var(--bg-hover);padding:1px var(--space-2);border-radius:var(--radius-full)}.kanban-body{min-height:60px}.kanban-body,.kanban-card{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.kanban-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:grab;transition:border-color var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out)}.kanban-card:hover{border-color:var(--border-muted);box-shadow:var(--shadow-sm)}.kanban-card.is-dragging{opacity:.5;border-style:dashed}.kanban-card-title{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.kanban-card-desc{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.kanban-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:var(--space-1)}.kanban-card-badge{font-family:var(--font-mono);font-size:10px;padding:1px var(--space-2);border-radius:var(--radius-sm);background:var(--accent-muted);color:var(--accent)}.kanban-placeholder{border:1px dashed var(--border-muted);border-radius:var(--radius-md);background:var(--bg-hover);min-height:48px}.kanban-add{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-tertiary);background:none;border:1px dashed var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-base) var(--ease-out),border-color var(--duration-base) var(--ease-out);outline:none;width:100%}.kanban-add:hover{color:var(--text-secondary);border-color:var(--border-muted)}.calendar{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-4);font-family:var(--font-ui)}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.cal-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.cal-nav{gap:var(--space-1)}.cal-nav,.cal-nav-btn{display:flex;align-items:center}.cal-nav-btn{width:28px;height:28px;justify-content:center;background:none;border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;outline:none;transition:all var(--duration-fast) var(--ease-out)}.cal-nav-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-muted)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.cal-weekday{font-size:10px;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);text-align:center;padding:var(--space-2) 0}.cal-day{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2) var(--space-1);font-size:var(--text-sm);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-fast) var(--ease-out);text-align:center;min-height:36px}.cal-day:hover{background:var(--bg-hover)}.cal-day.is-today{font-weight:600;color:var(--accent)}.cal-day.is-today:after{content:"";width:4px;height:4px;border-radius:50%;background:var(--accent);position:absolute;bottom:2px}.cal-day.is-selected{background:var(--accent);color:var(--bg-base)}.cal-day.is-selected:hover{background:var(--accent-hover)}.cal-day.is-disabled,.cal-day.is-other-month{color:var(--text-disabled)}.cal-day.is-disabled{pointer-events:none;cursor:default}.cal-event{display:flex;gap:2px;justify-content:center}.cal-event-dot{width:4px;height:4px;border-radius:50%;background:var(--accent)}.cal-event-dot-success{background:var(--success)}.cal-event-dot-warning{background:var(--warning)}.cal-event-dot-error{background:var(--error)}.activity-feed{display:flex;flex-direction:column}.activity-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);transition:background var(--duration-fast) var(--ease-out);border-bottom:1px solid var(--border-faint)}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:var(--bg-subtle)}.activity-item.is-unread{background:var(--accent-muted);border-left:2px solid var(--accent)}.activity-item.is-unread:hover{background:var(--bg-subtle)}.activity-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-hover);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;font-weight:600}.activity-avatar,.activity-body{font-family:var(--font-ui);color:var(--text-secondary)}.activity-body{flex:1;min-width:0;font-size:var(--text-sm);line-height:var(--leading-normal)}.activity-action{font-weight:500;color:var(--text-primary)}.activity-target{color:var(--accent);font-weight:500}.activity-desc{font-size:var(--text-xs);line-height:var(--leading-relaxed)}.activity-desc,.activity-time{color:var(--text-tertiary);margin-top:2px}.activity-time{font-family:var(--font-mono);font-size:10px;white-space:nowrap;flex-shrink:0}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.kpi-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);transition:border-color var(--duration-base) var(--ease-out)}.kpi-card:hover{border-color:var(--border-muted)}.kpi-label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:500;color:var(--text-tertiary);letter-spacing:var(--tracking-wide)}.kpi-value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);letter-spacing:-.02em;line-height:1}.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-mono);font-size:var(--text-xs)}.kpi-delta-up{color:var(--success)}.kpi-delta-down{color:var(--error)}.kpi-delta-flat{color:var(--text-tertiary)}.kpi-trend{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-mono);font-size:var(--text-xs)}.kpi-trend-arrow{font-size:10px;line-height:1}.kpi-trend-up{color:var(--success)}.kpi-trend-down{color:var(--error)}.kpi-trend-flat{color:var(--text-tertiary)}.kpi-sparkline{height:32px;margin-top:var(--space-1);overflow:visible;display:block;width:100%}.kpi-sparkline path{fill:none;stroke:var(--text-tertiary);stroke-width:1.5}.kpi-sparkline .kpi-sparkline-area{fill:var(--accent-muted);stroke:none}.kpi-sparkline .kpi-sparkline-line{stroke:var(--accent)}.kpi-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-1)}.gauge{position:relative;display:inline-flex;align-items:center;justify-content:center}.gauge-svg{transform:rotate(-90deg);display:block}.gauge-track{fill:none;stroke:var(--bg-hover);stroke-linecap:round}.gauge-fill{fill:none;stroke:var(--text-secondary);stroke-linecap:round;transition:stroke-dasharray var(--duration-slow) var(--ease-default)}.gauge-accent .gauge-fill{stroke:var(--accent)}.gauge-success .gauge-fill{stroke:var(--success)}.gauge-warning .gauge-fill{stroke:var(--warning)}.gauge-error .gauge-fill{stroke:var(--error)}.gauge-info .gauge-fill{stroke:var(--info)}.gauge-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}.gauge-value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:300;color:var(--text-primary);letter-spacing:-.02em;line-height:1}.gauge-label{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:var(--tracking-wide)}.gauge-sm .gauge-value{font-size:var(--text-base)}.gauge-lg .gauge-value{font-size:var(--text-2xl)}.heatmap{flex-direction:column}.heatmap,.heatmap-row{display:flex;gap:var(--space-1)}.heatmap-row{align-items:center}.heatmap-row-label{font-family:var(--font-mono);font-size:9px;color:var(--text-tertiary);width:48px;text-align:right;flex-shrink:0;padding-right:var(--space-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.heatmap-col-labels{display:flex;gap:var(--space-1);padding-left:56px}.heatmap-col-label{font-family:var(--font-mono);font-size:9px;color:var(--text-tertiary);width:22px;text-align:center;flex-shrink:0}.heatmap-cell{width:22px;height:22px;border-radius:3px;flex-shrink:0;cursor:pointer;transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.heatmap-cell:hover{transform:scale(1.15)}.heatmap-cell[data-level="0"]{background:var(--bg-hover)}.heatmap-cell[data-level="1"]{background:var(--accent);opacity:.2}.heatmap-cell[data-level="2"]{background:var(--accent);opacity:.4}.heatmap-cell[data-level="3"]{background:var(--accent);opacity:.65}.heatmap-cell[data-level="4"]{background:var(--accent);opacity:.85}.heatmap-cell[data-level="5"]{background:var(--accent);opacity:1}.heatmap-legend{display:flex;align-items:center;gap:var(--space-2);padding-left:56px;margin-top:var(--space-2)}.heatmap-legend-label{font-family:var(--font-mono);font-size:9px;color:var(--text-tertiary)}.treemap{flex-wrap:wrap;gap:2px;border-radius:var(--radius-lg)}.treemap,.treemap-cell{display:flex;overflow:hidden}.treemap-cell{flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2);min-height:48px;cursor:pointer;transition:opacity var(--duration-fast) var(--ease-out),filter var(--duration-fast) var(--ease-out);position:relative;background:var(--accent)}.treemap-cell:hover{filter:brightness(1.15)}.treemap-label{font-family:var(--font-ui);font-size:10px;font-weight:500;line-height:var(--leading-snug);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.treemap-label,.treemap-value{color:var(--bg-base);text-align:center}.treemap-value{font-family:var(--font-mono);font-size:9px;opacity:.8}.treemap-cell-accent{background:var(--accent)}.treemap-cell-info{background:var(--info)}.treemap-cell-success{background:var(--success)}.treemap-cell-warning{background:var(--warning)}.treemap-cell-error{background:var(--error)}.treemap-cell-muted{background:var(--text-secondary)}.treemap-outlined .treemap-cell{background:var(--bg-surface);border:1px solid var(--border-default)}.treemap-outlined .treemap-label{color:var(--text-primary)}.treemap-outlined .treemap-value{color:var(--text-tertiary);opacity:1}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.product-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out)}.product-card:hover{border-color:var(--border-muted)}.product-image{position:relative;height:180px;background:var(--bg-subtle);overflow:hidden;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-faint)}.product-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-slow) var(--ease-out)}.product-card:hover .product-image img{transform:scale(1.04)}.product-badge{position:absolute;top:var(--space-2);left:var(--space-2);font-family:var(--font-ui);font-size:10px;font-weight:600;padding:2px var(--space-2);border-radius:var(--radius-sm);letter-spacing:var(--tracking-wide);text-transform:uppercase}.product-badge-sale{background:var(--error-muted);color:var(--error)}.product-badge-new{background:var(--accent-muted);color:var(--accent)}.product-body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.product-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.product-desc{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.product-price{display:flex;align-items:baseline;gap:var(--space-2)}.product-price-current{font-family:var(--font-display);font-size:var(--text-lg);font-weight:400;color:var(--text-primary);line-height:1}.product-price-old{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);text-decoration:line-through}.product-rating{display:flex;align-items:center;gap:var(--space-1)}.product-rating-stars{display:flex;gap:1px;color:var(--warning)}.product-rating-count{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary)}.product-variants{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.product-color-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--border-default);cursor:pointer;transition:border-color var(--duration-fast) var(--ease-out)}.product-color-dot.is-active,.product-color-dot:hover{border-color:var(--text-primary)}.product-size-btn{padding:2px var(--space-2);font-family:var(--font-ui);font-size:10px;font-weight:500;color:var(--text-secondary);background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;outline:none;transition:all var(--duration-fast) var(--ease-out)}.product-size-btn:hover{border-color:var(--border-muted);color:var(--text-primary)}.product-size-btn.is-active{background:var(--text-primary);color:var(--bg-base);border-color:transparent}.product-quick-add{width:100%;height:34px;display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-ui);font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);background:none;border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;outline:none;transition:all var(--duration-base) var(--ease-out)}.product-quick-add:hover{color:var(--text-primary);border-color:var(--border-muted);background:var(--bg-subtle)}.cart-flyout{position:fixed;top:0;right:0;width:360px;max-width:100%;height:100%;background:var(--bg-elevated);border-left:1px solid var(--border-muted);display:flex;flex-direction:column;z-index:var(--z-overlay);box-shadow:var(--shadow-xl)}.cart-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default)}.cart-title{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.cart-close{background:none;border:none;outline:none;cursor:pointer;color:var(--text-tertiary);padding:0;transition:color var(--duration-fast) var(--ease-out)}.cart-close:hover{color:var(--text-secondary)}.cart-body{flex:1;overflow-y:auto;display:flex;flex-direction:column}.cart-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-faint)}.cart-item-image{width:56px;height:56px;border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border-default);overflow:hidden;flex-shrink:0}.cart-item-image img{width:100%;height:100%;object-fit:cover}.cart-item-body{flex:1;min-width:0}.cart-item-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.cart-item-meta{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.cart-item-price{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);flex-shrink:0}.cart-qty{display:inline-flex;align-items:center;gap:0;border:1px solid var(--border-default);border-radius:var(--radius-md);margin-top:var(--space-2)}.cart-qty-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:var(--text-sm);outline:none;transition:color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.cart-qty-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.cart-qty-value{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-primary);min-width:28px;text-align:center;border-left:1px solid var(--border-default);border-right:1px solid var(--border-default);padding:var(--space-1) 0}.cart-summary{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-default);display:flex;flex-direction:column;gap:var(--space-2)}.cart-summary-row{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary)}.cart-summary-row-total{font-weight:500;color:var(--text-primary);font-size:var(--text-base)}.cart-summary-value{font-family:var(--font-mono)}.cart-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);text-align:center;padding:var(--space-7)}.cart-empty-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.cart-empty-desc{font-size:var(--text-xs);color:var(--text-secondary)}.checkout-flow{display:grid;grid-template-columns:1fr 340px;gap:var(--space-6);align-items:flex-start}@media (max-width:768px){.checkout-flow{grid-template-columns:1fr}}.checkout-main{display:flex;flex-direction:column;gap:var(--space-5)}.checkout-section{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.checkout-section-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default)}.checkout-section-num{width:24px;height:24px;border-radius:50%;background:var(--bg-subtle);border:1px solid var(--border-muted);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);flex-shrink:0}.checkout-section-num.is-done{background:var(--success-muted);border-color:var(--success);color:var(--success)}.checkout-section-num.is-active{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.checkout-section-title{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.checkout-section-body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.checkout-summary{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;position:sticky;top:var(--space-4)}.checkout-summary-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.checkout-summary-body{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.checkout-line-item{display:flex;align-items:center;gap:var(--space-3)}.checkout-line-thumb{width:44px;height:44px;border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border-default);flex-shrink:0;overflow:hidden}.checkout-line-thumb img{width:100%;height:100%;object-fit:cover}.checkout-line-body{flex:1;min-width:0}.checkout-line-name{font-size:var(--text-xs);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.checkout-line-qty{font-size:var(--text-xs);color:var(--text-tertiary)}.checkout-line-price{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-primary);flex-shrink:0}.checkout-divider{height:1px;background:var(--border-faint)}.checkout-total{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-default)}.checkout-total-row{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary)}.checkout-total-row-final{font-weight:500;color:var(--text-primary);font-size:var(--text-base)}.checkout-total-value{font-family:var(--font-mono)}.invoice{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-7);font-family:var(--font-ui);max-width:720px}@media print{.invoice{border:none;border-radius:0;box-shadow:none;padding:0}}.invoice-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4)}.invoice-logo{max-height:36px}.invoice-company{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);text-align:right}.invoice-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--space-5)}.invoice-meta{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-6)}.invoice-meta-group{display:flex;flex-direction:column;gap:var(--space-1)}.invoice-meta-label{font-size:10px;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.invoice-meta-value{font-size:var(--text-sm);color:var(--text-primary)}.invoice-table{width:100%;border-collapse:collapse;margin-bottom:var(--space-5)}.invoice-table thead th{padding:var(--space-2) var(--space-3);text-align:left;font-size:10px;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);border-bottom:1px solid var(--border-default)}.invoice-table thead th:last-child{text-align:right}.invoice-table tbody td{padding:var(--space-3);font-size:var(--text-sm);color:var(--text-primary);border-bottom:1px solid var(--border-faint);vertical-align:top}.invoice-table tbody td:last-child{text-align:right;font-family:var(--font-mono)}.invoice-table tbody tr:last-child td{border-bottom:none}.invoice-item-desc{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.invoice-totals{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-2);margin-bottom:var(--space-6)}.invoice-totals-row{display:flex;align-items:center;gap:var(--space-6);font-size:var(--text-sm);color:var(--text-secondary)}.invoice-totals-row-final{font-weight:500;color:var(--text-primary);font-size:var(--text-base);padding-top:var(--space-2);border-top:1px solid var(--border-default)}.invoice-totals-label{min-width:100px;text-align:right}.invoice-totals-value{font-family:var(--font-mono);min-width:80px;text-align:right}.invoice-footer{padding-top:var(--space-5);border-top:1px solid var(--border-faint);font-size:var(--text-xs);color:var(--text-tertiary);line-height:var(--leading-relaxed);text-align:center}.rating-summary{display:flex;align-items:flex-start;gap:var(--space-5)}.rating-overview{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);flex-shrink:0}.rating-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:300;color:var(--text-primary);letter-spacing:-.02em;line-height:1}.rating-count{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary)}.rating-stars{display:inline-flex;align-items:center;gap:2px}.rating-star{color:var(--border-muted);transition:color var(--duration-fast) var(--ease-out);cursor:pointer}.rating-star.is-filled,.rating-star.is-half{color:var(--warning)}.rating-stars:hover .rating-star,.rating-stars:hover .rating-star:hover,.rating-stars:hover .rating-star:hover~.rating-star{color:var(--border-muted)}.rating-stars .rating-star:hover,.rating-stars .rating-star:hover~.rating-star{color:var(--warning)}.rating-breakdown{flex:1;flex-direction:column}.rating-bar,.rating-breakdown{display:flex;gap:var(--space-2)}.rating-bar{align-items:center}.rating-bar-label{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);width:18px;text-align:right;flex-shrink:0}.rating-bar-track{flex:1;height:4px;background:var(--bg-hover);border-radius:var(--radius-full);overflow:hidden}.rating-bar-fill{height:100%;border-radius:var(--radius-full);background:var(--warning);transition:width .4s ease}.rating-bar-count{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);width:28px;flex-shrink:0}.rating-inline{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary)}.rating-inline .rating-stars{gap:1px}.filter-sidebar{display:flex;flex-direction:column;gap:var(--space-1);width:240px;flex-shrink:0}.filter-group{border-bottom:1px solid var(--border-faint);padding-bottom:var(--space-3);margin-bottom:var(--space-3)}.filter-group:last-child{border-bottom:none;margin-bottom:0}.filter-group-title{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);letter-spacing:var(--tracking-wide);text-transform:uppercase;cursor:pointer;user-select:none;padding:var(--space-2) 0;margin-bottom:var(--space-2)}.filter-group-title:hover{color:var(--text-primary)}.filter-group-arrow{color:var(--text-tertiary);transition:transform var(--duration-base) var(--ease-out);flex-shrink:0}.filter-group.is-collapsed .filter-group-arrow{transform:rotate(-90deg)}.filter-group.is-collapsed .filter-group-body{display:none}.filter-group-body{display:flex;flex-direction:column;gap:var(--space-2)}.filter-option{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast) var(--ease-out)}.filter-option:hover{color:var(--text-primary)}.filter-count{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);background:var(--bg-hover);padding:1px var(--space-2);border-radius:var(--radius-full);margin-left:auto}.filter-pills{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.filter-pill{gap:var(--space-1);font-family:var(--font-ui);font-size:var(--text-xs);padding:3px var(--space-2) 3px var(--space-3);background:var(--accent-muted);border-radius:var(--radius-full);border:1px solid transparent}.filter-pill,.filter-pill-remove{display:inline-flex;align-items:center;color:var(--accent)}.filter-pill-remove{width:14px;height:14px;border-radius:50%;justify-content:center;background:none;border:none;outline:none;cursor:pointer;font-size:9px;line-height:1;transition:all var(--duration-fast) var(--ease-out)}.filter-pill-remove:hover{background:var(--error-muted);color:var(--error)}.filter-clear{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-tertiary);background:none;border:none;outline:none;cursor:pointer;padding:0;transition:color var(--duration-fast) var(--ease-out)}.filter-clear:hover{color:var(--error)}.article{max-width:680px;margin:0 auto;padding:var(--space-6) var(--space-4);font-family:var(--font-ui)}.article-hero{margin-bottom:var(--space-7);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-faint)}.article-hero-title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:300;color:var(--text-primary);letter-spacing:-.03em;line-height:var(--leading-tight);margin-bottom:var(--space-3)}.article-hero-subtitle{font-size:var(--text-lg);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:560px}.article-meta{display:flex;align-items:center;gap:var(--space-4);font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);letter-spacing:.03em;margin-top:var(--space-4)}.article-meta-sep{width:3px;height:3px;border-radius:50%;background:var(--border-strong);flex-shrink:0}.article-author{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-5)}.article-author-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-subtle);border:1px solid var(--border-default);flex-shrink:0;object-fit:cover}.article-author-name{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.article-author-bio{font-size:var(--text-xs);color:var(--text-secondary)}.article-author-bio,.article-body{line-height:var(--leading-relaxed)}.article-body{color:var(--text-primary);font-size:var(--text-base)}.article-body h2{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:400;letter-spacing:-.02em;margin:var(--space-8) 0 var(--space-4);color:var(--text-primary)}.article-body h3{font-size:var(--text-lg);font-weight:500;margin:var(--space-6) 0 var(--space-3);color:var(--text-primary)}.article-body h4{font-size:var(--text-base);font-weight:600;margin:var(--space-5) 0 var(--space-2);color:var(--text-primary)}.article-body ol,.article-body p,.article-body ul{margin:var(--space-4) 0;color:var(--text-secondary)}.article-body ol,.article-body ul{padding-left:var(--space-5)}.article-body li{margin-bottom:var(--space-2)}.article-body img{width:100%;border-radius:var(--radius-lg);margin:var(--space-5) 0}.article-body code{font-family:var(--font-mono);font-size:.9em;background:var(--bg-subtle);border:1px solid var(--border-faint);border-radius:var(--radius-sm);padding:1px 5px}.article-body a{color:var(--accent);text-decoration:none;transition:opacity .12s}.article-body a:hover{opacity:.75}.article-body figcaption{font-size:var(--text-xs);color:var(--text-tertiary);text-align:center;margin-top:var(--space-2)}.article-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-7);padding-top:var(--space-5);border-top:1px solid var(--border-faint)}.article-tag{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3);transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out);cursor:pointer;text-decoration:none}.article-tag:hover{color:var(--text-primary);border-color:var(--border-muted)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.blog-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out),background .15s ease;display:flex;flex-direction:column}.blog-card:hover{border-color:var(--border-muted);background:var(--bg-elevated)}.blog-card-image{height:180px;background:var(--bg-subtle);border-bottom:1px solid var(--border-default);overflow:hidden}.blog-card-image img{width:100%;height:100%;object-fit:cover}.blog-card-body{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);flex:1}.blog-card-title{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--text-primary);line-height:var(--leading-snug)}.blog-card-excerpt{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-card-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-faint);display:flex;align-items:center;justify-content:space-between}.blog-card-date{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}.blog-featured{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out)}.blog-featured:hover{border-color:var(--border-muted)}.blog-featured .blog-card-image{height:100%;border-bottom:none;border-right:1px solid var(--border-default)}.blog-featured .blog-card-body{padding:var(--space-6);justify-content:center;gap:var(--space-3)}.blog-featured .blog-card-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;letter-spacing:-.02em}.blog-author{display:inline-flex;align-items:center;gap:var(--space-2)}.blog-author-avatar{width:24px;height:24px;border-radius:var(--radius-full);background:var(--bg-subtle);border:1px solid var(--border-default);flex-shrink:0;object-fit:cover}.blog-author-name{font-size:var(--text-xs);font-weight:500;color:var(--text-primary)}.blog-category{display:inline-block;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:var(--accent-muted);border-radius:var(--radius-full);padding:2px var(--space-2)}.hero{width:100%;padding:var(--space-9) var(--space-6);display:flex;align-items:center}.hero-centered{text-align:center;flex-direction:column;justify-content:center;align-items:center}.hero-centered .hero-desc{max-width:520px;margin-left:auto;margin-right:auto}.hero-centered .hero-actions{justify-content:center}.hero-split{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);align-items:center}.hero-split-image{width:100%;border-radius:var(--radius-xl);background:var(--bg-subtle);border:1px solid var(--border-default);overflow:hidden}.hero-split-image img{width:100%;height:auto;display:block}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--space-4)}.hero-badge:before{content:"";width:20px;height:1px;background:var(--accent);display:block}.hero-title{font-size:64px;line-height:.94;letter-spacing:-.04em;color:var(--text-primary);margin-bottom:var(--space-4)}.hero-subtitle,.hero-title{font-family:var(--font-display);font-weight:300}.hero-subtitle{font-size:var(--text-xl);letter-spacing:-.01em;margin-bottom:var(--space-3)}.hero-desc,.hero-subtitle{color:var(--text-secondary);line-height:var(--leading-relaxed)}.hero-desc{font-family:var(--font-ui);font-size:var(--text-sm);max-width:440px;margin-bottom:var(--space-6)}.hero-actions{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.toc{position:sticky;top:var(--space-6);width:220px;max-height:calc(100vh - var(--space-9));overflow-y:auto;padding:var(--space-4) 0;flex-shrink:0}.toc-title{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--text-tertiary);padding:0 var(--space-4) var(--space-3);border-bottom:1px solid var(--border-faint);margin-bottom:var(--space-2)}.toc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1px}.toc-list .toc-list{padding-left:var(--space-4)}.toc-item,.toc-item a{display:block}.toc-item a{padding:var(--space-2) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;border-left:2px solid transparent;transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out);line-height:var(--leading-normal)}.toc-item a:hover{color:var(--text-primary)}.toc-item.is-active a{color:var(--accent);border-left-color:var(--accent);font-weight:500}.toc-progress{width:100%;height:2px;background:var(--border-faint);margin-top:var(--space-4);overflow:hidden}.toc-progress,.toc-progress-bar{border-radius:var(--radius-full)}.toc-progress-bar{height:100%;background:var(--accent);width:0;transition:width var(--duration-base) var(--ease-out)}.blockquote{position:relative;padding:var(--space-4) var(--space-5);margin:var(--space-5) 0;border-left:3px solid var(--accent);background:var(--bg-subtle);border-radius:0 var(--radius-md) var(--radius-md) 0;font-style:italic;font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed)}.blockquote p{margin:0}.blockquote-cite{display:block;margin-top:var(--space-3);font-style:normal;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.02em}.blockquote-cite:before{content:"\2014\00A0"}.pullquote{text-align:center;padding:var(--space-7) var(--space-6);margin:var(--space-7) 0;position:relative;max-width:600px;margin-left:auto;margin-right:auto}.pullquote p{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);letter-spacing:-.02em;line-height:var(--leading-relaxed);margin:0}.pullquote .blockquote-cite{margin-top:var(--space-4);font-size:var(--text-sm)}.pullquote-mark{display:block;font-family:var(--font-display);font-size:72px;font-weight:300;line-height:1;color:var(--accent);opacity:.35;user-select:none;margin-bottom:var(--space-2)}.pullquote-mark:before{content:"\201C"}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-3)}.gallery-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-subtle);cursor:pointer;transition:box-shadow var(--duration-base) var(--ease-out)}.gallery-item:hover{box-shadow:var(--shadow-md)}.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--duration-base) var(--ease-out)}.gallery-item:hover img{transform:scale(1.03)}.gallery-item:after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.35);opacity:0;transition:opacity var(--duration-fast) var(--ease-out)}.gallery-item:hover:after{opacity:1}.gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:var(--space-3) var(--space-4);font-family:var(--font-ui);font-size:var(--text-xs);color:#fff;z-index:1;opacity:0;transform:translateY(4px);transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.gallery-item:hover .gallery-caption{opacity:1;transform:translateY(0)}.gallery-lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.gallery-lightbox img{max-width:100%;max-height:90vh;border-radius:var(--radius-lg);object-fit:contain}.gallery-lightbox-close,.gallery-lightbox-nav{position:absolute;background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-full);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:background var(--duration-fast) var(--ease-out);outline:none}.gallery-lightbox-close{top:var(--space-5);right:var(--space-5)}.gallery-lightbox-nav{top:50%;transform:translateY(-50%)}.gallery-lightbox-nav:first-of-type{left:var(--space-5)}.gallery-lightbox-nav:last-of-type{right:var(--space-5)}.gallery-lightbox-close:hover,.gallery-lightbox-nav:hover{background:var(--bg-hover)}.comment{display:flex;gap:var(--space-3);padding:var(--space-4) 0;border-bottom:1px solid var(--border-faint)}.comment:last-child{border-bottom:none}.comment-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--bg-subtle);border:1px solid var(--border-default);flex-shrink:0;object-fit:cover}.comment-body{flex:1;min-width:0}.comment-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.comment-author{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.comment-date{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}.comment-author-badge{display:inline-block;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;padding:1px 6px;border-radius:var(--radius-full);background:var(--accent-muted);color:var(--accent)}.comment-author-badge-admin{background:var(--warning-muted);color:var(--warning)}.comment-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.comment-actions{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-2)}.comment-action{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-tertiary);background:none;border:none;outline:none;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:var(--space-1);transition:color var(--duration-fast) var(--ease-out)}.comment-action:hover{color:var(--text-secondary)}.comment-reply{margin-left:var(--space-7);padding-left:var(--space-4);border-left:1px solid var(--border-faint)}.comment-form{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5) 0}.comment-form-textarea{width:100%;min-height:80px;padding:var(--space-3) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);resize:vertical;outline:none;transition:border-color var(--duration-fast) var(--ease-out);line-height:var(--leading-relaxed)}.comment-form-textarea:focus{border-color:var(--accent)}.comment-form-actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4)}.dash-widget{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;transition:border-color var(--duration-base) var(--ease-out)}.dash-widget:hover{border-color:var(--border-muted)}.dash-widget-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-faint);gap:var(--space-3)}.dash-widget-title{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.dash-widget-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.dash-widget-body{flex:1;padding:var(--space-4) var(--space-5)}.dash-widget-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-faint);font-size:var(--text-xs);color:var(--text-tertiary)}.dash-widget-2x{grid-column:span 2}.dash-widget-full{grid-column:1/-1}.dash-placeholder{background:var(--accent-muted);border:2px dashed var(--accent);border-radius:var(--radius-lg);opacity:.5;min-height:120px}.notif-center{background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-xl);width:380px;max-height:480px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg)}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default)}.notif-header-title{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.notif-mark-read{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--accent);cursor:pointer;background:none;border:none;outline:none;padding:0;transition:opacity .12s}.notif-mark-read:hover{opacity:.75}.notif-tabs{display:flex;align-items:center;gap:0;border-bottom:1px solid var(--border-faint);padding:0 var(--space-5)}.notif-tab{padding:var(--space-2) var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;background:none;outline:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.notif-tab.is-active,.notif-tab:hover{color:var(--text-primary)}.notif-tab.is-active{border-bottom-color:var(--text-primary);font-weight:500}.notif-list{flex:1;overflow-y:auto}.notif-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-5);cursor:pointer;transition:background var(--duration-fast) var(--ease-out);position:relative}.notif-item:hover{background:var(--bg-hover)}.notif-item-icon{width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-item-body{flex:1;min-width:0}.notif-item-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.notif-item-msg{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-top:2px}.notif-item-time{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);margin-top:var(--space-1)}.notif-item.is-unread:before{content:"";position:absolute;left:var(--space-2);top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--accent)}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-5);text-align:center;gap:var(--space-2)}.notif-empty-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.notif-empty-desc{font-size:var(--text-xs);color:var(--text-tertiary)}.settings-page{display:grid;grid-template-columns:220px 1fr;gap:0;min-height:100%}.settings-nav{display:flex;flex-direction:column;gap:2px;padding:var(--space-5) var(--space-4);border-right:1px solid var(--border-default)}.settings-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;background:none;outline:none;width:100%;text-align:left}.settings-nav-item:hover{background:var(--bg-subtle);color:var(--text-primary)}.settings-nav-item.is-active{background:var(--bg-hover);color:var(--text-primary);font-weight:500}.settings-nav-item.is-active .fi{color:var(--accent)}.settings-content{padding:var(--space-6) var(--space-7);max-width:640px}.settings-section{margin-bottom:var(--space-7)}.settings-section-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;color:var(--text-primary);letter-spacing:-.01em;margin-bottom:var(--space-1)}.settings-section-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-5)}.settings-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-5);padding:var(--space-4) 0;border-bottom:1px solid var(--border-faint)}.settings-row:last-child{border-bottom:none}.settings-row-info{flex:1;min-width:0}.settings-row-label{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);margin-bottom:2px}.settings-row-desc{font-size:var(--text-xs);color:var(--text-tertiary);line-height:var(--leading-relaxed)}.settings-row-control{flex-shrink:0}.settings-divider{height:1px;background:var(--border-default);margin:var(--space-6) 0}.team-list{display:flex;flex-direction:column;border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-surface)}.team-member{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border-faint);transition:background .1s ease}.team-member:last-child{border-bottom:none}.team-member-avatar,.team-member:hover{background:var(--bg-subtle)}.team-member-avatar{width:32px;height:32px;border-radius:var(--radius-full);border:1px solid var(--border-default);flex-shrink:0;object-fit:cover}.team-member-info{flex:1;min-width:0}.team-member-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.team-member-email,.team-member-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-member-email{font-size:var(--text-xs);color:var(--text-secondary)}.team-role{display:inline-block;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border-faint);white-space:nowrap}.team-role-owner{background:var(--accent-muted);color:var(--accent);border-color:transparent}.team-role-admin{background:var(--warning-muted);color:var(--warning);border-color:transparent}.team-role-member{background:var(--bg-hover);color:var(--text-tertiary)}.team-invite{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-default);background:var(--bg-subtle)}.team-invite-input{flex:1;min-width:0;padding:var(--space-2) var(--space-3);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);outline:none;transition:border-color var(--duration-fast) var(--ease-out)}.team-invite-input:focus{border-color:var(--accent)}.team-actions{gap:var(--space-2);flex-shrink:0}.team-action-btn,.team-actions{display:flex;align-items:center}.team-action-btn{width:28px;height:28px;justify-content:center;background:none;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;outline:none;transition:all var(--duration-fast) var(--ease-out)}.team-action-btn:hover{color:var(--text-secondary);background:var(--bg-subtle);border-color:var(--border-default)}.audit-log{display:flex;flex-direction:column;border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-surface)}.audit-filter{gap:var(--space-3);border-bottom:1px solid var(--border-default);background:var(--bg-subtle);flex-wrap:wrap}.audit-entry,.audit-filter{display:flex;align-items:center;padding:var(--space-3) var(--space-5)}.audit-entry{gap:var(--space-4);border-bottom:1px solid var(--border-faint);transition:background .1s ease;font-size:var(--text-sm)}.audit-entry:last-child{border-bottom:none}.audit-entry:hover{background:var(--bg-subtle)}.audit-time{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);white-space:nowrap}.audit-actor,.audit-time{flex-shrink:0;min-width:140px}.audit-actor{display:inline-flex;align-items:center;gap:var(--space-2)}.audit-actor-avatar{width:22px;height:22px;border-radius:var(--radius-full);background:var(--bg-subtle);border:1px solid var(--border-default);flex-shrink:0;object-fit:cover}.audit-actor-name{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary)}.audit-action,.audit-actor-name{font-weight:500;white-space:nowrap}.audit-action{display:inline-block;font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0}.audit-action-create{background:var(--success-muted);color:var(--success)}.audit-action-update{background:var(--info-muted);color:var(--info)}.audit-action-delete{background:var(--error-muted);color:var(--error)}.audit-target{flex:1;min-width:0;font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-stack{position:fixed;z-index:9990;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none;max-width:400px}.toast-stack>*{pointer-events:auto}.toast-top-right{top:var(--space-5);right:var(--space-5)}.toast-top-left{top:var(--space-5);left:var(--space-5)}.toast-bottom-right{bottom:var(--space-5);right:var(--space-5)}.toast-bottom-left{bottom:var(--space-5);left:var(--space-5)}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-lg);max-width:360px;font-size:var(--text-sm);color:var(--text-primary);line-height:var(--leading-normal);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.toast-success{border-color:var(--success);background:var(--success-muted)}.toast-warning{border-color:var(--warning);background:var(--warning-muted)}.toast-error{border-color:var(--error);background:var(--error-muted)}.toast-info{border-color:var(--info);background:var(--info-muted)}.toast-body{flex:1;min-width:0}.toast-icon{flex-shrink:0;margin-top:1px}.toast-content{display:flex;flex-direction:column;gap:2px}.toast-title{font-weight:500}.toast-msg{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.toast-close{cursor:pointer;color:var(--text-tertiary);background:none;border:none;outline:none;padding:0;line-height:1;margin-top:1px;flex-shrink:0;transition:color .12s}.toast-close:hover{color:var(--text-secondary)}.toast-progress{position:absolute;bottom:0;left:0;height:3px;width:100%;background:var(--accent);transform-origin:left;animation:toast-progress-shrink var(--duration-base,4s) linear forwards}@keyframes toast-progress-shrink{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.empty-state{flex-direction:column;text-align:center;padding:var(--space-9) var(--space-6);gap:var(--space-3)}.empty-state,.empty-state-icon{display:flex;align-items:center;justify-content:center}.empty-state-icon{width:56px;height:56px;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-bottom:var(--space-2);color:var(--text-tertiary)}.empty-state-title{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.empty-state-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:320px}.empty-state-action{margin-top:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.empty-state-xl{padding:var(--space-10,120px) var(--space-7)}.empty-state-xl .empty-state-icon{width:80px;height:80px;border-radius:var(--radius-xl)}.empty-state-xl .empty-state-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:300;letter-spacing:-.01em}.empty-state-xl .empty-state-desc{font-size:var(--text-base);max-width:400px}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-6);text-align:center;gap:var(--space-3)}.error-code{font-size:120px;font-weight:300;line-height:1;letter-spacing:-.06em;opacity:.12;user-select:none}.error-code,.error-title{font-family:var(--font-display);color:var(--text-primary)}.error-title{font-size:var(--text-2xl);font-weight:400;letter-spacing:-.02em;margin-top:var(--space-2)}.error-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:380px}.error-actions{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-5)}.error-illustration{width:200px;height:160px;background:var(--bg-subtle);border:1px solid var(--border-faint);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);color:var(--text-disabled)}@keyframes skel-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skel-avatar,.skel-btn,.skel-image,.skel-text,.skel-title{background:linear-gradient(90deg,var(--bg-hover) 25%,var(--bg-subtle) 50%,var(--bg-hover) 75%);background-size:800px 100%;animation:skel-shimmer 1.6s ease-in-out infinite;border-radius:var(--radius-md)}.skel-text{height:14px;width:100%}.skel-title{height:20px;width:60%}.skel-btn{height:36px;width:100px;border-radius:var(--radius-md)}.skel-avatar{width:32px;height:32px;border-radius:var(--radius-full);flex-shrink:0}.skel-image{width:100%;height:140px;border-radius:var(--radius-lg)}.skel-page{gap:var(--space-5);padding:var(--space-6)}.skel-page,.skel-page-header{display:flex;flex-direction:column}.skel-page-header{gap:var(--space-3)}.skel-page-body{display:flex;flex-direction:column;gap:var(--space-2)}.skel-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5)}.skel-card,.skel-list{display:flex;flex-direction:column;gap:var(--space-3)}.skel-list-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0}.skel-list-row-body{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.mega-menu{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--bg-elevated);border:1px solid var(--border-muted);border-top:none;border-radius:0 0 var(--radius-xl) var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-5) var(--space-6)}.mega-menu-inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-6)}.mega-menu-col{display:flex;flex-direction:column;gap:var(--space-1)}.mega-menu-title{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--text-tertiary);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-faint);margin-bottom:var(--space-2)}.mega-menu-link{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);text-decoration:none;transition:background var(--duration-fast) var(--ease-out);cursor:pointer}.mega-menu-link-icon,.mega-menu-link:hover{background:var(--bg-subtle)}.mega-menu-link-icon{width:28px;height:28px;border-radius:var(--radius-md);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.mega-menu-link-body{flex:1;min-width:0}.mega-menu-link-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);line-height:var(--leading-snug)}.mega-menu-link-desc{font-size:var(--text-xs);color:var(--text-tertiary);line-height:var(--leading-relaxed);margin-top:1px}.mega-menu-featured{background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);cursor:pointer;transition:border-color var(--duration-base) var(--ease-out)}.mega-menu-featured:hover{border-color:var(--border-muted)}.mega-menu-featured-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.mega-menu-featured-desc{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.mobile-overlay{position:fixed;inset:0;z-index:999;background:rgba(0,0,0,.42);opacity:0;pointer-events:none;transition:opacity var(--duration-base) var(--ease-out)}.mobile-overlay.is-open{opacity:1;pointer-events:auto}.mobile-drawer{position:fixed;top:0;left:0;bottom:0;z-index:1000;width:280px;background:var(--bg-elevated);border-right:1px solid var(--border-muted);display:flex;flex-direction:column;transform:translateX(-100%);transition:transform var(--duration-base) var(--ease-out)}.mobile-drawer.is-open{transform:translateX(0)}.mobile-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default)}.mobile-drawer-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:300;color:var(--text-primary);letter-spacing:-.01em}.mobile-drawer-close{background:none;border:none;outline:none;cursor:pointer;color:var(--text-tertiary);padding:var(--space-1);border-radius:var(--radius-sm);transition:color .12s;display:flex;align-items:center}.mobile-drawer-close:hover{color:var(--text-secondary)}.mobile-drawer-body{flex:1;padding:var(--space-3) 0;overflow-y:auto}.mobile-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;background:none;outline:none;width:100%;text-align:left}.mobile-nav-item:hover{color:var(--text-primary);background:var(--bg-subtle)}.mobile-nav-item.is-active{color:var(--text-primary);background:var(--bg-hover);font-weight:500}.mobile-nav-item.is-active .fi{color:var(--accent)}.mobile-nav-group-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-5);font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);cursor:pointer;background:none;border:none;outline:none;width:100%;text-align:left}.mobile-nav-group-arrow{color:var(--text-tertiary);transition:transform .2s ease;flex-shrink:0}.mobile-nav-group.is-open .mobile-nav-group-arrow{transform:rotate(180deg)}.mobile-nav-group-items{max-height:0;overflow:hidden;transition:max-height .3s ease}.mobile-nav-group.is-open .mobile-nav-group-items{max-height:500px}.mobile-nav-group-items .mobile-nav-item{padding-left:var(--space-7)}.sidebar-collapsible{width:220px;background:var(--bg-surface);border-right:1px solid var(--border-default);display:flex;flex-direction:column;padding:var(--space-3) 0;transition:width var(--duration-base) var(--ease-out);overflow:hidden;position:relative;flex-shrink:0}.sidebar-collapsible.is-collapsed{width:56px}.sidebar-collapse-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;position:absolute;top:var(--space-3);right:var(--space-2);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;color:var(--text-tertiary);z-index:2;transition:all var(--duration-fast) var(--ease-out);outline:none}.sidebar-collapse-btn:hover{color:var(--text-secondary);border-color:var(--border-muted)}.sidebar-collapsible.is-collapsed .sidebar-collapse-btn{right:50%;transform:translateX(50%);top:var(--space-2)}.sidebar-collapsible .sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;background:none;outline:none;width:100%;text-align:left;white-space:nowrap;position:relative}.sidebar-collapsible .sidebar-item:hover{color:var(--text-primary);background:var(--bg-subtle)}.sidebar-collapsible .sidebar-item.is-active{color:var(--text-primary);background:var(--bg-hover);font-weight:500}.sidebar-collapsible .sidebar-item.is-active .fi{color:var(--accent)}.sidebar-collapsible .sidebar-item-label{opacity:1;transition:opacity var(--duration-fast) var(--ease-out);overflow:hidden}.sidebar-collapsible.is-collapsed .sidebar-item-label{opacity:0;width:0}.sidebar-collapsible.is-collapsed .sidebar-item{justify-content:center;padding:var(--space-2) 0}.sidebar-collapsible.is-collapsed .sidebar-item:after{content:attr(data-tooltip);position:absolute;left:calc(100% + var(--space-2));top:50%;transform:translateY(-50%);background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-md);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);color:var(--text-primary);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--duration-fast) var(--ease-out);z-index:10}.sidebar-collapsible.is-collapsed .sidebar-item:hover:after{opacity:1}.sidebar-collapsible .sidebar-section-label{transition:opacity var(--duration-fast) var(--ease-out)}.sidebar-collapsible.is-collapsed .sidebar-section-label{opacity:0;height:0;padding:0;margin:0;overflow:hidden}.patient-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:border-color var(--duration-base) var(--ease-out)}.patient-card:hover{border-color:var(--border-muted)}.patient-card-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--bg-subtle);border:1px solid var(--border-default);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:var(--text-md);font-weight:600;color:var(--text-secondary)}.patient-card-body{flex:1;min-width:0}.patient-card-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.patient-card-id{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.patient-card-meta{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary)}.patient-card-blood{display:inline-flex;padding:2px var(--space-2);background:var(--error-muted);color:var(--error);font-family:var(--font-mono);font-size:10px;font-weight:600;border-radius:var(--radius-sm);letter-spacing:.04em}.patient-card-status{width:8px;height:8px;border-radius:var(--radius-full);background:var(--success);flex-shrink:0}.vitals-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.vitals-grid>*{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4);background:var(--bg-subtle);border-radius:var(--radius-lg)}.vitals-icon{width:24px;height:24px;color:var(--accent);flex-shrink:0}.vitals-value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.vitals-unit{color:var(--text-tertiary);letter-spacing:var(--tracking-wide)}.vitals-trend,.vitals-unit{font-family:var(--font-mono);font-size:var(--text-xs)}.vitals-trend{font-weight:500}.vitals-trend-up{color:var(--error)}.vitals-trend-down{color:var(--success)}.appointment-slot{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);font-family:var(--font-ui);font-size:var(--text-sm);transition:border-color var(--duration-base) var(--ease-out)}.appointment-slot:hover{border-color:var(--border-muted)}.appointment-slot-time{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;min-width:56px}.appointment-slot-info{flex:1;min-width:0}.appointment-slot-doctor{font-weight:500;color:var(--text-primary)}.appointment-slot-dept{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:1px}.appointment-available{border-left:3px solid var(--success)}.appointment-booked{border-left:3px solid var(--accent)}.appointment-past{border-left:3px solid var(--border-muted);opacity:.65}.prescription{padding:var(--space-4) var(--space-5);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-2)}.prescription-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.prescription-details{display:flex;flex-wrap:wrap;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary)}.prescription-refills{display:inline-flex;padding:2px var(--space-2);background:var(--info-muted);color:var(--info);font-family:var(--font-mono);font-size:10px;font-weight:500;border-radius:var(--radius-sm)}.course-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out)}.course-card:hover{border-color:var(--border-muted)}.course-card-thumb{height:140px;background:var(--bg-subtle);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-default)}.course-card-body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.course-card-title{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.course-card-instructor{font-size:var(--text-xs);color:var(--text-secondary)}.course-card-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--text-tertiary)}.course-card-level{display:inline-flex;padding:2px var(--space-2);background:var(--accent-muted);color:var(--accent);font-family:var(--font-mono);font-size:10px;font-weight:500;border-radius:var(--radius-sm);letter-spacing:.04em}.course-progress{display:flex;align-items:center;gap:var(--space-3)}.course-progress-bar{flex:1;height:4px;background:var(--bg-hover);border-radius:var(--radius-full);overflow:hidden}.course-progress-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-default)}.course-progress-text{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;min-width:32px;text-align:right}.lesson-nav{display:flex;flex-direction:column;gap:1px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.lesson-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.lesson-item:hover{background:var(--bg-subtle)}.lesson-item.is-done{color:var(--text-tertiary)}.lesson-item.is-done:before{content:"\2713";color:var(--success);font-size:var(--text-xs);font-weight:600;min-width:16px;text-align:center}.lesson-item.is-active{background:var(--accent-muted);color:var(--text-primary);font-weight:500;border-left:3px solid var(--accent)}.lesson-item.is-locked{color:var(--text-disabled);pointer-events:none}.lesson-item.is-locked:after{content:"\1F512";font-size:10px;margin-left:auto}.quiz-question{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg)}.quiz-question-text{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--text-primary);line-height:var(--leading-normal)}.quiz-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--duration-base) var(--ease-out)}.quiz-option:hover{border-color:var(--border-muted);background:var(--bg-subtle)}.quiz-option.is-selected{border-color:var(--accent);background:var(--accent-muted);color:var(--text-primary)}.quiz-option.is-correct{border-color:var(--success);background:var(--success-muted);color:var(--success)}.quiz-option.is-wrong{border-color:var(--error);background:var(--error-muted);color:var(--error)}.grade-table{width:100%;border-collapse:collapse;font-family:var(--font-ui)}.grade-table thead th{padding:var(--space-2) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);border-bottom:1px solid var(--border-default)}.grade-table tbody td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);border-bottom:1px solid var(--border-faint)}.grade-table tbody tr:hover td{background:var(--bg-subtle)}.grade-letter{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600;background:var(--accent-muted);color:var(--accent)}.certificate{max-width:640px;margin:0 auto;padding:var(--space-8);background:var(--bg-surface);border:3px double var(--border-strong);border-radius:var(--radius-xl);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.certificate-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:300;color:var(--text-primary);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight)}.certificate-name{font-family:var(--font-display);font-size:var(--text-xl);color:var(--accent);font-weight:400}.certificate-course{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-secondary)}.certificate-date{font-family:var(--font-mono)}.certificate-date,.certificate-sig{font-size:var(--text-xs);color:var(--text-tertiary)}.certificate-sig{width:160px;border-top:1px solid var(--border-muted);padding-top:var(--space-2);margin-top:var(--space-4);font-family:var(--font-ui)}.transaction-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);font-family:var(--font-ui);font-size:var(--text-sm);border-bottom:1px solid var(--border-faint);transition:background var(--duration-fast) var(--ease-out)}.transaction-row:last-child{border-bottom:none}.transaction-row:hover{background:var(--bg-subtle)}.transaction-date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;min-width:72px}.transaction-desc{flex:1;min-width:0;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-amount{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:500;white-space:nowrap}.transaction-credit .transaction-amount{color:var(--success)}.transaction-debit .transaction-amount{color:var(--error)}.transaction-category{display:inline-flex;padding:2px var(--space-2);background:var(--bg-subtle);color:var(--text-secondary);font-size:10px;font-weight:500;border-radius:var(--radius-sm);letter-spacing:.03em;white-space:nowrap}.transaction-status{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.portfolio-card{padding:var(--space-4) var(--space-5);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-2);transition:border-color var(--duration-base) var(--ease-out)}.portfolio-card:hover{border-color:var(--border-muted)}.portfolio-card-header{display:flex;align-items:center;justify-content:space-between}.portfolio-card-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.portfolio-card-ticker{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.06em}.portfolio-card-value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:300;color:var(--text-primary);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.portfolio-card-change{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500}.portfolio-change-up{color:var(--success)}.portfolio-change-down{color:var(--error)}.portfolio-card-alloc{height:4px;background:var(--bg-hover);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-1)}.portfolio-card-alloc-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-default)}.market-ticker{display:flex;gap:var(--space-5);padding:var(--space-2) var(--space-4);background:var(--bg-subtle);border-radius:var(--radius-md);overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.market-ticker::-webkit-scrollbar{display:none}.market-ticker-item{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-xs);flex-shrink:0}.market-ticker-symbol{font-weight:600;color:var(--text-primary);letter-spacing:.04em}.market-ticker-price{color:var(--text-secondary)}.market-ticker-change{font-weight:500}.market-ticker-up{color:var(--success)}.market-ticker-down{color:var(--error)}.balance-card{padding:var(--space-5) var(--space-6);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--space-2)}.balance-card-type{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:var(--tracking-wide);text-transform:uppercase}.balance-card-amount{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:300;color:var(--text-primary);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.balance-card-updated{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary)}.balance-actions{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.balance-actions>*{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-ui);font-size:var(--text-xs);font-weight:500;border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-subtle);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-base) var(--ease-out)}.balance-actions>:hover{border-color:var(--border-muted);color:var(--text-primary);background:var(--bg-hover)}.contact-card{display:flex;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:border-color var(--duration-base) var(--ease-out)}.contact-card:hover{border-color:var(--border-muted)}.contact-card-avatar{width:44px;height:44px;border-radius:var(--radius-full);background:var(--bg-subtle);border:1px solid var(--border-default);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.contact-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.contact-card-name{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.contact-card-company{font-size:var(--text-xs);color:var(--text-secondary)}.contact-card-details{display:flex;flex-wrap:wrap;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-1)}.contact-card-tags{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-2)}.contact-card-tags>*{display:inline-flex;padding:1px var(--space-2);background:var(--bg-subtle);color:var(--text-secondary);font-size:10px;border-radius:var(--radius-full);border:1px solid var(--border-default)}.contact-card-last{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);margin-top:var(--space-1)}.contact-actions{display:flex;gap:var(--space-2);flex-shrink:0;align-self:flex-start}.contact-actions>*{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.contact-actions>:hover{border-color:var(--border-muted);color:var(--text-primary)}.deal-pipeline{display:flex;gap:var(--space-3);overflow-x:auto;padding-bottom:var(--space-2);-webkit-overflow-scrolling:touch}.deal-pipeline::-webkit-scrollbar{height:4px}.deal-pipeline::-webkit-scrollbar-thumb{background:var(--border-muted);border-radius:var(--radius-full)}.deal-stage{min-width:240px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-2)}.deal-stage-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--bg-subtle);border-radius:var(--radius-md)}.deal-stage-name{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;color:var(--text-primary);letter-spacing:var(--tracking-wide);text-transform:uppercase}.deal-stage-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary)}.deal-card{padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-1);cursor:grab;transition:border-color var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out)}.deal-card:hover{border-color:var(--border-muted);box-shadow:var(--shadow-sm)}.deal-card-company{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.deal-card-value{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent);font-weight:500}.deal-card-footer{justify-content:space-between;font-size:10px;color:var(--text-tertiary);margin-top:var(--space-1)}.deal-card-footer,.lead-score{display:flex;align-items:center}.lead-score{width:56px;height:56px;border-radius:var(--radius-full);justify-content:center;font-family:var(--font-mono);font-size:var(--text-md);font-weight:600;border:3px solid;flex-shrink:0}.lead-score-high{color:var(--success)}.lead-score-medium{color:var(--warning)}.lead-score-low{color:var(--error)}.interaction-log{display:flex;flex-direction:column;position:relative;padding-left:var(--space-5)}.interaction-log:before{content:"";position:absolute;left:11px;top:0;bottom:0;width:1px;background:var(--border-default)}.interaction-item{display:flex;gap:var(--space-3);padding:var(--space-3) 0;position:relative}.interaction-item-icon{width:24px;height:24px;border-radius:var(--radius-full);background:var(--bg-surface);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1;margin-left:calc(-1 * var(--space-5) - 12px);color:var(--text-tertiary);font-size:11px}.interaction-item-body{flex:1;min-width:0}.interaction-item-desc{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);line-height:var(--leading-normal)}.interaction-item-meta{display:flex;gap:var(--space-3);font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);margin-top:2px}.manuscript{max-width:680px;margin:0 auto;padding:var(--space-7) var(--space-6);font-family:var(--font-display);font-size:var(--text-md);line-height:var(--leading-relaxed);color:var(--text-primary)}.manuscript-title{font-size:var(--text-3xl);font-weight:300;line-height:var(--leading-tight);margin-bottom:var(--space-6);text-align:center}.manuscript-chapter,.manuscript-title{font-family:var(--font-display);letter-spacing:var(--tracking-tight);color:var(--text-primary)}.manuscript-chapter{font-size:var(--text-xl);font-weight:400;margin-top:var(--space-8);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-faint)}.editor-toolbar{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);flex-wrap:wrap}.editor-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:var(--text-sm);transition:all var(--duration-fast) var(--ease-out)}.editor-btn:hover{background:var(--bg-subtle);color:var(--text-primary);border-color:var(--border-default)}.editor-btn.is-active{background:var(--accent-muted);color:var(--accent);border-color:transparent}.editor-divider{width:1px;height:20px;background:var(--border-default);margin:0 var(--space-1);flex-shrink:0}.revision-mark{font-family:inherit;font-size:inherit;padding:1px 2px;border-radius:var(--radius-sm)}.revision-added{background:var(--success-muted);color:var(--success);text-decoration:none}.revision-deleted{background:var(--error-muted);color:var(--error);text-decoration:line-through}.revision-comment{background:var(--warning-muted);color:var(--warning);border-bottom:2px solid var(--warning);cursor:pointer}.footnote-ref{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--accent);cursor:pointer;vertical-align:super;line-height:1;min-width:14px;height:14px;background:var(--accent-muted);border-radius:var(--radius-sm);padding:0 3px;transition:background var(--duration-fast) var(--ease-out);position:relative}.footnote-ref:hover{background:var(--accent);color:var(--bg-base)}.footnote-content{display:none;position:absolute;bottom:calc(100% + var(--space-2));left:50%;transform:translateX(-50%);width:280px;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);z-index:var(--z-tooltip)}.footnote-ref:hover .footnote-content{display:block}.footnote{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);padding:var(--space-2) 0;border-top:1px solid var(--border-faint);display:flex;gap:var(--space-2)}.footnote-num{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--accent);min-width:16px;flex-shrink:0}.query-editor{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.query-editor-body{display:flex;min-height:120px}.query-editor-lines{padding:var(--space-3) var(--space-3);background:var(--bg-subtle);border-right:1px solid var(--border-default);color:var(--text-tertiary);text-align:right;user-select:none;min-width:36px}.query-editor-code,.query-editor-lines{font-family:var(--font-mono);font-size:var(--text-xs);line-height:var(--leading-relaxed)}.query-editor-code{flex:1;padding:var(--space-3) var(--space-4);color:var(--text-primary);white-space:pre;overflow-x:auto;outline:none}.query-toolbar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-top:1px solid var(--border-default);background:var(--bg-surface)}.query-toolbar>*{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-family:var(--font-ui);font-size:var(--text-xs);font-weight:500;border:1px solid var(--border-default);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.query-toolbar>:hover{border-color:var(--border-muted);color:var(--text-primary)}.query-toolbar>:first-child{background:var(--accent);border-color:transparent;color:var(--bg-base)}.query-toolbar>:first-child:hover{background:var(--accent-hover)}.query-status{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);border-top:1px solid var(--border-faint)}.schema-tree{font-family:var(--font-ui);font-size:var(--text-sm);display:flex;flex-direction:column}.schema-node{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease-out)}.schema-node:hover{background:var(--bg-subtle)}.schema-node-db{font-weight:600;color:var(--text-primary);padding-left:0}.schema-node-table{padding-left:var(--space-5);color:var(--text-primary)}.schema-node-column{padding-left:var(--space-8);color:var(--text-secondary);font-size:var(--text-xs)}.schema-type{display:inline-flex;padding:1px var(--space-2);background:var(--bg-subtle);color:var(--text-tertiary);font-size:10px;font-weight:500;border-radius:var(--radius-sm);letter-spacing:.02em;margin-left:auto;flex-shrink:0}.result-table,.schema-type{font-family:var(--font-mono)}.result-table{width:100%;border-collapse:collapse;font-size:var(--text-xs)}.result-table thead th{padding:var(--space-2) var(--space-3);text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-default);white-space:nowrap;cursor:pointer;user-select:none;letter-spacing:.02em;transition:color var(--duration-fast) var(--ease-out)}.result-table tbody td,.result-table thead th:hover{color:var(--text-primary)}.result-table tbody td{padding:var(--space-1) var(--space-3);border-bottom:1px solid var(--border-faint);white-space:nowrap;max-width:240px;overflow:hidden;text-overflow:ellipsis}.result-table tbody tr:nth-child(2n) td{background:var(--bg-subtle)}.result-table tbody tr:hover td{background:var(--bg-hover)}.notebook-cell{border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out)}.notebook-cell:hover{border-color:var(--border-muted)}.notebook-cell-code{display:flex;position:relative;background:var(--bg-elevated);font-family:var(--font-mono);font-size:var(--text-xs);line-height:var(--leading-relaxed)}.notebook-cell-code pre{flex:1;padding:var(--space-3) var(--space-4);color:var(--text-primary);white-space:pre;overflow-x:auto;margin:0}.notebook-run-btn{position:absolute;top:var(--space-2);right:var(--space-2);width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:11px;transition:all var(--duration-fast) var(--ease-out)}.notebook-run-btn:hover{background:var(--accent);border-color:transparent;color:var(--bg-base)}.notebook-cell-output{padding:var(--space-3) var(--space-4);background:var(--bg-surface);border-top:1px solid var(--border-default);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed);white-space:pre-wrap}@keyframes skel-pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes spin{to{transform:rotate(1turn)}}