/* =============================================================================
   РеабCV · Фаза 0 — стили рабочего прототипа
   Токены и визуальный язык — из утверждённого дизайна (tokens.css / patient.css),
   встроены сюда, чтобы прототип был самодостаточным.
   ============================================================================= */

:root{
  /* Бренд / клинический */
  --primary:#0E7F73; --primary-600:#0B6A60; --primary-700:#095A51;
  --primary-050:#E3F1EF; --primary-100:#CBE7E2;
  /* Нейтрали */
  --bg:#F1F5F4; --surface:#FFFFFF; --surface-2:#F7FAF9;
  --ink:#14201D; --ink-2:#42524D; --ink-3:#73837E; --line:#E1E9E6; --line-2:#EDF2F0;
  /* Светофор — поверхностные */
  --ok:#1E9E63; --ok-050:#E5F4EC; --ok-200:#B9E3CB;
  --warn:#C9821B; --warn-050:#FAEFD8; --warn-200:#F0D5A0;
  --err:#D8483F; --err-050:#FBE7E4; --err-200:#F2C2BD;
  /* Светофор — live (поверх тёмного видео) */
  --ok-live:#3BD27F; --warn-live:#FFB13C; --err-live:#FF5A4C;
  --ok-glow:rgba(59,210,127,.55); --warn-glow:rgba(255,177,60,.60); --err-glow:rgba(255,90,76,.62);
  /* Радиусы / тени */
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:32px; --r-pill:999px;
  --sh-1:0 1px 2px rgba(20,32,29,.06),0 2px 8px rgba(20,32,29,.05);
  --sh-2:0 6px 16px rgba(20,32,29,.08),0 2px 6px rgba(20,32,29,.05);
  --sh-3:0 20px 48px rgba(20,32,29,.14);
  --font:'Golos Text',system-ui,-apple-system,sans-serif;
  --touch-patient:64px; --touch-min:48px;
}
*{box-sizing:border-box;}
html,body{margin:0;height:100%;background:#0d141a;font-family:var(--font);color:var(--ink);-webkit-font-smoothing:antialiased;}

/* --- сцена: «планшет на тумбе», читается через комнату --- */
.stage{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#11181d;}
.device{position:relative;width:min(100vw,520px);height:100dvh;max-height:1000px;overflow:hidden;background:#0d141a;box-shadow:0 30px 80px rgba(0,0,0,.5);}
@media(min-width:560px){ .device{border-radius:34px;border:10px solid #05080a;height:min(100dvh,920px);} }

/* экраны UI — поверх постоянного слоя камеры; каждый со своим контекстом */
.screen{position:absolute;inset:0;display:none;z-index:2;}
.screen.active{display:block;}

/* постоянный слой камеры (P-2 и P-3) — свой стек-контекст ниже экранов,
   чтобы рамка-светофор/скримы не «протекали» поверх светлых экранов */
.camlayer{z-index:1;}

/* ---------------- общий тёмный холст камеры ---------------- */
.scr{position:absolute;inset:0;overflow:hidden;color:#fff;}
.scr.styl{background:radial-gradient(120% 80% at 38% 30%,#2b3a45 0%,#1a242c 48%,#0d141a 100%);}
#cam{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;background:#0d141a;}
.scr.styl #cam{opacity:0;}              /* скелет на тёмном фоне — приватность/контраст */
#overlay{position:absolute;inset:0;width:100%;height:100%;z-index:4;pointer-events:none;}
.grain{position:absolute;inset:0;opacity:.06;background-image:radial-gradient(rgba(255,255,255,.6) .5px,transparent .5px);background-size:3px 3px;mix-blend-mode:screen;z-index:3;pointer-events:none;}
.vig{position:absolute;inset:0;box-shadow:inset 0 0 140px 40px rgba(0,0,0,.5);z-index:3;pointer-events:none;}
.scrim-top{position:absolute;top:0;left:0;right:0;height:230px;z-index:5;pointer-events:none;background:linear-gradient(180deg,rgba(8,12,14,.74),rgba(8,12,14,.18) 60%,transparent);}
.scrim-bot{position:absolute;bottom:0;left:0;right:0;height:380px;z-index:5;pointer-events:none;background:linear-gradient(0deg,rgba(8,12,14,.88),rgba(8,12,14,.32) 55%,transparent);}

.edge{position:absolute;inset:0;z-index:6;pointer-events:none;transition:box-shadow .4s ease;}
.edge[data-s="good"]{box-shadow:inset 0 0 0 6px var(--ok-live),inset 0 0 44px 4px var(--ok-glow);}
.edge[data-s="warn"]{box-shadow:inset 0 0 0 7px var(--warn-live),inset 0 0 52px 6px var(--warn-glow);animation:edgePulse 1.4s ease-in-out infinite;}
.edge[data-s="err"]{box-shadow:inset 0 0 0 9px var(--err-live),inset 0 0 64px 8px var(--err-glow);animation:edgePulse .85s ease-in-out infinite;}
@keyframes edgePulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.5)}}

/* ---------------- оверлеи P-3 ---------------- */
.ov{position:absolute;z-index:8;color:#fff;}
.glass{background:rgba(18,26,32,.42);backdrop-filter:blur(14px) saturate(150%);-webkit-backdrop-filter:blur(14px) saturate(150%);border:1px solid rgba(255,255,255,.14);}
.topbar{top:40px;left:16px;right:16px;display:flex;justify-content:space-between;align-items:center;gap:10px;z-index:9;}
.topbar .row-chips{display:flex;gap:8px;}
.chip{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:var(--r-pill);font-size:15px;font-weight:600;color:#fff;}
.chip.btn-chip{cursor:pointer;border:1px solid rgba(255,255,255,.14);background:rgba(18,26,32,.42);}
.rec{width:10px;height:10px;border-radius:50%;background:var(--err-live);animation:rec 1.6s ease-out infinite;flex-shrink:0;}
@keyframes rec{0%{box-shadow:0 0 0 0 rgba(255,90,76,.6)}100%{box-shadow:0 0 0 9px rgba(255,90,76,0)}}

.reps{top:104px;right:18px;text-align:right;text-shadow:0 2px 18px rgba(0,0,0,.6);}
.reps .num{font-size:150px;font-weight:900;line-height:.84;letter-spacing:-.04em;font-variant-numeric:tabular-nums;}
.reps .num.pop{animation:pop .35s ease;}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.06)}100%{transform:scale(1)}}
.reps .of{font-size:30px;font-weight:700;color:rgba(255,255,255,.8);margin-top:6px;}
.reps .lbl{font-size:22px;font-weight:600;color:rgba(255,255,255,.66);margin-top:2px;}
.rom{left:22px;top:330px;text-shadow:0 2px 14px rgba(0,0,0,.6);}
.rom .v{font-size:74px;font-weight:800;line-height:.9;font-variant-numeric:tabular-nums;}
.rom .l{font-size:18px;font-weight:600;color:rgba(255,255,255,.7);margin-top:2px;}

.dock{left:14px;right:14px;bottom:30px;z-index:9;display:flex;flex-direction:column;gap:12px;}
.cap{border-radius:var(--r-lg);padding:16px 18px;display:flex;gap:14px;align-items:center;}
.statusbadge{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px;width:78px;}
.sb-ico{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:30px;color:#0d141a;background:var(--ok-live);}
.sb-word{font-size:17px;font-weight:800;color:var(--ok-live);}
.cap-body{flex:1;min-width:0;}
.cap-top{display:flex;align-items:center;gap:9px;margin-bottom:5px;}
.cap-top span{font-size:13px;font-weight:600;color:rgba(255,255,255,.62);letter-spacing:.04em;text-transform:uppercase;}
.wave{display:flex;align-items:flex-end;gap:3px;height:18px;}
.wave i{width:3px;background:#fff;border-radius:2px;height:5px;}
.speaking .wave i{animation:wv .9s ease-in-out infinite;}
.speaking .wave i:nth-child(2){animation-delay:.12s}.speaking .wave i:nth-child(3){animation-delay:.24s}
.speaking .wave i:nth-child(4){animation-delay:.36s}.speaking .wave i:nth-child(5){animation-delay:.18s}
@keyframes wv{0%,100%{height:5px}50%{height:18px}}
.cap-text{font-size:25px;font-weight:600;line-height:1.18;text-wrap:pretty;}
.muted-line{font-size:15px;color:rgba(255,255,255,.55);font-weight:500;margin-top:2px;}
.actions{display:flex;gap:12px;}
.abtn{flex:1;height:64px;border-radius:var(--r-md);border:0;font-family:inherit;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;}
.abtn-repeat{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.22);}
.abtn-stop{background:#fff;color:#16201d;flex:0 0 118px;}

/* ---------------- P-2 калибровка ---------------- */
.guide-banner{position:absolute;top:40px;left:16px;right:16px;z-index:9;border-radius:var(--r-lg);padding:16px 18px;display:flex;gap:13px;align-items:center;}
.guide-banner .gtext{font-size:19px;font-weight:700;line-height:1.25;}
.guide-banner .gsub{font-size:14px;color:rgba(255,255,255,.6);font-weight:500;margin-top:2px;}
.see-pill{position:absolute;bottom:48px;left:50%;transform:translateX(-50%);z-index:9;display:flex;align-items:center;gap:10px;padding:14px 22px;border-radius:var(--r-pill);font-size:19px;font-weight:700;white-space:nowrap;}
.see-pill.ok{background:var(--ok-live);color:#0d141a;}
.see-pill.no{background:rgba(18,26,32,.55);color:#fff;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(10px);}
.count-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9;width:128px;height:128px;display:none;}
.count-ring.show{display:block;}
.count-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:62px;font-weight:900;color:#fff;}

/* ---------------- P-1/permission/review (свет) ---------------- */
.light{position:absolute;inset:0;background:var(--bg);color:var(--ink);display:flex;flex-direction:column;padding:64px 22px 40px;overflow:auto;}
.kicker{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin:0 0 10px;}
.light h1{font-size:28px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px;}
.light .lead{font-size:16px;line-height:1.5;color:var(--ink-2);margin:0 0 22px;text-wrap:pretty;}
.exseg{display:flex;gap:6px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);padding:5px;margin:0 0 16px;box-shadow:var(--sh-1);}
.exseg button{flex:1;border:0;background:transparent;font-family:inherit;font-size:15px;font-weight:700;color:var(--ink-2);padding:12px 8px;border-radius:var(--r-pill);cursor:pointer;transition:.15s;}
.exseg button.on{background:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(14,127,115,.28);}

.excard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh-2);padding:22px;margin-bottom:18px;}
.exhead{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
.exico{width:60px;height:60px;border-radius:var(--r-md);background:var(--primary-050);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:30px;}
.exname{font-size:23px;font-weight:800;letter-spacing:-.01em;line-height:1.12;}
.exmeta{font-size:15px;color:var(--ink-3);margin-top:3px;font-weight:500;}
.instr{display:flex;gap:11px;background:var(--surface-2);border-radius:var(--r-md);padding:14px;font-size:16px;line-height:1.4;color:var(--ink-2);}
.stat-row{display:flex;gap:10px;margin-top:16px;}
.stat{flex:1;background:var(--surface-2);border-radius:var(--r-md);padding:12px 8px;text-align:center;}
.stat b{display:block;font-size:24px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;}
.stat span{font-size:12.5px;color:var(--ink-3);font-weight:600;}
.spacer{flex:1;min-height:14px;}
.privacy{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--ink-3);font-weight:500;line-height:1.4;margin:4px 0 16px;}
.privacy b{color:var(--ink-2);}

.btn-primary{height:var(--touch-patient);border-radius:var(--r-lg);border:0;background:var(--primary);color:#fff;font-family:inherit;font-size:22px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;width:100%;box-shadow:0 8px 22px rgba(14,127,115,.32);transition:.15s;}
.btn-primary:active{transform:scale(.985);background:var(--primary-600);}
.btn-primary[disabled]{opacity:.6;cursor:default;}
.btn-ghost{height:56px;border-radius:var(--r-lg);border:1.5px solid var(--line);background:var(--surface);color:var(--ink);font-family:inherit;font-size:18px;font-weight:700;cursor:pointer;width:100%;}

/* ---------------- P-4 разбор ---------------- */
.done-badge{display:flex;align-items:center;gap:10px;color:var(--ok);font-weight:700;font-size:16px;margin-bottom:6px;}
.metric-row{display:flex;gap:12px;margin-bottom:16px;}
.metric{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:16px;}
.metric .mv{font-size:40px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums;}
.metric .ml{font-size:13.5px;color:var(--ink-3);font-weight:600;margin-top:6px;}
.metric .delta{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:700;color:var(--ok);background:var(--ok-050);padding:3px 8px;border-radius:var(--r-pill);margin-top:8px;}
.focus{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:18px;margin-bottom:16px;}
.focus h3{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin:0 0 14px;}
.fitem{display:flex;gap:13px;align-items:flex-start;margin-bottom:14px;}
.fitem:last-child{margin-bottom:0;}
.fico{width:42px;height:42px;border-radius:var(--r-sm);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:24px;color:#fff;}
.ftitle{font-size:18px;font-weight:700;line-height:1.2;}
.ftip{font-size:15px;color:var(--ink-2);line-height:1.4;margin-top:4px;}
.praise{background:linear-gradient(180deg,var(--primary-050),var(--surface));border:1px solid var(--primary-100);border-radius:var(--r-lg);padding:16px 18px;font-size:17px;font-weight:600;color:var(--primary-700);line-height:1.35;margin-bottom:18px;}
.p4-actions{display:flex;flex-direction:column;gap:10px;margin-top:auto;}

/* ---------------- настройки голоса (модаль) ---------------- */
.sheet{position:absolute;inset:0;z-index:20;background:rgba(8,12,14,.55);backdrop-filter:blur(4px);display:none;align-items:flex-end;}
.sheet.show{display:flex;}
.sheet-card{width:100%;background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:22px 22px 28px;color:var(--ink);max-height:86%;overflow:auto;}
.sheet-card h2{font-size:21px;font-weight:800;margin:0 0 16px;}
.set-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-top:1px solid var(--line-2);}
.set-row:first-of-type{border-top:0;}
.set-l b{font-size:16px;font-weight:700;display:block;}
.set-l span{font-size:13.5px;color:var(--ink-3);}
.toggle{width:58px;height:34px;border-radius:var(--r-pill);background:var(--line);border:0;position:relative;cursor:pointer;transition:.18s;flex-shrink:0;}
.toggle[data-on="true"]{background:var(--primary);}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:28px;height:28px;border-radius:50%;background:#fff;box-shadow:var(--sh-1);transition:.18s;}
.toggle[data-on="true"]::after{transform:translateX(24px);}
.rng{flex:1;-webkit-appearance:none;appearance:none;height:8px;border-radius:var(--r-pill);background:var(--line);outline:0;}
.rng::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:var(--sh-1);}
.rng::-moz-range-thumb{width:26px;height:26px;border:0;border-radius:50%;background:var(--primary);cursor:pointer;}
.rng-v{font-size:15px;font-weight:800;width:54px;text-align:right;font-variant-numeric:tabular-nums;}
.vsel{width:100%;font-family:inherit;font-size:15px;padding:12px;border-radius:var(--r-md);border:1.5px solid var(--line);background:var(--surface);color:var(--ink);}
.sheet-card .btn-primary{margin-top:18px;}

/* загрузка движка */
.loading{position:absolute;inset:0;z-index:30;background:rgba(8,12,14,.82);display:none;flex-direction:column;align-items:center;justify-content:center;gap:18px;color:#fff;text-align:center;padding:30px;}
.loading.show{display:flex;}
.spinner{width:46px;height:46px;border-radius:50%;border:4px solid rgba(255,255,255,.2);border-top-color:var(--ok-live);animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.loading .lt{font-size:18px;font-weight:700;}
.loading .ls{font-size:14px;color:rgba(255,255,255,.6);max-width:300px;line-height:1.4;}

.toast{position:absolute;left:16px;right:16px;bottom:20px;z-index:40;background:var(--err);color:#fff;border-radius:var(--r-md);padding:14px 16px;font-size:14px;font-weight:600;display:none;}
.toast.show{display:block;}

/* ---------------- демо-панель (только при ?demo) ---------------- */
.demobar{position:absolute;top:6px;left:6px;right:6px;z-index:50;display:flex;flex-wrap:wrap;gap:6px;align-items:center;
  background:rgba(8,12,14,.85);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:7px 8px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
.demobar b{color:var(--warn-live);font-size:11px;font-weight:800;letter-spacing:.12em;margin-right:2px;}
.demobar .sep{flex:1;}
.demobar button{font-family:inherit;font-size:13px;font-weight:700;color:#fff;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:6px 10px;cursor:pointer;line-height:1;}
.demobar button:hover{background:rgba(255,255,255,.22);}

/* доступность: уважать reduce-motion (убрать пульсации, оставить цвет+форму) */
@media(prefers-reduced-motion:reduce){
  .edge[data-s]{animation:none!important;}
  .rec{animation:none!important;}
  .reps .num.pop{animation:none!important;}
  .speaking .wave i{animation:none!important;height:11px;}
}
