: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}@media (max-width: 900px){.landing-shell{padding:24px 16px}.landing-hero{grid-template-columns:1fr;gap:2rem;text-align:center}.landing-hero>div:first-child{display:flex;flex-direction:column;align-items:center}.auth-card{max-width:100%}}@media (max-width: 480px){.landing-shell{padding:16px 12px}.landing-hero{gap:1.5rem}.landing-hero h1{font-size:1.5rem}.landing-hero p{font-size:.9rem}.brand-icon{width:36px;height:36px;font-size:1rem}.auth-card{padding:1.25rem}.auth-card h2{font-size:1.25rem}.pill-group{flex-wrap:wrap;justify-content:center}.pill{font-size:.8rem;padding:.3rem .75rem}.auth-form{gap:10px}.auth-form input{padding:12px 10px;font-size:16px}.auth-form button{padding:14px 12px;font-size:1rem}}.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:linear-gradient(180deg,#0f172af2,#020617fa);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}.auth-forgot-link{text-align:right;margin-top:-4px}.link-button{background:none;border:none;color:var(--accent-strong);font-size:.85rem;cursor:pointer;padding:0;font-weight:500}.link-button:hover{color:#818cf8;text-decoration:underline;transform:none;box-shadow:none}.password-strength{display:flex;align-items:center;gap:.75rem;margin-top:-4px}.password-strength-bar{flex:1;height:4px;background:#94a3b833;border-radius:2px;overflow:hidden}.password-strength-fill{height:100%;border-radius:2px;transition:width .3s ease,background .3s ease}.password-strength-label{font-size:.75rem;font-weight:600;min-width:50px}.password-requirements{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:-4px}.password-requirements span{font-size:.7rem;color:var(--text-muted);background:#94a3b81a;padding:.2rem .5rem;border-radius:4px;transition:all .2s ease}.password-requirements span.met{color:var(--success);background:#22c55e26}.password-match-error{font-size:.8rem;color:var(--danger);margin-top:-4px}.forgot-password-modal{max-width:400px}.forgot-password-content{padding:1rem 0}.forgot-password-desc{color:var(--text-muted);font-size:.9rem;margin:0 0 1rem;line-height:1.5}.forgot-password-success{text-align:center;padding:1rem 0}.forgot-password-success .success-icon{width:60px;height:60px;background:#22c55e26;border:2px solid var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:var(--success);margin:0 auto 1rem}.forgot-password-success h3{color:var(--text);margin:0 0 .5rem;font-size:1.1rem}.forgot-password-success p{color:var(--text-muted);margin:0 0 .5rem;font-size:.9rem}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)}.ghost:hover{background:#ffffff0a;color:var(--text)}.btn{border:1px solid var(--border-subtle);border-radius:12px;padding:8px 14px;background:#0f172ad9;color:var(--text);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.btn:hover{background:#6366f140;box-shadow:0 10px 20px #6366f140}.btn-ghost{border:1px solid var(--border-subtle);background:#0f172a99;color:var(--text-muted)}.muted{color:var(--text-muted)}.small{font-size:12px}.error{color:#f87171;font-size:13px}.success{color:var(--success);font-size:13px}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:1px solid rgba(99,102,241,.4);box-shadow:0 12px 24px #6366f159}.btn-primary:hover{box-shadow:0 14px 28px #6366f173}.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}.live-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#22c55e1f;color:var(--text);border:1px solid rgba(34,197,94,.35);font-size:13px}.live-badge .dot{width:8px;height:8px;border-radius:999px;background:var(--success);box-shadow:0 0 0 6px #22c55e2e}.live-badge .dot.offline{background:var(--danger);box-shadow:0 0 0 6px #ef444433}.live-badge.offline{background:#ef44441a;border-color:#ef444459;color:#fecaca}.site-chip{padding:8px 12px;border-radius:12px;background:#4f46e51f;border:1px solid rgba(79,70,229,.35);color:var(--text);font-weight:600;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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:hover{background:#ffffff0a;color:var(--text)}.pill.is-active{background:var(--accent-soft);color:var(--accent-strong);font-weight:600}.site-tabs{margin:0 24px 16px;display:flex;flex-wrap:wrap;gap:.35rem;overflow-x:auto;padding:.25rem .3rem}.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)}.location-card-wrapper{position:relative}.location-card-improved{position:relative;background:#0f172ae6;border:1px solid var(--border-subtle);border-radius:16px;overflow:hidden;transition:all var(--transition-fast)}.location-card-improved:hover{border-color:#94a3b866;box-shadow:0 12px 30px #0006;transform:translateY(-2px)}.location-card-accent{position:absolute;top:0;left:0;right:0;height:4px;background:var(--card-accent)}.location-card-body{display:block;width:100%;padding:1.25rem 1rem 1rem;background:none;border:none;color:var(--text);text-align:left;cursor:pointer;font-family:inherit}.location-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.location-name-improved{font-size:1.1rem;font-weight:700;color:var(--text)}.location-status-badge{flex-shrink:0}.badge-online{display:inline-block;padding:.2rem .5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#22c55e26;color:var(--success);border-radius:6px;border:1px solid rgba(34,197,94,.3)}.badge-offline{display:inline-block;padding:.2rem .5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#9ca3af26;color:var(--text-muted);border-radius:6px;border:1px solid rgba(156,163,175,.3)}.badge-stale{display:inline-block;padding:.2rem .5rem;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;background:#f59e0b26;color:var(--warning);border-radius:6px;border:1px solid rgba(245,158,11,.3)}.location-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.location-info-item{display:flex;align-items:center;gap:.4rem;padding:.4rem .5rem;background:#ffffff08;border-radius:8px;font-size:.78rem}.info-icon{font-size:.9rem;flex-shrink:0}.info-label{color:var(--text-muted);font-size:.7rem;min-width:40px}.info-value{color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem;border-top:1px solid rgba(148,163,184,.1)}.location-updated-improved{font-size:.72rem;color:var(--text-muted)}.location-entsoe-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:.15rem .4rem;background:#4f46e526;color:var(--accent-strong);border-radius:4px}.location-delete-btn{position:absolute;bottom:.75rem;right:.75rem;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#ef444433;border:1px solid rgba(239,68,68,.4);border-radius:8px;font-size:1.1rem;cursor:pointer;opacity:0;transition:all var(--transition-fast)}.location-card-improved:hover .location-delete-btn{opacity:1}.location-delete-btn:hover{background:#ef444480;border-color:#ef4444cc;transform:scale(1.1);box-shadow:0 4px 16px #ef444466}.delete-confirm-modal{max-width:420px;text-align:center}.delete-confirm-content{padding:1rem 0}.delete-warning-icon{font-size:3rem;margin-bottom:.75rem}.delete-warning-text{font-size:1rem;color:var(--text);margin:0 0 .5rem}.delete-warning-sub{font-size:.85rem;color:var(--text-muted);margin:0;line-height:1.5}.delete-confirm-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem}.delete-confirm-actions button{min-width:120px}button.danger{background:var(--danger);color:#fff;border:none;padding:.6rem 1rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}button.danger:hover{background:#dc2626;box-shadow:0 4px 12px #ef44444d}@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;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.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:hover{box-shadow:0 18px 38px #00000073;border-color:#6366f159;transform:translateY(-2px)}.notification-list{display:flex;flex-direction:column;gap:.75rem;max-height:240px;overflow-y:auto;padding-right:4px}.notification-item{padding:.75rem;border-radius:12px;background:linear-gradient(135deg,#0f172ae6,#050816f2);border:1px solid rgba(148,163,184,.18);box-shadow:0 10px 22px #0003}.notification-title{font-weight:600}.notification-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.notif-pill{padding:4px 8px;border-radius:999px;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.notif-pill.info{background:#6366f126;color:#c7d2fe}.notif-pill.warning{background:#facc1526;color:#fde68a}.notif-pill.error{background:#f871712e;color:#fecdd3}.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}.chip-row{display:flex;gap:.4rem;flex-wrap:wrap}.timeline-nav{display:inline-flex;gap:.35rem;flex-wrap:wrap}.range-summary{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:8px}.notifications{position:relative}.notif-popover{position:absolute;top:46px;right:0;min-width:260px;background:#0a0c18f2;border:1px solid rgba(148,163,184,.35);border-radius:12px;box-shadow:0 12px 30px #0006;padding:10px;z-index:20;display:grid;gap:8px}.notif-header{display:flex;align-items:center;justify-content:space-between}.notif-list{display:grid;gap:8px;max-height:260px;overflow-y:auto}.notif-item{padding:8px 10px;border-radius:10px;background:#ffffff05;border:1px solid rgba(148,163,184,.25)}.notif-title{font-weight:600;font-size:.9rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:grid;place-items:center;z-index:50}.modal{background:#0a0c18f2;border:1px solid rgba(148,163,184,.35);border-radius:14px;padding:16px;min-width:320px;max-width:520px;width:90vw;box-shadow:0 16px 38px #00000073}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.modal-title{font-weight:700;font-size:1rem}.modal-body{max-height:360px;overflow-y:auto;display:grid;gap:10px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;padding:16px}.modal-close{background:none;border:none;color:var(--txt);font-size:1.5rem;cursor:pointer;padding:0;line-height:1;opacity:.7}.modal-close:hover{opacity:1}.wizard-modal{max-width:580px;width:100%}.wizard-modal .modal-header{border-bottom:1px solid rgba(148,163,184,.2);padding-bottom:12px}.wizard-modal .modal-header h2{font-size:1.1rem;font-weight:600;margin:0}.wizard-progress{display:flex;justify-content:space-between;padding:16px 0;gap:8px}.wizard-progress-step{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;cursor:pointer;opacity:.5;transition:opacity .2s}.wizard-progress-step.active,.wizard-progress-step.completed{opacity:1}.wizard-progress-circle{width:32px;height:32px;border-radius:50%;border:2px solid rgba(148,163,184,.4);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;transition:all .2s}.wizard-progress-step.active .wizard-progress-circle{border-color:var(--accent);background:var(--accent);color:#000}.wizard-progress-step.completed .wizard-progress-circle{border-color:var(--green);background:var(--green);color:#000}.wizard-progress-label{font-size:.7rem;text-align:center;white-space:nowrap}.wizard-modal .modal-body{max-height:400px;min-height:280px}.wizard-step{padding:8px 0}.wizard-step-title{font-size:1rem;font-weight:600;margin:0 0 4px}.wizard-step-desc{font-size:.85rem;color:var(--muted);margin:0 0 16px}.wizard-form{display:flex;flex-direction:column;gap:14px}.wizard-form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:500}.wizard-form input,.wizard-form select{padding:10px 12px;border:1px solid rgba(148,163,184,.35);border-radius:8px;background:#ffffff08;color:var(--txt);font-size:.9rem}.wizard-form input:focus,.wizard-form select:focus{outline:none;border-color:var(--accent)}.wizard-form input::placeholder{color:var(--muted);opacity:.6}.wizard-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.wizard-message{padding:8px 0 0;text-align:center}.wizard-modal .modal-footer{border-top:1px solid rgba(148,163,184,.2);padding-top:12px;justify-content:space-between}.wizard-nav{display:flex;gap:8px}@media (max-width: 480px){.wizard-progress-label{display:none}.wizard-form-row{grid-template-columns:1fr}}.plan-slot-list{display:grid;gap:10px}.plan-slot{border:1px solid rgba(148,163,184,.35);border-radius:12px;padding:10px;background:#ffffff05}.plan-slot-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.plan-slot-title{font-weight:700}.plan-slot-body{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.plan-slot-pill{padding:4px 8px;border-radius:8px;background:#6366f11f;color:var(--text);font-size:.85rem}.plan-slot-note{width:100%;font-size:.85rem;color:var(--text-muted)}.quick-settings{display:grid;gap:10px}.chart{width:100%;height:260px}.chart-loading{display:grid;place-items:center;background:#0f172a99;border:1px dashed var(--border-subtle);border-radius:12px}.spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:999px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.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{display:flex;flex-wrap:wrap;gap:.75rem;padding:.65rem .85rem;border-radius:14px;background:#0f172abf;border:1px solid rgba(148,163,184,.2);box-shadow:0 10px 30px #00000040}.timeline-controls .control-group{min-width:180px}.timeline-controls .pill-group{padding:.2rem .25rem;gap:.2rem}.timeline-controls .pill{font-size:.8rem;padding:.3rem .85rem}.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}.date-input:hover,.date-input:focus{border-color:#6366f199;outline:none;box-shadow:0 0 0 2px #6366f126}.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}.toast-stack{position:fixed;top:18px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:999}.toast{display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;background:#0f172ae6;border:1px solid rgba(148,163,184,.3);box-shadow:0 12px 30px #00000059;color:var(--text);min-width:240px}.toast-dot{width:10px;height:10px;border-radius:999px;background:var(--accent-strong)}.toast-text{font-size:.9rem}.toast.success{border-color:#22c55e73}.toast.error{border-color:#f8717173}.toast.info{border-color:#6366f166}.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)}.devices-list{display:flex;flex-direction:column;gap:.75rem}.device-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#0f172a80;border:1px solid var(--border-subtle);border-radius:10px;transition:all .2s ease}.device-item:hover{background:#6366f11a;border-color:#6366f14d}.device-item-left{display:flex;align-items:center;gap:.75rem}.device-item-info{display:flex;flex-direction:column;gap:.15rem}.device-icon{font-size:1.25rem}.device-status{font-size:.8rem;color:var(--text-muted)}.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%}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.gap-4{gap:1rem}.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}.device-card{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;border:1px solid rgba(148,163,184,.2);background:linear-gradient(135deg,#0f172aeb,#050816f2);box-shadow:0 10px 30px #00000040}.device-info h4{margin:0}.device-info p{margin:4px 0 0;color:var(--text-muted)}.status-pill{padding:4px 8px;border-radius:999px;font-weight:600}.status-pill.on{background:#22c55e26;color:#bbf7d0}.status-pill.off{background:#ef444426;color:#fecdd3}.status-pill.neutral{background:#94a3b826;color:var(--text-muted)}.table{width:100%;border-collapse:collapse;color:var(--text);font-size:.9rem}.table th{text-align:left;padding:10px 12px;color:var(--text-muted);font-weight:600;border-bottom:1px solid rgba(148,163,184,.2)}.table td{padding:10px 12px;border-bottom:1px solid rgba(148,163,184,.12)}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#ffffff05}.table-scroll{max-height:260px;overflow-y:auto;padding-right:4px}.notification-list::-webkit-scrollbar,.table-scroll::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-thumb,.table-scroll::-webkit-scrollbar-thumb{background:#94a3b859;border-radius:999px}.notification-list::-webkit-scrollbar-track,.table-scroll::-webkit-scrollbar-track{background:#0f172a66}input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:20px;height:20px;border-radius:6px;border:2px solid rgba(148,163,184,.5);background:#0f172a99;cursor:pointer;position:relative;transition:all .2s ease;flex-shrink:0}input[type=checkbox]:hover{border-color:#6366f199;background:#4f46e514}input[type=checkbox]:checked{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-color:#6366f1}input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px #6366f140}input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}input[type=checkbox]:disabled:hover{border-color:#94a3b880;background:#0f172a99}.period-dropdown-trigger{display:inline-flex;align-items:center;gap:.6rem;padding:.5rem .85rem;background:#0f172ad9;border:1px solid var(--border-subtle);border-radius:10px;color:var(--text);cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s ease}.calendar-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:280px;background:#0a0c18fa;border:1px solid rgba(99,102,241,.3);border-radius:14px;box-shadow:0 20px 50px #00000080;z-index:100;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s ease}.calendar-tabs{display:flex;padding:.5rem;gap:.25rem;background:#0f172a99;border-bottom:1px solid rgba(99,102,241,.1)}.calendar-tab{flex:1;padding:.45rem .25rem;border:none;background:transparent;color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease;white-space:nowrap}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;gap:.75rem}.savings-comparison{color:var(--success);font-weight:600}.savings-comparison.negative{color:var(--danger)}.config-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (min-width: 768px){.config-grid{grid-template-columns:repeat(4,1fr)}}.config-item{display:flex;flex-direction:column;gap:.35rem}.config-item label{font-size:.75rem;color:var(--text-muted);font-weight:500}.config-item input[type=text]{padding:.5rem .75rem;border-radius:8px;border:1px solid var(--border-subtle);background:#0f172a80;color:var(--text);font-size:.85rem;font-weight:500}.config-item input[type=text]:read-only{cursor:default;opacity:.9}: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: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif}*{box-sizing:border-box;margin:0;padding:0}*:focus-visible{outline:2px solid var(--accent-strong);outline-offset:2px}.skip-link{position:absolute;top:-100px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;padding:.75rem 1.5rem;border-radius:0 0 8px 8px;z-index:1000;transition:top .2s ease}.skip-link:focus{top:0}body{font-family:var(--font-sans);background:radial-gradient(circle at top,#1e293b 0,#020617 50%);color:var(--text);min-height:100vh;padding:1.5rem}.app-shell{max-width:1440px;margin:0 auto;background:linear-gradient(180deg,#0f172af2,#020617fa);border-radius:28px;padding:2rem;box-shadow:0 25px 60px #00000080,0 0 0 1px #ffffff08 inset;border:1px solid rgba(148,163,184,.08);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap;padding-bottom:1.5rem;border-bottom:1px solid rgba(148,163,184,.1)}.brand{display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .25s ease}.brand:hover{transform:scale(1.02)}.brand-icon{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,#facc15,#4f46e5,#1e1b4b);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1.1rem;box-shadow:0 8px 25px #4f46e566;letter-spacing:-.02em}.brand-text-title{font-weight:700;letter-spacing:-.01em;font-size:1.35rem;background:linear-gradient(135deg,#f9fafb,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-text-sub{font-size:.85rem;color:var(--text-muted);font-weight:400}.brand-text-sub span{color:var(--accent-strong);font-weight:500}.header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.select{position:relative;display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:999px;border:1px solid var(--border-subtle);background:#0f172ad9;color:var(--text);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.select:hover{background:#4f46e533;border-color:var(--accent-strong)}.select .label{color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}.select .value{font-weight:500}.select .chevron{font-size:.8rem;opacity:.7;transition:transform var(--transition-fast)}.select.open .chevron{transform:rotate(180deg)}.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:#0f172afa;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:.5rem;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast);z-index:100}.select.open .dropdown{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{padding:.6rem .8rem;border-radius:8px;cursor:pointer;transition:background var(--transition-fast)}.dropdown-item:hover{background:var(--accent-soft)}.dropdown-item.active{background:var(--accent-soft);color:var(--accent-strong)}.pill-group{display:inline-flex;padding:.25rem;border-radius:999px;background:#0f172ae6;border:1px solid var(--border-subtle);gap:.15rem}.pill{border:none;background:transparent;color:var(--text-muted);font-size:.8rem;padding:.35rem .85rem;border-radius:999px;cursor:pointer;transition:all var(--transition-fast)}.pill:hover{color:var(--text)}.pill.is-active{background:var(--accent-soft);color:var(--accent-strong);font-weight:500}.period-dropdown{position:relative;display:inline-block}.period-dropdown-trigger{display:inline-flex;align-items:center;gap:.6rem;padding:.5rem 1rem;background:#0f172ae6;border:1px solid var(--border-subtle);border-radius:10px;color:var(--text);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.period-dropdown-trigger:hover{border-color:var(--accent-strong);background:#6366f11a}.period-dropdown-trigger .period-icon{font-size:1rem}.period-dropdown-trigger .period-chevron{font-size:.75rem;color:var(--text-muted);transition:transform .2s ease}.period-dropdown.open .period-dropdown-trigger{border-color:var(--accent-strong);background:#6366f11a}.period-dropdown.open .period-chevron{transform:rotate(180deg)}.calendar-panel{position:absolute;top:calc(100% + 8px);right:0;width:300px;background:linear-gradient(180deg,#141e32fc,#0f1428fc);border:1px solid rgba(99,102,241,.25);border-radius:16px;padding:0;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .25s ease;z-index:200;box-shadow:0 20px 50px #00000080;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);overflow:hidden}.card:has(.period-dropdown.open),.card-inner:has(.period-dropdown.open),.chart-header:has(.period-dropdown.open){overflow:visible!important}.period-dropdown.open .calendar-panel{opacity:1;visibility:visible;transform:translateY(0)}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#6366f11a;border-bottom:1px solid rgba(99,102,241,.15)}.calendar-nav-btn{width:32px;height:32px;border:none;background:#6366f126;color:var(--text);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .15s ease;flex-shrink:0}.calendar-nav-btn:hover{background:#6366f14d}.calendar-title{font-size:.9rem;font-weight:600;color:var(--text);cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:all .15s ease;text-align:center;flex:1;white-space:nowrap}.calendar-title:hover{background:#6366f126}.calendar-tabs{display:flex;padding:.5rem;gap:.25rem;background:#0003;border-bottom:1px solid rgba(99,102,241,.1)}.calendar-tab{flex:1;padding:.45rem .25rem;border:none;background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .15s ease;white-space:nowrap}.calendar-tab:hover{color:var(--text);background:#6366f11a}.calendar-tab.is-active{background:var(--accent-soft);color:var(--accent-strong)}.calendar-body{padding:.75rem;max-height:280px;overflow-y:auto}.calendar-years{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.calendar-year{padding:.7rem .4rem;border:none;background:#0f172a80;color:var(--text-muted);font-size:.82rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s ease}.calendar-year:hover{background:#6366f126;color:var(--text)}.calendar-year.is-active{background:var(--accent-strong);color:#fff}.calendar-year.is-current{border:1px solid var(--accent-strong)}.calendar-quarters{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.calendar-quarter{padding:.875rem .5rem;border:none;background:#0f172a80;color:var(--text-muted);border-radius:10px;cursor:pointer;transition:all .15s ease;text-align:center}.calendar-quarter:hover{background:#6366f126;color:var(--text)}.calendar-quarter.is-active{background:var(--accent-strong);color:#fff}.calendar-quarter.is-current{border:1px solid var(--accent-strong)}.quarter-label{font-size:1rem;font-weight:600;margin-bottom:.25rem}.quarter-months{font-size:.65rem;opacity:.8}.calendar-months{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.calendar-month{padding:.6rem .4rem;border:none;background:#0f172a80;color:var(--text-muted);font-size:.8rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s ease}.calendar-month:hover{background:#6366f126;color:var(--text)}.calendar-month.is-active{background:var(--accent-strong);color:#fff}.calendar-month.is-current{border:1px solid var(--accent-strong)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.2rem;margin-bottom:.4rem}.calendar-weekday{padding:.3rem;text-align:center;font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.2rem}.calendar-day{aspect-ratio:1;border:none;background:transparent;color:var(--text-muted);font-size:.75rem;border-radius:6px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;min-height:32px}.calendar-day:hover{background:#6366f126;color:var(--text)}.calendar-day.other-month{opacity:.3}.calendar-day.is-today{border:1px solid var(--accent-strong);color:var(--accent-strong)}.calendar-day.is-active{background:var(--accent-strong);color:#fff}.calendar-day.in-week{background:#6366f133;color:var(--text)}.calendar-day.week-start{border-radius:6px 0 0 6px}.calendar-day.week-end{border-radius:0 6px 6px 0}.calendar-weeks-view{display:grid;gap:.3rem}.calendar-week-row{display:grid;grid-template-columns:36px repeat(7,1fr);gap:.2rem;align-items:center;padding:.15rem 0;border-radius:6px;cursor:pointer;transition:all .15s ease}.calendar-week-row:hover{background:#6366f114}.calendar-week-num{font-size:.65rem;color:var(--text-muted);text-align:center;font-weight:500}.calendar-week-row.is-active{background:#6366f126}.calendar-week-row.is-active .calendar-week-num{color:var(--accent-strong);font-weight:600}.calendar-week-row .calendar-day{min-height:28px;font-size:.7rem}.calendar-footer{padding:.5rem .75rem;border-top:1px solid rgba(99,102,241,.1);display:flex;justify-content:center}.calendar-today-btn{padding:.45rem 1rem;border:none;background:#6366f126;color:var(--accent-strong);font-size:.78rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s ease}.calendar-today-btn:hover{background:#6366f140}@media (max-width: 768px){.calendar-panel{width:280px;right:0;left:auto}.calendar-tab{font-size:.7rem;padding:.4rem .2rem}.calendar-title{font-size:.85rem}.calendar-year,.calendar-month{padding:.6rem .3rem;font-size:.78rem}.calendar-day{min-height:30px;font-size:.72rem}.calendar-week-row .calendar-day{min-height:26px;font-size:.68rem}.calendar-week-num{font-size:.62rem}.calendar-week-row{grid-template-columns:32px repeat(7,1fr)}}@media (max-width: 480px){.period-dropdown .calendar-panel{display:none!important}.calendar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;z-index:9998}.calendar-overlay.show{display:block}.mobile-calendar-modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - 2rem);max-width:320px;max-height:80vh;background:linear-gradient(180deg,#1e293bfa,#0f172afa);border:1px solid rgba(99,102,241,.3);border-radius:16px;z-index:9999;overflow:hidden}.mobile-calendar-modal.show{display:block}.mobile-calendar-header{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;background:#6366f11a;border-bottom:1px solid rgba(99,102,241,.2)}.mobile-calendar-title{font-size:.9rem;font-weight:600;color:var(--text)}.mobile-calendar-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#6366f126;border:none;border-radius:8px;color:var(--text);font-size:1.25rem;cursor:pointer}.mobile-calendar-tabs{display:flex;padding:.5rem;gap:.25rem;background:#0f172a80}.mobile-cal-tab{flex:1;padding:.5rem .25rem;font-size:.75rem;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-muted);cursor:pointer}.mobile-cal-tab.is-active{background:#6366f133;border-color:#6366f166;color:var(--accent-strong)}.mobile-calendar-nav{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;border-bottom:1px solid rgba(148,163,184,.1)}.mobile-cal-nav-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#6366f126;border:none;border-radius:8px;color:var(--text);font-size:1.1rem;cursor:pointer}.mobile-cal-title{font-size:.85rem;font-weight:500;color:var(--text)}.mobile-calendar-body{padding:.75rem;max-height:45vh;overflow-y:auto}.mobile-calendar-footer{padding:.75rem;border-top:1px solid rgba(148,163,184,.1);display:flex;justify-content:center}.mobile-cal-today{padding:.625rem 1.5rem;background:#6366f133;border:1px solid rgba(99,102,241,.4);border-radius:8px;color:var(--accent-strong);font-size:.85rem;font-weight:500;cursor:pointer}.mobile-cal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.mobile-cal-grid.months{grid-template-columns:repeat(3,1fr)}.mobile-cal-grid.quarters,.mobile-cal-grid.weeks{grid-template-columns:repeat(2,1fr)}.mobile-cal-grid.days{grid-template-columns:repeat(7,1fr);gap:.25rem}.mobile-cal-item{padding:.75rem .5rem;background:#6366f114;border:1px solid rgba(99,102,241,.15);border-radius:8px;color:var(--text);font-size:.8rem;text-align:center;cursor:pointer}.mobile-cal-item:active{background:#6366f140}.mobile-cal-item.current{background:#6366f133;border-color:#6366f180;color:var(--accent-strong)}.mobile-cal-item.selected{background:var(--accent);border-color:var(--accent);color:#fff}.card,.card-inner,.chart-header,.chart-header-controls{overflow:visible!important}}@media (min-width: 481px){.mobile-calendar-modal,.calendar-overlay{display:none!important}}@media (max-width: 360px){.calendar-panel{width:calc(100vw - 1.5rem)}.calendar-week-row{grid-template-columns:28px repeat(7,1fr);gap:.15rem}.calendar-week-num{font-size:.6rem}.calendar-week-row .calendar-day{min-height:24px;font-size:.65rem}}.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;font-size:1.1rem;transition:all var(--transition-fast)}.icon-button:hover{background:#4f46e566;border-color:var(--accent-strong);transform:translateY(-2px);box-shadow:0 8px 20px #4f46e54d}.icon-badge{position:absolute;top:-4px;right:-2px;min-width:18px;height:18px;border-radius:999px;background:var(--danger);color:#fff;font-size:.7rem;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 0 0 2px #020617}.nav-container{margin-bottom:2rem;display:flex;justify-content:center}.nav-tabs-desktop{display:none}.nav-dropdown{position:relative;display:inline-block}.nav-dropdown-trigger{display:inline-flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:#0f172acc;border:1px solid rgba(148,163,184,.2);border-radius:10px;color:var(--text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #00000026}.nav-dropdown-trigger:hover{border-color:#94a3b859;background:#1e293be6;box-shadow:0 4px 12px #0003}.nav-current-icon{font-size:1rem;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:linear-gradient(135deg,#6366f133,#6366f11a);border-radius:6px}.nav-current-label{letter-spacing:.01em}.nav-dropdown-chevron{font-size:.7rem;color:var(--text-muted);transition:transform .2s ease;margin-left:.25rem}.nav-dropdown.open .nav-dropdown-chevron{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;transform:translateY(-8px);min-width:200px;background:#0f172afa;border:1px solid rgba(148,163,184,.15);border-radius:12px;padding:6px;opacity:0;visibility:hidden;transition:all .15s ease;z-index:100;box-shadow:0 10px 40px #00000080,0 0 0 1px #ffffff08 inset;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.nav-dropdown.open .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.nav-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .875rem;background:transparent;border:none;border-radius:8px;color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .12s ease;text-align:left;position:relative}.nav-dropdown-item:hover{background:#94a3b814;color:var(--text)}.nav-dropdown-item.is-active{background:#6366f11f;color:var(--text)}.nav-dropdown-item.is-active .nav-dropdown-item-icon{color:var(--accent-strong)}.nav-dropdown-item.is-active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:50%;background:var(--accent-strong);border-radius:0 2px 2px 0}.nav-dropdown-item-icon{font-size:1rem;width:22px;text-align:center;opacity:.8}.nav-dropdown-item:hover .nav-dropdown-item-icon{opacity:1}.nav-dropdown-divider{height:1px;background:#94a3b81a;margin:6px 8px}@media (max-width: 768px){.nav-container{justify-content:center}.nav-dropdown{width:auto;max-width:90%}.nav-dropdown-trigger{width:auto}.nav-dropdown-menu{min-width:220px;left:0}}@media (max-width: 480px){.nav-dropdown-trigger{padding:.75rem 1.25rem;gap:.75rem}.nav-current-icon{width:32px;height:32px;font-size:1.1rem}.nav-current-label{font-size:.95rem}.nav-dropdown-chevron{width:26px;height:26px;font-size:1rem}.nav-dropdown-item{padding:.7rem .875rem;font-size:.9rem;justify-content:flex-start}.nav-dropdown-menu{left:0;min-width:200px}}.app-grid{display:flex;flex-direction:column;gap:2rem}.app-grid>section,.app-grid>.card{margin-bottom:1.5rem}.app-grid>section:last-child,.app-grid>.card:last-child{margin-bottom:0}.grid-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.grid-row-2{display:grid;grid-template-columns:2fr 1fr;gap:1rem}.grid-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}@media (max-width: 1200px){.grid-row{grid-template-columns:repeat(2,1fr)}.grid-row-2,.grid-row-3{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 768px){.grid-row{grid-template-columns:1fr}}.card{background:linear-gradient(145deg,#1e293b99,#0f172ae6);border-radius:20px;border:1px solid rgba(148,163,184,.1);padding:1.5rem;box-shadow:0 4px 20px #0000004d,0 0 0 1px #ffffff05 inset;position:relative;overflow:hidden;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.card:has(.period-dropdown.open),.card.calendar-open{overflow:visible!important}.card-inner:has(.period-dropdown.open),.chart-header:has(.period-dropdown.open),.chart-header-controls:has(.period-dropdown.open){overflow:visible!important}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,rgba(99,102,241,.08),transparent 70%);opacity:0;pointer-events:none;transition:opacity .3s ease}.card:hover{transform:translateY(-4px);border-color:#6366f14d;box-shadow:0 20px 40px #0006,0 0 30px #6366f11a}.card:hover:before{opacity:1}.card-inner{position:relative;z-index:1}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:.75rem}.card-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600}.badge{font-size:.7rem;padding:.25rem .75rem;border-radius:999px;border:1px solid rgba(148,163,184,.3);color:var(--text-muted);font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.badge.live{background:#ef444426;border-color:#ef444466;color:#fca5a5;animation:pulse 2s infinite}.badge.healthy{background:#22c55e26;border-color:#22c55e66;color:#86efac}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.card-main{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.75rem}.card-main-value{font-size:2.25rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,#f9fafb,#cbd5e1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card-main-unit{font-size:1rem;color:var(--text-muted);font-weight:500}.card-meta{font-size:.85rem;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:.5rem 1.25rem}.card-meta span strong{color:var(--text);font-weight:600}.battery-progress{display:flex;align-items:center;gap:1rem}.battery-bar{position:relative;width:90px;height:36px;border-radius:8px;border:2px solid rgba(148,163,184,.6);padding:3px;cursor:pointer;transition:all var(--transition-fast)}.battery-bar:hover{border-color:var(--accent-strong);box-shadow:0 0 20px #6366f14d}.battery-bar:after{content:"";position:absolute;right:-8px;top:8px;width:6px;height:16px;border-radius:3px;background:#94a3b8b3}.battery-bar-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#22c55e,#a3e635);transition:width .5s ease}.battery-bar-fill.low{background:linear-gradient(90deg,#ef4444,#f97316)}.battery-bar-fill.medium{background:linear-gradient(90deg,#f97316,#facc15)}.battery-label-main{font-size:.9rem;font-weight:500}.battery-label-sub{font-size:.78rem;color:var(--text-muted)}.chart-container{height:280px;position:relative}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.chart-header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.chart-filters{display:flex;gap:.4rem;flex-wrap:wrap}.chart-filter{font-size:.75rem;padding:.25rem .65rem;border-radius:999px;border:1px solid rgba(148,163,184,.5);background:#0f172ae6;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:.35rem}.chart-filter:hover{border-color:var(--accent-strong);color:var(--text)}.chart-filter.active{background:var(--accent-soft);color:var(--accent-strong);border-color:#818cf8e6}.chart-filter .dot{width:8px;height:8px;border-radius:50%}.dot.grid{background:#38bdf8}.dot.solar{background:#facc15}.dot.battery{background:#22c55e}.flow-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}@media (max-width: 900px){.flow-grid{grid-template-columns:repeat(2,1fr)}}.flow-node{background:#0f172ae6;border-radius:var(--radius-md);padding:.75rem;border:1px solid rgba(148,163,184,.35);cursor:pointer;transition:all var(--transition-fast);text-align:center}.flow-node:hover{border-color:var(--accent-strong);transform:scale(1.03)}.flow-node-icon{font-size:1.5rem;margin-bottom:.4rem}.flow-node-label{font-size:.75rem;color:var(--text-muted);margin-bottom:.2rem}.flow-node-value{font-size:1.1rem;font-weight:600}.flow-node-status{font-size:.7rem;color:var(--success);margin-top:.2rem}.devices-list{display:grid;gap:.6rem}.device-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-md);background:#0f172ae6;border:1px solid rgba(148,163,184,.35);cursor:pointer;transition:all var(--transition-fast)}.device-item-left{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.device-item-info{flex:1;min-width:0}.device-item:hover{border-color:var(--accent-strong);background:#4f46e51a}.device-icon{font-size:1.5rem;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:#6366f11a;border-radius:10px;flex-shrink:0}.device-name{font-weight:500;font-size:.9rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.device-status{font-size:.78rem;color:var(--text-muted);margin-top:.125rem}.tag{font-size:.68rem;padding:.1rem .5rem;border-radius:999px;background:#0f172ae6;border:1px solid rgba(148,163,184,.5);color:var(--text-muted)}.tag.smart{border-color:#34d399b3;color:#6ee7b7}.toggle{position:relative;width:44px;height:24px;border-radius:999px;background:#1e40af80;cursor:pointer;flex-shrink:0;transition:background var(--transition-fast)}.toggle:before{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:999px;background:#fff;transition:transform var(--transition-fast)}.toggle.is-on{background:var(--accent-strong)}.toggle.is-on:before{transform:translate(20px)}.toggle:hover{box-shadow:0 0 15px #6366f166}.notifications-list{display:grid;gap:.5rem}.notification-item{display:flex;gap:.6rem;align-items:flex-start;padding:.6rem .75rem;border-radius:var(--radius-md);background:#0f172ae6;border:1px solid rgba(148,163,184,.35);cursor:pointer;transition:all var(--transition-fast)}.notification-item:hover{border-color:var(--accent-strong);transform:translate(4px)}.notification-item.read{opacity:.6}.notification-icon{width:26px;height:26px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}.notification-icon.danger{background:#f8717126;color:#fecaca}.notification-icon.success{background:#4ade8026;color:#bbf7d0}.notification-icon.warning{background:#facc1526;color:#fef08a}.notification-icon.info{background:#60a5fa26;color:#bfdbfe}.notification-title{font-weight:500;font-size:.85rem;margin-bottom:.15rem}.notification-meta{font-size:.75rem;color:var(--text-muted)}.mode-tabs{display:inline-flex;gap:.25rem;padding:.2rem;border-radius:999px;background:#0f172ae6;border:1px solid var(--border-subtle)}.mode-tab{border:none;background:transparent;color:var(--text-muted);font-size:.8rem;padding:.4rem 1rem;border-radius:999px;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:.4rem}.mode-tab:hover{color:var(--text)}.mode-tab.is-active{background:var(--accent-soft);color:var(--accent-strong);font-weight:500}.link-muted{display:inline-flex;align-items:center;gap:.3rem;margin-top:.6rem;font-size:.8rem;color:var(--text-muted);cursor:pointer;text-decoration:none;transition:color var(--transition-fast)}.link-muted:hover{color:var(--accent-strong)}.schedule-list{display:grid;gap:.5rem}.schedule-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--radius-md);background:#0f172ae6;border:1px solid rgba(148,163,184,.35);cursor:pointer;transition:all var(--transition-fast)}.schedule-item:hover{border-color:var(--accent-strong);background:#4f46e51a}.schedule-time{font-size:.8rem;font-weight:500;min-width:90px}.schedule-action{padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500}.schedule-action.charge{background:#22c55e33;color:#86efac}.schedule-action.discharge{background:#fb923c33;color:#fdba74}.schedule-action.solar{background:#facc1533;color:#fef08a}.schedule-action.sell{background:#6366f133;color:#a5b4fc}.schedule-action.use{background:#38bdf833;color:#7dd3fc}.schedule-reason{flex:1;font-size:.8rem;color:var(--text-muted)}.schedule-power{font-size:.85rem;font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:all .25s ease}.modal-overlay.show{opacity:1;visibility:visible}.modal{background:radial-gradient(circle at top left,#1f2937 0,#0f172a 55%);border-radius:20px;border:1px solid var(--border-subtle);padding:1.5rem;max-width:500px;width:90%;max-height:85vh;overflow-y:auto;transform:scale(.9) translateY(20px);transition:transform .25s ease}.modal-overlay.show .modal{transform:scale(1) translateY(0)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{width:32px;height:32px;border-radius:999px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all var(--transition-fast)}.modal-close:hover{background:#ef444433;border-color:var(--danger);color:var(--danger)}.modal-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.25rem}.modal-stat{background:#0f172acc;border-radius:var(--radius-md);padding:.75rem;text-align:center}.modal-stat-value{font-size:1.5rem;font-weight:600}.modal-stat-label{font-size:.75rem;color:var(--text-muted);margin-top:.2rem}.modal-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.modal-action{padding:.75rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:#0f172acc;color:var(--text);cursor:pointer;font-size:.85rem;font-weight:500;transition:all var(--transition-fast);text-align:center}.modal-action:hover{border-color:var(--accent-strong);background:var(--accent-soft)}.modal-action.primary{background:var(--accent);border-color:var(--accent)}.modal-action.primary:hover{background:var(--accent-strong)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1100;display:flex;flex-direction:column;gap:.5rem}.toast{background:#0f172af2;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:.75rem 1rem;display:flex;align-items:center;gap:.6rem;font-size:.85rem;box-shadow:0 10px 30px #0006;transform:translate(120%);transition:transform .3s ease}.toast.show{transform:translate(0)}.toast.success{border-color:#22c55e80}.toast.error{border-color:#ef444480}.settings-tab{padding:.5rem .875rem;border-radius:999px;border:1px solid var(--border-subtle);background:#0f172acc;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all var(--transition-fast);min-height:36px;display:inline-flex;align-items:center}.settings-tab:hover{border-color:var(--accent-strong);color:var(--text)}.settings-tab.is-active{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent);font-weight:500}.config-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media (max-width: 600px){.config-grid{grid-template-columns:1fr}}.config-item{display:flex;flex-direction:column;gap:.25rem}.config-item label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.config-item input,.config-item select{padding:.625rem .875rem;border-radius:8px;border:1px solid var(--border-subtle);background:#0f172ae6;color:var(--text);font-size:.9rem;transition:border-color var(--transition-fast);min-height:44px}.config-item input:focus,.config-item select:focus{outline:none;border-color:var(--accent-strong)}.config-hint{font-size:.7rem;color:var(--text-muted);font-style:italic}.config-item.checkbox{flex-direction:row;align-items:center;gap:.5rem;cursor:pointer;padding:.25rem 0}.config-item.checkbox input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:16px!important;height:16px!important;min-width:16px!important;min-height:16px!important;max-width:16px!important;max-height:16px!important;border:2px solid var(--border-subtle);border-radius:3px;background:#0f172ae6;cursor:pointer;position:relative;transition:all var(--transition-fast);flex-shrink:0;padding:0!important;margin:0;box-sizing:border-box;aspect-ratio:1 / 1}.config-item.checkbox input[type=checkbox]:checked{background:var(--accent-strong);border-color:var(--accent-strong)}.config-item.checkbox input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.config-item.checkbox input[type=checkbox]:hover{border-color:var(--accent-strong)}.config-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(148,163,184,.1);font-size:.85rem}.config-toggle-row:last-child{border-bottom:none}.tab-view{animation:fadeIn .3s ease;display:flex;flex-direction:column;gap:1.5rem}.tab-view>section,.tab-view>.card{margin-bottom:1rem}.tab-view>section:last-child,.tab-view>.card:last-child{margin-bottom:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.notification-dropdown-wrapper{position:relative}.notification-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:340px;max-height:400px;overflow-y:auto;background:#0f172afa;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:0;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast);z-index:200;box-shadow:0 20px 40px #00000080}.notification-dropdown.show{opacity:1;visibility:visible;transform:translateY(0)}.notification-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border-subtle)}.notification-dropdown-header h3{font-size:.95rem;font-weight:600}.notification-dropdown-actions{display:flex;gap:.5rem}.notification-dropdown-actions button{background:transparent;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all var(--transition-fast)}.notification-dropdown-actions button:hover{background:var(--accent-soft);color:var(--accent-strong)}.notification-dropdown-list{padding:.5rem}.notification-dropdown-item{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border-left:3px solid transparent}.notification-dropdown-item:hover{background:#4f46e51a}.notification-dropdown-item.unread{background:#4f46e50d;border-left-color:var(--accent-strong)}.notification-dropdown-item .notif-icon{width:32px;height:32px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.notification-dropdown-item .notif-icon.danger{background:#f8717126}.notification-dropdown-item .notif-icon.success{background:#4ade8026}.notification-dropdown-item .notif-icon.warning{background:#facc1526}.notification-dropdown-item .notif-icon.info{background:#60a5fa26}.notification-dropdown-item .notif-content{flex:1}.notification-dropdown-item .notif-title{font-size:.85rem;font-weight:500;margin-bottom:.2rem}.notification-dropdown-item .notif-desc{font-size:.78rem;color:var(--text-muted);margin-bottom:.25rem}.notification-dropdown-item .notif-time{font-size:.7rem;color:var(--text-muted);opacity:.7}.notification-dropdown-footer{padding:.75rem 1rem;border-top:1px solid var(--border-subtle);text-align:center}.notification-dropdown-footer a{font-size:.8rem;color:var(--accent-strong);text-decoration:none;cursor:pointer}.notification-dropdown-footer a:hover{text-decoration:underline}@media (max-width: 1024px){body{padding:1rem}.app-shell{padding:1.25rem;border-radius:20px}.app-header{gap:1rem}.chart-container{height:240px}.modal-stats,.flow-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){:root{--spacing: 1rem}body{padding:.75rem}.app-shell{padding:1.25rem;border-radius:20px}.app-header{flex-direction:column;align-items:flex-start;gap:1.25rem;padding-bottom:1.25rem;margin-bottom:1.5rem}.brand{width:100%}.brand-icon{width:44px;height:44px;border-radius:12px;font-size:1rem}.brand-text-title{font-size:1.15rem}.brand-text-sub{font-size:.8rem}.header-controls{width:100%;justify-content:flex-end;gap:.5rem}.nav-mobile-dropdown{max-width:100%}.nav-dropdown-trigger{padding:.875rem 1.25rem;border-radius:14px}.nav-current-icon{width:36px;height:36px;font-size:1.2rem;border-radius:10px}.nav-dropdown-chevron{width:28px;height:28px;font-size:1.1rem}.nav-dropdown-menu{min-width:200px;left:0;border-radius:16px}.nav-dropdown-item{padding:.75rem 1rem;justify-content:flex-start}.nav-container{margin-bottom:1.5rem}.grid-row{grid-template-columns:1fr!important;gap:1.25rem}.grid-row-2,.grid-row-3{grid-template-columns:1fr;gap:1.25rem}.app-grid{gap:1.5rem}.tab-view{gap:1.25rem}.tab-view>section,.tab-view>.card{margin-bottom:.5rem}.tab-view>section:last-child,.tab-view>.card:last-child{margin-bottom:0}.modal-stats[style*="repeat(4"],.modal-stats[style*="repeat(5"]{grid-template-columns:repeat(2,1fr)!important;gap:.75rem!important}.modal-actions[style]{grid-template-columns:repeat(3,1fr)!important;gap:.5rem!important}.card{padding:1.25rem;border-radius:16px}.card:hover{transform:none;box-shadow:0 4px 20px #0000004d}.card-header{flex-wrap:wrap;gap:.5rem;margin-bottom:.875rem}.card-title{font-size:.75rem;letter-spacing:.08em}.card-main{margin-bottom:.625rem}.card-main-value{font-size:1.875rem}.card-main-unit{font-size:.9rem}.card-meta{font-size:.8rem;gap:.375rem 1rem}.chart-header{flex-direction:column;align-items:flex-start;gap:.875rem}.chart-header-controls{width:100%;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem}.pill-group{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;padding-bottom:.25rem}.pill-group::-webkit-scrollbar{display:none}.pill{font-size:.8rem;padding:.5rem .875rem;flex-shrink:0}.chart-filters{display:flex;gap:.5rem;flex-wrap:wrap;width:auto;justify-content:flex-start}.chart-filter{font-size:.8rem;padding:.5rem .875rem;border-radius:10px;min-height:40px;gap:.4rem;flex:0 0 auto}.chart-filter .dot{width:10px;height:10px}.period-dropdown-trigger{min-height:42px}.mode-tab{min-height:40px;padding:.5rem .875rem}.pill{min-height:40px}.schedule-item,.device-item{min-height:60px}.notification-item{min-height:56px}.chart-container{height:200px;margin-top:.5rem}.battery-bar{width:80px;height:32px}.battery-progress{flex-wrap:wrap;gap:.875rem}.battery-label-main{font-size:.9rem}.battery-label-sub{font-size:.75rem}.flow-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.flow-node{padding:.875rem;border-radius:12px}.flow-node-icon{font-size:1.5rem;margin-bottom:.5rem}.flow-node-value{font-size:1rem;font-weight:600}.flow-node-label{font-size:.7rem}.schedule-item{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:.5rem .75rem;padding:.875rem;border-radius:12px}.schedule-time{font-size:.8rem;font-weight:600;grid-row:1;grid-column:1}.schedule-action{grid-row:1;grid-column:2;justify-self:start}.schedule-power{grid-row:1;grid-column:3;font-size:.85rem}.schedule-reason{grid-row:2;grid-column:1 / -1;font-size:.75rem;opacity:.8}.device-item{padding:.625rem .75rem;gap:.5rem;border-radius:10px;min-height:auto}.device-item-left{gap:.5rem}.device-item .toggle{width:42px;height:24px;flex-shrink:0}.device-item .toggle:before{width:18px;height:18px;top:3px;left:3px}.device-item .toggle.is-on:before{transform:translate(18px)}.device-name{font-size:.8rem;gap:.375rem}.device-status{font-size:.68rem}.device-icon{font-size:1.1rem;width:1.75rem;height:1.75rem;border-radius:8px}.tag{font-size:.55rem;padding:.1rem .35rem;min-height:auto!important}.config-toggle-row .toggle{width:44px;height:24px;flex-shrink:0}.config-toggle-row .toggle:before{width:18px;height:18px;top:3px;left:3px}.config-toggle-row .toggle.is-on:before{transform:translate(20px)}.toggle{width:40px;height:22px}.toggle:before{width:16px;height:16px}.toggle.is-on:before{transform:translate(18px)}.notification-item{padding:.5rem .6rem;gap:.5rem}.notification-icon{width:24px;height:24px;font-size:.75rem}.notification-title{font-size:.8rem}.notification-meta{font-size:.7rem}.modal{padding:1.25rem;border-radius:16px;max-height:90vh}.modal-title{font-size:1.1rem}.modal-stats{grid-template-columns:repeat(2,1fr);gap:.5rem}.modal-stat{padding:.6rem}.modal-stat-value{font-size:1.2rem}.modal-stat-label{font-size:.7rem}.modal-actions{grid-template-columns:1fr;gap:.4rem}.modal-action{padding:.65rem;font-size:.8rem}.mode-tabs{flex-wrap:nowrap}.mode-tab{font-size:.75rem;padding:.35rem .75rem}.select{padding:.4rem .8rem;font-size:.8rem}.select .label{display:none}.dropdown{min-width:180px}.dropdown-item{padding:.5rem .7rem;font-size:.85rem}.notification-dropdown{width:calc(100vw - 2rem);max-width:340px;right:50%;transform:translate(50%) translateY(-10px);left:auto}.notification-dropdown.show{transform:translate(50%) translateY(0)}.notification-dropdown-wrapper{position:static}.notification-dropdown{position:fixed;top:70px;right:1rem;left:1rem;width:auto;max-width:none;transform:translateY(-10px)}.notification-dropdown.show{transform:translateY(0)}.toast-container{left:1rem;right:1rem;bottom:1rem}.toast{width:100%;font-size:.8rem;padding:.65rem .85rem}.icon-button{width:36px;height:36px;font-size:1rem}.icon-badge{min-width:16px;height:16px;font-size:.65rem}}@media (max-width: 480px){body{padding:.5rem}.app-shell{padding:1rem;border-radius:16px}.brand-icon{width:40px;height:40px;font-size:.9rem;border-radius:10px}.brand-text-title{font-size:1.1rem}.brand-text-sub{font-size:.75rem}.nav-dropdown-trigger{padding:.75rem 1rem}.nav-current-icon{width:32px;height:32px;font-size:1rem}.nav-current-label{font-size:.9rem}.nav-dropdown-chevron{width:24px;height:24px;font-size:.9rem}.grid-row,.grid-row-2,.grid-row-3,.tab-view{gap:.75rem}.card{padding:.875rem;border-radius:12px}.card-header{margin-bottom:.5rem}.card-title{font-size:.65rem;letter-spacing:.06em}.card-main{margin-bottom:.375rem}.card-main-value{font-size:1.5rem}.card-main-unit{font-size:.8rem}.card-meta{font-size:.75rem;flex-direction:row;flex-wrap:wrap;gap:.25rem .75rem}.card-meta span{font-size:.7rem}.badge{font-size:.6rem;padding:.2rem .5rem;min-height:auto!important}.badge.live,.badge.healthy{font-size:.6rem;padding:.2rem .5rem}.badge[style*="border-radius: 50%"],[style*="border-radius: 50%"].badge{width:36px!important;height:36px!important;font-size:.7rem!important;padding:0!important}.battery-progress{gap:.5rem;margin-bottom:.5rem!important}.battery-bar{width:80px!important;height:28px!important}.battery-label-main{font-size:.85rem!important}.battery-label-sub{font-size:.65rem}.modal-stats[style*="repeat(4"],.modal-stats[style*="repeat(5"]{grid-template-columns:repeat(2,1fr)!important;gap:.5rem!important}.modal-stat{padding:.625rem}.modal-stat-value{font-size:1.1rem!important}.modal-stat-label{font-size:.65rem}.grid-row[style*="repeat(2"]{grid-template-columns:1fr!important}.modal-actions[style]{grid-template-columns:repeat(3,1fr)!important;gap:.375rem}.modal-action{padding:.625rem .5rem;font-size:.75rem}.chart-container{height:180px}.flow-grid{gap:.5rem}.flow-node{padding:.75rem}.flow-node-icon{font-size:1.25rem;margin-bottom:.375rem}.flow-node-value{font-size:.9rem}.flow-node-label{font-size:.65rem}.schedule-list{gap:.5rem}.schedule-item{padding:.75rem;gap:.375rem .5rem}.schedule-time{font-size:.75rem}.pill{font-size:.75rem;padding:.375rem .75rem}.chart-header{gap:.75rem}.chart-header-controls{gap:.625rem;flex-direction:column;align-items:flex-start}.chart-filters{gap:.375rem;width:auto;flex-wrap:wrap}.chart-filter{font-size:.75rem;padding:.5rem .75rem;border-radius:8px;min-height:38px;flex:0 0 auto;justify-content:center}.chart-filter .dot{width:8px;height:8px}.chart-container{height:180px;margin-top:.375rem}.period-dropdown-trigger{min-height:40px;padding:.5rem .875rem}.calendar-tab{min-height:40px;padding:.5rem}.calendar-nav-btn{min-width:40px;min-height:40px}.calendar-year,.calendar-month{min-height:40px}.calendar-day{min-height:38px}.mode-tab{min-height:40px;padding:.5rem .75rem}.schedule-item,.device-item{min-height:56px}.notification-item{min-height:52px}.header-controls{gap:.375rem}.icon-button{width:34px;height:34px;font-size:.95rem}.link-muted{font-size:.75rem;margin-top:.625rem}}@media (max-width: 360px){.app-shell{padding:.875rem;border-radius:14px}.brand-icon{width:36px;height:36px;font-size:.85rem}.brand-text-title{font-size:1rem}.card-main-value{font-size:1.5rem}.chart-header{gap:.625rem}.chart-header-controls{gap:.5rem}.chart-container{height:160px}.chart-filters{gap:.25rem}.chart-filter{font-size:.7rem;padding:.45rem .5rem;min-height:38px}.chart-filter .dot{width:7px;height:7px}.period-dropdown-trigger{min-height:38px;padding:.45rem .75rem;font-size:.8rem}.period-dropdown-trigger .period-icon{font-size:.9rem}.calendar-tab{min-height:38px}.calendar-nav-btn{min-width:38px;min-height:38px}.calendar-year,.calendar-month{min-height:38px}.calendar-day{min-height:36px}.mode-tab{min-height:38px;padding:.45rem .625rem;font-size:.75rem}.nav-dropdown-trigger{padding:.625rem .875rem}.nav-current-icon{width:28px;height:28px;font-size:.9rem}.nav-current-label{font-size:.85rem}.card{padding:.75rem;border-radius:10px}.card-title{font-size:.6rem}.card-main-value{font-size:1.35rem}.card-main-unit{font-size:.7rem}.card-meta span{font-size:.65rem}.badge{font-size:.55rem;padding:.15rem .4rem}.device-item{padding:.625rem}.device-name{font-size:.75rem}.device-status{font-size:.62rem}.flow-grid{grid-template-columns:1fr 1fr;gap:.375rem}.flow-node{padding:.5rem}.flow-node-value{font-size:.85rem}.flow-node-label{font-size:.55rem}.modal-stat-value{font-size:1rem}.pill{font-size:.7rem;padding:.3rem .6rem}}@media (hover: none) and (pointer: coarse){.card:hover,.flow-node:hover,.device-item:hover,.notification-item:hover,.schedule-item:hover{transform:none;box-shadow:inherit}.card:active,.flow-node:active,.device-item:active,.schedule-item:active{transform:scale(.98);transition:transform .1s ease}.pill,.mode-tab,.nav-dropdown-trigger,.period-dropdown-trigger,.calendar-tab,.calendar-nav-btn,.calendar-today-btn,.settings-tab{min-height:44px;display:inline-flex;align-items:center;justify-content:center}.link-muted{min-height:36px;display:inline-flex;align-items:center}.chart-filter{min-height:40px;display:flex;align-items:center;justify-content:center}.nav-dropdown-item{min-height:48px;display:flex;align-items:center;justify-content:flex-start}.calendar-year,.calendar-month{min-height:44px;display:flex;align-items:center;justify-content:center}.calendar-day{min-height:40px;min-width:40px}.calendar-week-row{min-height:44px}.toggle{position:relative;min-width:50px;min-height:28px}.toggle:after{content:"";position:absolute;top:-10px;left:-6px;right:-6px;bottom:-10px}.icon-button{min-width:44px;min-height:44px}button,[role=button],.btn{min-height:44px}.schedule-item{min-height:60px;padding:.875rem 1rem}.schedule-action{min-height:32px;padding:.375rem .75rem}.device-item{min-height:60px;padding:1rem}.notification-item{min-height:56px;padding:.75rem}.flow-node{min-height:70px;padding:.75rem}.battery-card{min-height:100px}a,.link-muted{min-height:44px;display:inline-flex;align-items:center}.select{min-height:44px}.config-toggle-row{min-height:52px;padding:.75rem 0}input,select,textarea{min-height:44px;font-size:16px}}@media (max-height: 500px) and (orientation: landscape){.chart-container{height:150px}.modal{max-height:95vh;margin:.5rem}.app-shell{padding:.75rem}}@media (prefers-color-scheme: dark){.card{box-shadow:0 8px 20px #000c}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media print{body{background:#fff;color:#000}.app-shell{box-shadow:none;border:1px solid #ccc}.icon-button,.toggle,.notification-dropdown-wrapper{display:none}}
