/* ==========================================================================
   СервисДом · стили экранов разделов, модалок и поповеров
   ========================================================================== */

/* ---------------- Модальные окна ---------------- */
.modal-host{ position:fixed; inset:0; z-index:100; display:none; align-items:center; justify-content:center; padding:24px; }
.modal-host.on{ display:flex; }
.modal-card{ width:520px; max-width:100%; max-height:90vh; overflow-y:auto; background:var(--surface);
  border-radius:calc(var(--r) + 2px); box-shadow:var(--shadow-pop); animation:mdin .2s cubic-bezier(.3,.7,.3,1); }
@keyframes mdin{ from{ opacity:0; transform:translateY(12px) scale(.98); } to{ opacity:1; transform:none; } }
.md-head{ display:flex; gap:14px; align-items:flex-start; padding:18px 20px; border-bottom:1px solid var(--border); }
.md-ic{ width:44px; height:44px; border-radius:12px; background:var(--brand-soft); color:var(--brand);
  display:flex; align-items:center; justify-content:center; flex:none; }
.md-ic.ok{ background:var(--ok-soft); color:var(--ok); }
.md-t{ flex:1; min-width:0; padding-top:1px; }
.md-t h3{ margin:0; font-size:18px; font-weight:700; letter-spacing:-.01em; }
.md-sub{ font-size:12.5px; color:var(--muted); margin-top:3px; line-height:1.4; }
.md-head .icon-btn{ width:34px; height:34px; flex:none; }
.md-body{ padding:18px 20px; }
.md-foot{ display:flex; justify-content:flex-end; gap:10px; padding:14px 20px; border-top:1px solid var(--border); flex-wrap:wrap; }
.md-foot .btn.md-wide{ width:100%; justify-content:center; }
.md-label{ font-size:11.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); font-weight:600; margin-bottom:8px; }
.md-field{ display:block; margin-bottom:13px; }
.md-field > span{ display:block; font-size:12.5px; color:var(--ink-2); font-weight:500; margin-bottom:6px; }
.md-field input, .md-field select, .md-field textarea{ width:100%; font-family:inherit; font-size:13.5px; color:var(--ink);
  border:1px solid var(--border-2); border-radius:var(--r-sm); padding:9px 11px; background:var(--surface); transition:.14s; }
.md-field input:focus, .md-field select:focus, .md-field textarea:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-softer); }
.md-field textarea{ resize:vertical; }
.md-row2{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:520px){ .md-row2{ grid-template-columns:1fr; } }
.md-pick{ display:flex; flex-direction:column; gap:8px; margin-bottom:15px; }
.md-opt{ display:flex; align-items:center; gap:11px; padding:10px 12px; border:1px solid var(--border-2); border-radius:var(--r-sm);
  background:var(--surface); text-align:left; transition:.14s; }
.md-opt:hover{ border-color:var(--border-strong); }
.md-opt.on{ border-color:var(--brand); background:var(--brand-softer); }
.md-opt .md-check{ margin-left:auto; color:var(--brand); opacity:0; }
.md-opt.on .md-check{ opacity:1; }
.md-opt .pr-b{ min-width:0; }
.ctr-ava.sm{ width:34px; height:34px; font-size:12px; }
.md-call{ text-align:center; padding:14px 0 6px; }
.md-call-num{ font-size:27px; font-weight:700; letter-spacing:-.01em; }
.md-call-meta{ font-size:12.5px; color:var(--muted); margin-top:6px; }
.md-recos{ display:flex; flex-direction:column; gap:7px; margin-top:14px; }
.md-reco{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-2); }
.md-reco .ic{ color:var(--ok); flex:none; }
.md-tasks, .md-toggles{ display:flex; flex-direction:column; gap:9px; }
.md-task{ display:flex; align-items:center; gap:10px; padding:11px 13px; border:1px solid var(--border); border-radius:var(--r-sm); font-size:13.5px; font-weight:500; cursor:pointer; }
.md-task input{ width:17px; height:17px; accent-color:var(--brand); }
.md-toggle{ display:flex; align-items:center; gap:10px; width:100%; border:1px solid var(--border); border-radius:var(--r-sm); background:var(--surface); padding:11px 13px; font-size:13.5px; font-weight:500; }
.md-toggle span:first-child{ flex:1; text-align:left; }
.tg-knob{ width:38px; height:22px; border-radius:999px; background:var(--border-strong); position:relative; transition:.18s; flex:none; }
.tg-knob::after{ content:""; position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%; background:#fff; transition:.18s; box-shadow:0 1px 2px rgba(0,0,0,.2); }
.md-toggle.on .tg-knob{ background:var(--brand); } .md-toggle.on .tg-knob::after{ left:18px; }

/* Камера */
.cam-frame{ position:relative; aspect-ratio:4/3; border-radius:var(--r); background:var(--ink); color:rgba(255,255,255,.6);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; overflow:hidden; margin-bottom:14px; }
.cam-frame::before, .cam-frame::after{ content:""; position:absolute; width:28px; height:28px; border:2px solid rgba(255,255,255,.5); }
.cam-frame::before{ top:14px; left:14px; border-right:none; border-bottom:none; border-radius:6px 0 0 0; }
.cam-frame::after{ bottom:14px; right:14px; border-left:none; border-top:none; border-radius:0 0 6px 0; }
.cam-frame.done{ background:var(--ok); color:#fff; }
.cam-hint{ font-size:12.5px; }
.cam-progress{ height:5px; background:var(--surface-3); border-radius:999px; overflow:hidden; margin:12px 0 8px; }
.cam-progress > i{ display:block; height:100%; width:30%; background:var(--brand); border-radius:999px; animation:camp 1s ease-in-out infinite alternate; }
@keyframes camp{ from{ width:15%; } to{ width:95%; } }
.cam-scan{ text-align:center; }
.cam-result{ display:flex; gap:13px; align-items:center; padding:14px; background:var(--ok-soft); border-radius:var(--r-sm); }
.cam-result b{ font-size:14.5px; }

/* Товар / drop */
.prod{ display:flex; gap:14px; align-items:flex-start; padding:14px; background:var(--surface-2); border-radius:var(--r-sm); }
.prod-ic{ width:54px; height:54px; border-radius:13px; background:var(--brand-soft); color:var(--brand); display:flex; align-items:center; justify-content:center; flex:none; }
.prod-b b{ font-size:14.5px; }
.prod-price{ font-size:18px; font-weight:700; margin-top:8px; }
.md-drop{ display:flex; gap:14px; align-items:center; justify-content:center; text-align:left; padding:26px; border:2px dashed var(--border-2);
  border-radius:var(--r); color:var(--muted); margin-bottom:14px; }
.md-drop .ic{ color:var(--brand); }
.md-drop b{ color:var(--ink); display:block; font-size:14px; }

/* ---------------- Поповеры ---------------- */
.pop-host{ position:fixed; inset:0; z-index:95; display:none; }
.pop-host.on{ display:block; }
.pop-panel{ position:absolute; background:var(--surface); border:1px solid var(--border-2); border-radius:14px;
  box-shadow:var(--shadow-pop); overflow:hidden; animation:popin .16s ease; max-height:80vh; overflow-y:auto; }
@keyframes popin{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:none; } }
.pop-h{ display:flex; align-items:center; padding:12px 14px; font-size:12px; text-transform:uppercase; letter-spacing:.05em;
  color:var(--muted); font-weight:700; border-bottom:1px solid var(--border); }
.pop-link{ margin-left:auto; border:none; background:transparent; color:var(--brand); font-size:11.5px; font-weight:600; text-transform:none; letter-spacing:0; }
.pop-row{ display:flex; align-items:center; gap:11px; width:100%; padding:11px 14px; border:none; background:transparent; text-align:left; transition:.13s; border-bottom:1px solid var(--border); }
.pop-row:last-child{ border-bottom:none; }
.pop-row:hover{ background:var(--surface-2); }
.pop-row .pr-b{ flex:1; min-width:0; display:flex; flex-direction:column; line-height:1.3; }
.pop-row .pr-b b{ font-size:13.5px; font-weight:600; }
.pop-row .pr-b small{ font-size:12px; color:var(--muted); }
.pop-row .ic{ color:var(--brand); flex:none; }
.pop-row.simple .ic{ color:var(--ink-2); }
.pop-row.notif{ align-items:flex-start; }
.pop-row.notif.unread{ background:var(--brand-softer); }
.pop-row .n-ic{ width:32px; height:32px; border-radius:9px; display:flex; align-items:center; justify-content:center; flex:none; }
.n-ic.bad{ background:var(--bad-soft); color:var(--bad); } .n-ic.warn{ background:var(--warn-soft); color:var(--warn); }
.n-ic.ok{ background:var(--ok-soft); color:var(--ok); } .n-ic.brand{ background:var(--brand-soft); color:var(--brand); }
.n-ic.info{ background:var(--info-soft); color:var(--info); }
.pop-row .n-time{ font-size:11px; color:var(--faint); margin-top:3px; }
.pop-row .n-dot{ width:8px; height:8px; border-radius:50%; background:var(--brand); flex:none; margin-top:5px; }
.pop-foot{ display:flex; align-items:center; gap:8px; width:100%; padding:11px 14px; border:none; background:var(--surface-2); color:var(--brand); font-size:13px; font-weight:600; }
.pop-foot:hover{ background:var(--surface-3); }
.pop-prof{ display:flex; align-items:center; gap:12px; padding:14px; border-bottom:1px solid var(--border); }
.pop-prof .h-ava.lg{ width:42px; height:42px; font-size:15px; }
.pop-prof b{ font-size:14px; display:block; } .pop-prof small{ font-size:12px; color:var(--muted); }
/* поиск */
.ps-in{ display:flex; align-items:center; gap:9px; padding:13px 14px; border-bottom:1px solid var(--border); }
.ps-in .ic{ color:var(--faint); flex:none; }
.ps-in input{ flex:1; border:none; background:transparent; font-family:inherit; font-size:14px; color:var(--ink); }
.ps-in input:focus{ outline:none; }
.ps-res{ max-height:60vh; overflow-y:auto; padding:6px; }
.ps-cap{ font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:var(--faint); font-weight:700; padding:8px 10px 5px; }
.ps-row{ display:flex; align-items:center; gap:11px; width:100%; padding:9px 10px; border:none; background:transparent; text-align:left; border-radius:var(--r-sm); transition:.12s; }
.ps-row:hover{ background:var(--surface-2); }
.ps-ic{ width:30px; height:30px; border-radius:8px; background:var(--surface-3); color:var(--ink-2); display:flex; align-items:center; justify-content:center; flex:none; }
.ps-row .pr-b{ display:flex; flex-direction:column; min-width:0; line-height:1.3; }
.ps-row .pr-b b{ font-size:13.5px; font-weight:600; }
.ps-row .pr-b small{ font-size:11.5px; color:var(--muted); }
.ps-empty{ padding:24px; text-align:center; color:var(--muted); font-size:13px; }

/* ---------------- Сервисная книжка / списки задач ---------------- */
.svc-list{ display:flex; flex-direction:column; }
.svc{ display:flex; align-items:center; gap:13px; padding:13px 0; border-bottom:1px solid var(--border); flex-wrap:wrap; }
.svc:first-child{ padding-top:2px; } .svc:last-child{ border-bottom:none; padding-bottom:2px; }
.svc.done{ opacity:.6; }
.svc .svc-ic{ width:38px; height:38px; border-radius:10px; background:var(--surface-3); color:var(--ink-2); display:flex; align-items:center; justify-content:center; flex:none; }
.svc .svc-b{ flex:1; min-width:180px; }
.svc .svc-t{ font-weight:600; font-size:14px; }
.svc .svc-m{ font-size:12px; color:var(--muted); display:flex; align-items:center; gap:6px; margin-top:2px; flex-wrap:wrap; }
.svc .svc-acts{ display:flex; gap:8px; flex:none; }
.job-right{ display:flex; flex-direction:column; align-items:flex-end; gap:5px; flex:none; }
.job-price{ font-weight:700; font-size:14px; }
.obj-fill{ display:flex; align-items:center; gap:8px; flex:none; }
.obj-fill span{ font-size:12px; font-weight:600; color:var(--ink-2); width:34px; }

/* ---------------- Мастера ---------------- */
.ctr-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--gap); }
@media (max-width:820px){ .ctr-grid{ grid-template-columns:1fr; } }
.ctr-top{ display:flex; align-items:center; gap:12px; }
.ctr-ava{ width:42px; height:42px; border-radius:11px; background:var(--accent-warm-soft); color:var(--brown);
  display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; flex:none; }
.ctr-id{ flex:1; min-width:0; }
.ctr-nm{ font-weight:600; font-size:14.5px; display:flex; align-items:center; gap:7px; }
.ctr-vf{ width:16px; height:16px; border-radius:50%; background:var(--ok); color:#fff; display:inline-flex; align-items:center; justify-content:center; }
.ctr-vf .ic{ width:11px; height:11px; }
.ctr-spec{ font-size:12.5px; color:var(--muted); }
.ctr-rate{ display:flex; align-items:center; gap:4px; font-size:13px; font-weight:600; color:var(--warn); flex:none; }
.ctr-rate .ic{ color:var(--warn); }
.ctr-tags{ display:flex; flex-wrap:wrap; gap:6px; margin:13px 0 11px; }
.ctr-last{ font-size:12px; color:var(--ink-2); display:flex; align-items:center; gap:6px; padding-top:11px; border-top:1px solid var(--border); }
.ctr-last .ic{ color:var(--faint); }
.ctr-foot{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:13px; }

/* ---------------- Финансы ---------------- */
.fin-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:var(--gap); align-items:start; }
@media (max-width:900px){ .fin-grid{ grid-template-columns:1fr; } }
.fin-chart{ display:flex; align-items:flex-end; gap:14px; height:170px; padding-top:8px; }
.fbar{ flex:1; display:flex; flex-direction:column; align-items:center; gap:6px; height:100%; justify-content:flex-end; }
.fbar-track{ width:100%; flex:1; display:flex; align-items:flex-end; }
.fbar-fill{ width:100%; max-width:40px; margin:0 auto; background:var(--surface-3); border-radius:7px 7px 0 0; min-height:4px; transition:height .5s ease; }
.fbar-fill.cur{ background:var(--brand); }
.fbar-v{ font-size:11px; color:var(--ink-2); font-weight:600; }
.fbar-m{ font-size:11.5px; color:var(--muted); }
.fin-stack{ display:flex; height:14px; border-radius:999px; overflow:hidden; gap:2px; margin-bottom:16px; }
.fin-stack > span{ display:block; }
.fin-legend{ display:flex; flex-direction:column; gap:10px; }
.fl-row{ display:flex; align-items:center; gap:10px; font-size:13px; }
.fl-dot{ width:11px; height:11px; border-radius:3px; flex:none; }
.fl-cat{ flex:1; color:var(--ink-2); }
.fl-val{ font-weight:600; }
.fin-recent{ display:flex; flex-direction:column; }
.frx{ display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--border); }
.frx:last-child{ border-bottom:none; }
.frx-ic{ width:34px; height:34px; border-radius:9px; background:var(--surface-3); color:var(--ink-2); display:flex; align-items:center; justify-content:center; flex:none; }
.frx-b{ flex:1; min-width:0; }
.frx-t{ font-weight:500; font-size:13.5px; }
.frx-m{ font-size:12px; color:var(--muted); }
.frx-a{ font-weight:700; font-size:14px; flex:none; }

/* ---------------- Квесты ---------------- */
.quest-hero{ display:flex; gap:22px; align-items:center; margin-bottom:var(--gap); }
.quest-hero .ring{ width:104px; height:104px; }
.quest-hero .qh-b{ flex:1; min-width:0; }

/* ---------------- DomAI ---------------- */
.ai-wrap{ display:flex; flex-direction:column; height:calc(100vh - var(--topbar-h) - 150px); min-height:420px;
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r); box-shadow:var(--shadow-1); overflow:hidden; }
.ai-chat{ flex:1; overflow-y:auto; padding:20px; display:flex; flex-direction:column; gap:14px; }
.msg{ display:flex; gap:10px; max-width:80%; }
.msg.me{ align-self:flex-end; }
.msg-ava{ width:30px; height:30px; border-radius:9px; background:var(--brand-soft); color:var(--brand); display:flex; align-items:center; justify-content:center; flex:none; }
.msg-b{ font-size:13.5px; line-height:1.5; padding:11px 14px; border-radius:14px; }
.msg.ai .msg-b{ background:var(--surface-2); border-bottom-left-radius:4px; }
.msg.me .msg-b{ background:var(--brand); color:var(--on-brand); border-bottom-right-radius:4px; }
.msg-b.typing{ display:flex; gap:4px; align-items:center; }
.msg-b.typing i{ width:6px; height:6px; border-radius:50%; background:var(--faint); animation:tdot 1s infinite; }
.msg-b.typing i:nth-child(2){ animation-delay:.15s; } .msg-b.typing i:nth-child(3){ animation-delay:.3s; }
@keyframes tdot{ 0%,60%,100%{ opacity:.3; transform:translateY(0); } 30%{ opacity:1; transform:translateY(-3px); } }
.ai-chips{ display:flex; gap:8px; flex-wrap:wrap; padding:0 16px 12px; }
.ai-chip{ border:1px solid var(--border-2); background:var(--surface); border-radius:var(--r-pill); padding:7px 13px; font-size:12.5px; color:var(--ink-2); font-weight:500; transition:.14s; }
.ai-chip:hover{ border-color:var(--brand); color:var(--brand); }
.ai-input{ display:flex; gap:10px; padding:14px 16px; border-top:1px solid var(--border); }
.ai-input input{ flex:1; border:1px solid var(--border-2); border-radius:var(--r-pill); padding:11px 16px; font-family:inherit; font-size:14px; }
.ai-input input:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-softer); }
.ai-input .btn{ padding:0 16px; }

/* ---------------- Документы ---------------- */
.doc-chips{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.dchip{ display:flex; align-items:center; gap:7px; border:1px solid var(--border-2); background:var(--surface); border-radius:var(--r-pill);
  padding:7px 14px; font-size:13px; font-weight:500; color:var(--ink-2); transition:.14s; }
.dchip:hover{ border-color:var(--border-strong); }
.dchip.on{ background:var(--brand); color:var(--on-brand); border-color:var(--brand); }
.dchip span{ font-size:11px; background:rgba(0,0,0,.08); border-radius:999px; padding:1px 7px; font-weight:600; }
.dchip.on span{ background:rgba(255,255,255,.22); }
.doc-list{ display:flex; flex-direction:column; }
.doc-row{ display:flex; align-items:center; gap:14px; width:100%; padding:13px 18px; border:none; background:transparent;
  text-align:left; border-bottom:1px solid var(--border); transition:.13s; }
.doc-row:last-child{ border-bottom:none; }
.doc-row:hover{ background:var(--surface-2); }
.doc-ic{ width:38px; height:38px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex:none; background:var(--brand-soft); color:var(--brand); }
.doc-ic.jpg{ background:var(--accent-warm-soft); color:var(--brown); } .doc-ic.dwg{ background:var(--info-soft); color:var(--info); }
.doc-nm{ flex:1; min-width:0; font-weight:600; font-size:13.5px; display:flex; flex-direction:column; line-height:1.3; }
.doc-nm small{ font-size:11.5px; color:var(--muted); font-weight:400; }
.doc-type{ font-size:10.5px; font-weight:700; letter-spacing:.04em; color:var(--ink-2); background:var(--surface-3); border-radius:5px; padding:3px 7px; flex:none; }
.doc-date{ font-size:12px; color:var(--muted); width:104px; flex:none; }
.doc-size{ font-size:12px; color:var(--muted); width:62px; text-align:right; flex:none; }
.doc-dl{ color:var(--faint); flex:none; }
.doc-row:hover .doc-dl{ color:var(--brand); }
@media (max-width:760px){ .doc-date, .doc-size{ display:none; } }

/* ---------------- Постройки ---------------- */
.ob-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--gap); }
@media (max-width:820px){ .ob-grid{ grid-template-columns:1fr; } }
.ob{ position:relative; }
.ob.flag::before{ content:""; position:absolute; left:0; top:16px; bottom:16px; width:3px; border-radius:3px; background:var(--warn); }
.ob-top{ display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.ob-ic{ width:44px; height:44px; border-radius:11px; background:var(--brand-soft); color:var(--brand); display:flex; align-items:center; justify-content:center; flex:none; }
.ob-nm{ font-weight:600; font-size:15px; }
.ob-meta{ font-size:12px; color:var(--muted); }
.ob-area{ margin-left:auto; font-size:13px; font-weight:600; color:var(--ink-2); flex:none; }
.ob-note{ font-size:12.5px; color:var(--ink-2); line-height:1.45; min-height:36px; }
.ob-note.warn{ color:var(--warn); display:flex; align-items:flex-start; gap:5px; }
.ob-foot{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:13px; padding-top:12px; border-top:1px solid var(--border); }
.ob-sys{ display:flex; flex-wrap:wrap; gap:6px; }

/* ---------------- Главная (MVP) ---------------- */
.dash-mvp{ display:grid; grid-template-columns:1.1fr 1fr 1.2fr; gap:var(--gap); margin-bottom:var(--gap); align-items:stretch; }
@media (max-width:1000px){ .dash-mvp{ grid-template-columns:1fr 1fr; } .master-card{ grid-column:1/-1; } }
@media (max-width:680px){ .dash-mvp{ grid-template-columns:1fr; } }
.pf-card .pf-big{ font-size:30px; font-weight:700; letter-spacing:-.02em; margin-top:6px; line-height:1; }
.spend-card .sp-alert, .pf-card .sp-alert{ margin-top:auto; padding-top:11px; cursor:pointer; }

/* Главная — компактная высота карточек (≈ −40%) */
.dash-mvp > .card.pad{ padding:12px 14px; }
.dash-mvp .master-card{ padding:13px 15px; }
.dash-mvp .sp-month{ margin-bottom:3px; }
.dash-mvp .spend-card .sp-amount{ font-size:21px; }
.dash-mvp .pf-card .pf-big{ font-size:21px; margin-top:3px; }
.dash-mvp .pf-card .bar{ margin:6px 0 7px !important; }
.dash-mvp .sp-alert{ padding-top:8px; }
.dash-mvp .mc-ic{ width:34px; height:34px; border-radius:9px; margin-bottom:8px; }
.dash-mvp .mc-ic .ic{ width:19px; height:19px; }
.dash-mvp .mc-t{ font-size:15px; }
.dash-mvp .mc-s{ margin-top:3px; }
.dash-mvp .mc-cta{ margin-top:10px; }

/* ---------------- Календарь: типы событий ---------------- */
.cd-dots{ position:absolute; bottom:4px; left:0; right:0; display:flex; gap:3px; justify-content:center; }
.cd-dots i{ width:5px; height:5px; border-radius:50%; display:block; }
.cd.today .cd-dots i{ box-shadow:0 0 0 1px rgba(255,255,255,.5); }
.cal-legend{ display:flex; flex-wrap:wrap; gap:10px 14px; margin-top:14px; padding-top:13px; border-top:1px solid var(--border); }
.cal-leg{ display:flex; align-items:center; gap:6px; font-size:11.5px; color:var(--muted); font-weight:500; }
.cal-leg i{ width:9px; height:9px; border-radius:3px; flex:none; }
.ev-bar{ width:4px; align-self:stretch; min-height:36px; border-radius:3px; flex:none; }
.ev-type{ display:inline-flex; align-items:center; gap:4px; font-weight:600; }
.ev-type .ic{ margin:-1px 0; }

/* ---------------- Карточка оборудования: бейджи ---------------- */
.eq-badges{ display:flex; flex-wrap:wrap; gap:6px; margin-top:9px; }
.eq-badge{ display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:600; padding:3px 9px; border-radius:var(--r-pill);
  background:var(--surface-3); color:var(--ink-2); }
.eq-badge .ic{ color:var(--muted); }
.eq-badge.ok{ background:var(--ok-soft); color:var(--ok); } .eq-badge.ok .ic{ color:var(--ok); }
.eq-badge.bad{ background:var(--bad-soft); color:var(--bad); } .eq-badge.bad .ic{ color:var(--bad); }
.eq-badge.warn{ background:var(--warn-soft); color:var(--warn); } .eq-badge.warn .ic{ color:var(--warn); }

/* ---------------- Drawer оборудования: гарантия / история / лог ---------------- */
.dw-warr{ border:1px solid var(--border); border-radius:var(--r-sm); padding:13px 14px; margin-bottom:14px; }
.dw-warr.ok{ background:var(--ok-soft); border-color:transparent; } .dw-warr.bad{ background:var(--bad-soft); border-color:transparent; }
.dw-warr-h{ display:flex; align-items:center; gap:8px; font-size:13.5px; font-weight:600; margin-bottom:11px; }
.dw-warr-h .ic{ color:currentColor; }
.dw-warr-g{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.dw-warr-g > div{ display:flex; flex-direction:column; gap:3px; }
.dw-warr-g span{ font-size:11px; color:var(--muted); }
.dw-warr-g b{ font-size:13px; }
.dw-next{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-2); padding:10px 12px; background:var(--surface-2); border-radius:var(--r-sm); margin-bottom:14px; }
.dw-next .ic{ color:var(--warn); }
.dw-hist, .dw-log{ display:flex; flex-direction:column; gap:0; }
.dw-hrow{ display:flex; gap:12px; align-items:flex-start; padding:12px 0; border-bottom:1px solid var(--border); }
.dw-hrow:last-child{ border-bottom:none; }
.dw-hic{ width:32px; height:32px; border-radius:9px; background:var(--surface-3); color:var(--ink-2); display:flex; align-items:center; justify-content:center; flex:none; }
.dw-hic.warn{ background:var(--warn-soft); color:var(--warn); } .dw-hic.ok{ background:var(--ok-soft); color:var(--ok); }
.dw-hrow b{ font-size:13.5px; }
.dw-lrow{ display:flex; gap:13px; align-items:flex-start; padding:11px 0 11px 4px; position:relative; }
.dw-lrow:not(:last-child)::after{ content:""; position:absolute; left:8px; top:20px; bottom:-6px; width:2px; background:var(--border); }
.dw-ldot{ width:11px; height:11px; border-radius:50%; background:var(--brand); border:2px solid var(--surface); box-shadow:0 0 0 2px var(--brand-soft); flex:none; margin-top:4px; z-index:1; }
.dw-lrow b{ font-size:13.5px; }

/* ---------------- Заявки ---------------- */
.req-row{ cursor:pointer; }
.req-row:hover{ background:var(--surface-2); }
.req-steps{ display:flex; align-items:center; gap:4px; margin-bottom:var(--gap); background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:14px 18px; box-shadow:var(--shadow-1); overflow-x:auto; }
.req-step{ display:flex; align-items:center; gap:8px; flex:1; min-width:120px; color:var(--muted); font-size:12.5px; font-weight:500; position:relative; }
.req-step:not(:last-child)::after{ content:""; flex:1; height:2px; background:var(--border); margin:0 4px; }
.rs-dot{ width:24px; height:24px; border-radius:50%; background:var(--surface-3); color:var(--muted); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; flex:none; }
.req-step.cur{ color:var(--ink); font-weight:600; }
.req-step.cur .rs-dot{ background:var(--brand); color:var(--on-brand); box-shadow:0 0 0 4px var(--brand-soft); }
.req-step.done{ color:var(--ink-2); }
.req-step.done .rs-dot{ background:var(--ok); color:#fff; }
.req-step.done::after{ background:var(--ok); }
.req-grid{ display:grid; grid-template-columns:1fr 1.2fr; gap:var(--gap); align-items:start; }
@media (max-width:900px){ .req-grid{ grid-template-columns:1fr; } }
.req-info .ri-row{ display:flex; justify-content:space-between; gap:14px; padding:11px 0; border-bottom:1px solid var(--border); font-size:13.5px; }
.req-info .ri-row:last-child{ border-bottom:none; }
.req-info .ri-row span{ color:var(--muted); }
.req-info .ri-row b{ font-weight:600; text-align:right; }
.req-action{ margin-top:var(--gap); }
.ra-h{ font-size:14px; font-weight:600; margin-bottom:12px; display:flex; align-items:center; gap:8px; }
.req-action.closed .ra-h{ color:var(--ok); }
.ra-stars{ display:flex; gap:6px; margin-bottom:14px; }
.ra-star{ border:none; background:transparent; color:var(--border-strong); padding:0; transition:.12s; }
.ra-star.on{ color:var(--warn); }
.ra-stars.ro .ra-star{ color:var(--border-strong); } .ra-stars.ro .ra-star.on{ color:var(--warn); }
.ra-btns{ display:flex; gap:10px; justify-content:flex-end; }
@media (max-width:520px){ .ra-btns{ flex-direction:column-reverse; } .ra-btns .btn{ width:100%; justify-content:center; } }

/* ---------------- Чат по заявке ---------------- */
.req-chat{ display:flex; flex-direction:column; height:480px; max-height:62vh; overflow:hidden; }
.rc-head{ display:flex; align-items:center; gap:9px; padding:14px 16px; border-bottom:1px solid var(--border); font-size:13.5px; font-weight:600; }
.rc-head .ic{ color:var(--brand); }
.rc-body{ flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:12px; }
.rc-sys{ text-align:center; }
.rc-sys span{ display:inline-block; font-size:11.5px; color:var(--muted); background:var(--surface-2); border:1px solid var(--border); border-radius:var(--r-pill); padding:4px 12px; }
.rc-time{ display:block; font-size:10.5px; opacity:.6; margin-top:4px; }
.rc-input{ display:flex; align-items:center; gap:8px; padding:12px 14px; border-top:1px solid var(--border); }
.rc-attach{ border:none; background:transparent; color:var(--muted); width:36px; height:36px; border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; flex:none; }
.rc-attach:hover{ background:var(--surface-2); color:var(--brand); }
.rc-input input{ flex:1; border:1px solid var(--border-2); border-radius:var(--r-pill); padding:10px 15px; font-family:inherit; font-size:13.5px; }
.rc-input input:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-softer); }
.rc-input .btn{ padding:0 14px; height:38px; }

/* ---------------- Заглушки (пост-MVP) ---------------- */
.stub{ text-align:center; max-width:480px; margin:30px auto; position:relative; padding:40px 28px; }
.stub-badge{ position:absolute; top:16px; right:16px; display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:600;
  color:var(--ink-2); background:var(--surface-3); border-radius:var(--r-pill); padding:4px 10px; }
.stub-ic{ width:64px; height:64px; border-radius:18px; background:var(--brand-soft); color:var(--brand); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.stub h3{ font-size:18px; margin:0 0 16px; }
.stub-list{ list-style:none; padding:0; margin:0 0 22px; display:inline-flex; flex-direction:column; gap:9px; text-align:left; }
.stub-list li{ display:flex; align-items:flex-start; gap:8px; font-size:13.5px; color:var(--ink-2); }
.stub-list li .ic{ color:var(--ok); flex:none; margin-top:2px; }

/* ---------------- Паспорт: редактируемые параметры (эпик 7) ---------------- */
.spec-list .row{ grid-template-columns:168px 1fr auto; align-items:center; }
.spec-list .row.editable{ cursor:pointer; border-radius:var(--r-sm); transition:.13s; margin:0 -10px; padding-left:10px; padding-right:10px; }
.spec-list .row.editable:hover{ background:var(--brand-softer); }
.spec-list .v-wrap{ min-width:0; }
.spec-list .param-hist{ display:flex; align-items:center; gap:5px; font-size:11px; color:var(--brand); margin-top:4px; font-weight:500; }
.spec-list .param-hist .ic{ color:var(--brand); }
.row-edit{ display:flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:var(--r-sm); color:var(--faint); opacity:0; transition:.13s; flex:none; }
.spec-list .row.editable:hover .row-edit{ opacity:1; color:var(--brand); background:var(--surface); }
.acc.editing .row-edit{ opacity:1; color:var(--ink-2); }
.acc-head .ah-fill{ width:54px; height:6px; flex:none; margin-right:4px; }
.acc-head .ah-edit{ width:32px; height:32px; border-radius:var(--r-sm); border:1px solid var(--border); background:var(--surface); color:var(--ink-2);
  display:flex; align-items:center; justify-content:center; flex:none; transition:.13s; }
.acc-head .ah-edit:hover{ border-color:var(--brand); color:var(--brand); }
.acc-head .ah-edit.on{ background:var(--brand); border-color:var(--brand); color:var(--on-brand); }
.add-param{ display:inline-flex; align-items:center; gap:7px; margin-top:13px; padding:9px 14px; border:1px dashed var(--border-strong); border-radius:var(--r-sm);
  background:var(--surface-2); color:var(--ink-2); font-size:13px; font-weight:600; transition:.13s; }
.add-param:hover{ border-color:var(--brand); color:var(--brand); background:var(--brand-softer); }

/* ---------------- Деталь / закрытие события ---------------- */
.ev-kv{ grid-template-columns:180px 1fr; }
.ev-kv .v .ev-type{ font-size:13px; }
.ev-linked{ display:flex; align-items:center; gap:11px; margin-top:14px; padding:12px 14px; border:1px solid var(--border); border-radius:var(--r-sm);
  cursor:pointer; transition:.13s; }
.ev-linked:hover{ border-color:var(--brand); background:var(--brand-softer); }
.ev-linked-ic{ width:34px; height:34px; border-radius:9px; background:var(--brand-soft); color:var(--brand); display:flex; align-items:center; justify-content:center; flex:none; }
.ev-linked-b{ flex:1; }
.ev-linked-b b{ font-size:13.5px; }
.seg2{ display:flex; gap:6px; margin-bottom:12px; }
.seg2 button{ flex:1; padding:9px 12px; border:1px solid var(--border-2); border-radius:var(--r-sm); background:var(--surface); color:var(--ink-2); font-size:13px; font-weight:600; transition:.13s; }
.seg2 button.on{ background:var(--brand); border-color:var(--brand); color:var(--on-brand); }
.md-note{ display:flex; align-items:flex-start; gap:8px; font-size:12px; color:var(--ink-2); background:var(--surface-2); border-radius:var(--r-sm);
  padding:10px 12px; margin-bottom:13px; line-height:1.4; }
.md-note .ic{ color:var(--brand); flex:none; margin-top:1px; }
.eq-check{ display:flex; flex-direction:column; gap:6px; margin-bottom:11px; }
.eqc{ display:flex; align-items:center; gap:10px; padding:10px 12px; border:1px solid var(--border); border-radius:var(--r-sm); font-size:13px; cursor:pointer; transition:.13s; }
.eqc:hover{ border-color:var(--brand); background:var(--brand-softer); }
.eqc input{ width:17px; height:17px; accent-color:var(--brand); flex:none; }

/* История параметра в модалке */
.param-log{ display:flex; flex-direction:column; gap:0; max-height:180px; overflow-y:auto; }
.pl-row{ display:flex; gap:11px; align-items:flex-start; padding:10px 0 10px 4px; position:relative; }
.pl-row:not(:last-child)::after{ content:""; position:absolute; left:8px; top:18px; bottom:-6px; width:2px; background:var(--border); }
.pl-dot{ width:10px; height:10px; border-radius:50%; background:var(--brand); border:2px solid var(--surface); box-shadow:0 0 0 2px var(--brand-soft); flex:none; margin-top:4px; z-index:1; }
.pl-row b{ font-size:13px; }

/* Кнопка-опасность */
.btn.ghost.danger{ color:var(--bad); }
.btn.ghost.danger:hover{ background:var(--bad-soft); border-color:var(--bad); }
.svc-open{ cursor:pointer; }
.svc-open:hover .svc-t{ color:var(--brand); }

/* ---------------- Финансы: категории + граница приватности (эпик 11) ---------------- */
.fin-cat{ font-weight:600; color:var(--ink-2); }
.fin-priv{ display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:600; padding:1px 7px; border-radius:var(--r-pill); }
.fin-priv .ic{ margin:-1px 0; }
.fin-priv.me{ background:var(--surface-3); color:var(--ink-2); }
.fin-priv.b2b{ background:var(--brand-soft); color:var(--brand-ink); }
.frx.link{ cursor:pointer; margin:0 -8px; padding-left:8px; padding-right:8px; border-radius:var(--r-sm); }
.frx.link:hover{ background:var(--surface-2); }
.frx.link:hover .frx-t{ color:var(--brand); }
.fin-note{ display:flex; gap:8px; align-items:flex-start; font-size:12px; color:var(--muted); margin-top:12px; padding:11px 13px; background:var(--surface-2); border-radius:var(--r-sm); line-height:1.5; }
.fin-note .ic{ flex:none; margin-top:1px; color:var(--brand); }

/* ---------------- Рекомендации по дому (эпик 9, MVP-эвристика) ---------------- */
.rec-deadline{ display:inline-flex; align-items:center; gap:4px; font-size:11.5px; font-weight:700; padding:3px 9px; border-radius:var(--r-pill); white-space:nowrap; }
.rec-deadline.bad{ background:var(--bad-soft); color:var(--bad); }
.rec-deadline.warn{ background:var(--warn-soft); color:var(--warn); }
.rec-deadline.ok{ background:var(--ok-soft); color:var(--ok); }
.reco-empty{ display:flex; gap:13px; align-items:center; padding:4px 0; }
.reco-empty .rec-ic{ width:36px; height:36px; border-radius:9px; display:flex; align-items:center; justify-content:center; flex:none; }
.reco-empty .rec-b{ flex:1; min-width:0; }
.reco-empty .rec-t{ font-size:14px; font-weight:600; }
.reco-empty .rec-d{ font-size:12.5px; color:var(--muted); margin-top:3px; line-height:1.45; }
.reco-empty .rec-acts{ flex:none; }

/* Кликабельные строки заполнения паспорта (раздел → экран) */
.frow.link{ cursor:pointer; border-radius:var(--r-sm); transition:.13s; }
.frow.link:hover .fn{ color:var(--brand); }
.frow.link .fn .ic{ color:var(--faint); margin-left:3px; vertical-align:middle; }

/* ============ §10 Виджет «Индекс дома» на Главной ============ */
.dash-index{ display:flex; gap:20px; align-items:center; margin-bottom:var(--gap); cursor:pointer; transition:.14s; }
.dash-index:hover{ border-color:var(--border-strong); }
.dash-index .ring{ width:86px; height:86px; }
.dash-index .ring .rv b{ font-size:24px; }
.dash-index .ring .rv span{ font-size:9px; }
.di-b{ flex:1; min-width:0; }
.di-h{ font-size:15px; font-weight:700; display:flex; align-items:center; gap:6px; }
.di-h .ic{ color:var(--brand); }
.di-s{ font-size:12px; color:var(--muted); margin:2px 0 9px; line-height:1.4; }
.di-bars{ display:flex; gap:18px; flex-wrap:wrap; }
.di-row{ display:flex; align-items:center; gap:8px; min-width:160px; flex:1; }
.di-l{ font-size:12px; color:var(--ink-2); white-space:nowrap; }
.di-row .bar{ flex:1; min-width:54px; }
.di-p{ font-size:12px; font-weight:700; color:var(--ink); width:34px; text-align:right; }
.di-cta{ flex:none; align-self:flex-start; display:flex; align-items:center; gap:5px; font-size:13px; font-weight:600; color:var(--brand); }
.di-cta .ic{ transition:transform .14s; }
.dash-index:hover .di-cta .ic{ transform:translateX(3px); }
@media (max-width:760px){ .dash-index{ flex-wrap:wrap; } .di-cta{ width:100%; } }
body.no-gami .dash-index{ display:none; }

/* ============ §10 Квесты / геймификация ============ */
.quest-hero{ display:flex; gap:24px; align-items:center; margin-bottom:var(--gap); }
.quest-hero .ring{ width:118px; height:118px; }
.qh-b{ flex:1; min-width:0; }
.qh-lvl{ font-size:17px; font-weight:600; display:flex; align-items:center; gap:7px; }
.qh-lvl .ic{ color:var(--brand); }
.qh-metrics{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
@media (max-width:680px){ .qh-metrics{ grid-template-columns:1fr; } .quest-hero{ flex-direction:column; align-items:flex-start; } }
.qh-metric .qh-mtop{ display:flex; justify-content:space-between; font-size:12.5px; color:var(--ink-2); margin-bottom:5px; }
.qh-metric .qh-mtop b{ color:var(--ink); }
.qh-w{ font-size:10.5px; color:var(--muted); margin-top:4px; text-transform:uppercase; letter-spacing:.05em; }
.quest-list{ display:flex; flex-direction:column; gap:10px; }
.quest{ display:flex; align-items:center; gap:13px; padding:13px 14px; border:1px solid var(--border); border-radius:var(--r-sm); background:var(--surface); transition:.13s; }
.quest:hover{ border-color:var(--border-strong); }
.quest.done{ opacity:.7; background:var(--surface-2); }
.quest .q-ic{ width:38px; height:38px; border-radius:10px; background:var(--brand-soft); color:var(--brand); display:flex; align-items:center; justify-content:center; flex:none; }
.quest.done .q-ic{ background:var(--ok-soft); color:var(--ok); }
.quest .q-b{ flex:1; min-width:0; }
.quest .q-t{ font-weight:600; font-size:14px; }
.quest .q-d{ font-size:12px; color:var(--muted); margin-top:1px; }
.quest .q-r{ font-size:11.5px; color:var(--brand); font-weight:600; margin-top:4px; display:inline-flex; align-items:center; gap:4px; }
.quest.done .q-r{ color:var(--ok); }
.ach-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gap); margin-bottom:var(--gap); }
@media (max-width:900px){ .ach-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .ach-grid{ grid-template-columns:1fr; } }
.ach{ border:1px solid var(--border); border-radius:var(--r); background:var(--surface); padding:16px 15px; text-align:center; transition:.14s; cursor:pointer; box-shadow:var(--shadow-1); }
.ach:hover{ border-color:var(--border-strong); transform:translateY(-2px); }
.ach-ic{ width:48px; height:48px; border-radius:13px; margin:0 auto 10px; display:flex; align-items:center; justify-content:center; background:var(--accent-warm-soft); color:var(--brown); }
.ach-nm{ font-weight:700; font-size:13.5px; }
.ach-d{ font-size:11.5px; color:var(--muted); margin:3px 0 9px; line-height:1.35; min-height:32px; }
.ach-badge{ display:inline-flex; align-items:center; gap:4px; font-size:10.5px; font-weight:700; padding:3px 9px; border-radius:var(--r-pill); background:var(--ok-soft); color:var(--ok); }
.ach-badge.lock{ background:var(--surface-3); color:var(--faint); }
.ach.locked{ opacity:.62; }
.ach.locked .ach-ic{ background:var(--surface-3); color:var(--faint); filter:grayscale(1); }

/* ============ §12 Маршрут мастера (Яндекс.Карты) ============ */
.route-days{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.rd-chip{ display:flex; align-items:center; gap:7px; border:1px solid var(--border-2); background:var(--surface); border-radius:var(--r-pill);
  padding:7px 14px; font-size:13px; font-weight:600; color:var(--ink-2); transition:.13s; text-transform:capitalize; }
.rd-chip:hover{ border-color:var(--border-strong); }
.rd-chip.on{ background:var(--brand); color:var(--on-brand); border-color:var(--brand); }
.rd-chip span{ font-size:11px; background:rgba(0,0,0,.08); border-radius:999px; padding:1px 7px; font-weight:700; }
.rd-chip.on span{ background:rgba(255,255,255,.22); }
.route-grid{ display:grid; grid-template-columns:1.35fr 1fr; gap:var(--gap); align-items:start; }
@media (max-width:920px){ .route-grid{ grid-template-columns:1fr; } }
.route-map{ position:relative; height:380px; }
.rm-svg{ position:absolute; inset:0; width:100%; height:100%; background:var(--surface-2); }
.rm-bg{ fill:var(--surface-2); }
.rm-grid{ stroke:var(--border); stroke-width:1; opacity:.6; vector-effect:non-scaling-stroke; }
.rm-route{ fill:none; stroke:var(--brand); stroke-width:3; stroke-linejoin:round; stroke-linecap:round; stroke-dasharray:3 7; opacity:.9; vector-effect:non-scaling-stroke; }
.rm-mk{ position:absolute; transform:translate(-50%,-50%); width:30px; height:30px; border-radius:50%; background:var(--brand); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700; border:3px solid #fff; box-shadow:0 2px 6px rgba(0,0,0,.25); z-index:2; }
.rm-mk.base{ width:20px; height:20px; background:var(--ok); }
.rm-mk.base::after{ content:""; width:6px; height:6px; border-radius:50%; background:#fff; }
.rm-attr{ position:absolute; left:12px; bottom:12px; z-index:3; display:flex; align-items:center; gap:5px; font-size:11px; font-weight:600;
  color:var(--ink-2); background:var(--surface); border:1px solid var(--border); border-radius:var(--r-pill); padding:4px 10px; box-shadow:var(--shadow-1); }
.rm-attr .ic{ color:var(--brand); }
.route-list{ display:flex; flex-direction:column; }
.rl-base{ display:flex; align-items:center; gap:7px; font-size:12.5px; color:var(--ink-2); padding:8px 11px; background:var(--ok-soft); border-radius:var(--r-sm); margin-bottom:11px; }
.rl-base .ic{ color:var(--ok); }
.rl-stop{ display:flex; gap:12px; padding:11px 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.rl-num{ width:26px; height:26px; border-radius:50%; background:var(--brand); color:var(--on-brand); display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; flex:none; }
.rl-b{ flex:1; min-width:0; }
.rl-t{ font-size:13.5px; font-weight:600; }
.rl-m{ font-size:12px; color:var(--muted); display:flex; align-items:center; gap:5px; margin-top:2px; }
.rl-m .ic{ color:var(--faint); flex:none; }
.rl-acts{ display:flex; flex-direction:column; align-items:flex-end; gap:6px; flex:none; }

/* ============ §13 Дашборды администратора ============ */
.adm-rolebar{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:var(--gap); }
.adm-rolebar .seg{ display:inline-flex; background:var(--surface-2); border:1px solid var(--border); border-radius:9px; padding:3px; }
.adm-rolebar .seg button{ border:none; background:transparent; padding:8px 13px; border-radius:7px; font-size:12.5px; font-weight:600; color:var(--muted); display:flex; align-items:center; gap:6px; transition:.13s; }
.adm-rolebar .seg button.on{ background:var(--surface); color:var(--ink); box-shadow:var(--shadow-1); }
.adm-role-note{ display:inline-flex; align-items:center; gap:6px; font-size:12px; color:var(--muted); font-weight:500; }
.adm-role-note .ic{ color:var(--brand); }
.adm-grid{ display:grid; grid-template-columns:1.5fr 1fr; gap:var(--gap); margin-bottom:var(--gap); align-items:start; }
@media (max-width:900px){ .adm-grid{ grid-template-columns:1fr; } }
.adm-statuses{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:16px; }
.adm-st{ display:flex; flex-direction:column; align-items:center; gap:5px; flex:1; min-width:60px; }
.adm-st-n{ justify-content:center; min-width:38px; font-size:14px; padding:5px 10px; }
.adm-st-l{ font-size:11px; color:var(--muted); font-weight:500; }
.adm-bars{ display:flex; flex-direction:column; gap:9px; }
.adm-bar-row{ display:flex; align-items:center; gap:11px; }
.adm-bar-l{ font-size:12px; color:var(--ink-2); width:88px; flex:none; }
.adm-bar-row .bar{ flex:1; }
.adm-bar-v{ font-size:12px; font-weight:700; width:26px; text-align:right; }
.adm-pilot-big{ font-size:34px; font-weight:700; letter-spacing:-.02em; line-height:1; }
.adm-pilot-big span{ font-size:16px; color:var(--muted); font-weight:600; margin-left:4px; }
.adm-pilot-foot{ display:flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600; margin-top:10px; }
.adm-pilot-foot.ok{ color:var(--ok); } .adm-pilot-foot.warn{ color:var(--warn); }
.adm-unit{ border-radius:var(--r-sm); }
.adm-unit-head{ cursor:pointer; }
.adm-unit-head .svc-t{ font-size:14px; }
.adm-unit.open .adm-unit-head{ background:var(--surface-2); }
.adm-unit-body{ display:grid; grid-template-columns:repeat(3,1fr); gap:11px 18px; padding:14px 14px 16px; border-bottom:1px solid var(--border); background:var(--surface-2); }
@media (max-width:680px){ .adm-unit-body{ grid-template-columns:1fr 1fr; } }
.adm-uk{ display:flex; flex-direction:column; gap:2px; }
.adm-uk span{ font-size:11px; color:var(--muted); }
.adm-uk b{ font-size:14px; }

/* §9 Сервисная книжка — строки истории */
.svc.hist{ cursor:pointer; }
.svc.hist:hover{ background:var(--surface-2); }
.svc-ic.ok{ background:var(--ok-soft); color:var(--ok); }
.svc.hist .job-price{ color:var(--ink); }

/* Вкладка «ТО и история» — записи по единице (AC-3) */
.dw-sec-t{ font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); margin:16px 0 8px; }
.dw-eqhist{ display:flex; flex-direction:column; gap:7px; }
.dw-eqh{ display:flex; align-items:center; gap:10px; padding:9px 11px; border:1px solid var(--border); border-radius:var(--r-sm); cursor:pointer; transition:.12s; background:var(--surface); }
.dw-eqh:hover{ border-color:var(--border-strong); background:var(--surface-2); }
.dw-eqh-ic{ width:26px; height:26px; border-radius:50%; background:var(--ok-soft); color:var(--ok); display:flex; align-items:center; justify-content:center; flex:none; }
.dw-eqh-b{ flex:1; min-width:0; }
.dw-eqh-t{ font-size:13px; font-weight:600; }
.dw-eqh-m{ font-size:11.5px; color:var(--muted); margin-top:1px; }
.dw-eqh-c{ font-size:12.5px; font-weight:700; color:var(--ink); flex:none; }
.dw-acts{ display:flex; gap:9px; margin-top:16px; }
.dw-safety{ display:flex; gap:9px; align-items:flex-start; font-size:12px; line-height:1.45; padding:10px 12px; border-radius:var(--r-sm); margin-top:14px; }
.dw-safety.gas{ background:var(--bad-soft, #fbecea); color:var(--bad); }
.dw-safety.elec{ background:var(--warn-soft); color:var(--warn); }
.dw-safety .ic{ flex:none; margin-top:1px; }

/* §10а Режим Полный/Лайт */
.mode-pick{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:6px; }
@media (max-width:520px){ .mode-pick{ grid-template-columns:1fr; } }
.mode-opt{ text-align:left; border:1.5px solid var(--border); background:var(--surface); border-radius:var(--r-sm); padding:12px 13px; transition:.13s; cursor:pointer; }
.mode-opt:hover{ border-color:var(--border-strong); }
.mode-opt.on{ border-color:var(--brand); background:var(--brand-soft); }
.mode-opt .mo-top{ display:flex; align-items:center; gap:7px; font-size:14px; }
.mode-opt .mo-top .ic{ color:var(--brand); }
.mode-opt .mo-badge{ margin-left:auto; display:inline-flex; align-items:center; gap:3px; font-size:10.5px; font-weight:700; color:var(--brand); background:var(--surface); border-radius:var(--r-pill); padding:2px 8px; }
.mode-opt .mo-d{ font-size:11.5px; color:var(--muted); margin-top:5px; line-height:1.4; }
.md-hr{ height:1px; background:var(--border); margin:16px 0; }
.lite-master{ margin-bottom:var(--gap); }
[data-screen="dashboard"].lite .master-card{ max-width:none; }
