@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";.auth-guard-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background-color:var(--color-bg)}.auth-guard-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:auth-spinner-spin .8s linear infinite}@keyframes auth-spinner-spin{to{transform:rotate(360deg)}}.auth-guard-text{font-size:14px;color:var(--color-text-secondary)}*,: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:Inter,system-ui,sans-serif;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:JetBrains Mono,Fira Code,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}:root{--background: 220 20% 6%;--foreground: 210 20% 95%;--card: 220 18% 8%;--card-foreground: 210 20% 95%;--popover: 220 18% 8%;--popover-foreground: 210 20% 95%;--primary: 175 70% 50%;--primary-foreground: 220 20% 6%;--secondary: 220 15% 14%;--secondary-foreground: 210 15% 75%;--muted: 220 15% 12%;--muted-foreground: 215 15% 55%;--accent: 175 60% 45%;--accent-foreground: 220 20% 6%;--destructive: 0 65% 55%;--destructive-foreground: 210 20% 95%;--success: 145 60% 45%;--success-foreground: 220 20% 6%;--warning: 35 90% 55%;--warning-foreground: 220 20% 6%;--border: 220 15% 16%;--input: 220 15% 14%;--ring: 175 70% 50%;--radius: .5rem;--sidebar-background: 220 18% 8%;--sidebar-foreground: 210 15% 75%;--sidebar-primary: 175 70% 50%;--sidebar-primary-foreground: 220 20% 6%;--sidebar-accent: 220 15% 14%;--sidebar-accent-foreground: 210 20% 95%;--sidebar-border: 220 15% 16%;--sidebar-ring: 175 70% 50%;--terminal-green: 145 70% 55%;--terminal-cyan: 175 70% 55%;--terminal-yellow: 45 90% 60%;--terminal-red: 0 70% 60%;--glow-primary: 0 0 20px hsl(175 70% 50% / .3);--glow-success: 0 0 20px hsl(145 60% 45% / .3)}.dark{--background: 220 20% 6%;--foreground: 210 20% 95%;--card: 220 18% 8%;--card-foreground: 210 20% 95%;--popover: 220 18% 8%;--popover-foreground: 210 20% 95%;--primary: 175 70% 50%;--primary-foreground: 220 20% 6%;--secondary: 220 15% 14%;--secondary-foreground: 210 15% 75%;--muted: 220 15% 12%;--muted-foreground: 215 15% 55%;--accent: 175 60% 45%;--accent-foreground: 220 20% 6%;--destructive: 0 65% 55%;--destructive-foreground: 210 20% 95%;--border: 220 15% 16%;--input: 220 15% 14%;--ring: 175 70% 50%}*{border-color:hsl(var(--border))}html{scroll-behavior:smooth}body{background-color:hsl(var(--background));color:hsl(var(--foreground));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,sans-serif}code,pre,.font-mono{font-family:JetBrains Mono,Fira Code,monospace}.container{width:100%;margin-right:auto;margin-left:auto;padding-right:2rem;padding-left:2rem}@media(min-width:1400px){.container{max-width:1400px}}.terminal-window{overflow:hidden;border-radius:var(--radius);border-width:1px;border-color:hsl(var(--border));background-color:hsl(var(--card));box-shadow:0 4px 24px #0006}.terminal-header{display:flex;align-items:center;gap:.5rem;border-bottom-width:1px;border-color:hsl(var(--border));background-color:hsl(var(--muted));padding:.75rem 1rem}.terminal-dot{height:.75rem;width:.75rem;border-radius:9999px}.terminal-body{font-family:JetBrains Mono,Fira Code,monospace;padding:1rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;line-height:1.25rem;line-height:1.625}.text-gradient-primary{-webkit-background-clip:text;background-clip:text;color:transparent;background-image:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--terminal-cyan)))}.border-glow{border-width:1px;border-color:hsl(var(--primary) / .3);box-shadow:inset 0 0 20px hsl(var(--primary) / .05)}.feature-card{border-radius:var(--radius);border-width:1px;border-color:hsl(var(--border));background-color:hsl(var(--card));padding:1.5rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;animation-duration:.3s}.feature-card:hover{border-color:hsl(var(--primary) / .4);box-shadow:0 0 30px hsl(var(--primary) / .1)}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.left-0{left:0}.left-6{left:1.5rem}.right-0{right:0}.top-0{top:0}.top-12{top:3rem}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-4{margin-left:1rem}.mt-0\.5{margin-top:.125rem}.mt-20{margin-top:5rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-2{width:.5rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-8{width:2rem}.w-px{width:1px}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-xl{max-width:36rem}.flex-shrink-0{flex-shrink:0}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in .5s ease-out forwards}@keyframes terminal-blink{0%,to{opacity:1}50%{opacity:0}}.animate-terminal-blink{animation:terminal-blink 1s step-end infinite}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-16{gap:4rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-border{border-color:hsl(var(--border))}.border-primary\/20{border-color:hsl(var(--primary) / .2)}.border-primary\/30{border-color:hsl(var(--primary) / .3)}.border-primary\/50{border-color:hsl(var(--primary) / .5)}.bg-background{background-color:hsl(var(--background))}.bg-background\/80{background-color:hsl(var(--background) / .8)}.bg-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-card\/50{background-color:hsl(var(--card) / .5)}.bg-destructive{background-color:hsl(var(--destructive))}.bg-primary{background-color:hsl(var(--primary))}.bg-primary\/10{background-color:hsl(var(--primary) / .1)}.bg-secondary{background-color:hsl(var(--secondary))}.bg-terminal-green{background-color:hsl(var(--terminal-green))}.bg-terminal-red{background-color:hsl(var(--terminal-red))}.bg-terminal-yellow{background-color:hsl(var(--terminal-yellow))}.bg-transparent{background-color:transparent}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-primary\/5{--tw-gradient-from: hsl(var(--primary) / .05) var(--tw-gradient-from-position);--tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.p-6{padding:1.5rem}.px-10{padding-left:2.5rem;padding-right:2.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-24{padding-top:6rem;padding-bottom:6rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pb-12{padding-bottom:3rem}.pb-20{padding-bottom:5rem}.pl-16{padding-left:4rem}.pt-1{padding-top:.25rem}.pt-32{padding-top:8rem}.pt-4{padding-top:1rem}.text-center{text-align:center}.font-mono{font-family:JetBrains Mono,Fira Code,monospace}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-relaxed{line-height:1.625}.tracking-tight{letter-spacing:-.025em}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-foreground{color:hsl(var(--foreground))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-success{color:hsl(var(--success))}.text-terminal-cyan{color:hsl(var(--terminal-cyan))}.text-terminal-green{color:hsl(var(--terminal-green))}.underline-offset-4{text-underline-offset:4px}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-primary\/20{--tw-shadow-color: hsl(var(--primary) / .2);--tw-shadow: var(--tw-shadow-colored)}.outline{outline-style:solid}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-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}.duration-200{transition-duration:.2s}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.duration-200{animation-duration:.2s}.running{animation-play-state:running}.animation-delay-300{animation-delay:.3s}.animation-delay-500{animation-delay:.5s}.last\:pb-0:last-child{padding-bottom:0}.hover\:border-primary:hover{border-color:hsl(var(--primary))}.hover\:border-primary\/30:hover{border-color:hsl(var(--primary) / .3)}.hover\:border-primary\/50:hover{border-color:hsl(var(--primary) / .5)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-primary\/10:hover{background-color:hsl(var(--primary) / .1)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-secondary:hover{background-color:hsl(var(--secondary))}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:text-foreground:hover{color:hsl(var(--foreground))}.hover\:underline:hover{text-decoration-line:underline}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}@media(min-width:640px){.sm\:flex-row{flex-direction:row}}@media(min-width:768px){.md\:flex{display:flex}.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\:flex-row{flex-direction:row}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media(min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:text-7xl{font-size:4.5rem;line-height:1}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);padding:24px}.login-container{width:100%;max-width:400px;display:flex;flex-direction:column;gap:32px}.login-header{text-align:center}.login-title{font-size:28px;font-weight:700;color:var(--color-text);margin-bottom:8px}.login-subtitle{font-size:14px;color:var(--color-text-secondary);line-height:1.5}.login-actions{display:flex;flex-direction:column;gap:12px}.login-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 20px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background-color .2s ease,transform .1s ease}.login-btn:active{transform:scale(.98)}.login-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.login-btn.github{background-color:#24292e;color:#fff;border:1px solid #30363d}.login-btn.github:hover{background-color:#2f363d}.login-btn-icon{width:20px;height:20px;flex-shrink:0}.login-footer{text-align:center}.login-footer-text{font-size:12px;color:var(--color-text-secondary)}@media(max-width:480px){.login-container{gap:24px}.login-title{font-size:24px}.login-subtitle{font-size:13px}.login-btn{padding:12px 16px;font-size:14px}}.admin-page{min-height:100vh;background:var(--color-bg, #1a1a1a);color:var(--color-text, #e0e0e0)}.admin-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.admin-denied h1{color:var(--color-error, #ff5555)}.admin-denied button{padding:.75rem 1.5rem;background:var(--color-accent, #4a9eff);border:none;border-radius:4px;color:#fff;cursor:pointer}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--color-bg-secondary, #252525);border-bottom:1px solid var(--color-border, #333)}.admin-header h1{margin:0;font-size:1.25rem}.admin-back-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--color-border, #333);border-radius:4px;color:var(--color-text, #e0e0e0);cursor:pointer}.admin-back-btn:hover{background:var(--color-bg, #1a1a1a)}.admin-layout{display:flex;min-height:calc(100vh - 60px)}.admin-sidebar{width:200px;background:var(--color-bg-secondary, #252525);border-right:1px solid var(--color-border, #333);padding:1rem 0}.admin-nav-btn{display:block;width:100%;padding:.75rem 1.5rem;background:transparent;border:none;text-align:left;color:var(--color-text-secondary, #888);cursor:pointer;transition:background .2s,color .2s}.admin-nav-btn:hover{background:#ffffff0d;color:var(--color-text, #e0e0e0)}.admin-nav-btn.active{background:#4a9eff1a;color:var(--color-accent, #4a9eff);border-left:3px solid var(--color-accent, #4a9eff)}.admin-content{flex:1;padding:1.5rem;overflow-y:auto}@media(max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-border, #333);display:flex;overflow-x:auto;padding:0}.admin-nav-btn{flex:1;text-align:center;border-left:none!important;border-bottom:3px solid transparent}.admin-nav-btn.active{border-bottom-color:var(--color-accent, #4a9eff)}}.admin-section{background:var(--color-bg-secondary, #252525);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.admin-section h2{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text, #e0e0e0)}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.admin-stat-card{background:var(--color-bg, #1a1a1a);border-radius:6px;padding:1rem;text-align:center}.admin-stat-value{font-size:2rem;font-weight:700;color:var(--color-accent, #4a9eff)}.admin-stat-label{font-size:.85rem;color:var(--color-text-secondary, #888);margin-top:.25rem}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border, #333)}.admin-table th{font-weight:500;color:var(--color-text-secondary, #888);font-size:.85rem;text-transform:uppercase}.admin-table tr:hover{background:#ffffff05}.admin-select{padding:.4rem .6rem;background:var(--color-bg, #1a1a1a);border:1px solid var(--color-border, #333);border-radius:4px;color:var(--color-text, #e0e0e0);font-size:.9rem}.admin-input{padding:.5rem .75rem;background:var(--color-bg, #1a1a1a);border:1px solid var(--color-border, #333);border-radius:4px;color:var(--color-text, #e0e0e0)}.admin-input:focus{outline:none;border-color:var(--color-accent, #4a9eff)}.admin-search-bar{display:flex;gap:.5rem;margin-bottom:1rem}.admin-search-bar input{flex:1}.admin-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border, #333)}.admin-pagination button{padding:.5rem 1rem;background:var(--color-bg, #1a1a1a);border:1px solid var(--color-border, #333);border-radius:4px;color:var(--color-text, #e0e0e0);cursor:pointer}.admin-pagination button:disabled{opacity:.5;cursor:not-allowed}.admin-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.admin-badge.admin{background:#4a9eff33;color:var(--color-accent, #4a9eff)}.admin-badge.user,.admin-badge.free{background:#8883;color:var(--color-text-secondary, #888)}.admin-badge.pro{background:#4a9eff33;color:var(--color-accent, #4a9eff)}.admin-badge.unlimited,.admin-badge.success{background:#4caf5033;color:#4caf50}.admin-badge.failure{background:#f553;color:var(--color-error, #ff5555)}.admin-loading{text-align:center;padding:2rem;color:var(--color-text-secondary, #888)}.admin-error{background:#ff55551a;border:1px solid var(--color-error, #ff5555);border-radius:4px;padding:1rem;color:var(--color-error, #ff5555);margin-bottom:1rem}.admin-filters{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.admin-filter-group{display:flex;align-items:center;gap:.5rem}.admin-filter-group label{font-size:.85rem;color:var(--color-text-secondary, #888)}*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #1a1a1a;--color-bg-secondary: #252525;--color-text: #e0e0e0;--color-text-secondary: #888888;--color-border: #333333;--color-accent: #4a9eff;--color-warning: #f5a623;--color-error: #ff5555}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg);color:var(--color-text);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.offline-banner{position:fixed;top:0;left:0;right:0;background-color:var(--color-warning);color:#000;text-align:center;padding:4px 12px;font-size:12px;font-weight:500;z-index:1000;opacity:0;transform:translateY(-100%);transition:opacity .3s ease,transform .3s ease}.offline-banner.visible{opacity:1;transform:translateY(0)}.app-header{position:relative;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);min-height:48px}.app-header h1{font-size:16px;font-weight:600;color:var(--color-text)}.header-placeholder{font-size:12px;color:var(--color-text-secondary)}.app-header-left{display:flex;align-items:center;gap:12px}.app-header-machines{flex:1;min-width:0;overflow-x:auto;margin-left:16px}.sidebar-toggle{display:none;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.sidebar-toggle:hover{background-color:var(--color-bg-secondary);border-color:var(--color-accent)}.sidebar-toggle-icon{font-size:16px;line-height:1}.app-layout{flex:1;display:flex;flex-direction:row;overflow:hidden}.app-sidebar{width:240px;flex-shrink:0;display:flex;flex-direction:column;background-color:var(--color-bg-secondary);border-right:1px solid var(--color-border);overflow:hidden;transition:width .3s ease,margin-left .3s ease}.app-sidebar.closed{width:0;margin-left:-1px}.sidebar-header{padding:12px 16px;border-bottom:1px solid var(--color-border)}.sidebar-header h2{font-size:14px;font-weight:600;color:var(--color-text)}.sidebar-placeholder{padding:16px;text-align:center}.sidebar-placeholder p{font-size:13px;color:var(--color-text-secondary)}.app-sidebar .session-list{flex:1;padding:12px;overflow-y:auto}.sidebar-machines,.sidebar-backdrop{display:none}@media(max-width:768px){.sidebar-toggle{display:flex}.sidebar-backdrop{display:block;position:fixed;top:48px;left:0;right:0;bottom:0;background-color:#00000080;z-index:99}.app-sidebar{position:fixed;top:48px;left:0;bottom:0;width:280px;z-index:100;transform:translate(-100%);transition:transform .3s ease}.app-sidebar.open{transform:translate(0)}.app-sidebar.closed{width:280px;margin-left:0;transform:translate(-100%)}.app-header-machines{display:none}.app-header{padding:8px 12px}.app-header h1{font-size:14px}.app-header-left{gap:8px}.user-name{display:none}.app-header-actions{gap:8px}.add-machine-header-btn{padding:6px 10px;font-size:12px}.sidebar-machines{display:block;border-bottom:1px solid var(--color-border);padding-bottom:8px;margin-bottom:8px}.sidebar-machines .machine-selector{flex-direction:column;padding:0 12px;gap:8px}.sidebar-machines .machine-card{min-width:unset;width:100%}}.app-main{flex:1;display:flex;flex-direction:column;padding:16px;overflow:hidden}.terminal-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:32px}.terminal-placeholder-text{font-size:14px;color:var(--color-text-secondary);text-align:center}.terminal-placeholder-text p{margin-bottom:8px}.terminal-placeholder-text p:last-child{margin-bottom:0}.app-status-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background-color:var(--color-bg-secondary);border-top:1px solid var(--color-border);font-size:11px;color:var(--color-text-secondary)}.status-indicator{display:flex;align-items:center;gap:6px}.status-dot{width:6px;height:6px;border-radius:50%;background-color:var(--color-text-secondary)}.status-dot.online{background-color:#4caf50}.status-dot.offline{background-color:var(--color-error)}.terminal-container{position:relative;flex:1;display:flex;flex-direction:column;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.terminal-xterm{flex:1}.terminal-status-badge{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:6px;padding:4px 10px;background-color:#252525e6;border:1px solid var(--color-border);border-radius:4px;font-size:11px;z-index:10;opacity:1;transition:opacity .3s ease}.terminal-status-badge[data-status=connected]{opacity:0}.terminal-status-badge:hover{opacity:1}.terminal-status-dot{width:6px;height:6px;border-radius:50%;background-color:var(--color-text-secondary)}.terminal-status-badge[data-status=connecting] .terminal-status-dot{background-color:var(--color-warning)}.terminal-status-badge[data-status=connected] .terminal-status-dot{background-color:#4caf50}.terminal-status-badge[data-status=disconnected] .terminal-status-dot{background-color:var(--color-warning)}.terminal-status-badge[data-status=error] .terminal-status-dot{background-color:var(--color-error)}.terminal-status-text{color:var(--color-text-secondary)}.machine-selector{display:flex;flex-direction:row;gap:12px;overflow-x:auto;padding:4px 0;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.machine-selector::-webkit-scrollbar{height:6px}.machine-selector::-webkit-scrollbar-track{background:transparent}.machine-selector::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:3px}.machine-selector-empty{justify-content:center;align-items:center;padding:12px}.machine-selector-empty-text{font-size:13px;color:var(--color-text-secondary)}.machine-card{flex-shrink:0;display:flex;flex-direction:column;gap:4px;min-width:120px;padding:10px 14px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:border-color .2s ease,background-color .2s ease;text-align:left;color:var(--color-text);font-family:inherit;font-size:inherit}.machine-card:hover{background-color:#2a2a2a}.machine-card.selected{border-color:var(--color-accent);background-color:#4a9eff1a}.machine-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.machine-card-header{display:flex;align-items:center;gap:8px}.machine-card .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.machine-card .status-dot.status-online{background-color:#4caf50}.machine-card .status-dot.status-offline{background-color:#888}.machine-card .status-dot.status-sleeping{background-color:var(--color-warning)}.machine-name{font-size:14px;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.machine-hostname{font-size:11px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.machine-card-skeleton{cursor:default;pointer-events:none}.skeleton-name{width:80px;height:14px;background:linear-gradient(90deg,var(--color-border) 0%,#3a3a3a 50%,var(--color-border) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}.skeleton-hostname{width:60px;height:11px;background:linear-gradient(90deg,var(--color-border) 0%,#3a3a3a 50%,var(--color-border) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.session-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;padding:4px 0}.session-list-empty{justify-content:center;align-items:center;padding:16px}.session-list-empty-text{font-size:13px;color:var(--color-text-secondary);text-align:center}.new-session-btn{display:flex;align-items:center;justify-content:center;padding:10px 12px;background-color:var(--color-accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease}.new-session-btn:hover:not(:disabled){background-color:#3a8ee6}.new-session-btn:disabled{opacity:.6;cursor:not-allowed}.session-item{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:border-color .2s ease,background-color .2s ease;text-align:left;color:var(--color-text);font-family:inherit;font-size:inherit;width:100%}.session-item:hover{background-color:#2a2a2a}.session-item.selected{border-color:var(--color-accent);background-color:#4a9eff1a}.session-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.session-item-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.session-id{font-size:13px;font-weight:500;font-family:Menlo,Monaco,Courier New,monospace;color:var(--color-text)}.session-status{font-size:10px;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:4px;background-color:var(--color-text-secondary);color:var(--color-bg)}.session-status-active{background-color:#4caf50}.session-status-waiting{background-color:var(--color-warning)}.session-status-ended{background-color:var(--color-text-secondary)}.session-delete-btn{display:none;padding:0;margin-left:auto;width:20px;height:20px;border:none;border-radius:4px;background:transparent;color:var(--color-text-secondary);font-size:16px;line-height:1;cursor:pointer;opacity:.6;transition:opacity .15s,background-color .15s,color .15s}.session-item:hover .session-delete-btn{display:flex;align-items:center;justify-content:center}.session-delete-btn:hover{opacity:1;background-color:var(--color-error);color:#fff}.session-cwd{font-size:11px;font-family:Menlo,Monaco,Courier New,monospace;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-time{font-size:10px;color:var(--color-text-secondary)}.session-item-skeleton{cursor:default;pointer-events:none}.skeleton-id{width:70px;height:13px;background:linear-gradient(90deg,var(--color-border) 0%,#3a3a3a 50%,var(--color-border) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}.skeleton-cwd{width:120px;height:11px;background:linear-gradient(90deg,var(--color-border) 0%,#3a3a3a 50%,var(--color-border) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}.app-header-actions{display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-secondary)}.user-avatar{width:24px;height:24px;border-radius:50%}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-btn{background:transparent;border:1px solid var(--color-border);border-radius:4px;padding:.5rem;cursor:pointer;font-size:.875rem;line-height:1;color:var(--color-text);transition:border-color .15s ease}.settings-btn:hover{border-color:var(--color-accent)}.logout-btn{background:transparent;border:1px solid var(--color-border);border-radius:4px;padding:.5rem;cursor:pointer;font-size:.875rem;line-height:1;color:var(--color-text-secondary);transition:border-color .15s ease,color .15s ease}.logout-btn:hover{border-color:var(--color-error);color:var(--color-error)}.settings-panel{position:absolute;top:100%;right:0;width:320px;max-width:90vw;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:100;margin-top:.5rem}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border)}.settings-header h2{margin:0;font-size:1rem}.settings-close{background:transparent;border:none;color:var(--color-text-secondary);font-size:1.5rem;cursor:pointer;line-height:1}.settings-close:hover{color:var(--color-text)}.notification-settings{padding:1rem}.notification-status{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.notification-status-dot{width:10px;height:10px;border-radius:50%;background:var(--color-text-secondary)}.notification-status-dot.subscribed{background:#4caf50}.notification-status-dot.unsubscribed{background:var(--color-warning)}.notification-status-dot.denied,.notification-status-dot.error{background:var(--color-error)}.notification-status-dot.loading{animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.notification-status-text{font-size:.875rem;color:var(--color-text-secondary)}.notification-error{color:var(--color-error);font-size:.75rem;margin-bottom:1rem}.notification-actions{display:flex;gap:.5rem}.notification-btn{flex:1;padding:.75rem 1rem;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background-color .15s ease}.notification-btn.subscribe{background:var(--color-accent);color:#fff}.notification-btn.subscribe:hover{background:#3a8ee8}.notification-btn.unsubscribe{background:#374151;color:var(--color-text)}.notification-btn.unsubscribe:hover{background:#4b5563}.notification-hint{margin-top:1rem;padding:.75rem;background:#1f2937;border-radius:6px;font-size:.75rem;color:var(--color-text-secondary)}.notification-hint p{margin:.25rem 0}.quick-reply-bar{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;gap:8px;padding:12px 16px;background-color:#252525f2;border-top:1px solid var(--color-border);transform:translateY(100%);transition:transform .3s ease;z-index:20}.quick-reply-bar.visible{transform:translateY(0)}.quick-reply-bar.hidden{transform:translateY(100%)}.quick-reply-prompt{font-size:12px;color:var(--color-text-secondary);font-family:Menlo,Monaco,Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.quick-reply-buttons{display:flex;flex-direction:row;gap:8px;flex-wrap:wrap}.quick-reply-btn{padding:8px 16px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .15s ease,border-color .15s ease;background-color:var(--color-bg-secondary);color:var(--color-text)}.quick-reply-btn:hover{border-color:var(--color-accent)}.quick-reply-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.quick-reply-btn.allow{background-color:#4caf5026;border-color:#4caf50;color:#4caf50}.quick-reply-btn.allow:hover{background-color:#4caf5040}.quick-reply-btn.deny{background-color:#ff555526;border-color:var(--color-error);color:var(--color-error)}.quick-reply-btn.deny:hover{background-color:#ff555540}.quick-reply-btn.neutral{background-color:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-secondary)}.quick-reply-btn.neutral:hover{background-color:#2a2a2a;border-color:var(--color-text-secondary)}.quick-reply-btn.dismiss{margin-left:auto;padding:8px 12px;background-color:transparent;border-color:transparent;color:var(--color-text-secondary);font-size:18px;line-height:1}.quick-reply-btn.dismiss:hover{color:var(--color-text);border-color:transparent}.machine-info-panel{display:flex;flex-direction:row;align-items:center;gap:16px;padding:8px 16px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;margin-bottom:12px}.machine-info-status{display:flex;align-items:center;gap:8px}.machine-info-status .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.machine-info-status .status-dot.status-online{background-color:#4caf50}.machine-info-status .status-dot.status-offline{background-color:#888}.machine-info-status .status-dot.status-sleeping{background-color:var(--color-warning)}.machine-info-name{font-size:14px;font-weight:600;color:var(--color-text)}.machine-info-hostname{font-size:12px;font-family:Menlo,Monaco,Courier New,monospace;color:var(--color-text-secondary)}.machine-info-lastseen{font-size:11px;color:var(--color-text-secondary)}.machine-info-platform{font-size:11px;color:var(--color-text-secondary);margin-left:auto}.add-machine-header-btn{padding:6px 12px;background:var(--color-accent, #4a9eff);color:#fff;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:background .2s ease}.add-machine-header-btn:hover{background:#3a8eef}.machine-delete-btn{padding:4px 8px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:16px;border-radius:4px;opacity:.5;transition:opacity .2s,background-color .2s,color .2s}.machine-delete-btn:hover:not(:disabled){opacity:1;background-color:#ff52521a;color:#ff5252}.machine-delete-btn:disabled{cursor:not-allowed}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.mobile-input-bar{display:none;flex-direction:column;gap:8px;padding:8px 12px;background-color:#252525f2;border-top:1px solid var(--color-border)}.mobile-special-keys{display:flex;flex-direction:row;gap:6px}.mobile-special-key{flex:1;min-height:36px;padding:6px 8px;font-size:13px;font-family:Menlo,Monaco,Courier New,monospace;background-color:var(--color-bg-secondary, #2a2a2a);color:var(--color-text);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;transition:background-color .15s ease}.mobile-special-key:hover:not(:disabled){background-color:var(--color-bg-hover, #3a3a3a)}.mobile-special-key:active:not(:disabled){background-color:var(--color-accent);color:#fff}.mobile-special-key:disabled{opacity:.5;cursor:not-allowed}.mobile-input-row{display:flex;flex-direction:row;gap:8px}.mobile-input-field{flex:1;min-height:44px;padding:10px 12px;font-size:16px;font-family:Menlo,Monaco,Courier New,monospace;background-color:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:6px;outline:none}.mobile-input-field:focus{border-color:var(--color-accent)}.mobile-input-field:disabled{opacity:.5}.mobile-input-field::-moz-placeholder{color:var(--color-text-secondary)}.mobile-input-field::placeholder{color:var(--color-text-secondary)}.mobile-input-send{min-width:60px;min-height:44px;padding:10px 16px;font-size:16px;font-weight:500;background-color:var(--color-accent);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .15s ease}.mobile-input-send:hover:not(:disabled){background-color:#3a8ee6}.mobile-input-send:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.app-main{padding:8px}.terminal-container{border-radius:0}.terminal-status-badge{top:4px;left:4px;right:auto;padding:2px 6px;font-size:10px}.mobile-input-bar{display:flex}.quick-reply-bar{padding:10px 12px}.quick-reply-btn{min-height:44px;padding:10px 16px;font-size:16px}.quick-reply-btn.dismiss{min-height:44px;min-width:44px;padding:10px}}/**
 * Copyright (c) 2014 The xterm.js authors. All rights reserved.
 * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
 * https://github.com/chjj/term.js
 * @license MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * Originally forked from (with the author's permission):
 *   Fabrice Bellard's javascript vt100 for jslinux:
 *   http://bellard.org/jslinux/
 *   Copyright (c) 2011 Fabrice Bellard
 *   The original design remains. The terminal itself
 *   has been extended to include xterm CSI codes, among
 *   other features.
 */.xterm{cursor:text;position:relative;-moz-user-select:none;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .xterm-accessibility-tree:not(.debug) *::-moz-selection{color:transparent}.xterm .xterm-accessibility-tree:not(.debug) *::selection{color:transparent}.xterm .xterm-accessibility-tree{font-family:monospace;-webkit-user-select:text;-moz-user-select:text;user-select:text;white-space:pre}.xterm .xterm-accessibility-tree>div{transform-origin:left;width:-moz-fit-content;width:fit-content}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:double underline;text-decoration:double underline}.xterm-underline-3{-webkit-text-decoration:wavy underline;text-decoration:wavy underline}.xterm-underline-4{-webkit-text-decoration:dotted underline;text-decoration:dotted underline}.xterm-underline-5{-webkit-text-decoration:dashed underline;text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;background:#0000;transition:opacity .1s linear;z-index:11}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{position:absolute;display:none}.xterm .xterm-scrollable-element>.shadow.top{display:block;top:0;left:3px;height:3px;width:100%;box-shadow:var(--vscode-scrollbar-shadow, #000) 0 6px 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.left{display:block;top:3px;left:0;height:100%;width:3px;box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.top-left-corner{display:block;top:0;left:0;height:3px;width:3px}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.daemon-tokens{padding:1rem 0}.daemon-tokens-header h3{margin:0 0 .5rem;font-size:1rem;color:var(--text-color, #e0e0e0)}.daemon-tokens-description{margin:0 0 1rem;font-size:.85rem;color:var(--text-secondary, #888)}.daemon-tokens-loading{padding:1rem;text-align:center;color:var(--text-secondary, #888)}.daemon-tokens-error{padding:.75rem;margin-bottom:1rem;background:#dc354533;border:1px solid rgba(220,53,69,.4);border-radius:4px;color:#ff6b6b;font-size:.85rem}.daemon-tokens-form{display:flex;gap:.5rem;margin-bottom:1rem}.daemon-tokens-input{flex:1;padding:.5rem .75rem;background:var(--bg-secondary, #2a2a2a);border:1px solid var(--border-color, #444);border-radius:4px;color:var(--text-color, #e0e0e0);font-size:.9rem}.daemon-tokens-input:focus{outline:none;border-color:var(--accent-color, #6c8eff)}.daemon-tokens-input::-moz-placeholder{color:var(--text-secondary, #888)}.daemon-tokens-input::placeholder{color:var(--text-secondary, #888)}.create-btn{padding:.5rem 1rem;background:var(--accent-color, #6c8eff);border:none;border-radius:4px;color:#fff;font-size:.9rem;cursor:pointer;white-space:nowrap}.create-btn:hover:not(:disabled){background:var(--accent-hover, #5a7ee0)}.create-btn:disabled{opacity:.5;cursor:not-allowed}.daemon-tokens-list{display:flex;flex-direction:column;gap:.5rem}.daemon-tokens-empty{padding:1rem;text-align:center;color:var(--text-secondary, #888);font-size:.9rem}.daemon-token-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-secondary, #2a2a2a);border:1px solid var(--border-color, #444);border-radius:4px}.daemon-token-info{display:flex;flex-direction:column;gap:.25rem}.daemon-token-name{font-weight:500;color:var(--text-color, #e0e0e0)}.daemon-token-preview{font-family:monospace;font-size:.8rem;color:var(--text-secondary, #888)}.daemon-token-meta{display:flex;align-items:center;gap:1rem}.daemon-token-used{font-size:.8rem;color:var(--text-secondary, #888)}.revoke-btn{padding:.25rem .5rem;background:transparent;border:1px solid rgba(220,53,69,.5);border-radius:4px;color:#ff6b6b;font-size:.8rem;cursor:pointer}.revoke-btn:hover{background:#dc354533}.daemon-tokens-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000}.daemon-tokens-modal-content{background:var(--bg-primary, #1e1e1e);border:1px solid var(--border-color, #444);border-radius:8px;padding:1.5rem;max-width:500px;width:90%}.daemon-tokens-modal-content h4{margin:0 0 .5rem;color:var(--text-color, #e0e0e0)}.daemon-tokens-warning{margin:0 0 1rem;padding:.5rem;background:#ffc10733;border:1px solid rgba(255,193,7,.4);border-radius:4px;color:#ffc107;font-size:.85rem}.daemon-tokens-new-token{display:flex;gap:.5rem;margin-bottom:1rem}.daemon-tokens-new-token code{flex:1;padding:.75rem;background:var(--bg-secondary, #2a2a2a);border:1px solid var(--border-color, #444);border-radius:4px;font-family:monospace;font-size:.85rem;color:var(--accent-color, #6c8eff);word-break:break-all}.copy-btn{padding:.5rem 1rem;background:var(--accent-color, #6c8eff);border:none;border-radius:4px;color:#fff;cursor:pointer;white-space:nowrap}.copy-btn:hover{background:var(--accent-hover, #5a7ee0)}.daemon-tokens-usage{margin-bottom:1rem}.daemon-tokens-usage p{margin:0 0 .5rem;font-size:.85rem;color:var(--text-secondary, #888)}.daemon-tokens-usage pre{padding:.75rem;background:var(--bg-secondary, #2a2a2a);border:1px solid var(--border-color, #444);border-radius:4px;font-family:monospace;font-size:.8rem;color:var(--text-color, #e0e0e0);overflow-x:auto;white-space:pre-wrap;word-break:break-all}.dismiss-btn{width:100%;padding:.75rem;background:var(--bg-secondary, #2a2a2a);border:1px solid var(--border-color, #444);border-radius:4px;color:var(--text-color, #e0e0e0);cursor:pointer}.dismiss-btn:hover{background:var(--bg-hover, #333)}.onboarding{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary, #1a1a1a);padding:1rem}.onboarding-card{background:var(--bg-secondary, #242424);border:1px solid var(--border-color, #333);border-radius:12px;padding:2rem;max-width:500px;width:100%;box-shadow:0 4px 20px #0000004d}.onboarding-header{text-align:center;margin-bottom:1.5rem}.onboarding-header h1{font-size:1.75rem;color:var(--text-primary, #fff);margin:0 0 .5rem}.onboarding-header h2{font-size:1.5rem;color:var(--text-primary, #fff);margin:0 0 .5rem}.onboarding-header p{color:var(--text-secondary, #888);margin:0}.onboarding-content{display:flex;flex-direction:column;gap:1rem}.onboarding-steps-preview{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.step-preview{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#4a9eff0d;border-radius:8px}.step-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-accent, #4a9eff);color:#fff;border-radius:50%;font-weight:600;font-size:.875rem}.step-label{color:var(--text-primary, #fff)}.onboarding-btn{padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.onboarding-btn.primary{background:var(--color-accent, #4a9eff);color:#fff}.onboarding-btn.primary:hover:not(:disabled){background:#3a8eef}.onboarding-btn.primary:disabled{opacity:.5;cursor:not-allowed}.onboarding-btn.secondary{background:transparent;color:var(--text-secondary, #888);border:1px solid var(--border-color, #333)}.onboarding-btn.secondary:hover{background:#ffffff0d}.onboarding-form{display:flex;flex-direction:column;gap:.75rem}.onboarding-input{padding:.875rem 1rem;border:1px solid var(--border-color, #333);border-radius:8px;background:var(--bg-primary, #1a1a1a);color:var(--text-primary, #fff);font-size:1rem}.onboarding-input:focus{outline:none;border-color:var(--color-accent, #4a9eff)}.onboarding-input::-moz-placeholder{color:var(--text-muted, #666)}.onboarding-input::placeholder{color:var(--text-muted, #666)}.onboarding-error{padding:.75rem;background:#ff52521a;border:1px solid rgba(255,82,82,.3);border-radius:8px;color:#ff5252;font-size:.875rem}.onboarding-command{display:flex;gap:.5rem;background:var(--bg-primary, #1a1a1a);border:1px solid var(--border-color, #333);border-radius:8px;padding:.75rem;overflow-x:auto}.onboarding-command code{flex:1;font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:.8rem;color:var(--color-success, #4ade80);white-space:nowrap;word-break:break-all;white-space:pre-wrap}.onboarding-copy-btn{flex-shrink:0;padding:.5rem 1rem;background:var(--color-accent, #4a9eff);color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background .2s ease}.onboarding-copy-btn:hover{background:#3a8eef}.onboarding-notes{padding:1rem;background:#ffffff08;border-radius:8px;font-size:.875rem}.onboarding-notes p{margin:0 0 .5rem;color:var(--text-secondary, #888)}.onboarding-notes ul{margin:0;padding-left:1.5rem;color:var(--text-secondary, #888)}.onboarding-notes li{margin-bottom:.25rem}.onboarding-waiting{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:#4a9eff0d;border-radius:8px;color:var(--text-secondary, #888)}.waiting-spinner{width:18px;height:18px;border:2px solid var(--border-color, #333);border-top-color:var(--color-accent, #4a9eff);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.onboarding-hint{text-align:center;font-size:.875rem;color:var(--text-muted, #666);margin:0}.add-machine-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:100}.add-machine-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-secondary, #242424);border:1px solid var(--border-color, #333);border-radius:12px;padding:1.5rem;width:90%;max-width:480px;z-index:101;box-shadow:0 4px 20px #0006}.add-machine-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.add-machine-header h2{margin:0;font-size:1.25rem;color:var(--text-primary, #fff)}.add-machine-close{background:transparent;border:none;color:var(--text-secondary, #888);font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.add-machine-close:hover{color:var(--text-primary, #fff)}.add-machine-content{display:flex;flex-direction:column;gap:1rem}.add-machine-content p{margin:0;color:var(--text-secondary, #888)}.add-machine-error{padding:.75rem;background:#ff52521a;border:1px solid rgba(255,82,82,.3);border-radius:6px;color:#ff5252;font-size:.875rem}.add-machine-form{display:flex;flex-direction:column;gap:.75rem}.add-machine-input{padding:.75rem;border:1px solid var(--border-color, #333);border-radius:6px;background:var(--bg-primary, #1a1a1a);color:var(--text-primary, #fff);font-size:1rem}.add-machine-input:focus{outline:none;border-color:var(--color-accent, #4a9eff)}.add-machine-btn{padding:.75rem 1rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.add-machine-btn.primary{background:var(--color-accent, #4a9eff);color:#fff}.add-machine-btn.primary:hover:not(:disabled){background:#3a8eef}.add-machine-btn.primary:disabled{opacity:.5;cursor:not-allowed}.add-machine-btn.secondary{background:transparent;color:var(--text-secondary, #888);border:1px solid var(--border-color, #333)}.add-machine-btn.secondary:hover{background:#ffffff0d}.add-machine-command{display:flex;gap:.5rem;background:var(--bg-primary, #1a1a1a);border:1px solid var(--border-color, #333);border-radius:6px;padding:.75rem}.add-machine-command code{flex:1;font-family:SF Mono,Monaco,monospace;font-size:.75rem;color:var(--color-success, #4ade80);word-break:break-all;white-space:pre-wrap}.add-machine-copy{flex-shrink:0;padding:.5rem .75rem;background:var(--color-accent, #4a9eff);color:#fff;border:none;border-radius:4px;font-size:.75rem;cursor:pointer}.add-machine-copy:hover{background:#3a8eef}.add-machine-requirements{font-size:.875rem;color:var(--text-muted, #666)}
