@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Bricolage+Grotesque:opsz,wght@12..96,600;12..96,700;12..96,800&display=swap";:root{--color-primary-50: #effcf9;--color-primary-100: #d0f7ef;--color-primary-200: #a4eedf;--color-primary-300: #6bdece;--color-primary-400: #38c9b8;--color-primary-500: #1aaea0;--color-primary-600: #0f8d83;--color-primary-700: #10716a;--color-primary-800: #125a56;--color-primary-900: #134b48;--color-primary-950: #042f2e;--color-gray-50: #f8fafb;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e1;--color-gray-400: #94a3b8;--color-gray-500: #64748b;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1e293b;--color-gray-900: #0f172a;--color-gray-950: #020617;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-white: #ffffff;--surface-canvas: #f0faf9;--surface-base: var(--color-white);--surface-subtle: #f0fdf9;--surface-accent: #ecfdf8;--surface-accent-strong: #d7f8ef;--text-strong: var(--color-gray-900);--text-base: var(--color-gray-800);--text-muted: var(--color-gray-600);--border-subtle: #d1fae5;--border-base: #a7f3d0;--border-accent: var(--color-primary-200);--focus-ring: 0 0 0 3px rgba(15, 141, 131, .25);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--font-brand: "Bricolage Grotesque", "Inter", system-ui, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--leading-tight: 1.2;--leading-snug: 1.35;--leading-normal: 1.5;--leading-relaxed: 1.65;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--container-max: 1240px;--container-padding: var(--space-6);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .06), 0 2px 4px -2px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .07), 0 4px 6px -4px rgba(0, 0, 0, .03);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .07), 0 8px 10px -6px rgba(0, 0, 0, .03);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease-in-out}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-base);background:var(--surface-canvas);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,svg{display:block;max-width:100%}h1,h2,h3,h4,h5,h6{margin:0;color:var(--text-strong);line-height:var(--leading-tight)}h1{font-size:clamp(var(--text-3xl),4vw,var(--text-5xl))}h2{font-size:clamp(var(--text-2xl),3vw,var(--text-4xl))}h3{font-size:clamp(var(--text-xl),2vw,var(--text-2xl))}p{margin:0;color:var(--text-muted);line-height:var(--leading-relaxed)}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]),textarea,select{width:100%;max-width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border-base);border-radius:var(--radius-md);background:var(--surface-base);color:var(--text-strong);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]):focus-visible,textarea:focus-visible,select:focus-visible,button:focus-visible,.btn:focus-visible,.ui-btn:focus-visible{outline:none;border-color:var(--color-primary-500);box-shadow:var(--focus-ring)}textarea{min-height:6.75rem;resize:vertical}button:disabled,input:disabled,textarea:disabled,select:disabled{opacity:.65;cursor:not-allowed}.btn,.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border:1px solid transparent;border-radius:var(--radius-lg);padding:var(--space-3) var(--space-5);font-size:var(--text-base);font-weight:var(--font-semibold);line-height:var(--leading-tight);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.btn--primary,.ui-btn--primary{background:var(--color-primary-600);border-color:var(--color-primary-600);color:var(--color-white)}.btn--primary:hover,.ui-btn--primary:hover{background:var(--color-primary-700);border-color:var(--color-primary-700);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--secondary,.ui-btn--secondary{background:var(--surface-base);border-color:var(--border-base);color:var(--text-base)}.btn--secondary:hover,.ui-btn--secondary:hover{background:var(--color-gray-100);border-color:var(--color-gray-400)}.btn--ghost,.ui-btn--ghost{background:transparent;border-color:transparent;color:var(--color-primary-700)}.btn--ghost:hover,.ui-btn--ghost:hover{background:var(--color-primary-50);border-color:var(--color-primary-200)}.btn--large,.ui-btn--large{padding:var(--space-4) var(--space-8);border-radius:var(--radius-xl);font-size:var(--text-lg)}.card,.ui-card{background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.panel,.ui-panel{background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.badge,.ui-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:.3rem var(--space-3);border-radius:var(--radius-full);border:1px solid var(--border-accent);background:var(--surface-accent);color:var(--color-primary-700);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.04em;text-transform:uppercase}.ui-table{width:100%;border-collapse:collapse;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-base)}.ui-table th,.ui-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);text-align:left;vertical-align:top}.ui-table th{background:var(--color-gray-100);color:var(--text-strong);font-size:var(--text-sm);font-weight:var(--font-semibold)}.ui-table tr:last-child td{border-bottom:none}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.inset-y-0{top:0;bottom:0}.left-3{left:.75rem}.right-3{right:.75rem}.z-30{z-index:30}.m-0{margin:0}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-full{height:100%}.h-screen{height:100vh}.max-h-32{max-height:8rem}.max-h-\[440px\]{max-height:440px}.min-h-\[540px\]{min-height:540px}.min-h-screen{min-height:100vh}.w-0{width:0px}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[180px\]{min-width:180px}.min-w-\[260px\]{min-width:260px}.min-w-\[720px\]{min-width:720px}.max-w-0{max-width:0px}.max-w-\[180px\]{max-width:180px}.max-w-\[200px\]{max-width:200px}.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.resize{resize:both}.list-none{list-style-type:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0{gap:0px}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-x-6{-moz-column-gap:1.5rem;column-gap:1.5rem}.gap-y-4{row-gap:1rem}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-gray-100>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(241 245 249 / var(--tw-divide-opacity, 1))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.75rem}.rounded-md{border-radius:.5rem}.rounded-none{border-radius:0}.rounded-xl{border-radius:1rem}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-amber-200{--tw-border-opacity: 1;border-color:rgb(253 230 138 / var(--tw-border-opacity, 1))}.border-current{border-color:currentColor}.border-emerald-100{--tw-border-opacity: 1;border-color:rgb(209 250 229 / var(--tw-border-opacity, 1))}.border-emerald-200{--tw-border-opacity: 1;border-color:rgb(167 243 208 / var(--tw-border-opacity, 1))}.border-emerald-50{--tw-border-opacity: 1;border-color:rgb(236 253 245 / var(--tw-border-opacity, 1))}.border-error{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity, 1))}.border-gray-100{--tw-border-opacity: 1;border-color:rgb(241 245 249 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(203 213 225 / var(--tw-border-opacity, 1))}.border-primary-200{--tw-border-opacity: 1;border-color:rgb(164 238 223 / var(--tw-border-opacity, 1))}.border-primary-600{--tw-border-opacity: 1;border-color:rgb(15 141 131 / var(--tw-border-opacity, 1))}.border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-amber-50{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity, 1))}.bg-emerald-50{--tw-bg-opacity: 1;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.bg-error{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(203 213 225 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(248 250 251 / var(--tw-bg-opacity, 1))}.bg-gray-50\/60{background-color:#f8fafb99}.bg-gray-900\/40{background-color:#0f172a66}.bg-primary-100{--tw-bg-opacity: 1;background-color:rgb(208 247 239 / var(--tw-bg-opacity, 1))}.bg-primary-50{--tw-bg-opacity: 1;background-color:rgb(239 252 249 / var(--tw-bg-opacity, 1))}.bg-primary-500{--tw-bg-opacity: 1;background-color:rgb(26 174 160 / var(--tw-bg-opacity, 1))}.bg-primary-600{--tw-bg-opacity: 1;background-color:rgb(15 141 131 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/10{background-color:#ffffff1a}.bg-white\/95{background-color:#fffffff2}.p-0{padding:0}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-0{padding-left:0;padding-right:0}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0{padding-top:0;padding-bottom:0}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-2{padding-bottom:.5rem}.pb-8{padding-bottom:2rem}.pl-9{padding-left:2.25rem}.pr-9{padding-right:2.25rem}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:JetBrains Mono,Fira Code,ui-monospace,monospace}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-tight{line-height:1.25}.tracking-\[0\.2em\]{letter-spacing:.2em}.tracking-\[0\.4em\]{letter-spacing:.4em}.tracking-wide{letter-spacing:.025em}.text-amber-700{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity, 1))}.text-amber-900{--tw-text-opacity: 1;color:rgb(120 53 15 / var(--tw-text-opacity, 1))}.text-emerald-700{--tw-text-opacity: 1;color:rgb(4 120 87 / var(--tw-text-opacity, 1))}.text-emerald-800{--tw-text-opacity: 1;color:rgb(6 95 70 / var(--tw-text-opacity, 1))}.text-error{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.text-primary-700{--tw-text-opacity: 1;color:rgb(16 113 106 / var(--tw-text-opacity, 1))}.text-primary-800{--tw-text-opacity: 1;color:rgb(18 90 86 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/50{color:#ffffff80}.text-white\/60{color:#fff9}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow-md{--tw-shadow: 0 4px 6px -1px rgba(0, 0, 0, .06), 0 2px 4px -2px rgba(0, 0, 0, .04);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--tw-shadow-colored: 0 1px 3px var(--tw-shadow-color), 0 1px 2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgba(0, 0, 0, .07), 0 8px 10px -6px rgba(0, 0, 0, .03);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur: blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[width\]{transition-property:width;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}body{background:radial-gradient(circle at top left,#d1fae5,#f0faf9 40%,#e8f5f5);color:var(--text-base)}.container{max-width:980px;margin:var(--space-10) auto;padding:var(--space-8);background:var(--surface-base);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);display:grid;gap:var(--space-3)}.container.viewer-page{max-width:none;width:100vw;height:100vh;margin:0;padding:0;border-radius:0;box-shadow:none;gap:0;grid-template-rows:1fr;background:#050a17;overflow:hidden;position:relative}.viewer-page:before{content:"";position:fixed;top:0;left:0;right:0;height:14px;z-index:27;pointer-events:auto}.viewer-floating-feedback{position:fixed;top:4.6rem;left:50%;transform:translate(-50%);z-index:25;margin:0;padding:.45rem var(--space-4);border-radius:var(--radius-full);font-size:var(--text-xs);color:#f8fafc;background:#0f172ad9;border:1px solid rgba(148,163,184,.4);box-shadow:var(--shadow-md);max-width:min(92vw,720px);text-align:center}.viewer-floating-feedback.error{border-color:#f87171b3;color:#fecaca}.row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.row-wrap{flex-wrap:wrap;justify-content:flex-start}button{min-height:2.6rem;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border:1px solid var(--color-primary-600);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);font-size:var(--text-base);font-weight:var(--font-semibold);background:var(--color-primary-600);color:var(--color-white);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast)}button:hover{background:var(--color-primary-700);border-color:var(--color-primary-700);box-shadow:var(--shadow-sm);transform:translateY(-1px)}button:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.feedback{margin:var(--space-2) 0}.feedback.error{color:var(--color-error);font-weight:var(--font-semibold)}.status-grid{margin-top:var(--space-2);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.status-item{padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--surface-subtle);display:grid;gap:.15rem}.status-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:var(--font-semibold)}.status-item small{color:var(--text-muted)}.status-panel{margin-top:var(--space-4);padding:var(--space-4);border-radius:var(--radius-lg);background:var(--surface-subtle);border:1px solid var(--border-subtle)}.viewer-launch-panel{margin-top:var(--space-2);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--border-accent);background:var(--surface-accent);display:grid;gap:var(--space-3)}.viewer-toolbar-wrap{position:fixed;top:0;left:0;right:0;z-index:26;pointer-events:none;padding:var(--space-2) var(--space-3);transition:transform var(--transition-base),opacity var(--transition-base)}.viewer-toolbar-wrap.is-hidden{transform:translateY(-110%);opacity:0}.viewer-toolbar{pointer-events:auto;margin:0 auto;padding:.4rem .6rem;border-radius:var(--radius-lg);border:1px solid rgba(148,163,184,.3);background:#080e1ec7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 12px 32px #00000073;display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;color:#e2e8f0;max-width:1480px}.viewer-toolbar-group{display:inline-flex;align-items:center;gap:var(--space-1);flex-wrap:wrap}.viewer-toolbar-group-status{margin-right:auto}.viewer-toolbar-group-actions{margin-left:auto}.viewer-toolbar button.is-toggled{border-color:#2dd4bfd9;background:#0d948866;color:#ccfbf1}.viewer-fps-pill{font-variant-numeric:tabular-nums;font-size:var(--text-xs);font-weight:600;letter-spacing:.02em;padding:.3rem .6rem;border-radius:var(--radius-full);border:1px solid rgba(148,163,184,.4);background:#0206178c;color:#e0f2fe}.viewer-toolbar button,.viewer-toolbar select{min-height:2.15rem;border-radius:var(--radius-md);font-size:var(--text-sm)}.viewer-toolbar button{border-color:#94a3b873;background:#02061785;color:#f8fafc}.viewer-toolbar button:hover{border-color:#38bdf8cc;background:#0f172ad9;box-shadow:none;transform:none}.viewer-toolbar select{min-width:160px;padding:.35rem .55rem;border:1px solid rgba(148,163,184,.45);background:#02061785;color:#f8fafc}.viewer-connection{border-radius:var(--radius-full);padding:.35rem var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em}.viewer-connection-ok{background:#22c55e29;color:#bbf7d0;border:1px solid rgba(34,197,94,.45)}.viewer-connection-warn{background:#f59e0b2e;color:#fde68a;border:1px solid rgba(245,158,11,.52)}.viewer-connection-muted{background:#94a3b82e;color:#e2e8f0;border:1px solid rgba(148,163,184,.45)}.viewer-toolbar-control{display:inline-flex;align-items:center;gap:var(--space-2);padding:.2rem var(--space-2);border:1px solid rgba(148,163,184,.35);border-radius:var(--radius-md);background:#02061766;font-size:var(--text-sm);color:#f8fafc}.viewer-toolbar-control input[type=checkbox]{width:16px;height:16px;margin:0}.viewer-toolbar-monitor{display:inline-flex;align-items:center;gap:var(--space-1);flex-wrap:wrap}.monitor-chip{min-height:2.15rem;padding:.25rem .45rem;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.45);background:#02061785;color:#f8fafc;display:inline-flex;align-items:center;gap:.35rem;font-size:.75rem;line-height:1}.monitor-chip:hover{border-color:#38bdf8cc;background:#0f172ad9}.monitor-chip.is-active{border-color:#2dd4bff2;background:#0d948859;color:#ecfeff}.monitor-chip-icon{width:1.25rem;height:.95rem;border:1px solid rgba(248,250,252,.9);border-radius:.18rem;display:inline-flex;align-items:center;justify-content:center;position:relative}.monitor-chip-number{font-size:.6rem;font-weight:700;color:#f8fafc;line-height:1}.monitor-chip-label{font-size:.7rem;font-weight:600}.monitor-chip-primary{font-size:.58rem;font-weight:700;padding:.12rem .2rem;border-radius:var(--radius-full);border:1px solid rgba(45,212,191,.8);color:#ccfbf1;background:#0d948838}.monitor-chip-icon-all{width:1.28rem;border:none;background:none}.monitor-chip-icon-all:before,.monitor-chip-icon-all:after{content:"";position:absolute;width:.72rem;height:.58rem;border:1px solid rgba(248,250,252,.9);border-radius:.14rem}.monitor-chip-icon-all:before{left:.08rem;top:.1rem}.monitor-chip-icon-all:after{left:.42rem;top:.24rem}.viewer-toolbar-feedback{position:fixed;top:calc(var(--space-4) + 4.2rem);left:50%;transform:translate(-50%);z-index:25;margin:0;padding:.35rem var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);color:#e2e8f0;background:#0f172ab8;border:1px solid rgba(148,163,184,.4)}.viewer-quick-drawer{position:fixed;top:44px;right:var(--space-3);width:min(94vw,360px);max-height:calc(100vh - 5.5rem);overflow-y:auto;z-index:24;border:1px solid rgba(148,163,184,.38);border-radius:var(--radius-xl);background:#080e1ee0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 20px 48px #0000008c;padding:var(--space-4);display:grid;gap:var(--space-4);transform:translate(calc(100% + var(--space-4)));opacity:0;pointer-events:none;transition:transform var(--transition-base),opacity var(--transition-base)}.viewer-quick-drawer.open{transform:translate(0);opacity:1;pointer-events:auto}.viewer-quick-drawer p{font-size:var(--text-sm);color:#cbd5e1;margin:0}.viewer-quick-drawer-header{display:flex;align-items:center;justify-content:space-between}.viewer-quick-drawer-header h3{font-size:var(--text-base);color:#f8fafc}.viewer-quick-drawer-header button{min-height:2rem}.viewer-quick-drawer-section{display:grid;gap:var(--space-2)}.viewer-quick-drawer-section h4{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8;margin:0}.viewer-quick-drawer-input{display:grid;grid-template-columns:1fr auto;gap:var(--space-2)}.viewer-quick-drawer-input input{background:#0206178c;color:#f8fafc;border:1px solid rgba(148,163,184,.4);border-radius:var(--radius-md);padding:.5rem .75rem}.viewer-quick-drawer-actions,.viewer-quick-drawer-combos{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-2)}.viewer-quick-drawer-actions button,.viewer-quick-drawer-combos button{min-height:2rem;font-size:.78rem;padding:.35rem .4rem}.viewer-quick-drawer-note{font-size:.72rem;color:#94a3b8;font-style:italic}.viewer-quick-drawer button{border-color:#94a3b873;background:#02061780;color:#f8fafc}.viewer-help-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:40;display:grid;place-items:center;padding:var(--space-4)}.viewer-help-modal{width:min(560px,100%);max-height:calc(100vh - 4rem);overflow-y:auto;background:#0f172a;border:1px solid rgba(148,163,184,.4);border-radius:var(--radius-xl);padding:var(--space-5);color:#e2e8f0;box-shadow:0 24px 60px #000000a6;display:grid;gap:var(--space-3)}.viewer-help-modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.viewer-help-modal-header h3{font-size:1.1rem;color:#f8fafc;margin:0}.viewer-help-list{display:grid;gap:.55rem;font-size:.85rem;line-height:1.45;margin:0;padding-left:1.1rem;color:#cbd5e1}.viewer-help-list strong{color:#f8fafc}.viewer-help-foot{font-size:.75rem;color:#94a3b8;font-style:italic}.viewer-placeholder{color:#94a3b8;font-size:.95rem;text-align:center}.viewer-stage{min-height:0;height:100%;display:grid}.viewer-page .viewer-stage{width:100vw;height:100vh;background:#050b18;padding:3.4rem 0 0;box-sizing:border-box;overflow:hidden;transition:padding-top var(--transition-base)}.viewer-page.viewer-page-toolbar-hidden .viewer-stage{padding-top:0}.viewer{min-height:260px;display:grid;place-items:center;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:#0f172a;color:#e2e8f0;padding:var(--space-2);touch-action:none}.viewer-page .viewer{min-height:0;height:100%;width:100%;border:none;border-radius:0;padding:0;background:#050b18;overflow:auto;place-items:center}.viewer-page .viewer.viewer-fit-actual{place-items:start}.viewer-control{outline:2px solid #38bdf8;cursor:crosshair}.viewer img,.viewer canvas{max-width:100%;max-height:100%;width:auto;height:auto;-o-object-fit:contain;object-fit:contain;border-radius:var(--radius-sm);-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none;will-change:transform;transform:translateZ(0);backface-visibility:hidden}.viewer-page .viewer img,.viewer-page .viewer canvas{border-radius:0;display:block;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none;will-change:transform;transform:translateZ(0);backface-visibility:hidden}.viewer-page .viewer.viewer-fit-contain img,.viewer-page .viewer.viewer-fit-contain canvas{width:auto;height:auto;max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}.viewer-page .viewer.viewer-fit-actual img,.viewer-page .viewer.viewer-fit-actual canvas{width:auto;height:auto;max-width:none;max-height:none;-o-object-fit:none;object-fit:none}ul{margin:0;padding-left:var(--space-4)}.viewer-top-bar{position:fixed;top:0;left:0;right:0;z-index:26;height:44px;display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3);background:#080e1eeb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(148,163,184,.12);box-shadow:0 2px 12px #0006;color:#e2e8f0}.viewer-top-bar-left{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.viewer-top-bar-right{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.viewer-top-bar-sep{width:1px;height:20px;background:#94a3b840;flex-shrink:0}.viewer-canvas-area{position:fixed;top:44px;bottom:40px;left:0;right:0;background:#000;display:grid;place-items:center;overflow:hidden}.viewer-page-toolbar-hidden .viewer-canvas-area{top:0}.viewer-bottom-bar{position:fixed;bottom:0;left:0;right:0;z-index:26;height:40px;display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-3);background:#0a0f1e;border-top:1px solid rgba(148,163,184,.1);color:#94a3b8;font-size:var(--text-xs)}.viewer-bottom-bar-left{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.viewer-bottom-bar-right{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.viewer-bottom-bar-sep{width:1px;height:16px;background:#94a3b833;flex-shrink:0}.control-switch{display:inline-flex;align-items:center;gap:.5rem;padding:.2rem .6rem .2rem .35rem;border-radius:var(--radius-full);border:1px solid rgba(148,163,184,.3);background:#02061799;color:#94a3b8;font-size:var(--text-xs);font-weight:var(--font-medium);cursor:pointer;transition:border-color .15s,background .15s,color .15s;white-space:nowrap}.control-switch:disabled{opacity:.5;cursor:not-allowed}.control-switch.is-on{border-color:#2dd4bfb3;background:#0d948840;color:#ccfbf1}.control-switch.is-pending{border-color:#f59e0b99;color:#fde68a}.control-switch-track{position:relative;width:28px;height:16px;border-radius:999px;background:#94a3b840;border:1px solid rgba(148,163,184,.35);transition:background .15s;flex-shrink:0}.control-switch.is-on .control-switch-track{background:#0d9488b3;border-color:#2dd4bfcc}.control-switch-thumb{position:absolute;top:2px;left:2px;width:10px;height:10px;border-radius:50%;background:#94a3b8;transition:transform .15s,background .15s}.control-switch.is-on .control-switch-thumb{transform:translate(12px);background:#2dd4bf}.viewer-session-timer{font-variant-numeric:tabular-nums;font-size:var(--text-xs);color:#64748b;white-space:nowrap}.viewer-system-stats{font-size:var(--text-xs);color:#64748b;white-space:nowrap}.viewer-tool-btn{min-height:28px;min-width:28px;padding:0 .45rem;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.3);background:#02061780;color:#94a3b8;font-size:var(--text-xs);display:inline-flex;align-items:center;gap:.3rem;cursor:pointer;transition:border-color .1s,color .1s}.viewer-tool-btn:hover{border-color:#38bdf8b3;color:#e2e8f0}.viewer-tool-btn.is-active{border-color:#2dd4bfb3;background:#0d948840;color:#ccfbf1}.viewer-tool-btn:disabled{opacity:.4;cursor:not-allowed}.viewer-file-panel{position:fixed;bottom:48px;right:var(--space-3);z-index:28;width:280px;padding:var(--space-3);background:#080e1ef7;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000080;display:none}.viewer-file-panel.open{display:block}.viewer-file-drop-zone{padding:var(--space-4);border:2px dashed rgba(148,163,184,.3);border-radius:var(--radius-md);text-align:center;color:#64748b;font-size:var(--text-sm);cursor:pointer;transition:border-color .15s,color .15s}.viewer-file-drop-zone.dragging{border-color:#2dd4bfcc;color:#ccfbf1}.viewer-command-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#000000b3;display:flex;align-items:center;justify-content:center}.viewer-command-modal{background:var(--surface-primary);border:1px solid var(--border-base);border-radius:var(--radius-lg);padding:var(--space-6);width:320px;display:flex;flex-direction:column;gap:var(--space-4)}.viewer-command-modal h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.viewer-command-modal p{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.viewer-command-modal-actions{display:flex;gap:var(--space-2);justify-content:flex-end}@media (max-width: 720px){.container{margin:0;border-radius:0;min-height:100vh;padding:var(--space-5)}.row{align-items:flex-start}.viewer-toolbar-wrap{padding:var(--space-1) var(--space-2)}.viewer-toolbar{gap:var(--space-1);padding:.3rem .45rem}.viewer-toolbar-group-status,.viewer-toolbar-group-actions{margin:0}.viewer-toolbar-feedback{top:calc(var(--space-2) + 7.2rem)}.viewer-quick-drawer-actions,.viewer-quick-drawer-combos{grid-template-columns:repeat(3,minmax(0,1fr))}.viewer-page .viewer-stage{padding-top:5.4rem}.viewer-quick-drawer{top:calc(var(--space-2) + 7.6rem);right:var(--space-2);width:calc(100vw - var(--space-4))}}.app-shell{min-height:100vh;display:grid;grid-template-columns:240px 1fr;background:var(--surface-canvas)}.app-sidebar{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5) var(--space-3);background:var(--color-gray-900);color:var(--color-gray-100);border-right:1px solid var(--color-gray-800);position:sticky;top:0;height:100vh}.app-sidebar-brand{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3)}.app-sidebar-brand-mark{width:2rem;height:2rem;border-radius:var(--radius-md);background:var(--color-primary-500);display:grid;place-items:center;color:var(--color-white);font-weight:var(--font-bold);font-size:var(--text-sm)}.app-sidebar-brand-name{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-white)}.app-sidebar-brand-sub{font-size:var(--text-xs);color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.04em}.app-sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.nav-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid transparent;color:var(--color-gray-300);text-align:left;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);display:flex;align-items:center;gap:var(--space-2);min-height:2.4rem;transition:background-color var(--transition-fast),color var(--transition-fast);cursor:pointer}.nav-item:hover{background:var(--color-gray-800);color:var(--color-white);border-color:transparent;box-shadow:none;transform:none}.nav-item.is-active{background:var(--color-primary-700);color:var(--color-white);border-color:var(--color-primary-600)}.nav-item-icon{width:1.1rem;height:1.1rem;display:inline-grid;place-items:center;font-size:.95rem;line-height:1;opacity:.9}.app-sidebar-user{border-top:1px solid var(--color-gray-800);padding-top:var(--space-3);display:grid;gap:var(--space-1)}.app-sidebar-user-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-white)}.app-sidebar-user-meta{font-size:var(--text-xs);color:var(--color-gray-400)}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--surface-base);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:5}.app-topbar-title{display:grid;gap:2px}.app-topbar-title h1{font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0;color:var(--text-strong)}.app-topbar-title small{color:var(--text-muted);font-size:var(--text-xs)}.app-topbar-actions{display:flex;align-items:center;gap:var(--space-2)}.app-main{padding:var(--space-5) var(--space-6);display:grid;gap:var(--space-4);max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.app-main-inner{display:grid;gap:var(--space-4)}.session-table-panel{background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);display:grid;gap:var(--space-3);box-shadow:var(--shadow-sm)}.session-table-panel-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.session-table-panel-header h2{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-strong)}.session-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.session-table th,.session-table td{text-align:left;padding:var(--space-3);border-bottom:1px solid var(--border-subtle);vertical-align:middle}.session-table thead th{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:var(--font-semibold);background:var(--surface-subtle)}.session-table tbody tr:last-child th,.session-table tbody tr:last-child td{border-bottom:none}.session-table-empty{padding:var(--space-5);text-align:center;color:var(--text-muted);font-size:var(--text-sm);border:1px dashed var(--border-base);border-radius:var(--radius-md)}.session-table-actions{display:inline-flex;gap:var(--space-2);flex-wrap:wrap}.session-table-actions button{min-height:2.1rem;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold)}.session-table-actions .btn-secondary{background:var(--surface-base);color:var(--color-primary-700);border-color:var(--border-base)}.session-table-actions .btn-secondary:hover{background:var(--surface-accent);border-color:var(--color-primary-300)}.session-table-actions .btn-danger{background:var(--surface-base);color:var(--color-error);border-color:#fecaca}.session-table-actions .btn-danger:hover{background:#fef2f2;border-color:var(--color-error)}.session-code-cell{font-family:var(--font-mono);font-weight:var(--font-semibold);color:var(--text-strong);letter-spacing:.05em}.session-status-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.18rem var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.04em;border:1px solid transparent}.session-status-badge:before{content:"";width:.45rem;height:.45rem;border-radius:50%;background:currentColor;display:inline-block}.session-status-badge.tone-pending{background:#fef3c7;color:#92400e;border-color:#fde68a}.session-status-badge.tone-progress{background:#dbeafe;color:#1e40af;border-color:#bfdbfe}.session-status-badge.tone-active{background:#d1fae5;color:#065f46;border-color:#a7f3d0}.session-status-badge.tone-ended{background:var(--color-gray-100);color:var(--color-gray-700);border-color:var(--color-gray-300)}.session-status-badge.tone-error{background:#fee2e2;color:#991b1b;border-color:#fecaca}.panel{background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.panel-heading{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3);gap:var(--space-3)}.panel-heading h2{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-strong)}.panel-heading small{color:var(--text-muted);font-size:var(--text-xs)}.view-placeholder{background:var(--surface-base);border:1px dashed var(--border-base);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;color:var(--text-muted);display:grid;gap:var(--space-2)}.view-placeholder h2{margin:0;color:var(--text-strong);font-size:var(--text-xl)}.view-placeholder p{margin:0;font-size:var(--text-sm)}.view-placeholder .tag{display:inline-flex;margin:0 auto;padding:.2rem var(--space-3);background:var(--surface-accent);color:var(--color-primary-700);border:1px solid var(--border-accent);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.04em}@media (max-width: 960px){.app-shell{grid-template-columns:1fr}.app-sidebar{position:static;height:auto;flex-direction:row;align-items:center;gap:var(--space-3);padding:var(--space-3);overflow-x:auto}.app-sidebar-brand{margin-bottom:0;flex-shrink:0}.app-sidebar-nav{flex-direction:row;flex:1;gap:var(--space-1)}.app-sidebar-user{border:none;padding-top:0;display:none}.app-topbar{padding:var(--space-3) var(--space-4)}.app-main{padding:var(--space-4)}}.viewer-resolution-hud{font-family:monospace;font-size:11px;color:#64748b;padding:2px 6px;background:#1e293b;border-radius:4px;white-space:nowrap}.viewer-stage:fullscreen{background:#000;display:grid;place-items:center}.viewer-stage:fullscreen .viewer{max-width:100vw;max-height:100vh}.placeholder\:text-gray-400::-moz-placeholder{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.placeholder\:text-gray-400::placeholder{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.first\:pt-0:first-child{padding-top:0}.last\:border-0:last-child{border-width:0px}.last\:pb-0:last-child{padding-bottom:0}.hover\:border-gray-400:hover{--tw-border-opacity: 1;border-color:rgb(148 163 184 / var(--tw-border-opacity, 1))}.hover\:border-primary-200:hover{--tw-border-opacity: 1;border-color:rgb(164 238 223 / var(--tw-border-opacity, 1))}.hover\:border-primary-700:hover{--tw-border-opacity: 1;border-color:rgb(16 113 106 / var(--tw-border-opacity, 1))}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(248 250 251 / var(--tw-bg-opacity, 1))}.hover\:bg-primary-50:hover{--tw-bg-opacity: 1;background-color:rgb(239 252 249 / var(--tw-bg-opacity, 1))}.hover\:bg-primary-700:hover{--tw-bg-opacity: 1;background-color:rgb(16 113 106 / var(--tw-bg-opacity, 1))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:text-white\/90:hover{color:#ffffffe6}.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px rgba(0, 0, 0, .06), 0 2px 4px -2px rgba(0, 0, 0, .04);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:brightness-95:hover{--tw-brightness: brightness(.95);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.focus-visible\:border-primary-500:focus-visible{--tw-border-opacity: 1;border-color:rgb(26 174 160 / var(--tw-border-opacity, 1))}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-primary-500\/30:focus-visible{--tw-ring-color: rgb(26 174 160 / .3)}.focus-visible\:ring-primary-500\/40:focus-visible{--tw-ring-color: rgb(26 174 160 / .4)}.focus-visible\:ring-white\/20:focus-visible{--tw-ring-color: rgb(255 255 255 / .2)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-60:disabled{opacity:.6}.group:hover .group-hover\:text-white\/90{color:#ffffffe6}@supports (backdrop-filter: var(--tw)){.supports-\[backdrop-filter\]\:bg-white\/80{background-color:#fffc}}@media (min-width: 640px){.sm\:flex{display:flex}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 768px){.md\:col-span-2{grid-column:span 2 / span 2}.md\:flex{display:flex}.md\:w-64{width:16rem}.md\:w-\[60px\]{width:60px}.md\:shrink-0{flex-shrink:0}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-\[minmax\(0\,220px\)_minmax\(0\,280px\)_1fr\]{grid-template-columns:minmax(0,220px) minmax(0,280px) 1fr}.md\:flex-col{flex-direction:column}.md\:items-end{align-items:flex-end}.md\:px-8{padding-left:2rem;padding-right:2rem}.md\:py-8{padding-top:2rem;padding-bottom:2rem}}@media (min-width: 1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-\[360px_minmax\(0\,1fr\)\]{grid-template-columns:360px minmax(0,1fr)}.lg\:grid-cols-\[minmax\(0\,1fr\)_320px\]{grid-template-columns:minmax(0,1fr) 320px}.lg\:border-b-0{border-bottom-width:0px}.lg\:border-r{border-right-width:1px}}@media (min-width: 1280px){.xl\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}
