@import "https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--bg-deep:#1a2020;--bg-base:#232b2b;--bg-surface:#2e3838;--bg-elevated:#3a4747;--bg-card:#344040;--text-primary:#e8edec;--text-secondary:#7a908f;--text-muted:#4e6362;--accent:#ffd400;--accent-dim:#ffd4001f;--accent-hover:#ffe44d;--danger:#ff5c5c;--danger-bg:#ff5c5c1a;--border:#ffffff0f;--border-focus:#ffd40080;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 20px #00000059;--shadow-lg:0 12px 40px #0006;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--font:"Outfit", "Segoe UI", system-ui, sans-serif;--font-display:"Bebas Neue", "Outfit", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Cascadia Code", "Consolas", monospace}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font);background:var(--bg-deep);color:var(--text-primary);min-height:100vh}#app{width:100%;min-height:100vh}.bg-pattern{z-index:0;pointer-events:none;background-image:radial-gradient(circle at 15% 60%, #ffd4000f 0%, transparent 45%), radial-gradient(circle at 85% 15%, #ffd4000a 0%, transparent 40%), radial-gradient(circle at 60% 85%, #ffd40008 0%, transparent 35%), linear-gradient(180deg, var(--bg-deep) 0%, var(--bg-base) 100%);position:fixed;inset:0}.bg-grid{z-index:0;pointer-events:none;background-image:linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);background-size:60px 60px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(80% 60% at 50% 40%,#000 30%,#0000 100%);mask-image:radial-gradient(80% 60% at 50% 40%,#000 30%,#0000 100%)}.login-scene{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.login-container{z-index:1;flex-direction:column;align-items:center;gap:2.5rem;animation:.6s cubic-bezier(.16,1,.3,1) both fadeInUp;display:flex;position:relative}.login-brand{text-align:center}.login-wordmark{font-family:var(--font-display);letter-spacing:.12em;color:var(--text-primary);font-size:4.5rem;font-weight:400;line-height:1}.login-wordmark em{color:var(--accent);font-style:normal}.login-tagline{color:var(--text-muted);text-transform:uppercase;letter-spacing:.35em;margin-top:.6rem;font-size:.75rem;font-weight:500}.login-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:400px;box-shadow:var(--shadow-lg);padding:2.25rem;animation:.6s cubic-bezier(.16,1,.3,1) .1s both fadeInUp}.login-card h2{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.1rem;font-weight:600;display:flex}.login-card h2:before{content:"";background:var(--accent);border-radius:2px;width:3px;height:1em;display:block}.login-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);border:1px solid #ff5c5c40;margin-bottom:1rem;padding:.7rem 1rem;font-size:.82rem;font-weight:500;display:none}.login-error.visible{display:block}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.45rem;font-size:.7rem;font-weight:600;display:block}.form-group input{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-size:.95rem;font-family:var(--font);outline:none;padding:.7rem .9rem;font-weight:400;transition:border-color .25s,box-shadow .25s}.form-group input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.form-group input::placeholder{color:var(--text-muted);font-weight:300}.login-btn{background:var(--accent);width:100%;color:var(--bg-deep);border-radius:var(--radius-sm);font-size:.9rem;font-weight:700;font-family:var(--font);cursor:pointer;text-transform:uppercase;letter-spacing:.12em;border:none;margin-top:.5rem;padding:.75rem;transition:background .2s,transform .1s}.login-btn:hover{background:var(--accent-hover)}.login-btn:active{transform:scale(.985)}.login-btn:disabled{opacity:.5;cursor:wait}.login-dev-badge{color:var(--accent);background:var(--accent-dim);border-radius:100px;align-items:center;gap:.4rem;margin-top:.5rem;padding:.3rem .7rem;font-size:.7rem;font-weight:500;animation:.6s cubic-bezier(.16,1,.3,1) .2s both fadeInUp;display:inline-flex}.login-dev-badge:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px}.login-footer{color:var(--text-muted);font-size:.7rem;animation:.6s cubic-bezier(.16,1,.3,1) .25s both fadeInUp}.landing-wrap{min-height:100vh;position:relative}.landing-header{z-index:10;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);background:#232b2bbf;align-items:center;gap:.75rem;height:3.5rem;padding:0 2rem;display:flex;position:sticky;top:0}.landing-header-logo{align-items:center;gap:.6rem;display:flex}.landing-header-logo img{opacity:.85;height:22px}.landing-header-wordmark{font-family:var(--font-display);letter-spacing:.1em;font-size:1.5rem;font-weight:400}.landing-header-wordmark em{color:var(--accent);font-style:normal}.landing-header-env{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim);letter-spacing:.04em;border-radius:100px;padding:.2rem .55rem;font-size:.65rem;font-weight:500}.landing-header-spacer{flex:1}.landing-header-user{color:var(--text-secondary);font-size:.8rem;font-weight:400}.landing-header-logout{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:.72rem;font-weight:500;font-family:var(--font);letter-spacing:.04em;background:0 0;padding:.3rem .75rem;transition:all .2s}.landing-header-logout:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.landing-content{z-index:1;max-width:1360px;margin:0 auto;padding:2.5rem 2rem 4rem;position:relative}.landing-greeting{margin-bottom:2rem}.landing-greeting h1{font-family:var(--font-display);letter-spacing:.04em;color:var(--text-primary);font-size:2.8rem;font-weight:400;line-height:1}.landing-greeting p{color:var(--text-secondary);margin-top:.3rem;font-size:.88rem;font-weight:400}.landing-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem;display:grid}.module-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:inherit;flex-direction:column;text-decoration:none;transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s cubic-bezier(.16,1,.3,1),border-color .25s;animation:.5s cubic-bezier(.16,1,.3,1) both cardIn;display:flex;overflow:hidden}.module-card:hover{box-shadow:var(--shadow-lg), 0 0 0 1px #ffd4002e, 0 0 24px #ffd4000f;border-color:#ffd40040;transform:translateY(-4px)}.module-card-image{height:175px;position:relative;overflow:hidden}.module-card-image:after{content:"";background:linear-gradient(180deg, transparent 30%, var(--bg-card) 100%);pointer-events:none;position:absolute;inset:0}.module-card-image img{object-fit:cover;opacity:.55;width:100%;height:100%;transition:opacity .3s,transform .4s}.module-card:hover .module-card-image img{opacity:.75;transform:scale(1.03)}.module-card-body{flex:1;padding:1.1rem 1.25rem}.module-card-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-primary);margin-bottom:.4rem;font-size:.95rem;font-weight:700}.module-card-desc{color:var(--text-secondary);font-size:.82rem;font-weight:400;line-height:1.55}.module-card-action{border-top:1px solid var(--border);color:var(--accent);letter-spacing:.04em;align-items:center;gap:.4rem;padding:.7rem 1.25rem;font-size:.78rem;font-weight:600;transition:gap .2s;display:flex}.module-card-action:after{content:"→";transition:transform .2s}.module-card:hover .module-card-action{gap:.6rem}.module-card:hover .module-card-action:after{transform:translate(2px)}.landing-footer{color:var(--text-muted);pointer-events:none;justify-content:space-between;padding:.5rem 2rem;font-size:.7rem;display:flex;position:fixed;bottom:0;left:0;right:0}.app-loading{background:var(--bg-deep);justify-content:center;align-items:center;min-height:100vh;display:flex}.app-loading-wordmark{font-family:var(--font-display);letter-spacing:.15em;color:var(--text-muted);font-size:4rem;animation:1.6s ease-in-out infinite loadingPulse}.app-loading-wordmark em{color:var(--accent);font-style:normal}:root{--ws-green:#4ade80;--ws-orange:#fbbf24}.landing-header-ws{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;font-family:var(--font-mono);cursor:pointer;letter-spacing:.04em;background:0 0;padding:.3rem .6rem;transition:all .2s}.landing-header-ws:hover{border-color:var(--ws-green);color:var(--ws-green);background:#4ade8014}.landing-wrap.ws-open .landing-content{margin-right:420px;transition:margin-right .3s cubic-bezier(.16,1,.3,1)}.ws-panel{z-index:20;background:var(--bg-deep);border-left:1px solid var(--border);flex-direction:column;width:420px;animation:.25s cubic-bezier(.16,1,.3,1) both wsSlideIn;display:flex;position:fixed;top:3.5rem;bottom:0;right:0}@keyframes wsSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.ws-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.ws-panel-title{font-size:.8rem;font-weight:700;font-family:var(--font-mono);letter-spacing:.04em}.ws-panel-spacer{flex:1}.ws-panel-actions{gap:.4rem;display:flex}.ws-status-dot{background:var(--text-muted);border-radius:50%;width:8px;height:8px}.ws-status-dot.ws-status-connected{background:var(--ws-green)}.ws-status-dot.ws-status-connecting{background:var(--ws-orange)}.ws-status-dot.ws-status-disconnected{background:var(--danger)}.ws-status-text{color:var(--text-muted);font-size:.72rem;font-family:var(--font-mono)}.ws-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.7rem;font-weight:600;font-family:var(--font);cursor:pointer;background:0 0;padding:.3rem .6rem;transition:all .15s}.ws-btn:disabled{opacity:.35;cursor:not-allowed}.ws-btn-connect:hover:not(:disabled){border-color:var(--ws-green);color:var(--ws-green)}.ws-btn-disconnect:hover:not(:disabled){border-color:var(--danger);color:var(--danger)}.ws-btn-heartbeat:hover:not(:disabled){border-color:var(--ws-orange);color:var(--ws-orange)}.ws-btn-send:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.ws-btn-close{color:var(--text-muted);border:none;padding:.2rem .4rem;font-size:.85rem}.ws-btn-close:hover{color:var(--text-primary)}.ws-log{font-family:var(--font-mono);flex:1;padding:.5rem;font-size:.72rem;line-height:1.7;overflow-y:auto}.ws-log-entry{border-bottom:1px solid var(--border);word-break:break-all;gap:.5rem;padding:.15rem .4rem;display:flex}.ws-log-entry:last-child{border-bottom:none}.ws-log-time{color:var(--text-muted);flex-shrink:0}.ws-log-msg{color:var(--text-primary);white-space:pre-wrap}.ws-log-empty{color:var(--text-muted);text-align:center;padding:2rem;font-size:.78rem}.ws-send-bar{border-top:1px solid var(--border);flex-shrink:0;gap:.4rem;padding:.6rem;display:flex}.ws-send-input{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);outline:none;flex:1;padding:.45rem .6rem;font-size:.75rem;transition:border-color .15s}.ws-send-input:focus{border-color:var(--accent)}.ws-send-input::placeholder{color:var(--text-muted)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes loadingPulse{0%,to{opacity:.3}50%{opacity:1}}@keyframes cardIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=480px){.login-card{width:calc(100vw - 2rem);padding:1.75rem}.login-wordmark{font-size:2.5rem}.landing-header{padding:0 1rem}.landing-content{padding:1.5rem 1rem 3rem}.landing-grid{grid-template-columns:1fr}}
