:root{--bg: #0a0e17;--card: #111827;--border: #1e3a5f;--gold: #f0c040;--blue: #38bdf8;--green: #4ade80;--red: #f87171;--text: #e2e8f0;--muted: #94a3b8}[data-theme=light]{--bg: #f1f5f9;--card: #ffffff;--border: #cbd5e1;--gold: #b8860b;--blue: #0284c7;--green: #16a34a;--red: #dc2626;--text: #1e293b;--muted: #64748b}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;line-height:1.6;min-height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--card)}.header-right{display:flex;align-items:center;gap:12px}.theme-toggle{background:none;border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:1.2rem;cursor:pointer;transition:background .2s;line-height:1}.theme-toggle:hover{background:#ffffff0d}[data-theme=light] .theme-toggle:hover{background:#0000000d}.header-left .ship-name{font-size:1.6rem;font-weight:700;color:var(--gold);letter-spacing:.1em;text-transform:uppercase}.header-left .ship-sub{font-size:.75rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase}.artemis-mini{display:flex;align-items:center;gap:12px;background:#1e3a5f66;border:1px solid var(--border);border-radius:12px;padding:8px 16px}.artemis-mini .label{font-size:.7rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}.artemis-mini .live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:pulse 2s infinite}.artemis-progress{display:flex;flex-direction:column;gap:2px;min-width:120px}.artemis-track{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.artemis-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--gold));border-radius:2px;transition:width 1s ease}.artemis-stats{display:flex;gap:10px;font-size:.7rem;color:var(--muted)}.artemis-stats .val{color:var(--text);font-weight:600}.tab-bar{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--card);position:relative;z-index:100}.tab-bar-header{display:flex;align-items:center}.tab-current{display:flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid var(--border);border-radius:8px;background:#38bdf81f;border-color:var(--blue);color:var(--blue);font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.tab-current:hover{background:#38bdf833}.tab-current-icon{font-size:1.1rem}.tab-current-label{letter-spacing:.05em}.tab-chevron{font-size:.7rem;transition:transform .2s;margin-left:2px}.tab-chevron.open{transform:rotate(180deg)}.tab-menu{position:absolute;left:16px;right:16px;top:calc(100% - 1px);background:var(--card);border:1px solid var(--blue);border-top:none;border-radius:0 0 10px 10px;box-shadow:0 8px 24px #00000080;overflow:hidden;z-index:99}.tab-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;background:transparent;color:var(--muted);font-size:.9rem;cursor:pointer;font-family:inherit;text-align:left;transition:all .15s;border-bottom:1px solid rgba(30,58,95,.5)}.tab-menu-item:last-child{border-bottom:none}.tab-menu-item:hover{background:#38bdf81a;color:var(--text)}.tab-menu-item.active{background:#38bdf826;color:var(--blue)}.tab-menu-icon{font-size:1rem;width:20px;text-align:center}.tab-menu-check{margin-left:auto;color:var(--blue);font-size:.8rem}.main-content{max-width:900px;margin:0 auto;padding:20px 16px}.panel-title{font-size:.8rem;font-weight:700;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;margin-bottom:16px}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-bottom:20px}.device-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;transition:border-color .2s}.device-card:hover{border-color:var(--blue)}.device-card.card-on{border-color:#4ade8066}.device-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.device-icon{font-size:1.4rem}.device-info{flex:1;min-width:0}.device-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-room{font-size:.72rem;color:var(--muted)}.toggle{width:38px;height:22px;border-radius:11px;background:#ffffff1a;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.toggle.on{background:var(--green)}.toggle-knob{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s}.toggle.on .toggle-knob{left:19px}.slider-row{display:flex;align-items:center;gap:8px}.slider-label{font-size:.65rem;color:var(--muted);letter-spacing:.1em;width:60px}input[type=range]{flex:1;height:4px;-webkit-appearance:none;background:#ffffff1a;border-radius:2px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--blue);cursor:pointer}.slider-pct{font-size:.75rem;color:var(--blue);width:32px;text-align:right}.status-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;padding:2px 8px;border-radius:10px;margin-top:6px}.status-badge.online{background:#4ade8026;color:var(--green)}.status-badge.offline{background:#f8717126;color:var(--red)}.status-badge .dot{width:5px;height:5px;border-radius:50%;background:currentColor}.unavail-section{margin-top:16px}.unavail-title{font-size:.7rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}.unavail-card{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8717114;border:1px solid rgba(248,113,113,.2);border-radius:8px;font-size:.82rem;color:var(--red);opacity:.7;margin-bottom:6px}.climate-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;max-width:340px}.climate-current{font-size:2.4rem;font-weight:700;color:var(--gold);line-height:1}.climate-target{display:flex;align-items:center;gap:12px;margin:16px 0}.climate-target-val{font-size:1.4rem;font-weight:600;color:var(--blue)}.mode-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--border);border-radius:6px;font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.fan-mode-grid{display:flex;gap:6px;flex-wrap:wrap}.fan-mode-btn{padding:5px 10px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--muted);font-size:.75rem;cursor:pointer;transition:all .2s;font-family:inherit;text-transform:uppercase;letter-spacing:.05em}.fan-mode-btn:hover{border-color:var(--blue);color:var(--blue)}.fan-mode-btn.active{border-color:var(--gold);color:var(--gold);background:#f0c0401a}.power-btn{padding:4px 12px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--muted);font-size:.75rem;cursor:pointer;transition:all .2s;font-family:inherit;font-weight:600;letter-spacing:.05em}.power-btn:hover{border-color:var(--red);color:var(--red)}.power-btn.on{border-color:var(--green);color:var(--green);background:#4ade801a}.media-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px}.media-icon{font-size:1.6rem}.media-info{flex:1}.media-name{font-weight:600;font-size:.9rem}.media-state{font-size:.75rem;color:var(--muted)}.media-btn{padding:6px 12px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text);font-size:.8rem;cursor:pointer;transition:all .2s;font-family:inherit}.media-btn:hover{border-color:var(--blue);color:var(--blue)}.ev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.ev-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px}.ev-value{font-size:1.6rem;font-weight:700;color:var(--gold)}.ev-label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.energy-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;max-width:300px}.energy-price{font-size:2.5rem;font-weight:700}.energy-price.low{color:var(--green)}.energy-price.mid{color:var(--gold)}.energy-price.high{color:var(--red)}.energy-unit{font-size:.9rem;color:var(--muted)}.scene-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.scene-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 12px;background:var(--card);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s;font-family:inherit;color:var(--text)}.scene-btn:hover{border-color:var(--gold);background:#f0c04014}.scene-icon{font-size:2rem}.scene-name{font-weight:600;font-size:.88rem}.scene-desc{font-size:.68rem;color:var(--muted);text-align:center}.artemis-hero{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;margin-bottom:20px}.artemis-title{font-size:1.8rem;font-weight:700;color:var(--gold);text-align:center;margin-bottom:4px}.artemis-subtitle{text-align:center;color:var(--muted);font-size:.85rem;margin-bottom:20px}.artemis-crew{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:20px}.crew-tag{padding:4px 10px;background:#38bdf81a;border:1px solid var(--border);border-radius:20px;font-size:.75rem;color:var(--blue)}.artemis-bar-section{margin:24px 0}.artemis-bar-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted);margin-bottom:8px}.artemis-track-full{height:8px;background:#ffffff14;border-radius:4px;position:relative}.artemis-fill-full{height:100%;background:linear-gradient(90deg,var(--blue),var(--gold));border-radius:4px;transition:width 1s ease}.artemis-cursor{position:absolute;top:-4px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;transition:left 1s ease}.artemis-cursor-dot{width:16px;height:16px;border-radius:50%;background:var(--gold);border:2px solid var(--bg);box-shadow:0 0 8px var(--gold)}.artemis-cursor-label{font-size:.65rem;color:var(--gold);margin-top:2px;white-space:nowrap}.artemis-milestone{position:absolute;top:-6px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center}.artemis-ms-dot{width:8px;height:8px;border-radius:50%;background:#fff3;border:1px solid var(--border)}.artemis-ms-dot.done{background:var(--gold);border-color:var(--gold)}.artemis-milestone-label{font-size:.6rem;color:var(--muted);margin-top:3px;white-space:nowrap}.artemis-stats-row{display:flex;gap:24px;justify-content:center;margin-top:16px}.artemis-stat-val{font-size:1.4rem;font-weight:700;color:var(--text)}.artemis-stat-lbl{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.artemis-timeline{display:flex;flex-direction:column;gap:8px}.timeline-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:8px;font-size:.82rem}.timeline-item.done{background:#4ade8014;color:var(--green)}.timeline-item.current{background:#38bdf81a;color:var(--blue);border:1px solid rgba(56,189,248,.3)}.timeline-item.upcoming{background:transparent;color:var(--muted)}.timeline-icon{font-size:1.1rem;width:24px;text-align:center}.timeline-label{font-weight:600}.timeline-event{flex:1}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px;color:var(--muted)}.loading-spinner{width:36px;height:36px;border:3px solid rgba(56,189,248,.2);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:#f8717126;border:1px solid rgba(248,113,113,.4);border-radius:8px;padding:10px 14px;color:var(--red);font-size:.82rem;margin:12px 0}@media(max-width:600px){.header{flex-direction:column;gap:10px}.device-grid{grid-template-columns:1fr}}.nasa-live-container{position:relative;width:100%;height:60vh;background:#000;border-radius:12px;overflow:hidden;border:1px solid var(--border);margin-top:12px}.nasa-live-container iframe{width:100%;height:100%;border:0}.drake-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0}.drake-stat-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center}.drake-stat-val{font-size:1.6rem;font-weight:700;color:var(--gold);letter-spacing:.05em}.drake-stat-lbl{font-size:.7rem;color:var(--text);margin-top:4px;text-transform:uppercase;letter-spacing:.08em}.drake-stat-src{font-size:.6rem;color:var(--muted);margin-top:3px}.drake-presets{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.drake-preset-btn{padding:6px 14px;border-radius:20px;border:1px solid var(--accent, var(--border));background:transparent;color:var(--accent, var(--text));font-size:.75rem;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.08em}.drake-preset-btn:hover,.drake-preset-btn.active{background:var(--accent, var(--border));color:var(--bg)}.drake-result{text-align:center;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:20px}.drake-result-number{font-size:4rem;font-weight:800;letter-spacing:.05em;line-height:1}.drake-result-label{font-size:.8rem;color:var(--muted);margin-top:8px;text-transform:uppercase;letter-spacing:.1em}.drake-sliders{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.drake-param{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 16px}.drake-param-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.drake-param-label{font-size:.82rem;font-weight:600;color:var(--text);letter-spacing:.03em}.drake-param-value{font-size:.9rem;font-weight:700;color:var(--gold)}.drake-unit{font-size:.7rem;color:var(--muted);font-weight:400}.drake-param-desc{font-size:.65rem;color:var(--muted);margin-bottom:8px;line-height:1.4}.drake-slider-wrap{position:relative}.drake-slider{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.drake-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gold);cursor:pointer;border:2px solid var(--bg);box-shadow:0 0 8px #f0c04080}.drake-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--gold);cursor:pointer;border:2px solid var(--bg);box-shadow:0 0 8px #f0c04080}.drake-range-labels{display:flex;justify-content:space-between;font-size:.6rem;color:var(--muted);margin-top:4px}.drake-equation{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 16px;overflow-x:auto}.drake-eq-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.drake-eq-factor{display:flex;flex-direction:column;align-items:center;min-width:40px}.drake-eq-name{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.drake-eq-val{font-size:.85rem;font-weight:600;color:var(--blue)}.drake-eq-eq{font-size:1.2rem;color:var(--gold);margin:0 4px}.drake-eq-result{font-size:1.4rem;font-weight:800}.news-panel{padding:16px}.panel-header-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:12px}.news-columns{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;align-items:start}.news-col{display:flex;flex-direction:column;gap:6px}.news-col-header{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);padding:6px 8px;background:#f0c04014;border:1px solid rgba(240,192,64,.2);border-radius:6px;text-align:center}.news-col-body{display:flex;flex-direction:column;gap:4px}.news-col-empty{font-size:.78rem;color:var(--muted);text-align:center;padding:16px 8px;background:var(--card);border:1px solid var(--border);border-radius:6px}.news-item{display:flex;flex-direction:column;gap:3px;padding:9px 10px;background:var(--card);border:1px solid var(--border);border-radius:6px;text-decoration:none;transition:border-color .2s}.news-item:hover{border-color:var(--blue)}.news-item-time{font-size:.65rem;color:var(--muted)}.news-item-title{font-size:.82rem;font-weight:600;color:var(--text);line-height:1.35}.news-item-desc{font-size:.72rem;color:var(--muted);line-height:1.45}.budget-root{display:flex;flex-direction:column;gap:0}.budget-summary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:20px}.budget-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 12px;text-align:center}.budget-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:6px}.budget-value{font-size:1.1rem;font-weight:700}.budget-value.income{color:var(--green)}.budget-value.expense{color:var(--red)}.budget-value.balance-pos{color:var(--blue)}.budget-value.balance-neg{color:var(--red)}.budget-form{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:16px}.budget-form-row{display:grid;grid-template-columns:120px 1fr 110px auto auto;gap:8px;align-items:center}.budget-form input,.budget-form select{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:8px 10px;font-size:.9rem;width:100%}.budget-form input:focus,.budget-form select:focus{outline:none;border-color:var(--blue)}.budget-add-btn{background:var(--blue);border:none;border-radius:6px;color:#0a0e17;cursor:pointer;font-size:.9rem;font-weight:700;padding:8px 14px;white-space:nowrap}.date-picker-wrapper{position:relative;display:inline-block}.date-display-btn{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:7px 10px;cursor:pointer;font-family:inherit;font-size:.9rem;min-width:110px;text-align:center}.date-display-btn:hover{border-color:var(--blue)}.date-hidden-input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.date-picker-popup{position:absolute;top:calc(100% + 4px);left:0;z-index:1000;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px;box-shadow:0 8px 24px #00000080;min-width:220px}.date-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;color:var(--text);font-weight:600}.date-picker-header button{background:none;border:none;color:var(--blue);font-size:18px;cursor:pointer;padding:2px 8px;border-radius:4px}.date-picker-header button:hover{background:var(--border)}.date-picker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:4px}.date-picker-weekdays span{font-size:11px;color:var(--muted);font-weight:600;padding:2px}.date-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.date-picker-day{background:var(--surface2);border:none;color:var(--text);border-radius:4px;width:28px;height:28px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center}.date-picker-day:hover{background:var(--border)}.date-picker-day.selected{background:var(--blue);color:#0a0e17;font-weight:700}.date-picker-empty{width:28px;height:28px}.budget-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.budget-col{display:flex;flex-direction:column;gap:8px}.budget-col-header{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;font-weight:700;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--card)}.budget-col-header.income{color:var(--green);border-color:#4ade804d;background:#4ade800d}.budget-col-header.expense{color:var(--red);border-color:#f871714d;background:#f871710d}.budget-col-total{font-size:.9rem}.budget-col-body{display:flex;flex-direction:column;gap:8px}.budget-empty-col{text-align:center;color:var(--muted);padding:24px;font-size:.85rem;background:var(--card);border:1px solid var(--border);border-radius:8px}.budget-month-group{display:flex;flex-direction:column;gap:4px}.budget-month-label{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:6px 4px 2px}.budget-month-sum{font-size:.8rem;font-weight:700}.budget-month-sum.income{color:var(--green)}.budget-month-sum.expense{color:var(--red)}.budget-entry-row{display:grid;grid-template-columns:90px 1fr auto 28px;gap:8px;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:7px;padding:9px 10px}.budget-entry-date{font-size:.75rem;color:var(--muted);white-space:nowrap}.budget-entry-desc{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-entry-amount{font-size:.85rem;font-weight:600;text-align:right;white-space:nowrap}.budget-entry-amount.income{color:var(--green)}.budget-entry-amount.expense{color:var(--red)}.budget-del{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:1.2rem;line-height:1;padding:4px;text-align:center;width:auto}.budget-del:hover{color:var(--red)}.budget-clear{background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--muted);cursor:pointer;font-size:.8rem;margin-top:12px;padding:6px 14px;width:auto;align-self:flex-end}.budget-clear:hover{border-color:var(--red);color:var(--red)}.budget-login{display:flex;align-items:center;justify-content:center;min-height:400px}.budget-login-box{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:40px 36px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;min-width:280px}.budget-login-icon{font-size:2.5rem;margin-bottom:4px}.budget-login-title{font-size:1rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.budget-login-form{display:flex;flex-direction:column;gap:10px;width:100%}.budget-login-form input{background:var(--bg);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:10px 12px;font-size:.9rem;text-align:center;width:100%;box-sizing:border-box}.budget-login-form input:focus{outline:none;border-color:var(--blue)}.budget-login-form button{background:var(--blue);border:none;border-radius:7px;color:#0a0e17;cursor:pointer;font-size:.9rem;font-weight:700;padding:10px;width:100%}.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 0%,#0f1a2e,#060b14 60%);padding:20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px 36px;width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 24px 60px #0009}.login-ship{font-size:.75rem;letter-spacing:.35em;color:var(--blue);text-transform:uppercase;margin-bottom:8px}.login-title{font-size:1.6rem;font-weight:700;color:var(--text);text-align:center}.login-subtitle{font-size:.85rem;color:var(--muted);text-align:center;margin-bottom:16px}.login-form{width:100%;display:flex;flex-direction:column;gap:12px;margin-top:8px}.login-label{font-size:.78rem;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}.login-pin-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:1.4rem;letter-spacing:.3em;text-align:center;padding:14px;outline:none;box-sizing:border-box;transition:border-color .2s}.login-pin-input:focus{border-color:var(--blue)}.login-pin-input.login-pin-error{border-color:var(--red);animation:shake .3s ease}.login-token-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:.82rem;font-family:Courier New,monospace;padding:12px;outline:none;resize:none;box-sizing:border-box;transition:border-color .2s}.login-token-input:focus{border-color:var(--blue)}.login-hint{font-size:.75rem;color:var(--muted);text-align:center}.login-btn{background:var(--blue);border:none;border-radius:10px;color:#060b14;font-size:.95rem;font-weight:700;padding:14px;cursor:pointer;width:100%;transition:opacity .2s;letter-spacing:.05em}.login-btn:disabled{opacity:.4;cursor:not-allowed}.login-btn:not(:disabled):hover{opacity:.9}.login-error-msg{color:var(--red);font-size:.82rem;text-align:center;margin-top:-4px}.login-footer{margin-top:20px;font-size:.72rem;color:var(--muted);text-align:center}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.status-section{margin-bottom:20px}.status-section-title{font-size:.85rem;font-weight:700;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 12px;text-align:center;transition:border-color .2s}.stat-icon{font-size:1.5rem;margin-bottom:4px}.stat-label{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:2px}.stat-value{font-size:1.1rem;font-weight:700;color:var(--text)}.stat-sub{font-size:.65rem;color:var(--muted);margin-top:2px}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.qa-btn{background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.8rem;padding:12px 8px;cursor:pointer;transition:background .2s,border-color .2s}.qa-btn:hover{background:#38bdf81a;border-color:var(--blue)}.qa-btn:active{background:#38bdf833}.news-refresh-btn{background:var(--card);border:1px solid var(--border);border-radius:6px;color:var(--blue);font-size:.72rem;padding:4px 10px;cursor:pointer;transition:background .2s;white-space:nowrap}.news-refresh-btn:hover:not(:disabled){background:#38bdf81a}.news-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.pull-indicator{display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--muted);overflow:hidden;transition:height .15s}.news-src-err{margin-left:4px;font-size:.7rem;cursor:help}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.camera-panel{display:flex;flex-direction:column;height:100%}.camera-container{position:relative;flex:1;background:#000;border-radius:12px;overflow:hidden;border:1px solid var(--border);min-height:300px}.camera-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--muted);font-size:.9rem}.camera-frame{width:100%;height:100%;border:none;min-height:400px}.status-badge{font-size:.8rem;padding:4px 10px;border-radius:12px;background:#ffffff0d}.status-badge.online{color:var(--green)}.status-badge.loading{color:var(--gold);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.vlc-cone{font-size:1.3rem;margin-right:.3rem;filter:drop-shadow(0 0 6px #f80)}.vlc-player-wrapper{background:#0a0a0a!important;border:2px solid #f80!important;box-shadow:inset 0 0 40px #ff88000d,0 0 20px #ff88001a}.vlc-video{object-fit:contain!important;background:#000}.vlc-video::-webkit-media-controls-panel{background:linear-gradient(0deg,#1a1a1a,#2a2a2a)}.vlc-video::-webkit-media-controls-play-button{filter:hue-rotate(30deg) saturate(2)}.vlc-video::-webkit-media-controls-timeline{background:#f803;border-radius:4px}.vlc-video::-webkit-media-controls-current-time-display,.vlc-video::-webkit-media-controls-time-remaining-display{color:#f80}.vlc-spinner{border-color:#f80 transparent #f80 transparent!important}.vlc-controls-hint{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;margin-top:.5rem;background:#ff880014;border-radius:8px;border:1px solid rgba(255,136,0,.15);font-size:.75rem;color:#f80}.vlc-controls-hint span:last-child{color:var(--muted);font-size:.7rem}.status-badge.offline{color:#f44}.vlc-launcher-card{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a1a,#0a0a0a)!important;border:2px solid #f80!important;box-shadow:inset 0 0 60px #ff88000d,0 0 30px #ff880026}.vlc-launcher-content{text-align:center;padding:2rem}.vlc-cone-large{font-size:5rem;margin-bottom:1rem;filter:drop-shadow(0 0 20px #f80);animation:vlc-glow 2s ease-in-out infinite}@keyframes vlc-glow{0%,to{filter:drop-shadow(0 0 15px #f80)}50%{filter:drop-shadow(0 0 30px #fa0)}}.vlc-launcher-content h3{color:#fff;margin:.5rem 0;font-size:1.3rem}.vlc-rtsp-url{color:var(--muted);font-family:monospace;font-size:.75rem;background:#ffffff0d;padding:.4rem .8rem;border-radius:6px;display:inline-block;margin:.5rem 0;word-break:break-all}.vlc-hint{color:var(--muted);font-size:.8rem;margin:.5rem 0 1.5rem}.vlc-launch-btn{display:inline-block;background:linear-gradient(135deg,#f80,#e67000);color:#fff;font-size:1.1rem;font-weight:700;padding:.85rem 2.5rem;border-radius:12px;text-decoration:none;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 20px #f806}.vlc-launch-btn:hover{transform:scale(1.05);box-shadow:0 6px 30px #f809}.vlc-launch-btn:active{transform:scale(.97)}.windy-embed{border-radius:12px;overflow:hidden;border:1px solid var(--border);box-shadow:0 2px 12px #0000004d}.windy-embed iframe{width:100%;height:380px;border:none;display:block}
