:root,:root[data-theme=light]{--bg: #FBFBFD;--bg-elevated: #FFFFFF;--surface: #FFFFFF;--surface-2: #F5F5F7;--surface-3: #EBEBEF;--topbar-bg: rgba(251, 251, 253, .8);--border: rgba(0, 0, 0, .08);--border-strong: rgba(0, 0, 0, .15);--border-subtle: rgba(0, 0, 0, .04);--text: #1D1D1F;--text-muted: #6E6E73;--text-subtle: #86868B;--text-inverted: #FFFFFF;--primary: #007AFF;--primary-hover: #0066D6;--primary-active: #0052AC;--primary-bg: rgba(0, 122, 255, .1);--green: #30D158;--orange: #FF9500;--pink: #FF2D55;--purple: #AF52DE;--cyan: #5AC8FA;--indigo: #5E5CE6;--yellow: #FFCC00;--red: #FF3B30;--teal: #59ADC4;--mint: #00C7BE;--gradient-translate: linear-gradient(135deg, var(--primary), var(--indigo));--gradient-ocr: linear-gradient(135deg, var(--green), var(--cyan));--gradient-photobook: linear-gradient(135deg, var(--pink), var(--purple));--gradient-image-studio: linear-gradient(135deg, var(--purple), var(--indigo));--gradient-speech: linear-gradient(135deg, var(--orange), var(--pink));--gradient-chat: linear-gradient(135deg, var(--cyan), var(--primary));--success: #30D158;--success-bg: rgba(48, 209, 88, .12);--success-text: #1A7A2D;--warning: #FF9500;--warning-bg: rgba(255, 149, 0, .12);--warning-text: #8C5A00;--error: #FF3B30;--error-bg: rgba(255, 59, 48, .1);--error-text: #B81E14;--info: #007AFF;--info-bg: rgba(0, 122, 255, .1);--info-text: #004999;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04), 0 0 0 1px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06), 0 0 0 1px rgba(0, 0, 0, .04);--shadow-lg: 0 16px 32px rgba(0, 0, 0, .08), 0 0 0 1px rgba(0, 0, 0, .04);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .12), 0 0 0 1px rgba(0, 0, 0, .04);--focus-ring: 0 0 0 2px var(--bg), 0 0 0 4px var(--primary)}:root[data-theme=dark],:root.dark{--bg: #1C1C1E;--bg-elevated: #2C2C2E;--surface: #2C2C2E;--surface-2: #3A3A3C;--surface-3: #48484A;--topbar-bg: rgba(28, 28, 30, .8);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .15);--border-subtle: rgba(255, 255, 255, .04);--text: #F5F5F7;--text-muted: #98989D;--text-subtle: #6E6E73;--text-inverted: #1D1D1F;--primary: #0A84FF;--primary-hover: #2E97FF;--primary-active: #5AABFF;--primary-bg: rgba(10, 132, 255, .18);--green: #32D74B;--orange: #FF9F0A;--pink: #FF375F;--purple: #BF5AF2;--cyan: #64D2FF;--indigo: #5E5CE6;--yellow: #FFD60A;--red: #FF453A;--teal: #6AC4DC;--mint: #66D4CF;--gradient-translate: linear-gradient(135deg, var(--primary), var(--indigo));--gradient-ocr: linear-gradient(135deg, var(--green), var(--cyan));--gradient-photobook: linear-gradient(135deg, var(--pink), var(--purple));--gradient-image-studio: linear-gradient(135deg, var(--purple), var(--indigo));--gradient-speech: linear-gradient(135deg, var(--orange), var(--pink));--gradient-chat: linear-gradient(135deg, var(--cyan), var(--primary));--success: #32D74B;--success-bg: rgba(50, 215, 75, .18);--success-text: #74EE8C;--warning: #FF9F0A;--warning-bg: rgba(255, 159, 10, .18);--warning-text: #FFD175;--error: #FF453A;--error-bg: rgba(255, 69, 58, .18);--error-text: #FF8D85;--info: #0A84FF;--info-bg: rgba(10, 132, 255, .18);--info-text: #5AABFF;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .06);--shadow-lg: 0 16px 32px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .06);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .06);--focus-ring: 0 0 0 2px var(--bg), 0 0 0 4px var(--primary)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){color-scheme:dark;--bg: #1C1C1E;--bg-elevated: #2C2C2E;--surface: #2C2C2E;--surface-2: #3A3A3C;--surface-3: #48484A;--topbar-bg: rgba(28, 28, 30, .8);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .15);--border-subtle: rgba(255, 255, 255, .04);--text: #F5F5F7;--text-muted: #98989D;--text-subtle: #6E6E73;--text-inverted: #1D1D1F;--primary: #0A84FF;--primary-hover: #2E97FF;--primary-active: #5AABFF;--primary-bg: rgba(10, 132, 255, .18);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .06);--shadow-lg: 0 16px 32px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .06)}}:root{--font-sans: -apple-system, "SF Pro Display", "SF Pro Text", "PingFang TC", "Microsoft YaHei UI", BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-mono: "SF Mono", "JetBrains Mono", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--text-display: 2.625rem;--text-h1: 1.5rem;--text-h2: 1.375rem;--text-h3: 1.0625rem;--text-body: 1rem;--text-small: .875rem;--text-caption: .75rem;--text-tiny: .6875rem;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--line-display: 1.1;--line-heading: 1.25;--line-body: 1.5;--line-tight: 1.4;--tracking-tight: -.03em;--tracking-snug: -.02em;--tracking-normal: -.01em;--tracking-wide: .02em}:root{--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-14: 56px;--space-16: 64px}:root{--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-2xl: 24px;--radius-full: 9999px}:root{--duration-instant: .1s;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--easing: cubic-bezier(.4, 0, .2, 1);--easing-in: cubic-bezier(.4, 0, 1, 1);--easing-out: cubic-bezier(0, 0, .2, 1);--easing-spring: cubic-bezier(.34, 1.56, .64, 1)}:root{--z-base: 0;--z-elevated: 10;--z-sidebar: 20;--z-topbar: 30;--z-dropdown: 40;--z-popover: 50;--z-overlay: 60;--z-toast: 70;--z-critical: 90;--z-loader: 100}@media (prefers-reduced-motion: reduce){:root{--duration-instant: 0ms;--duration-fast: 0ms;--duration-normal: 0ms;--duration-slow: 0ms}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}html{font-family:var(--font-sans);font-size:var(--text-body);line-height:var(--line-body);letter-spacing:var(--tracking-normal);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{margin:0}.tabular{font-variant-numeric:tabular-nums}*:focus-visible{outline:none;box-shadow:var(--focus-ring)}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}.app-shell{display:grid;grid-template-columns:240px 1fr;height:100vh;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-6)}.brand{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-2)}.brand-mark{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--primary),var(--indigo));color:var(--text-inverted);display:grid;place-items:center;font-weight:var(--weight-bold);font-size:18px;flex-shrink:0}.brand-mark.large{width:56px;height:56px;font-size:28px;border-radius:var(--radius-lg)}.brand-text{line-height:1.2}.brand-title{font-size:var(--text-body);font-weight:var(--weight-semibold);letter-spacing:var(--tracking-snug)}.brand-sub{font-size:var(--text-caption);color:var(--text-muted)}.nav{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-muted);font-size:var(--text-small);font-weight:var(--weight-medium);transition:background var(--duration-fast) var(--easing),color var(--duration-fast) var(--easing)}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--primary-bg);color:var(--primary)}.nav-icon{width:20px;display:inline-grid;place-items:center;font-size:15px}.nav-badge{margin-left:auto;background:var(--warning-bg);color:var(--warning-text);font-size:var(--text-tiny);font-weight:var(--weight-semibold);padding:2px 8px;border-radius:var(--radius-full)}.main{display:flex;flex-direction:column;overflow:hidden}.topbar{height:56px;padding:0 var(--space-6);border-bottom:1px solid var(--border);background:var(--topbar-bg);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:var(--z-topbar)}.topbar-right{display:flex;align-items:center;gap:var(--space-3)}.user-chip{display:flex;align-items:center;gap:var(--space-3);padding:4px 4px 4px var(--space-3);background:var(--surface-2);border-radius:var(--radius-full);font-size:var(--text-caption)}.user-email{color:var(--text-muted);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.signout-btn,.theme-toggle{border:none;background:var(--surface-2);color:var(--text);padding:6px 12px;border-radius:var(--radius-full);font-size:var(--text-caption);font-weight:var(--weight-medium);transition:background var(--duration-fast) var(--easing)}.signout-btn:hover,.theme-toggle:hover{background:var(--surface-3)}.theme-toggle{padding:6px 8px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted)}.theme-toggle:hover{color:var(--text)}.nav-icon svg{display:block}.content{flex:1;overflow-y:auto;padding:var(--space-8) var(--space-8)}.page-title{margin:0 0 var(--space-2);font-size:var(--text-h1);font-weight:var(--weight-bold);letter-spacing:var(--tracking-snug)}.page-lede{margin:0 0 var(--space-6);color:var(--text-muted);font-size:var(--text-small)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm)}.stat-label{color:var(--text-muted);font-size:var(--text-caption);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.stat-num{font-size:32px;font-weight:var(--weight-bold);letter-spacing:var(--tracking-snug);margin-top:var(--space-2);font-variant-numeric:tabular-nums}.stat-note{font-size:var(--text-caption);color:var(--text-subtle);margin-top:var(--space-1)}.placeholder-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);text-align:center;color:var(--text-muted);box-shadow:var(--shadow-sm)}.placeholder-card h3{margin:0 0 var(--space-2);color:var(--text);font-weight:var(--weight-semibold)}.placeholder-card p{margin:0;font-size:var(--text-small)}.login-page{min-height:100vh;display:grid;place-items:center;padding:var(--space-6);background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);padding:var(--space-10);width:min(420px,100%);text-align:center}.login-brand{margin-bottom:var(--space-6)}.login-brand .brand-mark{margin:0 auto var(--space-4)}.login-card h1{margin:0;font-size:var(--text-h1);font-weight:var(--weight-bold);letter-spacing:var(--tracking-snug)}.login-card h2{margin:0 0 var(--space-3);font-size:var(--text-h2);font-weight:var(--weight-semibold)}.login-sub{margin:var(--space-1) 0 0;color:var(--text-muted);font-size:var(--text-small)}.signin-btn{background:var(--primary);color:var(--text-inverted);border:none;width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-body);font-weight:var(--weight-semibold);transition:background var(--duration-fast) var(--easing)}.signin-btn:hover:not(:disabled){background:var(--primary-hover)}.signin-btn:active:not(:disabled){background:var(--primary-active)}.signin-btn:disabled{opacity:.6;cursor:not-allowed}.login-note{margin:var(--space-6) 0 0;font-size:var(--text-caption);color:var(--text-muted);line-height:1.7}.login-error{margin-top:var(--space-3);background:var(--error-bg);color:var(--error-text);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--text-caption)}.login-theme{margin-top:var(--space-4);display:flex;justify-content:center}.center-loader{height:100vh;display:grid;place-items:center;color:var(--text-muted);font-size:var(--text-small)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);border:1px solid transparent;padding:8px 14px;border-radius:var(--radius-md);font-size:var(--text-small);font-weight:var(--weight-medium);transition:background var(--duration-fast) var(--easing),border-color var(--duration-fast) var(--easing),color var(--duration-fast) var(--easing),box-shadow var(--duration-fast) var(--easing);white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--text-inverted)}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:active:not(:disabled){background:var(--primary-active)}.btn-secondary{background:var(--surface-2);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-3)}.btn-danger{background:var(--error-bg);color:var(--error-text);border-color:transparent}.btn-danger:hover:not(:disabled){background:var(--error);color:var(--text-inverted)}.btn-ghost{background:transparent;color:var(--text-muted);padding:4px 8px}.btn-ghost:hover:not(:disabled){color:var(--text);background:var(--surface-2)}.btn-spinner{width:12px;height:12px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite;display:inline-block}@keyframes btn-spin{to{transform:rotate(360deg)}}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--space-4)}.field-label{font-size:var(--text-caption);font-weight:var(--weight-medium);color:var(--text-muted)}.field-required{color:var(--error)}.field-input,.field-textarea{background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:8px 12px;font:inherit;font-size:var(--text-small);transition:border-color var(--duration-fast) var(--easing),box-shadow var(--duration-fast) var(--easing)}.field-input:focus,.field-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.field-textarea{min-height:80px;resize:vertical;font-family:inherit}.field-msg{font-size:var(--text-caption);color:var(--text-subtle)}.field-msg-error{color:var(--error-text)}.field-error .field-input,.field-error .field-textarea{border-color:var(--error)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;padding:var(--space-6);z-index:var(--z-modal, 1000);animation:modal-fade .15s ease-out}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:min(560px,100%);max-height:calc(100vh - var(--space-12, 96px));display:flex;flex-direction:column;animation:modal-slide .18s ease-out}@keyframes modal-slide{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:var(--text-h3);font-weight:var(--weight-semibold)}.modal-close{background:transparent;border:none;color:var(--text-muted);font-size:18px;width:32px;height:32px;border-radius:var(--radius-full);display:grid;place-items:center}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-body{padding:var(--space-6);overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-small)}.data-table thead{background:var(--surface-2)}.data-table th{text-align:left;padding:12px 16px;font-weight:var(--weight-medium);color:var(--text-muted);font-size:var(--text-caption);letter-spacing:var(--tracking-wide);text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--surface-2)}.data-table .col-mono{font-family:var(--font-mono);font-size:var(--text-caption);color:var(--text)}.data-table .col-muted{color:var(--text-muted)}.data-table .col-actions{text-align:right;white-space:nowrap}.data-table .col-actions .btn+.btn{margin-left:var(--space-2)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-tiny);font-weight:var(--weight-semibold);letter-spacing:var(--tracking-wide);text-transform:uppercase;white-space:nowrap}.badge-neutral{background:var(--surface-3);color:var(--text-muted)}.badge-success{background:var(--success-bg);color:var(--success-text)}.badge-warning{background:var(--warning-bg);color:var(--warning-text)}.badge-danger{background:var(--error-bg);color:var(--error-text)}.badge-info{background:var(--primary-bg);color:var(--primary)}.empty-state{background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);text-align:center}.empty-title{margin:0 0 var(--space-2);font-size:var(--text-h3);font-weight:var(--weight-semibold)}.empty-desc{margin:0;color:var(--text-muted);font-size:var(--text-small)}.empty-action{margin-top:var(--space-5)}.page-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-5);flex-wrap:wrap}.page-toolbar-left,.page-toolbar-right{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.filter-chips{display:inline-flex;background:var(--surface-2);border-radius:var(--radius-full);padding:3px;gap:2px}.filter-chip{background:transparent;border:none;color:var(--text-muted);padding:5px 12px;border-radius:var(--radius-full);font-size:var(--text-caption);font-weight:var(--weight-medium)}.filter-chip.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.filter-chip:hover:not(.active){color:var(--text)}.search-input{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-full);padding:6px 14px;font-size:var(--text-caption);color:var(--text);width:240px}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.toast-error{margin:0 0 var(--space-4);background:var(--error-bg);color:var(--error-text);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-small)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.alert-list{display:flex;flex-direction:column;gap:var(--space-4)}.alert-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-5) var(--space-6)}.alert-card-head{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap}.alert-sn{font-family:var(--font-mono);font-size:var(--text-body);font-weight:var(--weight-semibold)}.alert-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3) var(--space-5);font-size:var(--text-caption);color:var(--text-muted);margin-bottom:var(--space-4)}.alert-meta dt{color:var(--text-subtle);margin:0 0 2px;font-size:var(--text-tiny);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.alert-meta dd{margin:0;color:var(--text);font-family:var(--font-mono);font-size:var(--text-caption)}.alert-actions{display:flex;gap:var(--space-3);align-items:flex-end;flex-wrap:wrap;border-top:1px solid var(--border-subtle);padding-top:var(--space-4)}.alert-actions .field{flex:1;min-width:160px;margin-bottom:0}.nav-badge{margin-left:auto;background:var(--error);color:var(--text-inverted);font-size:var(--text-tiny);font-weight:var(--weight-semibold);padding:1px 7px;border-radius:var(--radius-full);min-width:20px;text-align:center}@media (max-width: 768px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.content{padding:var(--space-5)}.search-input{width:100%}}.nav-group{margin-bottom:var(--space-4)}.nav-section-label{font-size:var(--text-tiny);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--text-subtle);padding:0 var(--space-3) var(--space-1)}.role-badge{font-size:var(--text-caption);font-weight:var(--weight-medium);color:var(--primary);background:var(--primary-bg);padding:2px var(--space-3);border-radius:var(--radius-full);white-space:nowrap}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.page-title{font-size:var(--text-h1);font-weight:var(--weight-semibold);letter-spacing:var(--tracking-snug);margin:0}.page-sub{color:var(--text-muted);font-size:var(--text-small);margin:var(--space-1) 0 0}.page-actions{display:flex;gap:var(--space-2);flex-shrink:0}.card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-5)}.card+.card{margin-top:var(--space-5)}.card-title{font-size:var(--text-h3);font-weight:var(--weight-semibold);margin:0 0 var(--space-4)}.tab-bar{display:flex;gap:var(--space-1);border-bottom:1px solid var(--border);margin-bottom:var(--space-5)}.tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;cursor:pointer;font:inherit;color:var(--text-muted);padding:var(--space-3) var(--space-4);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--duration-fast) var(--easing)}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:var(--weight-medium)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.kpi-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-5)}.kpi-card.attention{box-shadow:var(--shadow-sm),inset 0 0 0 1px var(--warning)}.kpi-label{font-size:var(--text-caption);color:var(--text-muted);margin:0 0 var(--space-2)}.kpi-value{font-size:var(--text-display);font-weight:var(--weight-bold);line-height:1;letter-spacing:var(--tracking-tight)}.kpi-value.warn{color:var(--warning-text)}.kpi-sub{font-size:var(--text-caption);color:var(--text-subtle);margin-top:var(--space-2)}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:flex-end;margin-bottom:var(--space-4)}.filter-bar .field{margin:0;min-width:180px}.search-box{position:relative;flex:1;min-width:200px}.chart-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-5)}.sparkline{width:100%;height:64px;display:block}.sparkline polyline{fill:none;stroke:var(--primary);stroke-width:2}.sparkline .area{fill:var(--primary-bg);stroke:none}.donut-legend{display:flex;flex-direction:column;gap:var(--space-2);font-size:var(--text-caption)}.donut-legend .dot{display:inline-block;width:10px;height:10px;border-radius:var(--radius-full);margin-right:var(--space-2)}.bars{display:flex;flex-direction:column;gap:var(--space-2)}.bar-row{display:grid;grid-template-columns:120px 1fr 48px;align-items:center;gap:var(--space-3);font-size:var(--text-caption)}.bar-track{background:var(--surface-2);border-radius:var(--radius-full);height:8px;overflow:hidden}.bar-fill{background:var(--primary);height:100%;border-radius:var(--radius-full)}.support-layout{display:grid;grid-template-columns:320px 1fr;gap:var(--space-4);height:calc(100vh - 160px);min-height:420px}.ticket-list{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow-y:auto}.ticket-item{width:100%;text-align:left;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;border-bottom:1px solid var(--border-subtle);padding:var(--space-4);cursor:pointer;font:inherit;color:var(--text)}.ticket-item:hover{background:var(--surface-2)}.ticket-item.active{background:var(--primary-bg)}.ticket-item .subject{font-weight:var(--weight-medium);display:block}.ticket-item .meta{font-size:var(--text-caption);color:var(--text-subtle);margin-top:var(--space-1)}.chat-pane{display:flex;flex-direction:column;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.chat-head{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:var(--space-3)}.chat-msgs{flex:1;overflow-y:auto;padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.msg{max-width:78%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-small)}.msg .who{font-size:var(--text-tiny);color:var(--text-subtle);margin-bottom:2px}.msg.user{align-self:flex-start;background:var(--surface-2)}.msg.admin{align-self:flex-end;background:var(--primary-bg)}.msg.internal_note{align-self:flex-end;background:var(--warning-bg);color:var(--warning-text)}.chat-composer{display:flex;align-items:flex-end;gap:var(--space-2);padding:var(--space-4);border-top:1px solid var(--border)}.chat-composer .field{flex:1;margin-bottom:0}.chat-composer .field-textarea{resize:none}.msg-attachments{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.attachment-chip{display:inline-flex;align-items:center;gap:6px;max-width:100%;padding:4px 10px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:var(--text-caption);text-decoration:none}a.attachment-chip:hover{border-color:var(--primary);color:var(--primary)}.attachment-chip svg{flex:0 0 auto}.attachment-chip__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-chip.is-loading,.attachment-chip.is-failed{color:var(--text-subtle)}.attachment-chip.is-failed{color:var(--error)}.mono{font-family:var(--font-mono);font-size:var(--text-caption)}.muted{color:var(--text-muted)}.subtle{color:var(--text-subtle)}.stack{display:flex;flex-direction:column;gap:var(--space-4)}.row{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap}.audit-line{display:grid;grid-template-columns:150px 90px 1fr;gap:var(--space-3);font-size:var(--text-caption);padding:var(--space-2) 0;border-bottom:1px solid var(--border-subtle)}.diff{font-family:var(--font-mono);font-size:var(--text-tiny);background:var(--surface-2);padding:var(--space-2);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-all}
