*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.bottom-4{bottom:1rem}.left-3{left:.75rem}.right-0{right:0}.right-2{right:.5rem}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-2{top:.5rem}.top-4{top:1rem}.top-full{top:100%}.z-10{z-index:10}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[9999\]{z-index:9999}.col-span-2{grid-column:span 2 / span 2}.row-span-2{grid-row:span 2 / span 2}.m-0{margin:0}.m-1\.5{margin:.375rem}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:1rem;margin-bottom:1rem}.\!mb-8{margin-bottom:2rem!important}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-7{margin-bottom:1.75rem}.ml-0\.5{margin-left:.125rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.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}.size-full{width:100%;height:100%}.\!h-9{height:2.25rem!important}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-16{height:4rem}.h-3\.5{height:.875rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-full{height:100%}.h-screen{height:100vh}.max-h-\[200px\]{max-height:200px}.max-h-\[60vh\]{max-height:60vh}.max-h-none{max-height:none}.min-h-0{min-height:0px}.min-h-\[44px\]{min-height:44px}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-1\/2{width:50%}.w-16{width:4rem}.w-24{width:6rem}.w-28{width:7rem}.w-32{width:8rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-full{width:100%}.w-screen{width:100vw}.min-w-0{min-width:0px}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-\[200px\]{max-width:200px}.max-w-\[400px\]{max-width:400px}.max-w-\[85\%\]{max-width:85%}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;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))}.translate-y-\[20px\]{--tw-translate-y: 20px;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))}.rotate-180{--tw-rotate: 180deg;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))}.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 pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.resize-none{resize:none}.resize{resize:both}.grid-flow-dense{grid-auto-flow:dense}.auto-rows-\[200px\]{grid-auto-rows:200px}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:14px}.rounded-\[var\(--radius\)\]{border-radius:var(--radius)}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:20px}.rounded-sm{border-radius:10px}.\!border-0{border-width:0px!important}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.\!border-danger{border-color:var(--danger)!important}.border-accent{border-color:var(--accent)}.border-border{border-color:var(--border)}.border-t-transparent{border-top-color:transparent}.\!bg-transparent{background-color:transparent!important}.bg-\[color\:var\(--accent-lighter\)\]{background-color:var(--accent-lighter)}.bg-\[color\:var\(--danger-bg\)\]{background-color:var(--danger-bg)}.bg-accent{background-color:var(--accent)}.bg-bg{background-color:var(--bg)}.bg-bg-card{background-color:var(--bg-card)}.bg-bg-elevated{background-color:var(--bg-elevated)}.bg-bg-secondary{background-color:var(--bg-secondary)}.bg-danger{background-color:var(--danger)}.bg-transparent{background-color:transparent}.object-cover{-o-object-fit:cover;object-fit:cover}.\!p-0{padding:0!important}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.\!px-4{padding-left:1rem!important;padding-right:1rem!important}.\!py-3{padding-top:.75rem!important;padding-bottom:.75rem!important}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-3\.5{padding-left:.875rem;padding-right:.875rem}.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}.py-1{padding-top:.25rem;padding-bottom:.25rem}.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}.\!pl-9{padding-left:2.25rem!important}.pr-1{padding-right:.25rem}.pr-11{padding-right:2.75rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.\!text-sm{font-size:.875rem!important;line-height:1.25rem!important}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-6xl{font-size:3.75rem;line-height:1}.text-\[11px\]{font-size:11px}.text-\[15px\]{font-size:15px}.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-relaxed{line-height:1.625}.tracking-wide{letter-spacing:.025em}.text-\[\#2AABEE\]{--tw-text-opacity: 1;color:rgb(42 171 238 / var(--tw-text-opacity, 1))}.text-\[color\:var\(--warning\)\]{color:var(--warning)}.text-accent{color:var(--accent)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-text{color:var(--text)}.text-text-hint{color:var(--text-hint)}.text-text-secondary{color:var(--text-secondary)}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.opacity-50{opacity:.5}.shadow-lg{--tw-shadow: 0 8px 32px rgba(0,0,0,.5), 0 4px 8px rgba(0,0,0,.3);--tw-shadow-colored: 0 8px 32px var(--tw-shadow-color), 0 4px 8px 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-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.\!ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)!important}.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)}.\!transition-all{transition-property:all!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}.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-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--bg: #0d0d0f;--bg-secondary: #1a1a1f;--bg-card: #141418;--bg-elevated: #1e1e24;--text: #f0f0f5;--text-secondary: #a0a0b0;--text-hint: #606070;--text-on-accent: #ffffff;--accent: #4a8df5;--accent-dark: #3a7de5;--accent-light: #6ba3f7;--accent-lighter: rgba(74, 141, 245, .12);--accent-glow: rgba(74, 141, 245, .25);--accent-gradient: linear-gradient(135deg, #5a9df7 0%, #3a7de5 100%);--danger: #ef5350;--danger-bg: rgba(239, 83, 80, .12);--success: #4caf50;--success-bg: rgba(76, 175, 80, .12);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .12);--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .12);--radius-sm: 10px;--radius: 14px;--radius-lg: 20px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4), 0 2px 4px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5), 0 4px 8px rgba(0, 0, 0, .3);--shadow-accent: 0 4px 20px rgba(74, 141, 245, .28);--sidebar-w: 260px;--sidebar-w-collapsed: 72px;--topbar-h: 64px;--mobile-nav-h: 72px;--ease: cubic-bezier(.4, 0, .2, 1);--font-heading: "Comfortaa", "SF Pro Display", sans-serif;--font-body: "SF Pro Display", -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{scrollbar-gutter:stable;height:100%;min-height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overscroll-behavior:none}button{background:none;border:0;padding:0;cursor:pointer;color:inherit;font:inherit;-webkit-tap-highlight-color:transparent}button:disabled{cursor:not-allowed}a{color:inherit;text-decoration:none}input,button,textarea,select{font:inherit;color:inherit}.h1,.h2,.h3{font-family:var(--font-heading);font-weight:700;letter-spacing:-.3px}.h1{font-size:56px;line-height:1.05}.h2{font-size:32px;line-height:1.15}.h3{font-size:22px;line-height:1.25}.brand-text{font-family:var(--font-heading);font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.5px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .18s var(--ease),border-color .18s var(--ease),box-shadow .18s var(--ease)}.card.hoverable:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:48px;padding:0 22px;border-radius:var(--radius);font-weight:600;font-size:15px;white-space:nowrap;transition:transform .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease),box-shadow .15s var(--ease),color .15s var(--ease);-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-accent)}.btn-primary:hover{box-shadow:0 6px 28px var(--accent-glow)}.btn-secondary{background:var(--bg-elevated);border:1px solid var(--border-strong);color:var(--text)}.btn-secondary:hover{border-color:var(--accent);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text)}.btn-sm{height:36px;padding:0 14px;font-size:13.5px;border-radius:var(--radius-sm)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-sm)}.btn:disabled{opacity:.5;cursor:not-allowed}.input{width:100%;height:48px;padding:0 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:16px;transition:border-color .15s var(--ease),background .15s var(--ease);outline:none}.input::-moz-placeholder{color:var(--text-hint)}.input::placeholder{color:var(--text-hint)}.input:focus{border-color:var(--accent);background:#1d1d23}.input-group{position:relative}.input-group .input{padding-left:44px}.input-group .leading-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-hint);pointer-events:none}.chip{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;background:var(--accent-lighter);color:var(--accent-light);border-radius:999px;font-size:12.5px;font-weight:500;letter-spacing:.1px}.chip.neutral{background:#ffffff0d;color:var(--text-secondary)}.chip.success{background:var(--success-bg);color:var(--success)}.chip.warning{background:var(--warning-bg);color:var(--warning)}.chip.danger{background:var(--danger-bg);color:var(--danger)}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 0%,#25252c 50%,var(--bg-elevated) 100%);background-size:200% 100%;animation:shimmer 1.4s linear infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}.topnav{position:sticky;top:0;z-index:40;height:64px;display:flex;align-items:center;gap:24px;padding:0 28px;background:#0d0d0fc7;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}.topnav .tn-brand{display:flex;align-items:center;gap:10px;min-width:0}.topnav .logo-mark{width:30px;height:30px;font-size:15px;border-radius:9px;background:var(--accent-gradient);display:grid;place-items:center;color:#fff;font-family:var(--font-heading);font-weight:700;letter-spacing:-.5px;box-shadow:0 6px 18px var(--accent-glow),inset 0 1px #fff3}.topnav .brand-text{font-size:18px}.cap-tabs{display:inline-flex;align-items:center;background:var(--bg-card);border:1px solid var(--border);padding:4px;border-radius:12px;gap:2px}.cap-wrap{position:relative}.mega-menu{position:absolute;top:calc(100% + 10px);left:50%;transform:translate(calc(-50% + var(--mm-shift, 0px)));width:min(720px,calc(100vw - 24px));display:grid;grid-template-columns:1fr 1fr;gap:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:12px;box-shadow:0 20px 60px #0000008c;z-index:60;animation:capMenuIn .16s var(--ease)}.mega-menu:before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}@keyframes capMenuIn{0%{opacity:0;transform:translate(calc(-50% + var(--mm-shift, 0px))) translateY(-4px)}to{opacity:1;transform:translate(calc(-50% + var(--mm-shift, 0px)))}}.mega-col{display:flex;flex-direction:column;min-width:0}.mega-col+.mega-col{border-left:1px solid var(--border);padding-left:12px}.mega-col-head{font-size:11px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--text-hint);padding:6px 10px 10px}.mega-list{display:flex;flex-direction:column;gap:2px;max-height:64vh;overflow-y:auto}.mega-item{display:grid;grid-template-columns:32px 1fr;gap:10px;align-items:flex-start;text-align:left;padding:9px 10px;border-radius:10px;transition:background .12s var(--ease);min-width:0}.mega-item:hover{background:var(--bg-card)}.mega-ico{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);font-size:16px;line-height:1}.mega-ico.letter{font-family:var(--font-heading);font-weight:700;color:var(--accent-light);font-size:14px}.mega-body{min-width:0;display:flex;flex-direction:column;gap:2px}.mega-name{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;font-weight:600;font-size:14px;color:var(--text)}.mega-desc{font-size:12.5px;color:var(--text-secondary);line-height:1.4}.mega-badge{font-size:9.5px;font-weight:700;letter-spacing:.6px;padding:2px 6px;border-radius:5px;background:var(--bg-elevated);color:var(--text-secondary)}.mega-badge.top{background:#ffc85024;color:#f4c46b}.mega-badge.new{background:var(--accent-lighter);color:var(--accent-light)}.mega-empty{padding:14px 10px;color:var(--text-hint);font-size:12.5px;text-align:center}@media(max-width:820px){.mega-menu{grid-template-columns:1fr;width:min(440px,92vw)}.mega-col+.mega-col{border-left:0;border-top:1px solid var(--border);padding-left:0;padding-top:8px;margin-top:4px}}.cap-tabs .cap{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;border-radius:9px;color:var(--text-secondary);font-size:13.5px;font-weight:500;transition:color .15s var(--ease),background .15s var(--ease);white-space:nowrap}.cap-tabs .cap:hover{color:var(--text)}.cap-tabs .cap.on{background:var(--bg-elevated);color:var(--text);box-shadow:var(--shadow-sm)}.cap-tabs .cap.on .cap-dot{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.cap-tabs .cap .cap-dot{width:5px;height:5px;border-radius:50%;background:var(--text-hint);transition:background .15s var(--ease),box-shadow .15s var(--ease)}.cap-tabs .cap.soon{opacity:.55;cursor:not-allowed}.cap-tabs .cap .badge{font-size:9.5px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--text-hint);padding:2px 5px;border-radius:4px;background:#ffffff0a}.tn-right{margin-left:auto;display:flex;align-items:center;gap:10px}.tn-balance{display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 12px 0 14px;border-radius:999px;background:var(--bg-card);border:1px solid var(--border);font-size:13px;font-weight:500;cursor:pointer;transition:border-color .15s var(--ease)}.tn-balance:hover{border-color:var(--accent)}.tn-balance .b-dot{width:18px;height:18px;border-radius:50%;background:var(--accent-gradient);box-shadow:0 0 12px var(--accent-glow),inset 0 1px #ffffff40}.tn-balance .b-val{font-variant-numeric:tabular-nums;color:var(--text)}.tn-balance .b-lbl{color:var(--text-secondary)}.tn-balance .b-plus{width:22px;height:22px;border-radius:50%;background:var(--accent-lighter);color:var(--accent-light);display:grid;place-items:center;margin-left:2px}.tn-icon-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:var(--text-secondary);background:transparent;position:relative;transition:background .15s var(--ease),color .15s var(--ease)}.tn-icon-btn:hover{background:var(--bg-elevated);color:var(--text)}.tn-icon-btn .pip{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.account-btn{display:inline-flex;align-items:center;gap:9px;height:36px;padding:3px 10px 3px 4px;border-radius:999px;background:var(--bg-card);border:1px solid var(--border);transition:border-color .15s var(--ease),background .15s var(--ease)}.account-btn:hover{border-color:var(--accent)}.account-btn .avatar{width:28px;height:28px;font-size:11px}.account-btn .a-name{font-size:13px;font-weight:500;color:var(--text)}.menu-pop{position:absolute;top:calc(100% + 8px);right:0;min-width:260px;background:#141418eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:8px;z-index:50;animation:pop .16s var(--ease) both}@keyframes pop{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.menu-pop .menu-head{padding:10px 12px 12px;border-bottom:1px solid var(--border);margin-bottom:6px;display:flex;gap:12px;align-items:center}.menu-pop .menu-head .who{min-width:0}.menu-pop .menu-head .name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.menu-pop .menu-head .mail{font-size:12px;color:var(--text-hint);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.menu-item{display:flex;align-items:center;gap:10px;width:100%;height:38px;padding:0 10px;border-radius:9px;color:var(--text-secondary);font-size:13.5px;font-weight:500;transition:background .12s var(--ease),color .12s var(--ease)}.menu-item:hover{background:var(--bg-elevated);color:var(--text)}.menu-item.active{color:var(--text);background:var(--accent-lighter)}.menu-item .chev{margin-left:auto;color:var(--text-hint)}.menu-sep{height:1px;background:var(--border);margin:6px 4px}.menu-item.danger{color:var(--danger)}.menu-item.danger:hover{background:#ef535014}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#2e3848,#3a7de5);color:#fff;font-weight:600;display:grid;place-items:center;font-size:13px;letter-spacing:.5px;flex-shrink:0}.avatar.lg{width:64px;height:64px;font-size:22px}.main{min-width:0;display:flex;flex-direction:column;flex:1}.page{flex:1;display:flex;flex-direction:column;padding:36px 44px 48px;gap:24px;max-width:1400px;width:100%;margin:0 auto}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}.page-head .h1{margin:0}.page-head .sub{color:var(--text-secondary);margin:8px 0 0;font-size:15.5px;max-width:62ch}.page-head .actions{display:flex;gap:10px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(72px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:#141418d9;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:30}.bottom-nav .bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-hint);font-size:11px;font-weight:500;transition:color .15s var(--ease)}.bottom-nav .bn-item.active{color:var(--accent-light)}.bottom-nav .bn-item .dot{width:4px;height:4px;border-radius:50%;background:transparent;margin-top:-2px}.bottom-nav .bn-item.active .dot{background:var(--accent);box-shadow:0 0 10px var(--accent-glow)}.bottom-nav .bn-center{gap:6px;position:relative}.bottom-nav .bn-center .bn-fab{width:54px;height:54px;border-radius:18px;background:var(--accent-gradient);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-accent),inset 0 1px #ffffff38;margin-top:-22px;border:4px solid var(--bg);transition:transform .18s var(--ease),box-shadow .18s var(--ease)}.bottom-nav .bn-center:active .bn-fab{transform:translateY(1px) scale(.97)}.bottom-nav .bn-center.active .bn-fab{box-shadow:0 6px 28px var(--accent-glow),inset 0 1px #ffffff38}.bottom-nav .bn-center span:last-child{font-weight:600;color:var(--text)}.mobile-top{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;gap:12px;border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:20}.mobile-top .brand-text{font-size:17px}.mobile-top .logo-mark{width:28px;height:28px;border-radius:8px;font-size:14px}.row{display:flex;align-items:center;gap:12px}.col{display:flex;flex-direction:column;gap:12px}.between{justify-content:space-between}.muted{color:var(--text-secondary)}.hint{color:var(--text-hint)}.divider{height:1px;background:var(--border);width:100%}.mono{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-variant-numeric:tabular-nums}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:999px}*::-webkit-scrollbar-thumb:hover{background:#ffffff29}*::-webkit-scrollbar-track{background:transparent}.app.mobile .page{padding:22px 18px calc(100px + env(safe-area-inset-bottom))}.app.mobile .page-head .h1{font-size:34px}.app.mobile .page-head{align-items:flex-start}@keyframes rise{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.rise{animation:rise .36s var(--ease) both}.rise.d1{animation-delay:60ms}.rise.d2{animation-delay:.12s}.rise.d3{animation-delay:.18s}.rise.d4{animation-delay:.24s}.chat-wrap{display:flex;flex-direction:column;height:100%;min-height:0}.chat-scroll{flex:1;overflow:auto;padding:12px 0 24px;display:flex;flex-direction:column;gap:18px}.msg{display:flex;gap:14px;max-width:820px;width:100%;align-self:center}.msg.user{justify-content:flex-end}.msg .bubble{max-width:78%;padding:14px 18px;border-radius:18px;font-size:15px;line-height:1.55;text-wrap:pretty}.msg.ai .bubble{background:var(--bg-card);border:1px solid var(--border);border-radius:18px 18px 18px 6px;box-shadow:var(--shadow-sm)}.msg.user .bubble{background:var(--accent-lighter);border:1px solid rgba(74,141,245,.25);color:var(--text);border-radius:18px 18px 6px;padding:10px 18px}.msg .ai-mark{width:32px;height:32px;border-radius:9px;background:var(--accent-gradient);display:grid;place-items:center;color:#fff;flex-shrink:0;box-shadow:0 4px 14px var(--accent-glow)}.msg-meta{font-size:11.5px;color:var(--text-hint);margin-top:8px;display:flex;gap:10px}.msg-actions{display:flex;gap:4px;margin-top:6px;opacity:0;transition:opacity .15s var(--ease)}.msg:hover .msg-actions{opacity:1}.msg-actions button{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;color:var(--text-hint)}.msg-actions button:hover{background:var(--bg-elevated);color:var(--text)}.composer{position:sticky;bottom:0;background:linear-gradient(to top,var(--bg) 60%,transparent);padding:18px 0 8px}.composer-inner{max-width:820px;margin:0 auto;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:18px;padding:12px 12px 12px 16px;box-shadow:var(--shadow-md);transition:border-color .15s var(--ease)}.composer-inner:focus-within{border-color:var(--accent);box-shadow:var(--shadow-md),0 0 0 4px var(--accent-lighter)}.composer-row{display:flex;align-items:flex-end;gap:8px}.composer textarea{flex:1;resize:none;background:transparent;border:0;outline:0;color:var(--text);font-size:16px;line-height:1.5;padding:10px 4px;min-height:28px;max-height:200px;font-family:var(--font-body)}.composer textarea::-moz-placeholder{color:var(--text-hint)}.composer textarea::placeholder{color:var(--text-hint)}.composer .send{width:40px;height:40px;border-radius:12px;background:var(--accent-gradient);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-accent);transition:transform .15s var(--ease)}.composer .send:hover{transform:translateY(-1px)}.composer .send:disabled{opacity:.4;box-shadow:none}.composer .tool{width:36px;height:36px;border-radius:10px;color:var(--text-secondary);display:grid;place-items:center;transition:background .15s var(--ease),color .15s var(--ease)}.composer .tool:hover{background:var(--bg-elevated);color:var(--text)}.composer-meta{display:flex;justify-content:space-between;gap:12px;max-width:820px;margin:8px auto 0;padding:0 4px}.composer-meta .hint{font-size:11.5px;color:var(--text-hint)}.chat-shell{display:grid;grid-template-columns:280px 1fr;gap:0;height:calc(100vh - var(--topbar-h));min-height:0;background:var(--bg)}.app.mobile .chat-shell{grid-template-columns:1fr;height:calc(100vh - var(--topbar-h) - var(--mobile-nav-h))}.chat-side{display:flex;flex-direction:column;min-height:0;background:var(--bg-secondary);border-right:1px solid var(--border)}.app.mobile .chat-side{position:fixed;inset:var(--topbar-h) 0 var(--mobile-nav-h) 0;z-index:70;width:min(320px,86vw);right:auto;box-shadow:24px 0 48px #0000008c}.chat-side.open-backdrop:before{content:"";position:fixed;inset:var(--topbar-h) 0 var(--mobile-nav-h) 0;background:#00000080;z-index:-1}.cs-head{display:flex;align-items:center;gap:8px;padding:14px 14px 8px}.cs-head .cs-new{flex:1;min-width:0;justify-content:center}.cs-head .cs-collapse{width:34px;height:34px;flex:none;display:grid;place-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;color:var(--text-secondary)}.cs-head .cs-collapse:hover{background:var(--bg-elevated);color:var(--text)}.cs-search{margin:4px 14px 10px;display:flex;align-items:center;gap:8px;height:36px;padding:0 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;color:var(--text-hint)}.cs-search input{flex:1;background:transparent;border:0;outline:0;color:var(--text);font-size:13px;font-family:var(--font-body)}.cs-search input::-moz-placeholder{color:var(--text-hint)}.cs-search input::placeholder{color:var(--text-hint)}.cs-list{flex:1;overflow-y:auto;padding:4px 8px 16px}.cs-group{font-size:10.5px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--text-hint);padding:14px 10px 6px}.cs-item{width:100%;text-align:left;display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-radius:10px;background:transparent;border:1px solid transparent;transition:background .12s var(--ease),border-color .12s var(--ease);min-width:0}.cs-item:hover{background:var(--bg-card)}.cs-item.active{background:var(--bg-card);border-color:var(--border)}.cs-item.active .cs-title{color:var(--text)}.cs-title{display:flex;align-items:center;gap:6px;font-size:13.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-prev{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-meta{display:flex;justify-content:space-between;gap:8px;font-size:11px;color:var(--text-hint);font-family:ui-monospace,SF Mono,Menlo,monospace}.chat-shell.side-collapsed{grid-template-columns:1fr}.chat-shell.side-collapsed .chat-side{display:none}.chat-main{display:flex;flex-direction:column;min-width:0;min-height:0}.chat-head{display:flex;align-items:center;gap:12px;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--bg)}.app.mobile .chat-head{padding:12px 16px}.chat-head .expand-side{width:34px;height:34px;display:grid;place-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:9px;color:var(--text-secondary)}.chat-head .expand-side:hover{color:var(--text);background:var(--bg-elevated)}.chat-title{min-width:0;flex:1}.ct-name{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ct-sub{font-size:12px;color:var(--text-hint);margin-top:2px}.ch-actions{display:flex;align-items:center;gap:6px}.ch-actions .btn-icon{width:34px;height:34px;padding:0;display:grid;place-items:center}.chat-main .chat-scroll{flex:1;min-height:0;overflow-y:auto;padding:24px 0 16px}.chat-thread{width:100%;max-width:820px;margin:0 auto;padding:0;display:flex;flex-direction:column;gap:18px}.app.mobile .chat-thread{padding:0 16px}.chat-empty{max-width:560px;margin:8vh auto 0;padding:0 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}.ce-mark{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;background:var(--accent-lighter);color:var(--accent-light);border:1px solid var(--border)}.chat-empty h2{font-family:var(--font-heading);font-size:26px;font-weight:700;color:var(--text);margin:4px 0 0}.chat-empty p{font-size:14px;color:var(--text-secondary);max-width:420px;line-height:1.55}.ce-suggest{margin-top:12px;display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.ce-suggest button{padding:8px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;font-size:13px;color:var(--text-secondary);transition:background .12s var(--ease),color .12s var(--ease)}.ce-suggest button:hover{background:var(--bg-elevated);color:var(--text)}.chat-main .composer{position:sticky;bottom:0;padding:16px 24px 20px;background:linear-gradient(to top,var(--bg) 70%,transparent)}.app.mobile .chat-main .composer{padding:12px 16px 16px}.chat-main .composer-inner{max-width:820px}.composer-foot{display:flex;align-items:center;gap:12px;padding:8px 6px 2px;flex-wrap:wrap}.model-pick{position:relative;display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:999px;font-size:12.5px;color:var(--text-secondary);cursor:pointer;transition:border-color .12s var(--ease),color .12s var(--ease)}.model-pick:hover{color:var(--text);border-color:var(--border-strong)}.mp-dot{width:7px;height:7px;border-radius:50%;background:#5fd29a;box-shadow:0 0 8px #5fd29a99}.mp-name{font-weight:500;color:var(--text)}.mp-pop{position:absolute;bottom:calc(100% + 8px);left:0;width:320px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;padding:6px;box-shadow:0 20px 60px #0000008c;z-index:50;cursor:default;max-height:420px;overflow-y:auto}.mp-row{display:grid;grid-template-columns:1fr auto;gap:4px 12px;width:100%;text-align:left;padding:10px 12px;border-radius:10px;background:transparent;transition:background .12s var(--ease)}.mp-row:hover{background:var(--bg-card)}.mp-row.on{background:var(--accent-lighter)}.mp-row-name{font-size:13.5px;font-weight:600;color:var(--text);display:inline-flex;align-items:center;gap:6px}.mp-row-desc{grid-column:1 / -1;font-size:12px;color:var(--text-secondary)}.mp-row-rate{font-size:11px;color:var(--text-hint);align-self:center}.cs-item-menu{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;color:var(--text-hint);background:transparent;opacity:0;transition:opacity .12s var(--ease),background .12s var(--ease)}.cs-item:hover~.cs-item-menu,.cs-item-menu:hover,.cs-item-menu:focus-visible{opacity:1}.cs-list>div:hover .cs-item-menu{opacity:1}.cs-item-menu:hover{background:var(--bg-elevated);color:var(--text)}.cs-item-pop{position:absolute;top:36px;right:8px;z-index:30;min-width:180px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:6px;box-shadow:0 14px 40px #00000073}.cs-item-pop button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:8px;font-size:13px;color:var(--text-secondary);text-align:left;background:transparent;transition:background .1s var(--ease)}.cs-item-pop button:hover{background:var(--bg-card);color:var(--text)}.cs-item-pop button.danger{color:var(--danger)}.cs-item-pop button.danger:hover{background:#ef535014}.chat-error{margin:0 24px;padding:10px 14px;background:var(--danger-bg);border:1px solid rgba(239,83,80,.32);border-radius:12px;color:var(--danger);font-size:13px;display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-error button{width:24px;height:24px;border-radius:6px;display:grid;place-items:center;color:inherit;background:transparent}.chat-error button:hover{background:#ef535024}.app.mobile .chat-error{margin:0 16px}.msg-typing{display:inline-flex;gap:4px;color:var(--text-secondary);font-size:18px;letter-spacing:4px;line-height:1}.anim-spin{animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.composer-attachments{display:flex;flex-wrap:wrap;gap:8px;padding:4px 4px 10px;border-bottom:1px dashed var(--border);margin-bottom:8px}.msg-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.msg.user .msg-attachments{justify-content:flex-end}.att-chip{display:inline-flex;align-items:center;gap:8px;max-width:280px;padding:6px 10px 6px 6px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:12px;line-height:1.3;transition:border-color .12s var(--ease),background .12s var(--ease);text-decoration:none}.att-chip-link:hover{border-color:var(--accent)}.att-chip-loading{opacity:.7}.att-chip-error{border-color:#ef535066;background:#ef53500f}.att-chip-error .att-chip-meta{color:var(--danger)}.att-chip-icon{flex:0 0 28px;width:28px;height:28px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-secondary);overflow:hidden}.att-chip-icon img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.att-chip-body{min-width:0;display:flex;flex-direction:column;gap:1px}.att-chip-name{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.att-chip-meta{font-size:11px;color:var(--text-hint);white-space:nowrap}.att-chip-remove{flex:0 0 20px;width:20px;height:20px;border-radius:6px;background:transparent;border:none;display:grid;place-items:center;color:var(--text-hint);cursor:pointer;transition:background .1s var(--ease)}.att-chip-remove:hover{background:var(--bg-elevated);color:var(--text)}.att-chip-image{padding:0;width:140px;height:140px;max-width:none;overflow:hidden;border-radius:12px}.att-chip-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.topbar{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);margin-bottom:4px}.model-picker{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;font-size:13.5px;font-weight:500;color:var(--text);cursor:pointer;transition:border-color .15s var(--ease)}.model-picker:hover{border-color:var(--accent)}.model-picker .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.empty-illu{display:grid;place-items:center;padding:40px;background:var(--bg-card);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--text-hint);font-size:13px}.home{display:flex;flex-direction:column;gap:64px;padding:40px 48px 96px;max-width:1320px;margin:0 auto;width:100%}.app.mobile .home{padding:20px 18px 40px;gap:44px}.home-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:32px}.home-hero .eyebrow{font-size:11.5px;font-weight:600;letter-spacing:2.4px;text-transform:uppercase;color:var(--text-secondary);display:inline-flex;align-items:center;gap:10px;padding:7px 14px;border-radius:999px;background:var(--bg-card);border:1px solid var(--border);margin-bottom:28px}.home-hero .eyebrow .live-dot{width:6px;height:6px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 4px #4a8df52e}.home-h1{font-family:var(--font-heading);font-weight:700;font-size:clamp(44px,8.5vw,92px);line-height:.98;letter-spacing:-2.4px;margin:0;background:linear-gradient(180deg,#fff,#c8c8d0);-webkit-background-clip:text;background-clip:text;color:transparent}.home-h1 em{font-style:normal;background:linear-gradient(135deg,var(--accent-light),var(--accent-dark));-webkit-background-clip:text;background-clip:text;color:transparent}.home-hero .sub{font-size:18px;color:var(--text-secondary);margin:22px 0 40px;max-width:560px;line-height:1.5}.app.mobile .home-hero .sub{font-size:15px;margin:16px 0 28px}.home-prompt{width:100%;max-width:760px;display:flex;align-items:center;gap:8px;padding:10px 10px 10px 20px;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:20px;box-shadow:var(--shadow-lg);transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}.home-prompt:focus-within{border-color:var(--accent);box-shadow:var(--shadow-lg),0 0 0 4px #4a8df51f}.home-prompt input{flex:1;background:transparent;border:0;outline:0;color:var(--text);font:500 16px var(--font-body);height:48px;min-width:0}.home-prompt input::-moz-placeholder{color:var(--text-hint)}.home-prompt input::placeholder{color:var(--text-hint)}.home-prompt .pill-model{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 12px;border-radius:10px;background:var(--bg-elevated);color:var(--text-secondary);font-size:13px;font-weight:500;border:1px solid var(--border);cursor:pointer;transition:all .15s var(--ease);white-space:nowrap}.home-prompt .pill-model:hover{color:var(--text);border-color:var(--border-strong)}.home-prompt .send-btn{height:48px;min-width:48px;border-radius:14px;background:var(--accent-gradient);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-accent);transition:transform .15s var(--ease)}.home-prompt .send-btn:hover{transform:translateY(-1px)}.app.mobile .home-prompt{padding:8px 8px 8px 14px;border-radius:16px}.app.mobile .home-prompt .pill-model{display:none}.starter-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:22px;max-width:760px}.starter-chip{height:34px;padding:0 14px;border-radius:999px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:all .15s var(--ease)}.starter-chip:hover{color:var(--text);border-color:var(--accent);transform:translateY(-1px)}.starter-chip svg{color:var(--accent-light)}.home-sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}.home-sec-head h2{font-family:var(--font-heading);font-weight:700;font-size:clamp(26px,3.4vw,36px);letter-spacing:-.8px;margin:0;color:var(--text)}.home-sec-head p{color:var(--text-secondary);font-size:14px;margin:6px 0 0}.home-sec-head .see-all{color:var(--text-secondary);font-size:13.5px;font-weight:500;display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:10px;transition:all .15s var(--ease)}.home-sec-head .see-all:hover{color:var(--accent-light);background:var(--bg-elevated)}.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.tool-tile{position:relative;padding:22px;background:var(--bg-card);border:1px solid var(--border);border-radius:18px;text-align:left;display:flex;flex-direction:column;gap:14px;min-height:168px;transition:transform .2s var(--ease),border-color .2s var(--ease),box-shadow .2s var(--ease);overflow:hidden}.tool-tile:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-md)}.tool-tile .ti-ico{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--bg-elevated);color:var(--text);border:1px solid var(--border);transition:all .2s var(--ease)}.tool-tile:hover .ti-ico{background:var(--accent-lighter);color:var(--accent-light);border-color:#4a8df54d}.tool-tile .ti-name{font-family:var(--font-heading);font-weight:700;font-size:20px;letter-spacing:-.3px;color:var(--text)}.tool-tile .ti-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-top:-8px}.tool-tile .ti-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-hint);font-weight:500}.tool-tile .ti-foot .arr{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);transition:color .15s var(--ease),transform .2s var(--ease)}.tool-tile:hover .ti-foot .arr{color:var(--accent-light);transform:translate(2px)}.tool-tile .ti-glow{position:absolute;inset:-40% -40% auto auto;width:220px;height:220px;background:radial-gradient(circle at center,rgba(74,141,245,.18),transparent 60%);opacity:0;transition:opacity .28s var(--ease);pointer-events:none}.tool-tile:hover .ti-glow{opacity:1}.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}.gen-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:18px;overflow:hidden;transition:transform .22s var(--ease),border-color .22s var(--ease),box-shadow .22s var(--ease);display:flex;flex-direction:column;cursor:pointer}.gen-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-md)}.gen-card .media{position:relative;width:100%;background:linear-gradient(135deg,#1a1a22,#11111a);overflow:hidden}.gen-card .media:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.025) 0 2px,transparent 2px 14px);pointer-events:none}.gen-card .media .label{position:absolute;inset:0;display:grid;place-items:center;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px;letter-spacing:1.6px;color:#f0f0f566;text-transform:uppercase;text-align:center;padding:0 16px}.gen-card .badge-model{position:absolute;top:12px;left:12px;height:24px;padding:0 9px;border-radius:7px;background:#0d0d0fb3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:10.5px;color:var(--text);display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(255,255,255,.08);font-weight:500}.gen-card .badge-kind{position:absolute;top:12px;right:12px;height:24px;padding:0 9px;border-radius:7px;background:var(--accent-lighter);color:var(--accent-light);font-size:10.5px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;display:inline-flex;align-items:center}.gen-card .body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:8px}.gen-card .prompt-line{font-size:13.5px;line-height:1.45;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.gen-card .meta-row{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-hint)}.gen-card .use-cta{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);font-weight:500;transition:color .15s var(--ease)}.gen-card:hover .use-cta{color:var(--accent-light)}.gc-3{grid-column:span 3}.gc-4{grid-column:span 4}.gc-5{grid-column:span 5}.gc-6{grid-column:span 6}.gc-7{grid-column:span 7}.gc-8{grid-column:span 8}.media-sq{aspect-ratio:1 / 1}.media-port{aspect-ratio:3 / 4}.media-land{aspect-ratio:16 / 10}.media-wide{aspect-ratio:21 / 9}@media(max-width:1080px){.gallery-grid{grid-template-columns:repeat(6,1fr)}.gc-3,.gc-4,.gc-5{grid-column:span 3}.gc-6,.gc-7,.gc-8{grid-column:span 6}}@media(max-width:640px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}.gc-3,.gc-4,.gc-5,.gc-6,.gc-7,.gc-8{grid-column:span 2}.media-wide,.media-land{aspect-ratio:4 / 3}}.recent-row{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(280px,1fr);gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin}.recent-row::-webkit-scrollbar{height:6px}.recent-row::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:999px}.recent-card{display:flex;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;transition:border-color .18s var(--ease),transform .18s var(--ease)}.recent-card:hover{border-color:var(--accent);transform:translateY(-1px)}.recent-card .thumb{width:60px;height:60px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,#1a1a22,#11111a);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-hint)}.recent-card .rc-body{min-width:0;display:flex;flex-direction:column;gap:3px;flex:1}.recent-card .rc-title{font-size:13.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-card .rc-meta{font-size:11.5px;color:var(--text-hint);display:flex;gap:8px;align-items:center}.recent-card .rc-meta .dot{width:3px;height:3px;border-radius:999px;background:var(--text-hint)}.recent-card .rc-model{font-family:ui-monospace,SF Mono,Menlo,monospace;color:var(--text-secondary)}.history-list{display:flex;flex-direction:column;gap:10px}.history-day{font-size:12px;color:var(--text-hint);letter-spacing:.4px;text-transform:uppercase;padding:12px 4px 4px}.history-row{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .18s var(--ease),transform .18s var(--ease),background .18s var(--ease);cursor:pointer}.history-row:hover{transform:translateY(-1px);border-color:var(--accent)}.history-row .h-title{font-weight:600;font-size:15px}.history-row .h-preview{color:var(--text-secondary);font-size:13.5px;margin-top:3px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.history-row .meta{margin-left:auto;display:flex;gap:12px;align-items:center;color:var(--text-hint);font-size:12.5px;flex-shrink:0}.history-row .h-model{font-family:var(--font-body);font-weight:500;color:var(--text-secondary);font-size:12px;padding:3px 8px;background:var(--bg-elevated);border-radius:6px}.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.app.mobile .plans{grid-template-columns:1fr}.plan{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:26px;box-shadow:var(--shadow-sm);transition:transform .22s var(--ease),border-color .22s var(--ease),box-shadow .22s var(--ease);overflow:hidden}.plan:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--shadow-md)}.plan.featured{background:radial-gradient(120% 90% at 0% 0%,#4a8df52e,#4a8df500 55%),var(--bg-card);border-color:#4a8df559;box-shadow:var(--shadow-md),0 0 0 1px #4a8df533}.plan .ribbon{position:absolute;top:18px;right:18px;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;background:var(--accent-lighter);color:var(--accent-light);padding:5px 9px;border-radius:999px}.plan .plan-name{font-family:var(--font-heading);font-weight:700;font-size:22px}.plan .price{display:flex;align-items:baseline;gap:6px;margin:18px 0 4px}.plan .price .amount{font-family:var(--font-heading);font-weight:700;font-size:48px;letter-spacing:-1px}.plan .price .per{color:var(--text-secondary);font-size:14px}.plan .price .currency{font-size:24px;font-weight:600;color:var(--text-secondary)}.plan .feat-list{display:flex;flex-direction:column;gap:10px;margin:18px 0 22px}.plan .feat-list li{list-style:none;display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--text-secondary)}.plan .feat-list li .ck{flex-shrink:0;margin-top:1px;color:var(--accent-light)}.plan .feat-list li.bold{color:var(--text);font-weight:500}.plan ul{padding:0;margin:0}.packs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.app.mobile .packs{grid-template-columns:1fr}.pack{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;cursor:pointer;transition:transform .18s var(--ease),border-color .18s var(--ease),box-shadow .18s var(--ease);position:relative}.pack:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-md)}.pack.selected{border-color:var(--accent);box-shadow:var(--shadow-md),0 0 0 1px var(--accent),0 0 0 6px var(--accent-lighter)}.pack .pack-amount{font-family:var(--font-heading);font-weight:700;font-size:36px;letter-spacing:-.8px}.pack .pack-unit{font-size:14px;color:var(--text-secondary);margin-left:8px}.pack .pack-price{font-size:22px;font-weight:600;margin-top:12px}.pack .pack-bonus{position:absolute;top:16px;right:16px;font-size:11px;font-weight:600;color:var(--success);background:var(--success-bg);padding:4px 8px;border-radius:999px;letter-spacing:.4px}.pack .pack-rate{font-size:12px;color:var(--text-hint);margin-top:6px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.app.mobile .stat-grid{grid-template-columns:repeat(2,1fr)}.stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.stat .lbl{font-size:12px;color:var(--text-secondary);letter-spacing:.3px;text-transform:uppercase}.stat .val{font-family:var(--font-heading);font-weight:700;font-size:26px;margin-top:8px;letter-spacing:-.4px}.stat .delta{font-size:12px;color:var(--success);margin-top:4px}.stat .delta.neg{color:var(--danger)}.section-title{font-family:var(--font-heading);font-weight:700;font-size:18px;letter-spacing:-.2px;margin:0 0 14px}.field-row{display:grid;grid-template-columns:200px 1fr auto;gap:18px;align-items:center;padding:14px 0}.app.mobile .field-row{grid-template-columns:1fr;gap:6px;padding:12px 0}.field-row .lbl{color:var(--text-secondary);font-size:14px}.field-row .val{color:var(--text);font-size:15px}.field-row+.field-row{border-top:1px solid var(--border)}.invoice-row{display:grid;grid-template-columns:110px 1fr 110px 110px 40px;gap:16px;align-items:center;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:14px}.app.mobile .invoice-row{grid-template-columns:1fr auto}.invoice-row .desc{color:var(--text);font-weight:500}.invoice-row .date{color:var(--text-secondary);font-size:13px}.invoice-row .amount{font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.token-hero{position:relative;overflow:hidden;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:center}.app.mobile .token-hero{grid-template-columns:1fr;padding:22px}.token-hero:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(60% 80% at 80% 20%,#4a8df52e,#4a8df500 60%)}.token-orb{position:relative;width:220px;height:220px;margin-left:auto;border-radius:50%;background:radial-gradient(circle at 30% 25%,#6ba3f7,#3a7de5,#1e3a7e 80%);box-shadow:0 30px 90px #4a8df559,inset 0 -20px 50px #0006,inset 0 20px 50px #ffffff26;animation:float 6s ease-in-out infinite}.token-orb:after{content:"";position:absolute;inset:-6px;border-radius:50%;background:radial-gradient(circle,rgba(74,141,245,.3) 0%,transparent 70%);z-index:-1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.app.mobile .token-orb{width:140px;height:140px;margin:0 auto}.spark{display:flex;align-items:flex-end;gap:4px;height:56px;margin-top:8px}.spark span{flex:1;background:var(--accent-lighter);border-radius:4px;transition:background .22s var(--ease)}.spark span.hi{background:var(--accent)}.toggle{width:38px;height:22px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:999px;position:relative;cursor:pointer;transition:background .15s var(--ease),border-color .15s var(--ease)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-secondary);transition:transform .15s var(--ease),background .15s var(--ease)}.toggle.on{background:var(--accent);border-color:var(--accent)}.toggle.on:after{transform:translate(16px);background:#fff}.custom-amount-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:stretch}.app.mobile .custom-amount-row{grid-template-columns:1fr}.amount-input{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius);padding:14px 18px;display:flex;align-items:baseline;gap:8px;transition:border-color .15s var(--ease)}.amount-input:focus-within{border-color:var(--accent)}.amount-input input{flex:1;background:transparent;border:0;outline:0;color:var(--text);font-family:var(--font-heading);font-weight:700;font-size:30px;letter-spacing:-.5px;min-width:0}.amount-input .suffix{color:var(--text-secondary);font-size:14px;font-weight:500}.tx-list{display:flex;flex-direction:column;gap:10px}.tx-row{display:grid;grid-template-columns:40px 1fr auto auto;gap:16px;align-items:center;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .18s var(--ease),transform .18s var(--ease)}.tx-row:hover{transform:translateY(-1px);border-color:var(--accent)}.tx-ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:var(--accent-lighter);color:var(--accent-light)}.tx-ico.refund{background:var(--success-bg);color:var(--success)}.tx-ico.bonus{background:#f59e0b1f;color:var(--warning)}.tx-ico.topup{background:var(--success-bg);color:var(--success)}.tx-title{font-weight:600;font-size:14.5px;color:var(--text)}.tx-sub{font-size:12.5px;color:var(--text-secondary);margin-top:2px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.tx-sub .model-tag{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11.5px;padding:2px 7px;background:var(--bg-elevated);border-radius:5px;color:var(--text-secondary)}.tx-amount{font-family:var(--font-heading);font-weight:700;font-size:18px;font-variant-numeric:tabular-nums;letter-spacing:-.3px;text-align:right;white-space:nowrap}.tx-amount.neg{color:var(--danger)}.tx-amount.pos{color:var(--success)}.tx-time{color:var(--text-hint);font-size:12px;font-variant-numeric:tabular-nums;white-space:nowrap}.app.mobile .tx-row{grid-template-columns:40px 1fr auto}.app.mobile .tx-row .tx-time{display:none}.tx-filters{display:flex;gap:6px;margin-bottom:4px;flex-wrap:wrap}.tx-filter{height:32px;padding:0 12px;border-radius:999px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);font-size:12.5px;font-weight:500;transition:all .15s var(--ease)}.tx-filter:hover{color:var(--text)}.tx-filter.on{background:var(--accent-lighter);border-color:#4a8df559;color:var(--accent-light)}.tx-filter .count{margin-left:6px;color:var(--text-hint);font-variant-numeric:tabular-nums}.tx-filter.on .count{color:var(--accent-light);opacity:.7}.auth-shell{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}.auth-shell.mobile{grid-template-columns:1fr}.auth-hero{position:relative;overflow:hidden;padding:64px;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(80% 60% at 20% 10%,#4a8df529,#4a8df500 60%),radial-gradient(60% 50% at 90% 90%,#4a8df51f,#4a8df500 60%),var(--bg-card);border-right:1px solid var(--border)}.auth-shell.mobile .auth-hero{display:none}.auth-hero .grid-bg{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(to right,rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.025) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(60% 60% at 30% 40%,#000 0%,transparent 70%);mask-image:radial-gradient(60% 60% at 30% 40%,#000 0%,transparent 70%)}.auth-hero .h1{font-size:68px;line-height:.98;max-width:11ch;margin:0;position:relative}.auth-hero .sub{color:var(--text-secondary);font-size:17px;max-width:36ch;margin-top:18px;position:relative}.auth-hero .quote{position:relative;max-width:38ch}.auth-hero .quote .q{color:var(--text);font-size:16px;line-height:1.55;font-family:var(--font-heading);font-weight:500}.auth-hero .quote .a{color:var(--text-hint);font-size:13px;margin-top:10px}.auth-form-wrap{display:flex;align-items:center;justify-content:center;padding:56px 40px}.auth-form{width:100%;max-width:380px}.auth-form .auth-brand{display:flex;gap:10px;align-items:center;margin-bottom:36px}.auth-form .auth-brand .logo-mark{width:36px;height:36px;border-radius:10px;background:var(--accent-gradient);display:grid;place-items:center;color:#fff;font-family:var(--font-heading);font-weight:700;font-size:16px;letter-spacing:-.5px;box-shadow:0 6px 18px var(--accent-glow),inset 0 1px #fff3}.auth-form .h2{margin:0 0 6px}.auth-form .sub{color:var(--text-secondary);font-size:14.5px;margin:0 0 28px}.auth-tab{display:flex;gap:4px;padding:4px;background:var(--bg-elevated);border-radius:12px;margin-bottom:22px}.auth-tab button{flex:1;height:36px;border-radius:9px;font-size:13.5px;font-weight:500;color:var(--text-secondary);transition:all .15s var(--ease)}.auth-tab button.on{background:var(--bg-card);color:var(--text);box-shadow:var(--shadow-sm)}.field-block{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field-block .lbl{font-size:13px;color:var(--text-secondary);padding-left:2px}.oauth-row{display:flex;gap:8px;margin-top:20px}.oauth-row .btn{flex:1}.oauth-sep{display:flex;align-items:center;gap:12px;color:var(--text-hint);font-size:12px;margin:18px 0}.oauth-sep:before,.oauth-sep:after{content:"";flex:1;height:1px;background:var(--border)}.two-col{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;align-items:start}.app.mobile .two-col{grid-template-columns:1fr}.safe-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.safe-top{padding-top:env(safe-area-inset-top,0)}.pad-safe-bottom{padding-bottom:calc(var(--mobile-nav-h) + env(safe-area-inset-bottom,0))}@keyframes page-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.anim-page-in{animation:page-in .25s var(--ease)}.tilted-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;max-width:520px;width:100%;margin:20vh auto 10vh;padding:20vh 24px;perspective:900px}@media(max-width:600px){.tilted-grid{gap:24px;padding:14vh 16px;margin:12vh auto 6vh;max-width:100%}}.tilted-tile{position:relative;margin:0;cursor:pointer;will-change:transform}.tilted-inner{position:relative;width:100%;aspect-ratio:3 / 4;overflow:hidden;border-radius:8px;will-change:transform,filter;background:#111;box-shadow:0 20px 60px #00000080;transition:box-shadow .2s var(--ease)}.tilted-img{position:absolute;inset:0;background-size:cover;background-position:center;backface-visibility:hidden;will-change:transform}.tilted-veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 45%,transparent 70%);pointer-events:none}.tilted-meta{position:absolute;left:14px;right:14px;bottom:14px;display:flex;flex-direction:column;gap:6px;pointer-events:none;color:#fff}.tm-tags{display:flex;gap:6px}.tm-kind,.tm-model{font-size:9.5px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;padding:3px 7px;border-radius:4px;background:#ffffff29;color:#fff;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.tm-model{background:#ffffff14;color:#ffffffd9;font-family:ui-monospace,SF Mono,Menlo,monospace;text-transform:none;letter-spacing:0}.tm-prompt{font-size:13px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 2px 8px rgba(0,0,0,.6)}.tm-cta{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--accent-light);font-weight:600;margin-top:2px}.tilted-tile:hover .tilted-inner{box-shadow:0 28px 80px #000000a6}.brand-hero{position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;width:100vw;max-width:100vw;height:100vh;min-height:520px;overflow:hidden;background:#000;margin-top:calc(-1 * var(--topbar-h));margin-bottom:0}.shader-hero-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;background:#000}.brand-hero-veil{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,transparent 0%,rgba(0,0,0,.35) 70%,rgba(0,0,0,.7) 100%),linear-gradient(to bottom,rgba(0,0,0,.4) 0%,transparent 28%,transparent 72%,var(--bg) 100%);pointer-events:none}.brand-hero-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:calc(var(--topbar-h) + 24px) 24px 24px;gap:18px;z-index:2}.brand-hero-content .eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:999px;font-size:12.5px;font-weight:500;letter-spacing:.3px;color:#ffffffd9}.brand-hero-content .live-dot{width:6px;height:6px;border-radius:50%;background:#5fd29a;box-shadow:0 0 10px #5fd29acc}.brand-hero-title{font-family:var(--font-heading);font-size:clamp(64px,12vw,168px);font-weight:700;letter-spacing:-.04em;line-height:.95;color:#fff;text-shadow:0 4px 40px rgba(0,0,0,.6);margin:0}.brand-hero-sub{max-width:640px;font-size:clamp(14px,1.6vw,17px);line-height:1.55;color:#fffc;text-shadow:0 2px 12px rgba(0,0,0,.5);margin:0}.brand-hero-cta{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:6px}.brand-hero-cta .btn-ghost{background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.brand-hero-cta .btn-ghost:hover{background:#ffffff24;color:#fff}@media(max-width:600px){.brand-hero{height:clamp(380px,calc(100vh - 136px),720px)}}.img-page{position:relative;min-height:calc(100vh - var(--topbar-h));left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;width:100vw;max-width:100vw;padding:0;overflow:hidden;background:#0a0a0d}.img-bg{position:absolute;inset:0;overflow:hidden}.img-bg-grid{position:absolute;inset:-10%;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:0;transform:rotate(-6deg) scale(1.15);transform-origin:center;animation:imgDrift 80s linear infinite}@keyframes imgDrift{0%{transform:rotate(-6deg) translateY(0) scale(1.15)}to{transform:rotate(-6deg) translateY(-8%) scale(1.15)}}.img-bg-tile{aspect-ratio:3 / 4;border-radius:14px;box-shadow:0 16px 40px #0006}.img-bg-tile.s1{aspect-ratio:4 / 3}.img-bg-tile.s2{aspect-ratio:1 / 1}.img-bg-tile.s3{aspect-ratio:9 / 16}.img-bg-veil{position:absolute;inset:0;background:radial-gradient(ellipse 70% 90% at 50% 60%,#0a0a0fb3,#0a0a0feb 60%,#0a0a0d),linear-gradient(to bottom,#0a0a0fa6,#0a0a0f66 30%,#0a0a0fe6);pointer-events:none}.img-foreground{position:relative;z-index:2;max-width:880px;margin:0 auto;padding:64px 24px 200px;min-height:calc(100vh - var(--topbar-h));display:flex;flex-direction:column;gap:28px;justify-content:center}.img-hero{text-align:center;display:flex;flex-direction:column;gap:14px;align-items:center}.img-hero .eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:999px;font-size:12.5px;font-weight:500;letter-spacing:.3px;color:#ffffffd9}.img-hero .live-dot{width:6px;height:6px;border-radius:50%;background:#5fd29a;box-shadow:0 0 10px #5fd29acc}.img-h1-wrap{position:relative;display:flex;flex-direction:column;align-items:center}.img-h1{font-family:var(--font-heading);font-size:clamp(38px,6vw,72px);font-weight:700;letter-spacing:-.03em;line-height:1;color:#fff;margin:0;text-shadow:0 4px 32px rgba(0,0,0,.7),0 2px 8px rgba(0,0,0,.5);position:relative;z-index:3}.img-sub{font-size:clamp(14px,1.5vw,16px);color:#ffffffb3;max-width:540px;margin:0;position:relative;z-index:10}.hero-shapes{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}.hero-shape{position:absolute;will-change:transform,opacity;opacity:0;animation:heroShapeIn 2.2s cubic-bezier(.23,.86,.39,.96) forwards}.hero-shape-inner{position:relative;will-change:transform;animation:heroShapeFloat 16s ease-in-out infinite;transform-origin:center}.hero-shape:nth-child(2n) .hero-shape-inner{animation-duration:21s;animation-direction:alternate}.hero-shape:nth-child(3n) .hero-shape-inner{animation-duration:25s}.hero-shape:nth-child(4n) .hero-shape-inner{animation-duration:19s;animation-direction:alternate-reverse}.hero-shape-frame{position:relative;width:100%;height:100%;border-radius:14px;overflow:hidden;box-shadow:0 18px 60px #00000080,0 2px 10px #0000004d;border:1px solid rgba(255,255,255,.08);background:#111}.hero-shape-frame img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;filter:saturate(.85) brightness(.85)}.hero-shape-frame-veil{position:absolute;inset:0;background:linear-gradient(160deg,#0a0a0f40,#0a0a0f8c)}@keyframes heroShapeIn{0%{opacity:0;transform:translateY(-180px) rotate(var(--rot-start))}to{opacity:.85;transform:translateY(0) rotate(var(--rot-end))}}@keyframes heroShapeFloat{0%{transform:translateZ(0) rotate(0)}25%{transform:translate3d(8px,-12px,0) rotate(1.4deg)}50%{transform:translate3d(-6px,14px,0) rotate(-1.2deg)}75%{transform:translate3d(10px,5px,0) rotate(.8deg)}to{transform:translateZ(0) rotate(0)}}.hf-dock{position:fixed;left:0;right:0;bottom:24px;z-index:30;display:flex;justify-content:center;padding:0 20px;pointer-events:none}.app.mobile .hf-dock{bottom:calc(var(--mobile-nav-h) + env(safe-area-inset-bottom,0) + 12px);padding:0 12px}.hf-dock .hf-bar{pointer-events:auto;max-width:980px;width:100%}.hf-bar{display:flex;align-items:stretch;gap:10px;background:#0e0e1273;backdrop-filter:blur(22px) saturate(140%);-webkit-backdrop-filter:blur(22px) saturate(140%);border:1px solid rgba(255,255,255,.06);border-radius:22px;padding:10px;box-shadow:0 30px 80px #0000008c;position:relative}.hf-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px;padding:6px 4px 4px 8px}.hf-prompt-row{display:flex;align-items:flex-start;gap:12px;min-height:44px}.hf-plus{width:36px;height:36px;flex:0 0 36px;border-radius:10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:#ffffffd9;font-size:20px;font-weight:400;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s ease}.hf-plus:hover{background:#ffffff1a}.hf-prompt{flex:1;min-width:0;background:transparent;border:none;outline:none;color:#fff;font-family:var(--font-body);font-size:16px;padding:8px 0;min-height:36px;max-height:160px;line-height:1.45;resize:none;overflow-y:auto}.hf-prompt::-moz-placeholder{color:#ffffff6b}.hf-prompt::placeholder{color:#ffffff6b}.hf-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.hf-chip{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.06);border-radius:999px;color:#ffffffd9;font-size:13.5px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:background .12s ease,border-color .12s ease;white-space:nowrap}.hf-chip:hover{background:#ffffff14}.hf-chip-on{background:#ffffff1a;border-color:#ffffff29}.hf-chip-icon{font-size:14px;opacity:.8}.hf-chip-glyph{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;font-family:var(--font-heading)}.hf-chip-name{font-weight:600}.hf-chev{opacity:.5;font-size:16px;line-height:1;margin-left:-2px}.hf-stepper{gap:4px;padding:0 8px}.hf-step{width:24px;height:24px;border:none;background:transparent;color:#ffffffb3;font-size:16px;cursor:pointer;border-radius:6px;display:inline-flex;align-items:center;justify-content:center}.hf-step:hover{background:#ffffff14;color:#fff}.hf-step-val{font-variant-numeric:tabular-nums;min-width:28px;text-align:center;font-weight:500}.hf-pop-wrap{position:relative;display:inline-flex}.hf-pop{position:absolute;bottom:calc(100% + 10px);left:0;min-width:260px;background:#0e0e12d9;backdrop-filter:blur(22px) saturate(140%);-webkit-backdrop-filter:blur(22px) saturate(140%);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:12px;box-shadow:0 20px 60px #0000008c;z-index:50;animation:hfPopIn .16s cubic-bezier(.22,1,.36,1)}@keyframes hfPopIn{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}.hf-pop-title{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#ffffff80;padding:4px 8px 8px}.hf-pop-list{display:flex;flex-direction:column;gap:2px;max-height:360px;overflow-y:auto;padding-right:2px}.hf-pop-item{display:flex;align-items:flex-start;gap:10px;padding:9px 10px;background:transparent;border:none;border-radius:10px;color:#fff;text-align:left;cursor:pointer;transition:background .1s ease;width:100%}.hf-pop-item:hover{background:#ffffff0f}.hf-pop-item.on{background:#ffffff14}.hf-pop-glyph{width:26px;height:26px;flex:0 0 26px;border-radius:50%;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;font-family:var(--font-heading);margin-top:1px}.hf-pop-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.hf-pop-item-name{font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:8px}.hf-pop-badge{font-size:9.5px;font-weight:700;letter-spacing:.6px;color:var(--accent);border:1px solid var(--accent);padding:1px 5px;border-radius:4px;text-transform:uppercase}.hf-pop-item-desc{font-size:12px;color:#ffffff8c;line-height:1.35}.hf-pop-check{color:var(--accent);font-size:14px;margin-left:6px;align-self:center}.hf-pop-item-row{align-items:center}.hf-pop-item-row .hf-pop-item-name{font-size:14px;min-width:36px}.hf-pop-item-row .hf-pop-item-desc{margin-left:auto}.hf-pop-revolver{min-width:320px}.hf-revolver{display:flex;align-items:center;gap:16px;padding:8px}.hf-rev-preview{flex:0 0 140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:8px}.hf-rev-box{border:2px solid var(--accent);border-radius:12px;background:#4a8df50f;box-shadow:0 0 0 4px #4a8df514,0 0 24px #4a8df533;transition:width .22s cubic-bezier(.22,1,.36,1),height .22s cubic-bezier(.22,1,.36,1)}.hf-rev-label{font-family:var(--font-heading);font-size:18px;font-weight:700;color:#fff;letter-spacing:.5px}.hf-rev-wheel{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 0}.hf-rev-arrow{background:transparent;border:none;color:#fff6;cursor:pointer;padding:6px 10px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;width:100%}.hf-rev-arrow:hover{color:#fff;background:#ffffff0f}.hf-rev-opt{background:transparent;border:none;font-family:ui-monospace,monospace;font-size:14px;color:#fff6;padding:4px 0;text-align:center;cursor:pointer;border-radius:6px;width:100%}.hf-rev-opt:hover{color:#fff}.hf-rev-opt:nth-child(2),.hf-rev-opt:nth-last-child(2){font-size:13px;opacity:.55}.hf-rev-current{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--accent);padding:4px 0;text-align:center;cursor:default;width:100%}.hf-generate{position:relative;display:inline-flex;flex:0 0 auto;align-self:stretch;align-items:center;justify-content:center;min-width:168px;background:linear-gradient(180deg,var(--accent-light),var(--accent));color:#fff;border:1px solid var(--accent-light);border-radius:16px;padding:0 28px;font-family:var(--font-heading);font-weight:700;font-size:17px;cursor:pointer;transition:transform .12s ease,box-shadow .2s ease;box-shadow:0 8px 28px var(--accent-glow),0 0 40px var(--accent-glow);overflow:hidden}.hf-generate:hover{transform:translateY(-1px);box-shadow:0 12px 36px var(--accent-glow),0 0 60px var(--accent-glow)}.hf-generate:disabled{opacity:.6;cursor:not-allowed;transform:none}.hf-gen-glow{position:absolute;inset:-40%;background:radial-gradient(circle at 30% 50%,var(--accent-glow) 0%,transparent 55%),radial-gradient(circle at 70% 50%,rgba(255,255,255,.25) 0%,transparent 50%);filter:blur(20px);opacity:.7;pointer-events:none;animation:hfGenPulse 3.5s ease-in-out infinite}@keyframes hfGenPulse{0%,to{opacity:.55;transform:scale(1)}50%{opacity:.85;transform:scale(1.05)}}.hf-gen-inner{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px}.hf-gen-n{font-variant-numeric:tabular-nums;font-weight:700;opacity:.9}@media(max-width:820px){.hf-bar{flex-direction:column;padding:8px;gap:8px;border-radius:18px}.hf-generate{width:100%;min-height:50px}.hf-prompt{font-size:15px}.hf-pop{left:0;right:auto;min-width:280px}}@media(max-width:600px){.hf-chips{gap:6px}.hf-chip{height:34px;padding:0 11px;font-size:12.5px}.hf-pop-revolver{min-width:280px}.hf-rev-preview{flex:0 0 110px}.img-foreground{padding:28px 16px 40px;gap:20px}.img-bg-grid{grid-template-columns:repeat(3,1fr);gap:10px}}.gen-page{display:grid;grid-template-columns:minmax(320px,420px) 1fr;gap:20px;padding:24px 28px 32px;min-height:calc(100vh - var(--topbar-h))}.app.mobile .gen-page{grid-template-columns:1fr;padding:16px 14px calc(var(--mobile-nav-h) + 24px);gap:14px}.gen-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 18px;display:flex;flex-direction:column;gap:18px;align-self:start;position:sticky;top:calc(var(--topbar-h) + 16px)}.app.mobile .gen-panel{position:static}.gen-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.gen-panel-head h2{font-family:var(--font-heading);font-size:18px;font-weight:600;margin:0}.gen-panel-head .gen-sub{font-size:12px;color:var(--text-hint)}.gen-field{display:flex;flex-direction:column;gap:8px}.gen-field-label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-hint)}.gen-prompt{width:100%;min-height:110px;resize:vertical;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-size:14px;line-height:1.5;color:var(--text);transition:border-color .15s var(--ease)}.gen-prompt:focus{outline:none;border-color:var(--accent)}.gen-prompt::-moz-placeholder{color:var(--text-hint)}.gen-prompt::placeholder{color:var(--text-hint)}.gen-chips{display:flex;flex-wrap:wrap;gap:6px}.gen-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:999px;background:var(--bg);border:1px solid var(--border);color:var(--text-secondary);font-size:12.5px;font-weight:500;transition:border-color .15s var(--ease),color .15s var(--ease)}.gen-chip:hover{color:var(--text);border-color:var(--border-strong)}.gen-chip.on{color:var(--accent-light);border-color:var(--accent);background:var(--accent-lighter)}.gen-select{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:13.5px;cursor:pointer;transition:border-color .15s var(--ease)}.gen-select:hover{border-color:var(--border-strong)}.gen-select:focus{outline:none;border-color:var(--accent)}.gen-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;height:44px;border-radius:var(--radius);background:var(--accent-gradient);color:var(--text-on-accent);font-weight:600;font-size:14px;box-shadow:var(--shadow-accent);transition:transform .12s var(--ease),box-shadow .15s var(--ease)}.gen-cta:hover{transform:translateY(-1px);box-shadow:0 6px 24px var(--accent-glow)}.gen-cta:disabled{opacity:.55;transform:none;box-shadow:none}.gen-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);min-height:540px;display:grid;place-items:center;padding:32px;text-align:center}.gen-preview-empty{display:flex;flex-direction:column;align-items:center;gap:14px;color:var(--text-secondary);max-width:380px}.gen-preview-empty .gpe-icon{width:64px;height:64px;border-radius:16px;background:var(--bg-elevated);border:1px solid var(--border);display:grid;place-items:center;color:var(--accent-light)}.gen-preview-empty h3{font-family:var(--font-heading);font-size:18px;font-weight:600;color:var(--text);margin:0}.gen-preview-empty p{font-size:13.5px;line-height:1.5;margin:0}.gen-scene{position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;width:100vw;max-width:100vw;min-height:calc(100vh - var(--topbar-h));background:var(--bg);padding:32px 24px 48px;display:flex;justify-content:center}.app.mobile .gen-scene{padding:20px 14px calc(var(--mobile-nav-h) + 24px)}.gen-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;background:radial-gradient(ellipse 60% 80% at 50% 0%,var(--accent-lighter) 0%,transparent 60%),radial-gradient(ellipse 40% 60% at 50% 100%,rgba(74,141,245,.04) 0%,transparent 70%)}.gen-panel{position:relative;z-index:1;width:100%;max-width:520px;display:flex;flex-direction:column;gap:18px}.gen-head h1{font-family:var(--font-heading);font-size:clamp(24px,3vw,32px);font-weight:700;letter-spacing:-.02em;color:var(--text);margin:0 0 6px}.gen-head .gen-sub{font-size:13.5px;line-height:1.5;color:var(--text-secondary);margin:0}.gen-mode-tabs{display:flex;gap:24px;border-bottom:1px solid var(--border);padding:0 4px}.gen-mode-tab{padding:10px 0;background:transparent;border:none;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;position:relative;transition:color .12s var(--ease);white-space:nowrap}.gen-mode-tab:hover,.gen-mode-tab.on{color:var(--text)}.gen-mode-tab.on:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent);border-radius:2px}.gen-slots{display:grid;gap:12px}.gen-slots.is-single{grid-template-columns:1fr!important}.gen-slot{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:10px;min-width:0}.gen-slot-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.gen-slot-label{font-size:12.5px;font-weight:600;color:var(--text)}.gen-slot-badge{font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;padding:3px 7px;border-radius:5px}.gen-slot-badge.is-optional{background:var(--bg-elevated);color:var(--text-hint)}.gen-slot-badge.is-required{background:var(--accent-lighter);color:var(--accent-light)}.gen-slot-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:28px 16px;background:var(--bg);border:1px dashed var(--border-strong);border-radius:12px;color:var(--text-secondary);cursor:pointer;transition:border-color .12s var(--ease),background .12s var(--ease)}.gen-slot-drop:hover{border-color:var(--accent);background:var(--bg-elevated);color:var(--text)}.gen-slot-icon{width:36px;height:36px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-secondary)}.gen-slot-hint{font-size:13px;font-weight:500;color:var(--text)}.gen-slot-meta{font-size:11px;color:var(--text-hint)}.gen-slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px}.gen-slot-tile{position:relative;aspect-ratio:1 / 1;background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:grid;place-items:center}.gen-slot-tile img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.gen-slot-tile.is-uploading img{opacity:.5}.gen-slot-tile.is-error{border-color:#ef535066}.gen-slot-tile-icon{color:var(--text-hint)}.gen-slot-tile-overlay{position:absolute;inset:0;display:grid;place-items:center;background:#0006;color:#fff;font-size:16px;font-weight:700}.gen-slot-tile-remove{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:#0009;border:none;display:grid;place-items:center;color:#fff;cursor:pointer;transition:background .1s var(--ease)}.gen-slot-tile-remove:hover{background:var(--danger)}.gen-slot-add{aspect-ratio:1 / 1;background:var(--bg);border:1px dashed var(--border-strong);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-hint);cursor:pointer;transition:border-color .12s var(--ease)}.gen-slot-add:hover{border-color:var(--accent);color:var(--text)}.gen-slot-count{font-size:10px;font-family:ui-monospace,SF Mono,Menlo,monospace;color:var(--text-hint)}.gen-scene .gen-prompt{width:100%;min-height:100px;resize:vertical;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius);padding:14px 16px;font-size:14px;line-height:1.55;color:var(--text);font-family:var(--font-body);transition:border-color .15s var(--ease)}.gen-scene .gen-prompt:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-lighter)}.gen-scene .gen-prompt::-moz-placeholder{color:var(--text-hint)}.gen-scene .gen-prompt::placeholder{color:var(--text-hint)}.gen-settings{display:flex;flex-direction:column;gap:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.gen-set{display:flex;flex-direction:column;gap:8px}.gen-set-toggle{flex-direction:row;align-items:center;justify-content:space-between;gap:12px}.gen-set-label{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;font-weight:500;color:var(--text)}.gen-set-desc{font-size:11.5px;font-weight:400;color:var(--text-hint)}.gen-set-val{font-size:13px;color:var(--accent-light);font-weight:600}.gen-scene .gen-chips{display:flex;flex-wrap:wrap;gap:6px}.gen-scene .gen-chip{display:inline-flex;align-items:center;height:32px;padding:0 12px;background:var(--bg);border:1px solid var(--border);border-radius:999px;font-size:12.5px;color:var(--text-secondary);cursor:pointer;transition:background .12s var(--ease),border-color .12s var(--ease),color .12s var(--ease)}.gen-scene .gen-chip:hover{color:var(--text);border-color:var(--border-strong)}.gen-scene .gen-chip.on{background:var(--accent-lighter);border-color:var(--accent);color:var(--accent-light)}.gen-slider{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--bg-elevated);border-radius:2px;outline:none}.gen-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 0 2px var(--bg-card)}.gen-slider::-moz-range-thumb{width:16px;height:16px;border:none;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 0 2px var(--bg-card)}.gen-scene .gen-select,.gen-num,.gen-text{width:100%;height:36px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:0 12px;color:var(--text);font-size:13.5px;font-family:var(--font-body);transition:border-color .12s var(--ease)}.gen-scene .gen-select:focus,.gen-num:focus,.gen-text:focus{outline:none;border-color:var(--accent)}.gen-toggle{position:relative;width:40px;height:22px;flex:0 0 40px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:999px;cursor:pointer;transition:background .15s var(--ease),border-color .15s var(--ease)}.gen-toggle.on{background:var(--accent);border-color:var(--accent)}.gen-toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .15s var(--ease)}.gen-toggle.on .gen-toggle-knob{transform:translate(18px)}.gen-model-row{position:relative}.gen-model-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;transition:border-color .12s var(--ease)}.gen-model-btn:hover{border-color:var(--border-strong)}.gen-model-glyph{width:28px;height:28px;border-radius:8px;background:var(--accent-gradient);color:#fff;display:grid;place-items:center;font-family:var(--font-heading);font-weight:700;font-size:13px;flex:0 0 28px}.gen-model-text{flex:1;min-width:0;display:flex;flex-direction:column;text-align:left}.gen-model-meta{font-size:10.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--text-hint)}.gen-model-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gen-model-pop{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;padding:6px;box-shadow:0 20px 60px #0000008c;max-height:420px;overflow-y:auto}.gen-model-row-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px;background:transparent;border:none;border-radius:10px;color:var(--text);text-align:left;cursor:pointer;transition:background .1s var(--ease)}.gen-model-row-item:hover{background:var(--bg-card)}.gen-model-row-item.on{background:var(--accent-lighter)}.gen-model-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.gen-model-item-name{font-size:13.5px;font-weight:600;color:var(--text)}.gen-model-item-desc{font-size:12px;color:var(--text-secondary);line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gen-scene .gen-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;height:52px;border-radius:var(--radius);background:var(--accent-gradient);color:var(--text-on-accent);font-family:var(--font-heading);font-weight:700;font-size:15px;letter-spacing:.2px;border:none;cursor:pointer;box-shadow:var(--shadow-accent);transition:transform .12s var(--ease),box-shadow .15s var(--ease)}.gen-scene .gen-cta:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 28px var(--accent-glow)}.gen-scene .gen-cta:disabled{opacity:.5;cursor:not-allowed}.gen-cta-cost{margin-left:auto;font-size:12.5px;font-weight:600;opacity:.85;font-family:ui-monospace,SF Mono,Menlo,monospace}.gen-voice-btn{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;width:100%;height:38px;padding:0 12px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13.5px;font-family:var(--font-body);cursor:pointer;transition:border-color .12s var(--ease)}.gen-voice-btn:hover{border-color:var(--border-strong)}.gen-voice-btn-name{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gen-scene.has-picker{align-items:flex-start;gap:16px}.voice-picker-backdrop{display:none}.voice-picker{position:relative;z-index:2;width:360px;flex-shrink:0;align-self:flex-start;position:sticky;top:calc(var(--topbar-h) + 16px);max-height:calc(100vh - var(--topbar-h) - 64px);background:var(--bg-secondary);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.voice-picker-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.voice-picker-title{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text)}.voice-picker-sub{font-size:11.5px;color:var(--text-hint);margin-top:2px;letter-spacing:.4px;text-transform:uppercase}.voice-picker-close{width:28px;height:28px;border-radius:8px;background:transparent;border:none;display:grid;place-items:center;color:var(--text-secondary);cursor:pointer;transition:background .1s var(--ease)}.voice-picker-close:hover{background:var(--bg-elevated);color:var(--text)}.voice-picker-search{display:flex;align-items:center;gap:8px;margin:10px 14px 6px;padding:0 12px;height:36px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;color:var(--text-hint)}.voice-picker-search input{flex:1;background:transparent;border:0;outline:0;color:var(--text);font-size:13px;font-family:var(--font-body)}.voice-picker-search input::-moz-placeholder{color:var(--text-hint)}.voice-picker-search input::placeholder{color:var(--text-hint)}.voice-picker-list{flex:1;overflow-y:auto;padding:4px 8px 12px}.voice-picker-empty{padding:24px 16px;text-align:center;font-size:13px;color:var(--text-hint)}.voice-picker-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:1px solid transparent;border-radius:10px;cursor:pointer;text-align:left;color:var(--text);transition:background .12s var(--ease),border-color .12s var(--ease)}.voice-picker-item:hover{background:var(--bg-card)}.voice-picker-item.is-selected{background:var(--accent-lighter);border-color:var(--accent)}.voice-picker-item-body{flex:1;min-width:0}.voice-picker-item-name{font-size:13.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-picker-item-meta{font-size:11.5px;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-picker-play{flex:0 0 30px;width:30px;height:30px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-secondary);cursor:pointer;transition:background .12s var(--ease),color .12s var(--ease),border-color .12s var(--ease)}.voice-picker-play:hover{border-color:var(--accent);color:var(--accent-light)}.voice-picker-play.is-playing{background:var(--accent);border-color:var(--accent);color:#fff}.media-picker-grid{flex:1;overflow-y:auto;padding:8px 12px 12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;align-content:start}.media-pick-tile{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:6px;cursor:pointer;display:flex;flex-direction:column;gap:6px;text-align:left;transition:border-color .12s var(--ease),background .12s var(--ease)}.media-pick-tile:hover{border-color:var(--border-strong)}.media-pick-tile.is-selected{border-color:var(--accent);background:var(--accent-lighter)}.media-pick-thumb{position:relative;width:100%;aspect-ratio:1 / 1;background:var(--bg-elevated);border-radius:8px;overflow:hidden}.media-pick-thumb img,.media-pick-thumb video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.media-pick-thumb-empty{width:100%;height:100%;display:grid;place-items:center;color:var(--text-hint);font-size:24px}.media-pick-check{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;box-shadow:0 2px 6px #0006}.media-pick-name{font-size:12.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 2px}.media-pick-meta{font-size:11px;color:var(--text-hint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 2px}.gen-color-row{display:flex;align-items:center;gap:8px}.gen-color-input{width:44px;height:36px;flex:0 0 44px;padding:0;border:1px solid var(--border);border-radius:10px;background:var(--bg);cursor:pointer}.gen-color-input::-webkit-color-swatch-wrapper{padding:4px}.gen-color-input::-webkit-color-swatch{border:none;border-radius:6px}.gen-color-text{flex:1;font-family:ui-monospace,SF Mono,Menlo,monospace;text-transform:uppercase}@media(max-width:820px){.gen-scene.has-picker{flex-direction:column;align-items:center;gap:0}.voice-picker-backdrop{display:block;position:fixed;inset:0;z-index:100;background:#0000008c;backdrop-filter:blur(2px)}.voice-picker{position:fixed;inset:auto 0 0;z-index:101;width:100%;max-width:100%;max-height:85vh;border-radius:18px 18px 0 0;animation:voicePickerIn .22s cubic-bezier(.22,1,.36,1)}@keyframes voicePickerIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}}.backdrop\:backdrop-blur::backdrop{--tw-backdrop-blur: blur(8px);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\:transition-all::backdrop{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.focus-within\:border-accent:focus-within{border-color:var(--accent)}.hover\:border-accent:hover{border-color:var(--accent)}.hover\:bg-\[color\:var\(--danger\)\]:hover{background-color:var(--danger)}.hover\:bg-bg-secondary:hover{background-color:var(--bg-secondary)}.hover\:text-text:hover{color:var(--text)}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-90:hover{opacity:.9}.focus\:\!border-0:focus{border-width:0px!important}.focus\:\!shadow-none:focus{--tw-shadow: 0 0 #0000 !important;--tw-shadow-colored: 0 0 #0000 !important;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)!important}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.group:hover .group-hover\:translate-y-0{--tw-translate-y: 0px;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))}.group:hover .group-hover\:opacity-100{opacity:1}.group:focus-visible .group-focus-visible\:translate-y-0{--tw-translate-y: 0px;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))}.group:focus-visible .group-focus-visible\:opacity-100{opacity:1}@media(min-width:768px){.md\:left-0{left:0}.md\:left-8{left:2rem}.md\:right-auto{right:auto}.md\:top-8{top:2rem}.md\:col-span-2{grid-column:span 2 / span 2}.md\:block{display:block}.md\:size-4\/5{width:80%;height:80%}.md\:w-1\/2{width:50%}.md\:max-w-\[75\%\]{max-width:75%}.md\:flex-none{flex:none}.md\:shrink{flex-shrink:1}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:p-6{padding:1.5rem}.md\:p-8{padding:2rem}}@media(min-width:1024px){.lg\:size-2\/3{width:66.666667%;height:66.666667%}.lg\:w-1\/2{width:50%}.lg\:w-1\/3{width:33.333333%}.lg\:w-2\/3{width:66.666667%}.lg\:auto-rows-\[400px\]{grid-auto-rows:400px}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}.\[\&_a\]\:text-accent a{color:var(--accent)}.\[\&_a\]\:underline a{text-decoration-line:underline}.\[\&_code\]\:rounded code{border-radius:14px}.\[\&_code\]\:bg-bg-elevated code{background-color:var(--bg-elevated)}.\[\&_code\]\:px-1 code{padding-left:.25rem;padding-right:.25rem}.\[\&_code\]\:py-0\.5 code{padding-top:.125rem;padding-bottom:.125rem}.\[\&_code\]\:text-\[0\.9em\] code{font-size:.9em}.\[\&_li\]\:my-1 li{margin-top:.25rem;margin-bottom:.25rem}.\[\&_ol\]\:ml-5 ol{margin-left:1.25rem}.\[\&_p\]\:my-2 p,.\[\&_pre\]\:my-2 pre{margin-top:.5rem;margin-bottom:.5rem}.\[\&_pre\]\:overflow-x-auto pre{overflow-x:auto}.\[\&_pre\]\:rounded pre{border-radius:14px}.\[\&_pre\]\:bg-bg-elevated pre{background-color:var(--bg-elevated)}.\[\&_pre\]\:p-3 pre{padding:.75rem}.\[\&_ul\]\:ml-5 ul{margin-left:1.25rem}
