/* ===== GERZOG device-cards: HUD + device-классы (из Claude Design, встройка 2026-06-07) =====
   Базовые классы (btn/card-glass/pill/chip…) НЕ дублируем — они в styles.css. ===== */
.btn-danger{background:linear-gradient(180deg,#f0584f,#c0322a);color:#fff;border-color:transparent;}
.btn-danger:hover{background:linear-gradient(180deg,#f46a61,#d23a31);}
.hex-bg{position:relative;overflow:hidden;}
.hex-bg::before{content:'';position:absolute;inset:0;pointer-events:none;opacity:.55;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='48' viewBox='0 0 28 48'%3E%3Cpath d='M14 0L0 8v16l14 8 14-8V8L14 0zM0 24v16l14 8 14-8V24' fill='none' stroke='%2300D1FF' stroke-opacity='0.5' stroke-width='1'/%3E%3C/svg%3E");background-size:28px 48px;-webkit-mask:radial-gradient(120% 90% at 50% 0%,#000 35%,transparent 80%);mask:radial-gradient(120% 90% at 50% 0%,#000 35%,transparent 80%);}
.hud-frame{position:relative;}
.hud-frame::before,.hud-frame::after{content:'';position:absolute;width:20px;height:20px;border:1.5px solid var(--neon);opacity:.55;pointer-events:none;}
.hud-frame::before{top:10px;left:10px;border-right:none;border-bottom:none;}
.hud-frame::after{bottom:10px;right:10px;border-left:none;border-top:none;}
/* доп. уголки на верх-право / низ-лево — все 4 угла */
.hud-frame .corner-tr,.hud-frame .corner-bl{content:'';position:absolute;width:20px;height:20px;border:1.5px solid var(--neon);opacity:.55;pointer-events:none;}
.hud-frame .corner-tr{top:10px;right:10px;border-left:none;border-bottom:none;}
.hud-frame .corner-bl{bottom:10px;left:10px;border-right:none;border-top:none;}
.tick-scale{height:14px;opacity:.55;background:repeating-linear-gradient(90deg,var(--line-hi) 0 1px,transparent 1px 7px);-webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);}
.seg-bar{display:flex;gap:3px;}
.seg-bar i{flex:1;height:8px;border-radius:2px;background:var(--card-hi);}
.seg-bar i.on{background:var(--neon);box-shadow:0 0 8px var(--neon);}
.seg-bar i.gold{background:var(--gold);box-shadow:0 0 8px var(--gold);}
.seg-bar i.warn{background:var(--warn);box-shadow:0 0 8px var(--warn);}
.glow-neon{box-shadow:0 0 0 1px rgba(0,209,255,.25),0 0 44px -10px rgba(0,209,255,.55);}
.text-glow{text-shadow:0 0 18px rgba(0,209,255,.45);}

/* PTZ-джойстик поворота камеры + полноэкранный режим (встройка #63) */
.ptz{display:inline-grid;grid-template-columns:repeat(3,36px);grid-template-rows:repeat(3,36px);gap:5px;}
.ptz button{border:1px solid var(--line-2);background:rgba(11,16,32,.72);color:var(--fg);border-radius:9px;display:grid;place-items:center;cursor:pointer;transition:.15s;backdrop-filter:blur(4px);padding:0;}
.ptz button:hover{border-color:var(--neon);color:var(--neon);background:rgba(0,209,255,.14);box-shadow:0 0 14px -4px var(--neon);}
.ptz .ptz-c{color:var(--neon);border-color:rgba(0,209,255,.4);}
.ptz-overlay{position:absolute;right:10px;top:50%;transform:translateY(-50%);z-index:6;}
.cam-fs{position:fixed;inset:0;z-index:200;background:#03050A;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:12px;}
.video-stage-big{position:relative;width:min(97vw,1800px);aspect-ratio:16/9;max-height:86vh;border-radius:14px;border:1px solid var(--line-2);background:radial-gradient(130% 130% at 50% 38%,#0a0f1a,#04060c);overflow:hidden;box-shadow:0 30px 80px -30px #000;}
.cam-flash{position:absolute;inset:0;background:#fff;pointer-events:none;z-index:7;animation:camflash .5s ease-out forwards;}
@keyframes camflash{from{opacity:.75;}to{opacity:0;}}
.cam-fs-bar{position:absolute;top:16px;right:16px;display:flex;gap:8px;z-index:201;}

/* ============================================================
   МОИ ДОБАВЛЕНИЯ (нет в брифе) — тоже строго в палитре
   ============================================================ */

/* device card shell */
.dev-card{width:100%;}
.dev-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px 20px;border-bottom:1px solid var(--line);flex-wrap:wrap;}
.dev-head .dh-left{display:flex;gap:14px;min-width:0;flex:1 1 200px;}
.dev-head .dh-title{font-size:18px;font-weight:700;margin:0;letter-spacing:-0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:linear-gradient(120deg,var(--neon),#b6e8ff 55%,var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent;}
.dev-head .dh-sub{font-size:12.5px;color:var(--muted);margin:3px 0 0;}
.dev-head .dh-status{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end;align-items:flex-start;flex:1 1 auto;min-width:0;}
.dev-nav{padding:14px 20px;border-bottom:1px solid var(--line);overflow-x:auto;}
.dev-nav::-webkit-scrollbar{height:0;}
.dev-body{padding:20px;}
.dev-foot{padding:16px 20px;border-top:1px solid var(--line);display:flex;gap:10px;align-items:center;}

/* hero blocks */
.hero{border-radius:var(--r);border:1px solid var(--line-2);background:linear-gradient(180deg,rgba(0,209,255,.05),rgba(255,255,255,.01));}
.hero-lock{display:flex;flex-direction:column;align-items:center;gap:18px;padding:30px 20px;}
.lock-ring{position:relative;width:184px;height:184px;border-radius:50%;display:grid;place-items:center;}
.lock-ring .ring-core{width:140px;height:140px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line-2);background:rgba(5,7,13,.5);}

/* toggle switch */
.toggle{position:relative;width:46px;height:26px;border-radius:999px;background:var(--card-hi);border:1px solid var(--line-2);cursor:pointer;transition:.2s;flex:none;padding:0;}
.toggle .knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--muted);transition:.2s;}
.toggle.on{background:rgba(0,209,255,.25);border-color:rgba(0,209,255,.5);box-shadow:0 0 0 1px rgba(0,209,255,.25) inset,0 0 16px -4px rgba(0,209,255,.6);}
.toggle.on .knob{left:22px;background:var(--neon);box-shadow:0 0 10px var(--neon);}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;}
.toggle-row+.toggle-row{border-top:1px solid var(--line);}

/* glass dropdown */
.gselect{position:relative;}
.gselect-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--card-2);border:1px solid var(--line-2);border-radius:10px;padding:10px 12px;color:var(--fg);font-size:13.5px;cursor:pointer;font-family:inherit;transition:.2s;}
.gselect-btn:hover{border-color:var(--line-hi);}
.gselect-btn.open{border-color:var(--neon);box-shadow:0 0 0 3px rgba(0,209,255,.15);}
.gselect-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:70;background:#0B1020;border:1px solid var(--line-2);border-radius:12px;padding:6px;backdrop-filter:blur(14px);box-shadow:0 24px 50px -18px rgba(0,0,0,.8);max-height:240px;overflow:auto;}
.gselect-opt{padding:9px 11px;border-radius:8px;font-size:13.5px;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;}
.gselect-opt:hover{background:var(--card-hi);color:var(--fg);}
.gselect-opt.sel{color:var(--fg);background:rgba(0,209,255,.1);}

/* video placeholder */
.video-area{position:relative;aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-2);background:linear-gradient(135deg,#0a0f1e,#0d1426);display:grid;place-items:center;}
.video-area .scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(0,209,255,.04) 0 2px,transparent 2px 4px);pointer-events:none;}
.video-play{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:rgba(0,209,255,.12);border:1px solid rgba(0,209,255,.4);color:var(--neon);cursor:pointer;transition:.2s;}
.video-play:hover{background:rgba(0,209,255,.2);}
.cam-osd{position:absolute;font-family:'JetBrains Mono',monospace;font-size:11.5px;letter-spacing:.04em;}
.cam-osd.tl{top:12px;left:12px;} .cam-osd.tr{top:12px;right:12px;} .cam-osd.bl{bottom:12px;left:12px;} .cam-osd.br{bottom:12px;right:12px;}
.rec-dot{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;background:rgba(239,68,68,.16);border:1px solid rgba(239,68,68,.45);color:#fbb6b6;font-weight:600;}
.rec-dot .b{width:7px;height:7px;border-radius:50%;background:var(--err);box-shadow:0 0 8px var(--err);animation:recblink 1.4s ease-in-out infinite;}
@keyframes recblink{50%{opacity:.25;}}
.cam-tools{display:flex;flex-wrap:wrap;gap:8px;}
.cam-tool{flex:1;min-width:74px;min-height:56px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border-radius:12px;border:1px solid var(--line-2);background:var(--card-2);color:var(--fg);font-size:11.5px;cursor:pointer;transition:.2s;font-family:inherit;}
.cam-tool:hover{border-color:var(--line-hi);background:var(--card-hi);}
.cam-tool.active{color:var(--neon);border-color:rgba(0,209,255,.45);background:rgba(0,209,255,.1);}

/* climate dial */
.dial-wrap{display:grid;place-items:center;position:relative;}
.dial-center{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:150px;height:150px;border-radius:50%;}
.dial-temp{font-family:'JetBrains Mono',monospace;font-size:46px;font-weight:600;line-height:1;letter-spacing:-0.02em;}
.dial-btns{display:flex;gap:14px;align-items:center;justify-content:center;}
.dial-step{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line-2);background:var(--card-2);color:var(--fg);cursor:pointer;transition:.2s;font-family:inherit;}
.dial-step:hover{border-color:var(--neon);color:var(--neon);background:rgba(0,209,255,.08);}

/* bar chart */
.bars{display:flex;align-items:flex-end;gap:6px;height:100px;}
.bars .bar{flex:1;border-radius:4px 4px 2px 2px;background:linear-gradient(180deg,rgba(0,209,255,.7),rgba(0,209,255,.12));min-height:4px;position:relative;}
.bars .bar.gold{background:linear-gradient(180deg,rgba(212,175,55,.75),rgba(212,175,55,.12));}
.bars .bar.peak{box-shadow:0 0 12px -2px var(--neon);}
.bar-axis{display:flex;justify-content:space-between;margin-top:8px;font-size:10.5px;color:var(--muted-2);font-family:'JetBrains Mono',monospace;}

/* list rows */
.lrow{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);}
.lrow:last-child{border-bottom:none;}
.lrow .l-ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--card-2);border:1px solid var(--line-2);color:var(--muted);flex:none;}
.lrow .l-main{min-width:0;flex:1;}
.lrow .l-t{font-size:13.5px;font-weight:600;}
.lrow .l-s{font-size:12px;color:var(--muted);margin-top:2px;}
.icon-btn{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:transparent;border:1px solid var(--line-2);color:var(--muted);cursor:pointer;transition:.2s;flex:none;}
.icon-btn:hover{color:var(--fg);border-color:var(--line-hi);background:var(--card-2);}
.icon-btn.danger:hover{color:#fbb6b6;border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.08);}

.divider{height:1px;background:var(--line);margin:4px 0;}
.kv{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13.5px;}
.kv:last-child{border-bottom:none;}
.kv .k{color:var(--muted);}
.section-label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;color:var(--muted-2);text-transform:uppercase;margin:0 0 12px;}

/* demo */
.demo-wrap{max-width:1100px;margin:0 auto;padding:28px;}
.demo-grid{display:grid;gap:22px;grid-template-columns:1fr 1fr;}
.demo-grid .span2{grid-column:1 / -1;}
@media(max-width:860px){.demo-grid{grid-template-columns:1fr;}}

/* ============================================================
   «Мои устройства» — master-detail (список слева · карточка справа) #64
   ============================================================ */
.dev-split{display:grid;grid-template-columns:300px minmax(0,760px);gap:18px;margin-top:18px;align-items:start;}
.dev-split-list{display:flex;flex-direction:column;gap:8px;position:sticky;top:14px;max-height:calc(100vh - 130px);overflow-y:auto;padding-right:4px;}
.dev-split-main{min-width:0;}
.dev-li{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:var(--card-2,rgba(255,255,255,.02));cursor:pointer;text-align:left;color:var(--fg);font:inherit;transition:border-color .15s,background .15s,box-shadow .15s;}
.dev-li:hover{border-color:rgba(0,209,255,.4);}
.dev-li.active{border-color:var(--neon);background:rgba(0,209,255,.08);box-shadow:inset 0 0 0 1px rgba(0,209,255,.3);}
.dev-meta-strip{display:flex;flex-wrap:wrap;align-items:center;gap:8px 16px;margin-bottom:12px;font-size:12px;color:var(--muted);}
.dev-meta-strip b{color:var(--fg);font-weight:600;}
@media(max-width:1100px){
  .dev-split{grid-template-columns:1fr;}
  .dev-split-list{flex-direction:row;overflow-x:auto;position:static;max-height:none;padding-bottom:6px;}
  .dev-li{min-width:210px;flex:0 0 auto;}
}

/* ============================================================
   Электрощит — модульные автоматы (карточка электросчётчика) #64
   ============================================================ */
.brk-rail{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding:16px 12px;border-radius:12px;
  background:linear-gradient(180deg,rgba(0,0,0,.28),rgba(0,0,0,.12));
  border:1px solid var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.04),inset 0 -1px 0 rgba(0,0,0,.4);position:relative;}
/* насечки DIN-рейки сверху/снизу */
.brk-rail::before,.brk-rail::after{content:'';position:absolute;left:10px;right:10px;height:6px;
  background:repeating-linear-gradient(90deg,var(--line-hi,rgba(255,255,255,.12)) 0 1px,transparent 1px 6px);opacity:.5;}
.brk-rail::before{top:5px;} .brk-rail::after{bottom:5px;}
.brk{display:flex;flex-direction:column;align-items:center;gap:7px;width:66px;padding:11px 6px 9px;border:1px solid var(--line);border-radius:11px;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012));cursor:pointer;transition:border-color .16s,box-shadow .16s,opacity .16s;position:relative;}
.brk:hover{border-color:rgba(0,209,255,.45);}
.brk.on{border-color:rgba(0,209,255,.38);box-shadow:0 0 0 1px rgba(0,209,255,.12),0 6px 18px -12px var(--neon);}
.brk.off{opacity:.55;}
.brk-led{width:7px;height:7px;border-radius:50%;background:var(--muted);transition:.16s;}
.brk.on .brk-led{background:#3ddc84;box-shadow:0 0 9px #3ddc84;}
/* вертикальный тумблер: ручка вверх = вкл, вниз = выкл */
.brk-sw{position:relative;width:24px;height:40px;border-radius:7px;border:1px solid var(--line-2);background:linear-gradient(180deg,#0a0f1a,#05080f);box-shadow:inset 0 2px 6px rgba(0,0,0,.55);}
.brk-knob{position:absolute;left:3px;right:3px;bottom:3px;height:16px;border-radius:5px;background:linear-gradient(180deg,#3a4150,#222833);box-shadow:inset 0 1px 0 rgba(255,255,255,.18);transition:bottom .18s cubic-bezier(.5,1.6,.5,1),background .18s;}
.brk.on .brk-knob{bottom:21px;background:linear-gradient(180deg,#9becff,#00d1ff);box-shadow:0 0 12px var(--neon),inset 0 1px 0 rgba(255,255,255,.5);}
.brk-amp{display:flex;align-items:baseline;gap:2px;font-size:17px;font-weight:700;line-height:1;color:var(--fg);}
.brk-amp small{font-size:10px;font-weight:500;color:var(--muted);}
.brk.on .brk-amp{color:var(--neon);}
.brk-lab{font-size:10px;line-height:1.1;color:var(--muted);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}

/* доработка автоматов: наработка (uptime) + заготовка расписания #64 */
.brk{width:74px;}
.brk-up{display:flex;align-items:center;gap:3px;font-size:9.5px;line-height:1;color:var(--muted);}
.brk.on .brk-up{color:#7fe7ff;}
.brk-up svg{flex:0 0 auto;}
.brk-sched{border-top:1px dashed var(--line);padding-top:13px;}

/* фикс прыжка layout: строка наработки постоянной высоты #64 */
.brk-up{height:13px;justify-content:center;}
.brk.off .brk-up{opacity:.7;}

/* электросчётчик — данные, встроенные в HUD-поле показания #64 */
.met-hud{align-items:flex-start;}
.met-stats{display:grid;grid-template-columns:repeat(4,1fr);width:100%;border-top:1px solid var(--line);padding-top:15px;}
.met-cell{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;padding:0 12px;border-right:1px solid var(--line);}
.met-cell:last-child{border-right:none;}
.met-k{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2,var(--muted));}
.met-v{font-size:17px;font-weight:700;color:var(--fg);display:flex;align-items:baseline;gap:3px;line-height:1;}
.met-v small{font-size:10px;font-weight:500;color:var(--muted);}
@media(max-width:560px){
  .met-stats{grid-template-columns:1fr 1fr;gap:16px 0;}
  .met-cell:nth-child(2n){border-right:none;}
}

/* расписание автоматов — живые детали режима #64 */
.brk-sched-info{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;margin-top:12px;}
.brk-win{display:inline-flex;align-items:center;gap:5px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--neon);}

/* цвет «тепла» для режима обогрева кондиционера — насыщенный красный #64 */
:root{ --heat:#FF2E2E; }

/* живой центральный циферблат кондиционера: дыхание + радар-сектор #64
   цвет берётся из --acc / --accrgb (задаются inline по режиму) */
.dial-wrap{position:relative;}
@keyframes dialBreath{
  0%,100%{box-shadow:0 0 26px -12px var(--acc), inset 0 0 20px -14px var(--acc);}
  50%    {box-shadow:0 0 48px -6px  var(--acc), inset 0 0 32px -10px var(--acc);}
}
.dial-core{animation:dialBreath 3.4s ease-in-out infinite;}
@keyframes dialSpin{to{transform:rotate(360deg);}}
.dial-sweep{
  position:absolute;inset:6px;border-radius:50%;pointer-events:none;z-index:1;
  background:conic-gradient(from 0deg,
     transparent 0 60%,
     rgba(var(--accrgb),.06) 68%,
     rgba(var(--accrgb),.34) 84%,
     rgba(var(--accrgb),0) 93%,
     transparent 100%);
  -webkit-mask:radial-gradient(circle, transparent 0 55%, #000 60% 100%);
          mask:radial-gradient(circle, transparent 0 55%, #000 60% 100%);
  animation:dialSpin 5.5s linear infinite;
  opacity:.9;
}
@media (prefers-reduced-motion: reduce){
  .dial-core{animation:none;}
  .dial-sweep{animation:none;opacity:.5;}
}

/* Индикатор силы Wi-Fi-сигнала устройства (рядом с «Онлайн») */
.dev-signal-pill{display:inline-flex;align-items:center;gap:7px;padding:4px 10px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.02);}
.dev-signal{display:inline-flex;gap:2px;align-items:flex-end;height:13px;}
.dev-signal i{width:3px;background:var(--line-2);border-radius:1px;transition:background .2s;}
.dev-signal i.on{background:var(--neon);box-shadow:0 0 5px -1px var(--neon);}
.dev-signal i:nth-child(1){height:4px;}.dev-signal i:nth-child(2){height:7px;}.dev-signal i:nth-child(3){height:10px;}.dev-signal i:nth-child(4){height:13px;}

/* Кнопка-иконка удаления устройства в шапке карточки */
.dev-del-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:border-color .18s,color .18s,background .18s,box-shadow .18s;}
.dev-del-btn:hover{border-color:var(--err);color:var(--err);background:rgba(239,68,68,.1);box-shadow:0 0 16px -6px var(--err);}
