/* ═══════════════════════════════════════════════════════════
   Domotica Casa — Echo Hub Style
   ═══════════════════════════════════════════════════════════ */

/* ── Theme: Dark (default) ────────────────────────────── */
:root {
  --bg: #0f0f1a;
  --bg2: #161628;
  --surface: #1a1a2e;
  --surface-h: #22223a;
  --surface-border: #2a2a45;
  --input-bg: #252540;
  --accent: #4fc3f7;
  --accent-h: #39b0e5;
  --accent-soft: rgba(79,195,247,.12);
  --tile-on: #2a6a8a;
  --tile-on-text: #fff;
  --text: #eaeaea;
  --text2: #999;
  --text3: #555;
  --ok: #66bb6a;
  --err: #e57373;
  --warn: #ffa726;
  --shadow: 0 2px 8px rgba(0,0,0,.3);
  --shadow-sm: 0 1px 4px rgba(0,0,0,.2);
  --r: 16px;
  --r-lg: 20px;
  --r-pill: 24px;
  --nav-h: 52px;
  --status-h: 48px;
  --sidebar-w: 200px;
  --hub-widgets-w: minmax(320px, min(420px, 30vw));
  --hub-cam-w: minmax(300px, min(580px, 34vw));
  --safe: env(safe-area-inset-bottom, 0px);
  color-scheme: dark;
}

/* ── Theme: Light ─────────────────────────────────────── */
[data-theme="light"] {
  --bg: #f0f0f5;
  --bg2: #e8e8ed;
  --surface: #ffffff;
  --surface-h: #f5f5fa;
  --surface-border: #e0e0e5;
  --input-bg: #f0f0f5;
  --accent: #4aadcf;
  --accent-h: #3a9bbf;
  --accent-soft: rgba(74,173,207,.12);
  --tile-on: #4db8d5;
  --tile-on-text: #fff;
  --text: #2c2c2e;
  --text2: #8e8e93;
  --text3: #c7c7cc;
  --ok: #34c759;
  --err: #ff3b30;
  --warn: #ff9500;
  --shadow: 0 2px 8px rgba(0,0,0,.08);
  --shadow-sm: 0 1px 4px rgba(0,0,0,.05);
  color-scheme: light;
}

/* ── Reset ────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{height:100%;overflow:hidden}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--text);
  height:100%;
  max-height:100%;
  overflow:hidden;
  -webkit-font-smoothing:antialiased;user-select:none;
  overscroll-behavior:none;
}
#app{
  height:100dvh;
  max-height:100dvh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
/* ═══════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════ */
.hdr{
  flex-shrink:0;
  padding:8px 14px;position:relative;z-index:50;
  background:var(--bg);display:flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--surface-border);
}
.hdr-time{font-size:14px;color:var(--text2);font-weight:500;min-width:44px}
.hdr h1{font-size:18px;font-weight:700;flex:1}
.hdr-user{
  display:flex;align-items:center;gap:6px;
  background:var(--surface);border-radius:var(--r-pill);
  padding:4px 14px 4px 8px;margin-left:auto;
  border:1px solid var(--surface-border);
}
.hdr-avatar{font-size:18px;line-height:1}
.hdr-uname{font-size:12px;font-weight:600;color:var(--text2);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hdr-btn{
  background:var(--surface);border:none;color:var(--text2);
  width:36px;height:36px;border-radius:50%;font-size:16px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:.15s;
}
.hdr-btn:hover{background:var(--surface-h)}
.hdr-btn:active{transform:scale(.9)}

/* ═══════════════════════════════════════════════════════════
   HUB LAYOUT (mobile flex; desktop 4 colonne)
   ═══════════════════════════════════════════════════════════ */
.hub{
  flex:1 1 0;
  min-height:0;
  display:flex;
  overflow:hidden;
}
.hub-sidebar{display:none}
.hub-widgets-col{display:none}
.hub-main{
  flex:1;
  min-width:0;
  min-height:0;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
  overflow-y:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  padding:8px 10px;
  padding-bottom:calc(var(--nav-h) + var(--safe) + 10px);
}
.hub-cameras{display:none}
.mobile-cam-panel{
  flex:1;
  min-height:0;
  overflow-y:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:8px 10px;
  padding-bottom:calc(var(--nav-h) + var(--safe) + 10px);
}

/* ═══════════════════════════════════════════════════════════
   ROOM CHIPS (mobile) / SIDEBAR (desktop)
   ═══════════════════════════════════════════════════════════ */
.room-chips{
  flex-shrink:0;
  display:flex;gap:6px;padding:0 0 8px;
  overflow-x:auto;scrollbar-width:none;
}
.room-chips::-webkit-scrollbar{display:none}
.room-chip{
  background:var(--surface);border:1.5px solid var(--surface-border);
  border-radius:var(--r-pill);padding:8px 18px;
  font-size:13px;font-weight:600;color:var(--text2);
  white-space:nowrap;cursor:pointer;transition:.15s;
  font-family:inherit;
}
.room-chip:active{transform:scale(.95)}
.room-chip.on{
  background:var(--accent-soft);border-color:var(--accent);
  color:var(--accent);
}

.sidebar-list{list-style:none;padding:16px 0}
.sidebar-item{
  display:block;width:100%;text-align:left;
  background:none;border:none;color:var(--text2);
  font-size:14px;font-weight:500;padding:10px 24px;
  cursor:pointer;transition:.15s;font-family:inherit;
  border-left:3px solid transparent;
}
.sidebar-item:hover{color:var(--text);background:var(--accent-soft)}
.sidebar-item.on{
  color:var(--text);font-weight:700;
  border-left-color:var(--accent);
}

/* ═══════════════════════════════════════════════════════════
   TILE GRID + TILES
   ═══════════════════════════════════════════════════════════ */
.tile-section-title{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--text2);padding:4px 0 6px;
}
.tile-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(128px,1fr));
  gap:8px;margin-bottom:10px;
}
.tile{
  background:var(--surface);border-radius:var(--r);
  padding:10px 12px;cursor:pointer;transition:.2s;
  display:flex;flex-direction:column;
  min-height:110px;position:relative;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--surface-border);
}
.tile:active{transform:scale(.96)}
.tile.is-on{
  background:var(--tile-on);border-color:transparent;
  box-shadow:var(--shadow);
}
.tile.is-on .tile-name,
.tile.is-on .tile-status,
.tile.is-on .tile-icon{color:var(--tile-on-text)}
.tile.is-offline{opacity:.45}

.tile-name{font-size:13px;font-weight:600;line-height:1.3;margin-bottom:2px}
.tile-status{font-size:11px;color:var(--text2);font-weight:400}
.tile.is-on .tile-status{color:rgba(255,255,255,.75)}

.tile-icon{
  font-size:36px;margin-top:auto;align-self:center;
  line-height:1;
}
.tile-extra{font-size:11px;color:var(--accent);margin-top:4px;font-weight:500}
.tile.is-on .tile-extra{color:rgba(255,255,255,.85)}

.tile-toggle{
  position:absolute;bottom:10px;right:10px;
  width:40px;height:22px;
}
.tile-toggle input{display:none}
.tile-toggle .tt-tr{
  position:absolute;inset:0;background:var(--text3);
  border-radius:11px;cursor:pointer;transition:.25s;
}
.tile-toggle input:checked+.tt-tr{background:var(--accent)}
.tile.is-on .tile-toggle .tt-tr{background:rgba(255,255,255,.35)}
.tile.is-on .tile-toggle input:checked+.tt-tr{background:rgba(255,255,255,.7)}
.tile-toggle .tt-th{
  position:absolute;top:2px;left:2px;width:18px;height:18px;
  background:#fff;border-radius:50%;transition:.25s;pointer-events:none;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.tile-toggle input:checked~.tt-th{transform:translateX(18px)}

/* ═══════════════════════════════════════════════════════════
   CAMERA PANEL
   ═══════════════════════════════════════════════════════════ */
.cam-section-title{
  font-size:14px;font-weight:700;padding:0 0 8px;
  flex-shrink:0;
}

/* Orologio + radar (colonna centrale desktop; sopra le cam su mobile) */
.hub-widgets-wrap{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-bottom:4px;
  flex-shrink:0;
}
.hub-widget{
  background:var(--surface);
  border-radius:var(--r);
  border:1px solid var(--surface-border);
  padding:16px 18px;
  box-shadow:var(--shadow-sm);
}
.hw-lbl{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text2);margin-bottom:10px;
}
.hub-widget-clock .hw-clock-time{
  font-size:clamp(36px,5.5vw,52px);font-weight:200;
  letter-spacing:.06em;line-height:1;font-variant-numeric:tabular-nums;
}
.hub-widget-clock .hw-clock-date{
  font-size:14px;color:var(--text2);margin-top:10px;text-transform:capitalize;
}
.hub-widget-clock .hw-clock-place{
  font-size:12px;color:var(--accent);margin-top:10px;line-height:1.35;min-height:2.6em;
}
.hw-radar-frame-wrap{
  position:relative;width:100%;
  aspect-ratio:4/3;
  min-height:240px;max-height:min(50vh,520px);
  border-radius:12px;overflow:hidden;background:var(--bg2);
}
#radar-host{
  position:fixed;
  pointer-events:auto;
  z-index:1;
  border-radius:12px;
  overflow:hidden;
  display:none;
}
#radar-host iframe{
  width:100%;height:100%;border:0;display:block;
}
.hw-radar-link{
  font-size:11px;color:var(--accent);margin-top:8px;
  display:inline-block;text-decoration:none;font-weight:600;
}
.hw-radar-link:hover{text-decoration:underline}

.cam-card{
  background:var(--surface);border-radius:var(--r);
  overflow:hidden;margin-bottom:8px;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--surface-border);
}
/* Un solo “viewport” 16:9 per tutte le cam (live, privacy, offline): stessa altezza/larghezza. */
.cam-img-wrap{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  max-height:min(36vh,340px);
  margin:0 auto;
  background:var(--bg2);
}
.cam-img-wrap > .cam-err,
.cam-img-wrap > .cam-media{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  max-height:none;
  aspect-ratio:unset;
  box-sizing:border-box;
}
.cam-img-wrap > .cam-err{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:var(--text3);
  font-size:13px;
  gap:6px;
}
.cam-img{
  width:100%;height:100%;object-fit:cover;background:var(--bg2);
  display:block;max-height:none;aspect-ratio:unset;
}
.cam-label{
  position:absolute;bottom:0;left:0;right:0;
  padding:22px 14px 10px;
  background:linear-gradient(transparent,rgba(0,0,0,.55));
  color:#fff;font-size:13px;font-weight:600;
  pointer-events:none;
}
.cam-refresh{
  position:absolute;top:8px;right:8px;
  background:rgba(0,0,0,.4);border:none;color:#fff;
  width:28px;height:28px;border-radius:50%;font-size:14px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.cam-refresh:active{transform:scale(.9)}
.cam-media{position:absolute;inset:0;width:100%;height:100%}
.cam-img-wrap .cam-media .cam-err{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:var(--text3);
  font-size:13px;
  gap:6px;
  background:var(--bg2);
}
.cam-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  background:#000;
  display:block;
  max-height:none;
  aspect-ratio:unset;
}
.cam-priv-btn{
  position:absolute;top:8px;left:8px;
  background:rgba(0,0,0,.4);border:none;color:#fff;
  width:28px;height:28px;border-radius:50%;font-size:14px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.cam-priv-btn:active{transform:scale(.9)}
.cam-priv-btn.cam-priv-on{background:rgba(229,115,115,.7)}
.cam-play-btn{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:rgba(0,0,0,.5);border:none;color:#fff;
  width:40px;height:40px;border-radius:50%;font-size:18px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.cam-play-btn:hover{background:rgba(78,130,255,.7)}
.cam-play-btn:active{transform:translate(-50%,-50%) scale(.9)}
/* Durante la live il pulsante play/stop resta nascosto (niente icona stop al centro) */
.cam-play-btn.cam-play-active{
  opacity:0;visibility:hidden;pointer-events:none;
}

/* ═══════════════════════════════════════════════════════════
   MOBILE CAMERA LIST
   ═══════════════════════════════════════════════════════════ */
.mcam-list{
  display:flex;flex-direction:column;gap:6px;
}
.mcam-row{
  display:flex;align-items:center;gap:12px;
  background:var(--surface);border:1px solid var(--surface-border);
  border-radius:var(--r);padding:14px 16px;
  cursor:pointer;width:100%;text-align:left;
  font-family:inherit;font-size:inherit;color:var(--text);
  transition:background .15s;
  -webkit-tap-highlight-color:transparent;
}
.mcam-row:active{background:var(--surface-h);transform:scale(.98)}
.mcam-row.mcam-disabled{opacity:.55}
.mcam-icon{font-size:24px;flex-shrink:0}
.mcam-info{
  display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;
}
.mcam-name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mcam-status{font-size:11px;color:var(--text2);display:flex;align-items:center;gap:5px}
.mcam-priv{
  background:var(--surface-h);border:1px solid var(--surface-border);
  color:var(--text);width:34px;height:34px;border-radius:50%;
  font-size:16px;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.mcam-priv:active{transform:scale(.9)}
.mcam-priv.mcam-priv-on{background:rgba(229,115,115,.2);border-color:var(--err)}
.mcam-arrow{font-size:20px;color:var(--text3);flex-shrink:0;font-weight:300}

/* ═══════════════════════════════════════════════════════════
   CAMERA FULLSCREEN OVERLAY
   ═══════════════════════════════════════════════════════════ */
.cam-fs-overlay{
  position:fixed;inset:0;z-index:250;
  background:#000;
  display:flex;flex-direction:column;
  animation:fi .2s;
}
.cam-fs-header{
  display:flex;align-items:center;gap:12px;
  padding:calc(env(safe-area-inset-top,12px) + 8px) 16px 10px;
  background:rgba(0,0,0,.6);
  flex-shrink:0;z-index:1;
}
.cam-fs-close{
  background:none;border:none;color:#fff;font-size:22px;
  width:36px;height:36px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.cam-fs-close:active{opacity:.6}
.cam-fs-title{flex:1;color:#fff;font-size:16px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cam-fs-refresh{
  background:none;border:none;color:#fff;font-size:18px;
  width:36px;height:36px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.cam-fs-refresh:active{opacity:.6}
.cam-fs-body{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  position:relative;min-height:0;
}
.cam-fs-body .cam-media{
  position:relative;width:100%;height:100%;
}
.cam-fs-body .cam-img{
  width:100%;height:100%;object-fit:contain;background:#000;display:block;
}
.cam-fs-body .cam-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:contain;background:#000;
}
.cam-fs-body .cam-err{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);font-size:14px;background:#000;
}
.cam-fs-play{
  position:absolute;bottom:calc(env(safe-area-inset-bottom,0px) + 20px);
  left:50%;transform:translateX(-50%);
  background:rgba(255,255,255,.15);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);color:#fff;
  padding:10px 28px;border-radius:var(--r-pill);
  font-size:14px;font-weight:600;cursor:pointer;
  font-family:inherit;
}
.cam-fs-play:active{transform:translateX(-50%) scale(.95)}
.cam-fs-play.cam-play-active{opacity:0;visibility:hidden;pointer-events:none}

/* ═══════════════════════════════════════════════════════════
   STATUS BAR
   ═══════════════════════════════════════════════════════════ */
.status-bar{
  display:flex;gap:6px;padding:8px 0;
  overflow-x:auto;scrollbar-width:none;
  border-top:1px solid var(--surface-border);
  margin-top:auto;
  flex-shrink:0;
}
.status-bar::-webkit-scrollbar{display:none}
.status-pill{
  display:flex;align-items:center;gap:8px;
  background:var(--surface);border-radius:var(--r-pill);
  padding:8px 16px;white-space:nowrap;flex-shrink:0;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--surface-border);
  cursor:pointer;transition:.15s;
}
.status-pill:active{transform:scale(.97)}
.sp-icon{font-size:18px;line-height:1}
.sp-text{display:flex;flex-direction:column}
.sp-label{font-size:11px;font-weight:600;color:var(--text)}
.sp-value{font-size:10px;color:var(--text2)}

/* ═══════════════════════════════════════════════════════════
   BOTTOM NAV
   ═══════════════════════════════════════════════════════════ */
.nav{
  position:fixed;bottom:0;left:0;right:0;
  height:calc(var(--nav-h) + var(--safe));padding-bottom:var(--safe);
  background:var(--bg);border-top:1px solid var(--surface-border);
  display:flex;z-index:100;
}
.nav-i{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:2px;color:var(--text3);
  font-size:10px;font-weight:600;cursor:pointer;
  border:none;background:none;-webkit-tap-highlight-color:transparent;transition:.15s;
  font-family:inherit;
}
.nav-i .ni{font-size:22px;line-height:1}
.nav-i.on{color:var(--accent)}
.nav-i:active{transform:scale(.92)}

/* ═══════════════════════════════════════════════════════════
   FULL-WIDTH PAGE (scenes, settings)
   ═══════════════════════════════════════════════════════════ */
.page-single{
  flex:1 1 0;
  min-height:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.page-single-inner{
  flex:1;
  min-height:0;
  overflow-x:hidden;
  overflow-y:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  padding:10px 12px;
  padding-bottom:calc(var(--nav-h) + var(--safe) + 10px);
}
.page-single--settings .page-set-add{
  font-size:15px;
  padding:12px 16px;
  margin-bottom:10px;
}
.page-single--settings .stitle{
  padding:6px 0 6px;
}
.page-single--settings .page-set-users-title{
  margin-top:14px;
}
/* Griglia dispositivi (Impostazioni): riquadri quadrati */
.set-dev-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(118px,1fr));
  gap:8px;
  margin-bottom:8px;
}
.set-dev-tile{
  background:var(--surface);
  border-radius:var(--r);
  border:1px solid var(--surface-border);
  box-shadow:var(--shadow-sm);
  padding:8px 6px 6px;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  min-width:0;
  width:100%;
  aspect-ratio:1;
  transition:.15s;
}
.set-dev-tile:active{transform:scale(.97)}
.set-dev-tile-icon{
  font-size:36px;
  line-height:1;
  width:56px;
  height:56px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--accent-soft);
  flex-shrink:0;
}
.set-dev-tile-name{
  font-size:12px;
  font-weight:600;
  line-height:1.25;
  margin-top:6px;
  width:100%;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  word-break:break-word;
}
.set-dev-tile-sub{
  font-size:9px;
  color:var(--text2);
  line-height:1.2;
  margin-top:4px;
  width:100%;
  flex:1;
  min-height:0;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  word-break:break-word;
}
.set-dev-tile-actions{
  display:flex;
  gap:4px;
  justify-content:center;
  align-items:center;
  margin-top:auto;
  padding-top:6px;
  flex-shrink:0;
}
.set-dev-tile .set-dev-tile-btn{
  width:32px;
  height:32px;
  font-size:14px;
}
.page-single--settings .dcard{
  padding:12px;
  margin-bottom:8px;
}
.page-single--settings .dcard-icon{
  font-size:30px;
  width:48px;
  height:48px;
}
.page-single--settings .page-set-footer{
  padding:12px 0 6px;
  text-align:center;
}
.set-loc-hint{
  font-size:13px;
  color:var(--text2);
  line-height:1.45;
  margin:0 0 12px;
}
.set-loc-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.set-loc-row .inp{
  flex:1;
  min-width:120px;
}
.set-loc-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:20px;
}
.page-single--settings .empty{
  padding:28px 16px;
}
.auto-intro{
  font-size:13px;
  color:var(--text2);
  line-height:1.45;
  margin-bottom:14px;
}
.stitle{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--text2);padding:16px 0 10px;
}

/* ═══════════════════════════════════════════════════════════
   DEVICE CARDS (settings list, scenes)
   ═══════════════════════════════════════════════════════════ */
.dcard{
  background:var(--surface);border-radius:var(--r);
  padding:16px;margin-bottom:10px;transition:.15s;
  border:1px solid var(--surface-border);
}
.dcard:active{transform:scale(.98)}
.dcard-top{display:flex;align-items:center;gap:12px}
.dcard-icon{
  font-size:36px;width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border-radius:12px;flex-shrink:0;
}
.dcard-info{flex:1;min-width:0}
.dcard-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dcard-sub{font-size:12px;color:var(--text2);margin-top:2px}

/* ═══════════════════════════════════════════════════════════
   BIG TOGGLE (modal)
   ═══════════════════════════════════════════════════════════ */
.tgl{position:relative;width:52px;height:28px;flex-shrink:0}
.tgl input{display:none}
.tgl-tr{position:absolute;inset:0;background:var(--text3);border-radius:14px;cursor:pointer;transition:.25s}
.tgl input:checked+.tgl-tr{background:var(--accent)}
.tgl-th{position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:.25s;pointer-events:none;box-shadow:0 2px 4px rgba(0,0,0,.2)}
.tgl input:checked~.tgl-th{transform:translateX(24px)}

/* ═══════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:var(--r);border:none;
  font-size:15px;font-weight:700;cursor:pointer;transition:.15s;
  -webkit-tap-highlight-color:transparent;font-family:inherit;
}
.btn:active{transform:scale(.96)}
.btn-p{background:var(--accent);color:#fff}
[data-theme="light"] .btn-p{color:#fff}
.btn-p:disabled{opacity:.4;cursor:not-allowed}
.btn-d{background:rgba(229,115,115,.12);color:var(--err)}
.btn-g{background:transparent;color:var(--text2);padding:10px 14px;font-size:13px}
.btn-w{width:100%}
.btn-s{padding:10px 16px;font-size:13px}
.btn-icon{
  background:var(--surface);border:none;color:var(--text2);
  width:36px;height:36px;border-radius:50%;font-size:16px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.btn-icon:active{transform:scale(.9)}
.btn-active{background:var(--accent)!important;color:#fff!important;font-weight:600}

/* ═══════════════════════════════════════════════════════════
   INPUTS
   ═══════════════════════════════════════════════════════════ */
.inp{
  width:100%;background:var(--input-bg);border:2px solid var(--surface-border);
  color:var(--text);border-radius:var(--r);padding:14px 16px;
  font-size:15px;outline:none;transition:.2s;font-family:inherit;
}
.inp:focus{border-color:var(--accent)}
.inp::placeholder{color:var(--text3)}
.lbl{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px}
.fg{margin-bottom:14px}

/* ═══════════════════════════════════════════════════════════
   WIZARD
   ═══════════════════════════════════════════════════════════ */
.wiz-title{font-size:18px;font-weight:700;text-align:center;margin-bottom:6px}
.wiz-sub{text-align:center;color:var(--text2);font-size:13px;margin-bottom:24px}
.wiz-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}
.wiz-opt{
  background:var(--surface);border:2px solid var(--surface-border);border-radius:var(--r);
  padding:18px 10px;text-align:center;cursor:pointer;transition:.15s;
}
.wiz-opt:active{transform:scale(.96)}
.wiz-opt.on{border-color:var(--accent);background:var(--accent-soft)}
.wiz-opt .wo-icon{font-size:32px;margin-bottom:6px}
.wiz-opt .wo-name{font-size:13px;font-weight:600}

/* ═══════════════════════════════════════════════════════════
   MODAL
   ═══════════════════════════════════════════════════════════ */
.mdl-bg{
  position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;
  display:flex;align-items:flex-end;justify-content:center;animation:fi .2s;
}
.mdl{
  background:var(--bg);border-radius:var(--r-lg) var(--r-lg) 0 0;
  width:100%;max-width:480px;max-height:85dvh;overflow-y:auto;
  padding:20px;padding-bottom:calc(20px + var(--safe));
  animation:su .3s ease-out;
  border:1px solid var(--surface-border);
  -webkit-overflow-scrolling:touch;overscroll-behavior:contain;
}
.mdl-bar{width:40px;height:4px;background:var(--text3);border-radius:2px;margin:0 auto 16px}
.scene-edit-mdl{max-height:88vh;overflow-y:auto;overscroll-behavior:contain}
.scene-act-list{max-height:min(52vh,420px);overflow-y:auto;overscroll-behavior:contain;margin-bottom:8px}
.scene-act-row{
  border:1px solid var(--surface-border);
  border-radius:var(--r);
  padding:10px 12px;
  margin-bottom:8px;
  background:var(--surface);
  display:flex;
  flex-direction:column;
  gap:0;
}
.scene-act-row .lbl{margin-top:8px;margin-bottom:4px;font-size:11px}
.scene-act-row .lbl:first-of-type{margin-top:0}
.scene-act-rm{margin-top:10px;align-self:flex-start}
.mdl-t{font-size:20px;font-weight:700;text-align:center;margin-bottom:4px}
.mdl-st{text-align:center;color:var(--text2);font-size:12px;margin-bottom:20px}
.mdl-sec{margin-bottom:20px}
.mdl-sl{font-size:12px;color:var(--text2);margin-bottom:8px}

/* ═══════════════════════════════════════════════════════════
   THERMOSTAT
   ═══════════════════════════════════════════════════════════ */
.thermo{text-align:center;padding:16px 0}
.thermo-power{display:flex;align-items:center;padding:12px 0;margin-bottom:12px;border-bottom:1px solid var(--surface-border)}
.thermo-now{font-size:56px;font-weight:200}
.thermo-lbl{font-size:12px;color:var(--text2);margin-top:2px}
.thermo-tgt{display:flex;align-items:center;justify-content:center;gap:28px;margin-top:24px}
.thermo-v{font-size:36px;font-weight:300;color:var(--accent);min-width:70px;text-align:center}
.thermo-b{
  width:48px;height:48px;border-radius:50%;background:var(--surface);
  border:1px solid var(--surface-border);
  color:var(--text);font-size:24px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.thermo-b:active{transform:scale(.9)}
.thermo-modes{margin-top:20px;padding-top:16px;border-top:1px solid var(--surface-border);text-align:center}
.thermo-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.thermo-mode-grid .btn{font-size:13px;padding:10px 8px}

/* ═══════════════════════════════════════════════════════════
   ALARM
   ═══════════════════════════════════════════════════════════ */
.alarm{
  text-align:center;padding:24px 0;position:relative;
  transition:background .35s ease;
}
.alarm-visual{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:128px;height:128px;margin:0 auto;
  border-radius:50%;
  border:3px solid var(--surface-border);
  background:linear-gradient(160deg,var(--bg2) 0%,var(--surface) 100%);
  box-sizing:border-box;
  box-shadow:0 4px 18px rgba(0,0,0,.12);
}
.alarm-glow{
  position:absolute;inset:6px;border-radius:50%;
  opacity:.45;pointer-events:none;
  transition:box-shadow .4s ease,transform .4s ease,opacity .4s ease;
}
.alarm-ico{
  position:relative;font-size:64px;line-height:1;z-index:1;
  transform-origin:center center;
  filter:drop-shadow(0 2px 3px rgba(0,0,0,.2));
}
html[data-theme="light"] .alarm-ico{
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.25));
}
.alarm-st{font-size:20px;font-weight:700;margin-top:12px}
.alarm-warn{color:var(--err);font-size:16px;font-weight:700;margin-top:8px}
.alarm-modes{display:flex;flex-direction:column;gap:8px;margin-top:16px}

/* — Modal: animazioni per stato (cerchio + alone ben visibile anche in tema chiaro) — */
.alarm--disarmed .alarm-visual{
  animation:alarm-frame-disarmed 2.8s ease-in-out infinite;
}
.alarm--disarmed .alarm-glow{
  background:radial-gradient(circle,rgba(120,130,150,.2) 0%,transparent 72%);
  animation:alarm-glow-rest 2.8s ease-in-out infinite;
}
.alarm--disarmed .alarm-ico{animation:alarm-ico-breathe 2.8s ease-in-out infinite}

.alarm--home .alarm-visual{
  border-color:rgba(230,160,40,.55);
  animation:alarm-frame-home 2.4s ease-in-out infinite;
}
.alarm--home .alarm-glow{
  background:radial-gradient(circle,rgba(245,180,50,.4) 0%,transparent 70%);
  animation:alarm-glow-home 2.4s ease-in-out infinite;
}
.alarm--home .alarm-ico{animation:alarm-ico-nudge 2.4s ease-in-out infinite}

.alarm--away .alarm-visual{
  border-color:rgba(60,170,100,.55);
  animation:alarm-frame-away 2s ease-in-out infinite;
}
.alarm--away .alarm-glow{
  background:radial-gradient(circle,rgba(80,200,120,.42) 0%,transparent 68%);
  animation:alarm-glow-away 2s ease-in-out infinite;
}
.alarm--away .alarm-ico{animation:alarm-ico-secure 2s ease-in-out infinite}

.alarm--triggered .alarm-visual{
  border-color:rgba(220,50,50,.75);
  animation:alarm-frame-siren .5s ease-in-out infinite;
}
.alarm--triggered{
  animation:alarm-bg-pulse .6s ease-in-out infinite;
}
.alarm--triggered .alarm-glow{
  background:radial-gradient(circle,rgba(255,60,60,.55) 0%,transparent 65%);
  animation:alarm-glow-siren .45s ease-in-out infinite;
  opacity:.75;
}
.alarm--triggered .alarm-ico{animation:alarm-ico-shake .5s ease-in-out infinite}
.alarm--triggered .alarm-warn{animation:alarm-warn-blink .6s step-end infinite}

@keyframes alarm-frame-disarmed{
  0%,100%{transform:scale(1);box-shadow:0 4px 18px rgba(0,0,0,.12);border-color:var(--surface-border)}
  50%{transform:scale(1.04);box-shadow:0 6px 28px rgba(0,0,0,.18);border-color:var(--text3)}
}
@keyframes alarm-frame-home{
  0%,100%{transform:scale(1);box-shadow:0 4px 20px rgba(230,160,40,.2)}
  50%{transform:scale(1.05);box-shadow:0 8px 32px rgba(230,160,40,.35)}
}
@keyframes alarm-frame-away{
  0%,100%{transform:scale(1);box-shadow:0 4px 20px rgba(60,170,100,.22)}
  50%{transform:scale(1.06);box-shadow:0 8px 36px rgba(60,170,100,.38)}
}
@keyframes alarm-frame-siren{
  0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(255,60,60,.4)}
  50%{transform:scale(1.05);box-shadow:0 0 28px 8px rgba(255,60,60,.45)}
}
@keyframes alarm-glow-rest{
  0%,100%{opacity:.35;transform:scale(1)}
  50%{opacity:.6;transform:scale(1.08)}
}
@keyframes alarm-ico-breathe{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.12)}
}
@keyframes alarm-glow-home{
  0%,100%{transform:scale(1);opacity:.35}
  50%{transform:scale(1.12);opacity:.55}
}
@keyframes alarm-ico-nudge{
  0%,100%{transform:scale(1) rotate(0deg)}
  40%{transform:scale(1.06) rotate(-2deg)}
  60%{transform:scale(1.06) rotate(2deg)}
}
@keyframes alarm-glow-away{
  0%,100%{box-shadow:0 0 0 0 rgba(80,200,120,.35);transform:scale(1)}
  50%{box-shadow:0 0 28px 10px rgba(80,200,120,.2);transform:scale(1.08)}
}
@keyframes alarm-ico-secure{
  0%,100%{transform:scale(1)}
  25%{transform:scale(1.05)}
  50%{transform:scale(1)}
  75%{transform:scale(1.04)}
}
@keyframes alarm-bg-pulse{
  0%,100%{background-color:transparent}
  50%{background-color:rgba(255,60,60,.06)}
}
@keyframes alarm-glow-siren{
  0%,100%{transform:scale(1);opacity:.5}
  50%{transform:scale(1.18);opacity:.85}
}
@keyframes alarm-ico-shake{
  0%,100%{transform:translateX(0) rotate(0)}
  20%{transform:translateX(-4px) rotate(-4deg)}
  40%{transform:translateX(4px) rotate(4deg)}
  60%{transform:translateX(-3px) rotate(-3deg)}
  80%{transform:translateX(3px) rotate(3deg)}
}
@keyframes alarm-warn-blink{
  0%,100%{opacity:1}
  50%{opacity:.35}
}

/* — Tile dashboard — */
.tile-alarm .tile-icon{
  transition:transform .3s ease,filter .3s ease;
}
.tile-alarm--disarmed .tile-icon{
  animation:tile-alarm-soft 3.5s ease-in-out infinite;
  filter:grayscale(.2);
}
.tile-alarm--home .tile-icon{
  animation:tile-alarm-warm 2.5s ease-in-out infinite;
}
.tile-alarm--away .tile-icon{
  animation:tile-alarm-armed 2s ease-in-out infinite;
}
.tile-alarm--siren .tile-icon{
  animation:tile-alarm-siren .45s ease-in-out infinite;
  filter:drop-shadow(0 0 6px rgba(255,60,60,.9));
}
@keyframes tile-alarm-soft{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.06)}
}
@keyframes tile-alarm-warm{
  0%,100%{transform:scale(1) rotate(0)}
  50%{transform:scale(1.08) rotate(-3deg)}
}
@keyframes tile-alarm-armed{
  0%,100%{transform:scale(1)}
  40%{transform:scale(1.1)}
  60%{transform:scale(1.05)}
}
@keyframes tile-alarm-siren{
  0%,100%{transform:scale(1) rotate(0)}
  25%{transform:scale(1.12) rotate(-6deg)}
  75%{transform:scale(1.12) rotate(6deg)}
}

@media (prefers-reduced-motion:reduce){
  .alarm--disarmed .alarm-visual,.alarm--disarmed .alarm-glow,.alarm--disarmed .alarm-ico,
  .alarm--home .alarm-visual,.alarm--home .alarm-glow,.alarm--home .alarm-ico,
  .alarm--away .alarm-visual,.alarm--away .alarm-glow,.alarm--away .alarm-ico,
  .alarm--triggered,.alarm--triggered .alarm-visual,.alarm--triggered .alarm-glow,.alarm--triggered .alarm-ico,.alarm--triggered .alarm-warn,
  .tile-alarm--disarmed .tile-icon,.tile-alarm--home .tile-icon,.tile-alarm--away .tile-icon,.tile-alarm--siren .tile-icon{
    animation:none!important;
  }
  .alarm--triggered .alarm-warn{opacity:1}
}

/* ═══════════════════════════════════════════════════════════
   SLIDER
   ═══════════════════════════════════════════════════════════ */
.sld{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--surface-border);outline:none;margin:6px 0}
.sld::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:var(--accent);cursor:pointer;border:3px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.sld::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--accent);cursor:pointer;border:3px solid #fff}

/* ═══════════════════════════════════════════════════════════
   LOGIN
   ═══════════════════════════════════════════════════════════ */
.login{
  flex:1;
  min-height:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:32px;
  overflow-y:auto;
}
.login-box{width:100%;max-width:360px}
.login-logo{text-align:center;font-size:56px;margin-bottom:8px}
.login-h{text-align:center;font-size:24px;font-weight:700;margin-bottom:36px}
.login-sw{text-align:center;margin-top:20px;color:var(--text2);font-size:13px}
.login-sw a{color:var(--accent);cursor:pointer;text-decoration:none;font-weight:600}
.login-err{color:var(--err);text-align:center;margin-bottom:14px;font-size:13px;min-height:18px}

/* ═══════════════════════════════════════════════════════════
   MISC
   ═══════════════════════════════════════════════════════════ */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px}
.dot.on{background:var(--ok)}.dot.off{background:var(--err)}

.empty{text-align:center;padding:60px 20px;color:var(--text3)}
.empty-i{font-size:48px;margin-bottom:12px}
.empty-t{font-size:15px;color:var(--text2)}
.empty-h{font-size:12px;margin-top:6px}

.toast{
  position:fixed;bottom:calc(var(--nav-h) + var(--safe) + 12px);
  left:50%;transform:translateX(-50%);
  background:var(--surface);color:var(--text);
  padding:12px 24px;border-radius:var(--r);font-size:14px;font-weight:500;
  z-index:300;animation:fi .3s,fo .3s 2.7s;
  box-shadow:var(--shadow);border:1px solid var(--surface-border);
}

/* ═══════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════ */
@keyframes fi{from{opacity:0}to{opacity:1}}
@keyframes fo{from{opacity:1}to{opacity:0}}
@keyframes su{from{transform:translateY(100%)}to{transform:translateY(0)}}

/* ═══════════════════════════════════════════════════════════
   DESKTOP (>= 1024px)
   ═══════════════════════════════════════════════════════════ */
@media(min-width:1024px){
  .hub{
    display:grid;
    grid-template-columns:var(--sidebar-w) minmax(0,1fr) var(--hub-widgets-w) var(--hub-cam-w);
    align-items:stretch;
    min-height:0;
  }
  .hub-sidebar{
    display:flex;flex-direction:column;min-height:0;
    width:auto;min-width:0;
    border-right:1px solid var(--surface-border);
    overflow-y:auto;overflow-x:hidden;
    overscroll-behavior:contain;
    background:var(--bg);
    grid-column:1;grid-row:1;
  }
  .hub-main{
    grid-column:2;grid-row:1;
    min-width:0;
    padding-bottom:10px;
  }
  .hub-widgets-col{
    display:flex;
    flex-direction:column;
    min-height:0;
    grid-column:3;
    grid-row:1;
    border-left:1px solid var(--surface-border);
    overflow-y:auto;
    overflow-x:hidden;
    overscroll-behavior:contain;
    padding:10px 14px;
    background:var(--bg);
  }
  .hub-widgets-col .hub-widgets-wrap{
    flex:0 0 auto;
  }
  .hub-cameras{
    display:flex;flex-direction:column;min-height:0;
    width:auto;min-width:0;
    justify-self:stretch;
    grid-column:4;grid-row:1;
    border-left:1px solid var(--surface-border);
    overflow-y:auto;overflow-x:hidden;
    overscroll-behavior:contain;
    padding:10px 14px;background:var(--bg);
  }
  .room-chips{display:none}
  .nav.nav-dash{display:none}
  .tile-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .set-dev-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .mdl{border-radius:var(--r-lg);margin-bottom:40px}
  .mdl-bg{align-items:center}
  .toast{bottom:20px}
}

/* ═══════════════════════════════════════════════════════════
   TABLET (768–1023px)
   ═══════════════════════════════════════════════════════════ */
@media(min-width:768px) and (max-width:1023px){
  .tile-grid{grid-template-columns:repeat(auto-fill,minmax(158px,1fr))}
  .set-dev-grid{grid-template-columns:repeat(auto-fill,minmax(132px,1fr))}
  .mdl{border-radius:var(--r-lg);margin-bottom:40px}
  .mdl-bg{align-items:center}
}
