/* =========================================================
   Jeedom Dashboard — charte inspiree du Trading Dashboard
   Fond quasi noir, accents violet + vert, cartes translucides
   ========================================================= */
:root{
  --bg:#0a0b10; --bg2:#0e1018; --bg3:#11131d;
  --card:rgba(255,255,255,.035); --card-h:rgba(255,255,255,.06);
  --line:rgba(255,255,255,.07); --line2:rgba(255,255,255,.12);
  --violet:#8b5cf6; --violet-2:#a78bfa; --violet-dim:rgba(139,92,246,.15);
  --green:#34d399; --green-dim:rgba(52,211,153,.14);
  --red:#f0506e; --red-dim:rgba(240,80,110,.14);
  --amber:#fbbf24;
  --text:#e7e9ef; --muted:#8b90a3; --muted-2:#5c6175;
  --r:18px; --r-sm:12px;
  --font:'Manrope',system-ui,sans-serif; --display:'Sora',system-ui,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:var(--font); color:var(--text); background:var(--bg);
  background-image:
    radial-gradient(120% 60% at 50% -10%, rgba(139,92,246,.12), transparent 60%),
    radial-gradient(80% 50% at 100% 0%, rgba(52,211,153,.06), transparent 55%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom);
  overscroll-behavior:none;
}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
.hidden{display:none!important}

/* ---------- Login ---------- */
.login{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;
  align-items:center;gap:26px;padding:32px}
.login .logo{width:74px;height:74px;border-radius:20px;display:grid;place-items:center;
  background:linear-gradient(160deg,#1b1d2b,#0c0d15);border:1px solid var(--line2);
  box-shadow:0 0 40px rgba(139,92,246,.25)}
.login .logo svg{width:40px;height:40px}
.login h1{font-family:var(--display);font-weight:700;font-size:26px;margin:0;letter-spacing:.3px}
.login .sub{color:var(--muted);margin:6px 0 0;font-size:14px}
.card-form{width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:12.5px;color:var(--muted);font-weight:600;letter-spacing:.3px}
.input{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:13px 14px;color:var(--text);font-size:16px;transition:border-color .15s}
.input:focus{outline:none;border-color:var(--violet)}
.btn{border-radius:var(--r-sm);padding:13px 16px;font-weight:700;font-size:15px;
  transition:transform .08s,filter .15s}
.btn:active{transform:scale(.98)}
.btn-primary{background:linear-gradient(135deg,var(--violet),#6d4ad6);color:#fff;
  box-shadow:0 6px 20px rgba(139,92,246,.35)}
.btn-ghost{background:var(--card);border:1px solid var(--line);color:var(--text)}
.err{color:var(--red);font-size:13.5px;min-height:18px;text-align:center}

/* ---------- App shell ---------- */
.app{min-height:100dvh;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;
  padding:14px 18px;background:linear-gradient(180deg,rgba(10,11,16,.92),rgba(10,11,16,.6));
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.topbar .brand{font-family:var(--display);font-weight:700;font-size:19px;flex:1}
.topbar .brand small{display:block;font-family:var(--font);font-weight:500;font-size:11px;
  color:var(--muted-2);letter-spacing:.4px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;
  padding:6px 11px;border-radius:999px;border:1px solid var(--line2)}
.pill .dot{width:8px;height:8px;border-radius:50%}
.pill.live{color:var(--green);background:var(--green-dim);border-color:transparent}
.pill.live .dot{background:var(--green);box-shadow:0 0 8px var(--green)}
.pill.offline{color:var(--red);background:var(--red-dim);border-color:transparent}
.pill.offline .dot{background:var(--red)}
.iconbtn{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:var(--card);border:1px solid var(--line)}
.iconbtn svg{width:18px;height:18px;stroke:var(--muted)}

/* ---------- Tabs (pages) ---------- */
.tabs{position:sticky;top:64px;z-index:15;display:flex;gap:6px;overflow-x:auto;
  padding:10px 14px;background:rgba(10,11,16,.7);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{white-space:nowrap;font-size:14px;font-weight:600;color:var(--muted);
  padding:8px 14px;border-radius:999px;transition:color .15s,background .15s}
.tab.active{color:#fff;background:var(--violet-dim)}
.tab .badge{display:inline-block;min-width:18px;margin-left:6px;font-size:11px;
  background:var(--red);color:#fff;border-radius:999px;padding:1px 5px;font-weight:800}

/* ---------- Pages (swipe via scroll-snap) ---------- */
.pages{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;flex:1;
  scrollbar-width:none}
.pages::-webkit-scrollbar{display:none}
.page{min-width:100%;scroll-snap-align:start;padding:16px 14px 90px}
.page h2{font-family:var(--display);font-size:15px;color:var(--muted);font-weight:600;
  letter-spacing:.5px;text-transform:uppercase;margin:6px 4px 14px}
.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}

/* ---------- Dalle (carte equipement) avec accent par type ---------- */
.dalle{position:relative;border-radius:18px;padding:16px;display:flex;flex-direction:column;gap:12px;
  overflow:hidden;
  border:1px solid color-mix(in srgb, var(--acc,#64748b) 26%, var(--line));
  background:
    linear-gradient(155deg, color-mix(in srgb, var(--acc,#64748b) 14%, transparent),
                            color-mix(in srgb, var(--acc,#64748b) 3%, transparent)),
    var(--card);
  transition:transform .12s ease, box-shadow .2s ease, border-color .2s ease}
.dalle::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--acc,#64748b);opacity:.75}
.dalle:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,0,0,.38)}
.dalle.alert{border-color:var(--red);box-shadow:0 0 0 1px var(--red-dim),0 0 26px var(--red-dim)}
.dalle.is-hidden{opacity:.4;filter:grayscale(.5)}
.dalle .head{display:flex;align-items:center;gap:12px}
.dalle .head-t{flex:1;min-width:0}
.dalle .ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:20px;flex:none;
  background:color-mix(in srgb, var(--acc,#64748b) 22%, transparent);
  border:1px solid color-mix(in srgb, var(--acc,#64748b) 32%, transparent)}
.dalle .name{font-weight:700;font-size:15px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dalle .meta{color:var(--muted);font-size:12.5px;margin-top:2px;font-weight:500}
.dalle .dvalue{display:flex;align-items:baseline;gap:6px}
.dalle .dnum{font-family:var(--display);font-weight:800;font-size:30px;color:#fff;line-height:1;letter-spacing:-.5px}
.dalle .dnum.muted{color:var(--muted-2);font-size:24px}
.dalle .dunit{font-size:14px;color:var(--muted);font-weight:700}
.dalle .value{font-family:var(--display);font-weight:700;font-size:20px}
.dalle .value.big{font-size:30px;color:#fff}
/* temp/hum : deux stats cote a cote */
.stat-row{display:flex;gap:10px}
.stat{flex:1;display:flex;align-items:center;gap:9px;padding:11px 12px;border-radius:13px;
  background:rgba(255,255,255,.045);border:1px solid var(--line)}
.stat-e{font-size:18px}
.stat-v{font-family:var(--display);font-weight:800;font-size:21px;color:#fff;line-height:1}
.stat-v small{font-size:11.5px;color:var(--muted);font-weight:700;margin-left:2px}
.state-line{font-weight:700;font-size:13px}
.state-line.on{color:var(--acc,#fbbf24)} .state-line.off{color:var(--muted)}

/* ---------- Mode personnalisation ---------- */
.eye{position:absolute;top:8px;right:8px;z-index:3;width:30px;height:30px;border-radius:9px;display:grid;
  place-items:center;background:rgba(0,0,0,.5);border:1px solid var(--line2);font-size:14px;cursor:pointer;padding:0}
.tab-eye{margin-left:7px;cursor:pointer;font-size:13px}
.tab.is-hidden{opacity:.5}
.editbanner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:12px 16px 0;padding:11px 14px;
  border-radius:13px;background:var(--violet-dim);color:#fff;font-size:13.5px;font-weight:600}
.editbanner button{margin-left:auto;padding:7px 14px;border-radius:10px;background:var(--violet);color:#fff;
  border:0;cursor:pointer;font-weight:700;font-size:13px}
#editbtn.active{background:var(--violet-dim);color:#fff;border-color:var(--violet)}
.readonly-tag{font-size:10.5px;color:var(--muted-2);border:1px solid var(--line);
  padding:2px 7px;border-radius:999px;font-weight:700}

/* statut pills dans une dalle */
.state{font-weight:700;font-size:14px;padding:6px 12px;border-radius:999px;align-self:flex-start}
.state.on{color:var(--green);background:var(--green-dim)}
.state.off{color:var(--muted);background:var(--card-h)}
.state.bad{color:var(--red);background:var(--red-dim)}

/* boutons d'action */
.actions{display:flex;gap:8px;flex-wrap:wrap}
.act{flex:1;min-width:84px;text-align:center;padding:12px;border-radius:var(--r-sm);
  background:var(--bg2);border:1px solid var(--line);font-weight:700;font-size:14px;
  color:var(--violet-2);transition:transform .08s,background .15s}
.act:active{transform:scale(.97)}
.act.green{color:var(--green)}
.act[disabled]{opacity:.4}
.toggle{margin-left:auto;width:60px;height:34px;border-radius:999px;background:var(--card-h);
  border:1px solid var(--line);position:relative;transition:background .2s}
.toggle.on{background:var(--green-dim);border-color:transparent}
.toggle .knob{position:absolute;top:3px;left:3px;width:26px;height:26px;border-radius:50%;
  background:var(--muted);transition:left .2s,background .2s}
.toggle.on .knob{left:31px;background:var(--green)}
.hint{font-size:11px;color:var(--muted-2);text-align:center}

/* ---------- Bottom sheet (slider appui long) ---------- */
.sheet-bg{position:fixed;inset:0;z-index:40;background:rgba(0,0,0,.55);
  backdrop-filter:blur(2px);display:flex;align-items:flex-end;animation:fade .2s}
.sheet{width:100%;background:var(--bg3);border-top-left-radius:24px;border-top-right-radius:24px;
  border-top:1px solid var(--line2);padding:20px 22px calc(26px + env(safe-area-inset-bottom));
  animation:up .25s cubic-bezier(.2,.8,.2,1)}
.sheet .grab{width:42px;height:5px;border-radius:999px;background:var(--line2);margin:0 auto 18px}
.sheet h3{font-family:var(--display);margin:0 0 4px;font-size:18px}
.sheet .pct{font-family:var(--display);font-size:44px;font-weight:700;text-align:center;
  margin:10px 0 18px;color:var(--violet-2)}
.range{width:100%;-webkit-appearance:none;height:10px;border-radius:999px;
  background:linear-gradient(90deg,var(--violet) var(--p,50%),var(--bg2) var(--p,50%))}
.range::-webkit-slider-thumb{-webkit-appearance:none;width:30px;height:30px;border-radius:50%;
  background:#fff;border:3px solid var(--violet);box-shadow:0 2px 10px rgba(0,0,0,.5)}
.sheet .row{display:flex;gap:10px;margin-top:22px}
.sheet .row .btn{flex:1}

@keyframes fade{from{opacity:0}} @keyframes up{from{transform:translateY(100%)}}

/* ---------- Toast ---------- */
.toast{position:fixed;left:50%;bottom:calc(24px + env(safe-area-inset-bottom));
  transform:translateX(-50%);z-index:60;background:var(--bg3);border:1px solid var(--line2);
  padding:11px 18px;border-radius:999px;font-size:13.5px;font-weight:600;
  box-shadow:0 10px 30px rgba(0,0,0,.5);animation:fade .2s}
.toast.bad{border-color:var(--red);color:var(--red)}

.spinner{width:30px;height:30px;border-radius:50%;border:3px solid var(--line2);
  border-top-color:var(--violet);animation:spin .8s linear infinite;margin:60px auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Panneau Reglages ---------- */
.overlay{position:fixed;inset:0;z-index:50;background:rgba(8,9,13,.96);
  backdrop-filter:blur(6px);overflow-y:auto;animation:fade .2s}
.sheet-full{max-width:560px;margin:0 auto;min-height:100dvh;
  padding:calc(16px + env(safe-area-inset-top)) 18px calc(40px + env(safe-area-inset-bottom))}
.sheet-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.sheet-top h2{font-family:var(--display);font-size:22px;margin:0}
.sheet-top .iconbtn svg{stroke:var(--text)}
.set-sec{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:6px 16px;margin-bottom:16px}
.set-sec-h{font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  color:var(--muted-2);padding:12px 0 6px}
.set-row{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:13px 0;border-top:1px solid var(--line)}
.set-sec-h + .set-row,.set-row:first-of-type{border-top:0}
.set-row-l{font-size:14.5px;font-weight:600}
.set-row-actions{display:flex;gap:8px}
.sbtn{padding:8px 14px;border-radius:10px;font-weight:700;font-size:13px;
  background:var(--bg2);border:1px solid var(--line);color:var(--violet-2);transition:transform .08s}
.sbtn:active{transform:scale(.96)}
.sbtn.green{color:var(--green)} .sbtn.red{color:var(--red)}
.sbtn.wide{width:100%;margin:12px 0;padding:13px}
.set-form{display:flex;flex-direction:column;gap:12px;padding:6px 0 16px}
.set-form select.input{appearance:none}
.set-hint{font-size:13px;color:var(--muted);margin:6px 0 0;line-height:1.45}
.set-key{font-family:var(--display);font-size:18px;letter-spacing:2px;text-align:center;
  background:var(--bg2);border:1px dashed var(--line2);border-radius:var(--r-sm);
  padding:14px;color:var(--violet-2);word-break:break-all}

/* ---------- Reglages : modale + sidebar (v0.4) ---------- */
.modal-bg{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;
  padding:16px;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);animation:fade .2s}
.modal{width:100%;max-width:720px;max-height:88dvh;display:flex;flex-direction:column;
  background:var(--bg3);border:1px solid var(--line2);border-radius:22px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.6);animation:pop .22s cubic-bezier(.2,.8,.2,1)}
@keyframes pop{from{transform:scale(.96);opacity:0}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;
  border-bottom:1px solid var(--line)}
.modal-title{font-family:var(--display);font-size:19px;font-weight:700}
.modal-head .iconbtn svg{stroke:var(--text)}
.modal-body{display:flex;flex:1;min-height:0}
.snav{width:200px;flex:none;border-right:1px solid var(--line);padding:12px;display:flex;
  flex-direction:column;gap:4px;overflow-y:auto}
.snav-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:10px 12px;
  border-radius:11px;font-size:14px;font-weight:600;color:var(--muted);transition:background .15s,color .15s}
.snav-item:hover{background:var(--card-h);color:var(--text)}
.snav-item.active{background:var(--violet-dim);color:#fff}
.snav-item.danger{color:var(--red);margin-top:auto}
.snav-ico{width:18px;text-align:center}
.snav-dot{margin-left:auto;width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.scontent{flex:1;padding:22px;overflow-y:auto}
.modal-foot{display:flex;align-items:center;justify-content:space-between;padding:11px 20px;
  border-top:1px solid var(--line);font-size:12px;color:var(--muted-2)}
.mono{font-family:var(--mono,ui-monospace,Menlo,monospace)}

.ssec{display:flex;flex-direction:column;gap:12px}
.ssec-h{font-family:var(--display);font-size:17px;margin:0 0 4px}
.srow{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.srow:last-child{border-bottom:0}
.srow-k{color:var(--muted);font-size:14px}
.srow-v{font-weight:700;font-size:14px}
.sform{display:flex;flex-direction:column;gap:12px;margin-top:4px}
.sform-h{font-family:var(--display);font-size:14px;color:var(--muted);margin:6px 0 2px;font-weight:700}
.sfield{display:flex;flex-direction:column;gap:6px}
.sfield label{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.3px}
.sfield select.input{appearance:none}
.shint{font-size:13px;color:var(--muted);line-height:1.5;margin:0}
.sbadge{padding:11px 14px;border-radius:12px;font-size:13.5px;font-weight:600}
.sbadge.ok{background:var(--green-dim);color:var(--green)}
.qrwrap{align-self:center;background:#fff;padding:12px;border-radius:14px;line-height:0}
.qrwrap img{width:200px;height:200px;display:block}
.sdetails{font-size:13px} .sdetails summary{cursor:pointer;color:var(--muted)}
.code-input{font-family:var(--display);text-align:center;font-size:24px;letter-spacing:8px}
.srowbtns{display:flex;gap:10px}
.urow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;
  border-bottom:1px solid var(--line)}
.urow-name{font-size:14px;font-weight:600}
.urow-acts{display:flex;gap:8px}

@media(max-width:560px){
  .modal-body{flex-direction:column}
  .snav{width:100%;flex-direction:row;border-right:0;border-bottom:1px solid var(--line);overflow-x:auto}
  .snav-item.danger{margin-top:0}
  .snav-item span:not(.snav-ico):not(.snav-dot){display:none}
  .snav-item{padding:10px 13px}
}

/* ---------- Alertes / skeleton / etat vide (v0.5) ---------- */
.alert-badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:800;
  padding:6px 11px;border-radius:999px;color:var(--red);background:var(--red-dim);border:0;cursor:pointer;
  animation:pulseAlert 1.6s ease-in-out infinite}
.alert-badge .ab-dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 8px var(--red)}
@keyframes pulseAlert{50%{opacity:.55}}

.dalle.skel{height:96px;border-color:transparent;
  background:linear-gradient(100deg,var(--card) 30%,var(--card-h) 50%,var(--card) 70%);
  background-size:200% 100%;animation:shimmer 1.3s linear infinite}
@keyframes shimmer{to{background-position:-200% 0}}

.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  gap:8px;padding:64px 24px;color:var(--muted)}
.empty-ico{font-size:46px;opacity:.7}
.empty-t{font-family:var(--display);font-size:18px;color:var(--text);font-weight:700}
.empty-s{font-size:13.5px;max-width:340px;line-height:1.5}

/* ---------- Diagnostic ---------- */
.debug-pre{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:14px;
  font-family:var(--mono,ui-monospace,Menlo,monospace);font-size:12px;line-height:1.5;
  white-space:pre-wrap;word-break:break-word;max-height:42vh;overflow:auto;color:var(--text)}

/* =========================================================
   REFONTE VISUELLE v0.6 — icones SVG, profondeur, accents
   ========================================================= */
/* Repere logo dans le header */
.logo-mark{width:38px;height:38px;flex:none;border-radius:12px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(150deg,#7c5cdb,#8b5cf6 55%,#6d4ad6);
  box-shadow:0 6px 18px rgba(139,92,246,.42),inset 0 1px 0 rgba(255,255,255,.25)}
.logo-mark svg{width:21px;height:21px}
.topbar .brand{margin-left:1px;letter-spacing:.2px}

/* Icone de dalle : SVG teinte par l'accent du type */
.dalle .ico{font-size:0;
  background:linear-gradient(150deg,color-mix(in srgb,var(--acc) 26%,transparent),
                                     color-mix(in srgb,var(--acc) 8%,transparent));
  border-color:color-mix(in srgb,var(--acc) 34%,transparent)}
.dalle .ico svg{width:22px;height:22px;color:var(--acc);stroke:var(--acc)}

/* Carte : profondeur + halo accent au survol, barre laterale en degrade */
.dalle::before{width:3px;
  background:linear-gradient(var(--acc),color-mix(in srgb,var(--acc) 25%,transparent));opacity:.9}
.dalle:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--acc) 42%,var(--line));
  box-shadow:0 16px 38px rgba(0,0,0,.46),0 0 0 1px color-mix(in srgb,var(--acc) 16%,transparent)}
.dalle .name{font-size:15.5px;letter-spacing:.1px}

/* Stats temperature / humidite : tuiles avec mini-icone accent */
.stat{background:linear-gradient(150deg,rgba(255,255,255,.055),rgba(255,255,255,.02));
  border-color:var(--line);padding:12px 13px}
.stat-e{display:grid;place-items:center;width:32px;height:32px;border-radius:10px;flex:none;font-size:0;
  background:rgba(255,255,255,.05)}
.stat-e svg{width:18px;height:18px}
.stat:nth-child(1) .stat-e{color:#f59e0b;background:rgba(245,158,11,.14)}
.stat:nth-child(2) .stat-e{color:#38bdf8;background:rgba(56,189,248,.14)}
.stat-v{font-size:22px}

/* Toggle allume : petit halo vert */
.toggle.on{box-shadow:0 0 0 1px var(--green-dim),0 0 14px rgba(52,211,153,.25)}

/* Boutons d'action : accent du type au survol */
.act{background:linear-gradient(150deg,rgba(255,255,255,.05),rgba(255,255,255,.02))}
.act:not([disabled]):hover{border-color:color-mix(in srgb,var(--acc) 40%,var(--line));
  background:color-mix(in srgb,var(--acc) 10%,transparent)}

/* Titre de page un peu plus present */
.page h2{font-size:13px;letter-spacing:1.2px;color:var(--muted-2)}

/* Pills statut + onglets : finition */
.tab.active{background:linear-gradient(150deg,var(--violet-dim),rgba(139,92,246,.05));
  box-shadow:inset 0 0 0 1px rgba(139,92,246,.25)}
.pill.live{box-shadow:0 0 0 1px rgba(52,211,153,.2)}

/* Œil de masquage : pastille nette */
.eye,.tab-eye{transition:transform .1s}
.eye:active{transform:scale(.9)}

/* Lampes / interrupteurs : carte vive quand allumee, assombrie quand eteinte */
.dalle.lamp-off{filter:saturate(.5);opacity:.72}
.dalle.lamp-off .name{color:var(--muted)}
.dalle.lamp-off::before{opacity:.4}
.dalle.lamp-on{box-shadow:0 0 0 1px color-mix(in srgb,var(--acc) 28%,transparent),0 16px 34px rgba(0,0,0,.42)}
.dalle.lamp-on .ico{box-shadow:0 0 18px color-mix(in srgb,var(--acc) 35%,transparent)}
.dalle.lamp-on .ico svg{filter:drop-shadow(0 0 5px color-mix(in srgb,var(--acc) 60%,transparent))}

/* Profil : carte recap + badges */
.acct-card{border:1px solid var(--line);border-radius:14px;padding:2px 16px;
  background:linear-gradient(150deg,rgba(255,255,255,.04),rgba(255,255,255,.015))}
.badge-role{font-size:11px;font-weight:800;letter-spacing:.6px;padding:4px 10px;border-radius:8px;
  background:var(--violet-dim);color:var(--violet-2);border:1px solid color-mix(in srgb,var(--violet) 32%,transparent)}
.badge-ok{font-size:11px;font-weight:800;padding:4px 10px;border-radius:999px;
  background:var(--green-dim);color:var(--green);border:1px solid color-mix(in srgb,var(--green) 32%,transparent)}
.badge-off{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--card-h);color:var(--muted)}

/* ---------- Bandeau de synthese par page (KPI) ---------- */
.kpi-row{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(158px,1fr));margin:0 0 18px}
.kpi{border-radius:16px;padding:14px 16px;overflow:hidden;
  border:1px solid color-mix(in srgb,var(--acc) 30%,transparent);
  background:linear-gradient(150deg,color-mix(in srgb,var(--acc) 20%,transparent),
                                     color-mix(in srgb,var(--acc) 4%,transparent))}
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:9px}
.kpi-l{font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--muted)}
.kpi-i{color:var(--acc);opacity:.75;font-size:0;flex:none}
.kpi-i svg{width:18px;height:18px}
.kpi-v{font-family:var(--display);font-weight:800;font-size:25px;color:#fff;line-height:1;letter-spacing:-.5px}
.kpi-s{font-size:11.5px;color:var(--muted);margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Hauteur minimale commune -> lignes homogenes quelle que soit la densite */
.dalle{min-height:118px;justify-content:flex-start}
.dalle .state-line.big{font-size:20px;font-weight:800}
.dalle .state-line.bad{color:var(--red)}
.dalle .state-line.ok{color:var(--green)}

/* =========================================================
   TUILES DOMOTIQUE v0.8 — style Apple Home / Home Assistant (Mushroom)
   Pastille d'icone coloree par l'etat, nom + etat, tap pour agir.
   ========================================================= */
.grid{grid-template-columns:repeat(auto-fill,minmax(224px,1fr));gap:12px}
.tile{position:relative;display:flex;align-items:center;gap:14px;padding:13px 15px;border-radius:20px;
  min-height:74px;overflow:hidden;background:var(--card);border:1px solid var(--line);
  transition:transform .12s,background .2s,border-color .2s,box-shadow .2s}
.tile.wide{grid-column:span 2}
.tile.tappable{cursor:pointer}
.tile.tappable:active{transform:scale(.985)}
.tile:hover{border-color:var(--line2);background:var(--card-h)}

.tchip{width:46px;height:46px;flex:none;border-radius:14px;display:grid;place-items:center;font-size:0;
  background:rgba(255,255,255,.055);color:var(--muted);
  transition:background .25s,color .25s,box-shadow .25s}
.tchip svg{width:23px;height:23px;stroke:currentColor}

.tbody{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.tname{font-weight:700;font-size:15px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tsub{font-size:12.5px;color:var(--muted);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tsub.on{color:var(--acc)} .tsub.off{color:var(--muted-2)}
.tsub.bad{color:var(--red)} .tsub.ok{color:var(--green)}

.ttrail{flex:none;display:flex;align-items:center;gap:7px;margin-left:auto}
.tval{font-family:var(--display);font-weight:800;font-size:25px;color:#fff;line-height:1;letter-spacing:-.5px}
.tunit{font-size:13px;color:var(--muted);font-weight:700;align-self:flex-end;margin-bottom:2px}

.tdot{width:14px;height:14px;border-radius:50%;background:var(--muted-2);transition:background .25s,box-shadow .25s}
.tdot.on{background:var(--acc);box-shadow:0 0 12px var(--acc)}

/* etat ACTIF -> la pastille s'allume + la tuile se teinte legerement */
.tile.on{border-color:color-mix(in srgb,var(--acc) 28%,transparent);
  background:linear-gradient(150deg,color-mix(in srgb,var(--acc) 9%,transparent),var(--card))}
.tile.on .tchip{background:color-mix(in srgb,var(--acc) 22%,transparent);color:var(--acc);
  box-shadow:0 0 16px color-mix(in srgb,var(--acc) 32%,transparent)}

/* lampe eteinte : sobre */
.tile.lamp-off .tchip{color:var(--muted-2)}

/* alerte (fumee / inondation) : rouge */
.tile.alert{border-color:color-mix(in srgb,var(--red) 55%,transparent);
  background:linear-gradient(150deg,var(--red-dim),var(--card));box-shadow:0 0 22px var(--red-dim)}
.tile.alert .tchip{background:var(--red-dim);color:var(--red);box-shadow:0 0 16px var(--red-dim)}

/* boutons (volet, alarme) */
.tbtn{flex:none;min-width:36px;height:38px;padding:0 12px;border-radius:11px;font-weight:800;font-size:14px;
  background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--text);
  display:grid;place-items:center;transition:background .15s,transform .08s,border-color .15s}
.tbtn:not([disabled]):hover{border-color:var(--line2);background:rgba(255,255,255,.1)}
.tbtn:active{transform:scale(.93)}
.tbtn.green{color:var(--green)}
.tbtn[disabled]{opacity:.35}

.tile.is-hidden{opacity:.4;filter:grayscale(.5)}
.tile .eye{top:8px;right:8px}
