:root{--bg: #050816;--bg-elevated: #0b1020;--bg-elevated-soft: #101629;--accent: #4f46e5;--accent-soft: rgba(79, 70, 229, .15);--accent-strong: #6366f1;--text: #f9fafb;--text-muted: #9ca3af;--border-subtle: rgba(148, 163, 184, .25);--danger: #ef4444;--success: #22c55e;--warning: #facc15;--radius-lg: 16px;--radius-md: 12px;--shadow-soft: 0 18px 45px rgba(15, 23, 42, .65);--spacing: 1.25rem;--transition-fast: .18s ease-out;--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);background:radial-gradient(circle at top,#1e293b 0,#020617 50%);color:var(--text);min-height:100vh;padding:1.5rem}a{color:var(--accent-strong)}.auth-shell{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:24px}.landing-shell{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top,#1e293b 0,#020617 50%);padding:32px}.landing-hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:1.5rem;align-items:center;max-width:1100px;width:100%}.landing-hero h1{margin:.4rem 0;font-size:2rem}.landing-menu{display:inline-flex;gap:.75rem;margin:.6rem 0 1rem}.landing-menu a{color:var(--text-muted);text-decoration:none;font-weight:600;padding:6px 10px;border-radius:10px;border:1px solid var(--border-subtle);background:#0f172acc}.primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:12px 16px;border-radius:12px;font-weight:700}.auth-card{max-width:420px;width:100%;padding:1.75rem;border-radius:var(--radius-lg);background:radial-gradient(circle at top left,#111827 0,#020617 55%);border:1px solid var(--border-subtle);box-shadow:var(--shadow-soft)}.auth-card h1{margin:0 0 .25rem}.auth-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}label{color:var(--text-muted);font-size:14px;display:flex;flex-direction:column;gap:4px}input,select{background:var(--bg-elevated-soft);border:1px solid var(--border-subtle);padding:10px 12px;border-radius:10px;color:var(--text);font-family:var(--font-sans)}button{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:10px 12px;border-radius:12px;font-weight:600;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}button:hover{transform:translateY(-1px);box-shadow:0 12px 24px #6366f159}.ghost{background:#0f172acc;color:var(--text-muted);border:1px solid var(--border-subtle)}.muted{color:var(--text-muted)}.small{font-size:12px}.error{color:#f87171;font-size:13px}.success{color:var(--success);font-size:13px}.app-shell{max-width:1300px;margin:0 auto;background:radial-gradient(circle at top left,#111827 0,#020617 55%);border-radius:24px;padding:1.75rem 1.75rem 2.25rem;box-shadow:var(--shadow-soft);border:1px solid rgba(148,163,184,.2);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem}.brand{display:flex;align-items:center;gap:.75rem}.brand-icon{width:42px;height:42px;border-radius:999px;background:radial-gradient(circle at 30% 0,#facc15,#4f46e5 55%,#020617);display:flex;align-items:center;justify-content:center;color:#0f172a;font-weight:800;font-size:1.25rem;box-shadow:0 10px 25px #0f172acc}.brand-text-title{font-weight:600;letter-spacing:.04em;font-size:1.1rem}.brand-text-sub{font-size:.8rem;color:var(--text-muted)}.header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}.select-inline{display:inline-flex;flex-direction:column;gap:.3rem;color:var(--text)}.select-inline .label{color:var(--text-muted);font-size:.75rem;letter-spacing:.06em}.pill-group{display:inline-flex;padding:.25rem .3rem;border-radius:999px;background:#0f172ae6;border:1px solid var(--border-subtle);gap:.25rem}.pill{border:none;background:transparent;color:var(--text-muted);font-size:.85rem;padding:.35rem 1rem;border-radius:999px;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.pill.is-active{background:var(--accent-soft);color:var(--accent-strong);font-weight:600}.icon-button{width:38px;height:38px;border-radius:999px;border:1px solid var(--border-subtle);background:#0f172ad9;display:inline-flex;align-items:center;justify-content:center;color:var(--text);cursor:pointer;position:relative;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.icon-button:hover{background:#6366f140;box-shadow:0 8px 20px #1e40af80;transform:translateY(-1px)}.icon-badge{position:absolute;top:-4px;right:-2px;min-width:16px;height:16px;border-radius:999px;background:var(--danger);color:#fff;font-size:.65rem;display:flex;align-items:center;justify-content:center;padding:0 3px;box-shadow:0 0 0 2px #020617}.app-grid{display:flex;flex-direction:column;gap:1.5rem}.grid-row{display:grid;grid-template-columns:minmax(0,2.2fr) minmax(0,1.3fr);gap:1.25rem}.grid-row--compact{grid-template-columns:minmax(0,2.2fr) minmax(0,1.3fr)}@media (max-width: 960px){.app-shell{padding:1.25rem}.grid-row,.grid-row--compact{grid-template-columns:minmax(0,1fr)}}.overview-cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.location-board{padding:1rem}.location-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.location-card{border:1px solid var(--border-subtle);background:#0f172acc;border-radius:14px;padding:.75rem .9rem;text-align:left;color:var(--text);cursor:pointer;transition:border var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.location-card.is-active{border-color:var(--accent-strong);box-shadow:0 12px 30px #4f46e540;transform:translateY(-2px)}.location-name{font-weight:700;margin-bottom:4px}.location-meta{display:flex;gap:8px;color:var(--text-muted);font-size:.82rem}.location-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem;margin-top:.6rem}.metric-value{font-weight:700}.location-updated{margin-top:.4rem;font-size:.78rem;color:var(--text-muted)}@media (max-width: 1024px){.overview-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.overview-cards{grid-template-columns:minmax(0,1fr)}}.card{background:radial-gradient(circle at top left,#1f2937 0,#020617 55%);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:var(--spacing);box-shadow:0 12px 30px #0f172ab3;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,rgba(79,70,229,.2),transparent);opacity:.7;pointer-events:none}.card-inner{position:relative;z-index:1}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;gap:.5rem}.card-title{font-size:.9rem;text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted)}.badge{font-size:.7rem;padding:.1rem .5rem;border-radius:999px;border:1px solid rgba(148,163,184,.5);color:var(--text-muted)}.card-main{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.5rem}.card-main-value{font-size:1.7rem;font-weight:600}.card-main-unit{font-size:.85rem;color:var(--text-muted)}.card-meta{font-size:.8rem;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:.4rem 1.25rem;margin-top:.25rem}.card-meta span strong{color:var(--text);font-weight:500}.chip{font-size:.7rem;padding:.1rem .45rem;border-radius:999px;background:#0f172ae6;border:1px solid rgba(148,163,184,.35);color:var(--text-muted);display:inline-flex;align-items:center;gap:.3rem}.chip-dot{width:8px;height:8px;border-radius:999px}.chip-dot.grid{background:#38bdf8}.chip-dot.solar{background:#facc15}.chip-dot.battery{background:#22c55e}.chip-dot.charge{background:#a855f7}.chart{width:100%;height:260px}.chart-small{width:100%;height:200px}.inline-actions{display:flex;gap:.5rem;flex-wrap:wrap}.timeline-controls{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;justify-content:flex-end;min-width:340px}.timeline-head{align-items:center;gap:1rem;flex-wrap:wrap}.timeline-head-info{flex:1;min-width:220px;display:flex;flex-direction:column;gap:.25rem}.timeline-controls .control-group{min-width:180px}.power-card{background:radial-gradient(circle at 20% 20%,rgba(99,102,241,.1),transparent 45%),radial-gradient(circle at 80% 10%,rgba(56,189,248,.08),transparent 40%),radial-gradient(circle at 50% 100%,rgba(34,197,94,.05),transparent 40%),#050816}.control-group{display:flex;flex-direction:column;gap:.3rem}.date-input{background:#0f172ae6;border:1px solid var(--border-subtle);color:var(--text);padding:10px 12px;border-radius:12px}.legend-dots{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.legend-item{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.85rem}.legend-dot{width:10px;height:10px;border-radius:999px}.legend-dot.grid{background:#38bdf8}.legend-dot.solar{background:#facc15}.legend-dot.battery{background:#22c55e}.timeline-footer{margin-top:.75rem;display:flex;justify-content:space-between;gap:.75rem;flex-wrap:wrap;align-items:center}.snapshot-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.pill-ghost{background:#ffffff0a;border:1px solid var(--border-subtle);padding:8px 10px;border-radius:12px;display:inline-flex;gap:6px;align-items:baseline}.empty-state{border:1px dashed var(--border-subtle);padding:16px;border-radius:12px;background:#ffffff05;margin-top:8px}.empty-title{font-weight:600;margin-bottom:4px}.flow-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.65rem}.flow-node{background:#0f172ae6;border-radius:var(--radius-md);padding:.6rem .75rem;border:1px solid rgba(148,163,184,.35);display:flex;flex-direction:column;gap:.15rem}.flow-node-header{display:flex;align-items:center;justify-content:space-between;font-size:.83rem}.flow-node-label{color:var(--text-muted);font-size:.74rem}.flow-node-value{font-size:.95rem;font-weight:600}.flow-links{margin-top:.75rem;display:grid;gap:.4rem;font-size:.8rem}.flow-link{display:flex;justify-content:space-between;align-items:center;padding:.35rem .5rem;border-radius:999px;background:#0f172ae6;border:1px solid rgba(148,163,184,.35)}.flow-link-left{display:flex;align-items:center;gap:.4rem}.flow-pill{font-size:.7rem;padding:.08rem .4rem;border-radius:999px;background:#0f172ae6;border:1px solid rgba(148,163,184,.35)}.flow-link-value{font-weight:600}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.65rem;margin-top:.5rem}.kpi-item{background:#0f172ae6;border:1px solid rgba(148,163,184,.35);border-radius:var(--radius-md);padding:.6rem .7rem}.kpi-label{font-size:.78rem;color:var(--text-muted)}.kpi-value{font-size:1.05rem;font-weight:600}.plan-list{display:grid;gap:.55rem;margin-top:.35rem}.plan-slot{background:#0f172ae6;border:1px solid rgba(148,163,184,.35);border-radius:var(--radius-md);padding:.5rem .65rem}.plan-slot-header{display:flex;justify-content:space-between;align-items:center;gap:.4rem}.plan-slot-time{font-size:.85rem;color:var(--text-muted)}.pill-flat{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:999px;background:#6366f126;color:#c7d2fe;font-size:.8rem;border:1px solid rgba(99,102,241,.35)}.plan-slot-meta{margin-top:.35rem;font-size:.8rem;color:var(--text-muted)}.admin-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.35rem}.admin-secrets{margin-top:.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.35rem;background:#0f172ab3;border:1px solid var(--border-subtle);border-radius:10px;padding:.6rem}.secret{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;word-break:break-all;color:var(--text)}.command-log{display:grid;gap:6px;margin-bottom:10px}.command-row{display:grid;grid-template-columns:auto auto 1fr auto;gap:8px;align-items:center;background:#0f172ae6;padding:8px;border:1px solid rgba(148,163,184,.35);border-radius:8px}.devices{display:flex;flex-direction:column;gap:10px}.device-row{display:flex;align-items:center;justify-content:space-between;padding:10px;border:1px solid rgba(148,163,184,.35);border-radius:10px;background:#0f172ae6}.device-name{font-weight:600;color:var(--text)}.slot-table{display:grid;gap:.5rem;margin-top:.5rem}.slot-row{display:grid;grid-template-columns:1.4fr .7fr .8fr 1.6fr;gap:.4rem;padding:.45rem .55rem;border:1px solid rgba(148,163,184,.25);border-radius:10px;background:#0f172ae6;font-size:.82rem;color:var(--text-muted)}.list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.pill.info{background:#4f46e526;color:#c7d2fe}.pill.warning{background:#facc151f;color:#facc15}.pill.error{background:#f871711f;color:#f87171}.insights-list{display:grid;gap:.5rem;margin-top:.5rem;font-size:.8rem}.insight-item{background:#0f172ae6;border-radius:var(--radius-md);padding:.5rem .6rem;border:1px solid rgba(148,163,184,.35)}.insight-title{font-weight:500;margin-bottom:.1rem}.subheading{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:.25rem;margin-bottom:.25rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.6rem;margin-top:.5rem}.form-grid input{width:100%}.card-footer{margin-top:.75rem;display:flex;justify-content:space-between;gap:.5rem;align-items:center;flex-wrap:wrap;color:var(--text-muted);font-size:.85rem}.divider{height:1px;background:var(--border-subtle);margin:.75rem 0;border:0}
