/* Точка опоры — дизайн-система веб-лица (см. docs/DESIGN.md). Регистр: product. */

/* ===== ТОКЕНЫ ===== */
:root{
  /* тёмная (вайб C — тёплый эспрессо), по умолчанию */
  --bg:oklch(0.18 0.014 50);
  --surface:oklch(0.215 0.015 50);
  --surface-2:oklch(0.25 0.016 50);
  --rail:oklch(0.155 0.013 48);
  --ink:oklch(0.96 0.006 60);
  --ink-soft:oklch(0.745 0.012 55);
  --ink-faint:oklch(0.625 0.012 55);
  --line:oklch(0.31 0.014 50);
  --line-soft:oklch(0.265 0.013 50);
  --accent:oklch(0.70 0.15 42);
  --accent-bg:oklch(0.30 0.07 42);
  --accent-ink:oklch(0.17 0.03 42);
  --acute:oklch(0.67 0.20 28);
  --acute-bg:oklch(0.30 0.10 28);
  --acute-line:oklch(0.47 0.14 28);
  --acute-quote:oklch(0.88 0.05 32);
  --attention:oklch(0.81 0.13 82);
  --attention-bg:oklch(0.30 0.06 82);
  --attention-line:oklch(0.46 0.08 82);
  --ok:oklch(0.77 0.14 155);
  --ok-bg:oklch(0.30 0.07 155);
  --shadow:0 10px 30px -22px oklch(0 0 0 / .7);

  --sans:"IBM Plex Sans",system-ui,-apple-system,Segoe UI,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,monospace;
  --maxw:960px;
  color-scheme:dark;
}
[data-theme="light"]{
  --bg:oklch(0.985 0.004 60);
  --surface:oklch(1 0 0);
  --surface-2:oklch(0.965 0.006 60);
  --rail:oklch(0.972 0.006 60);
  --ink:oklch(0.24 0.012 50);
  --ink-soft:oklch(0.455 0.012 50);
  --ink-faint:oklch(0.515 0.012 50);
  --line:oklch(0.915 0.006 60);
  --line-soft:oklch(0.945 0.005 60);
  --accent:oklch(0.485 0.17 38);
  --accent-bg:oklch(0.955 0.038 40);
  --accent-ink:oklch(0.99 0.01 40);
  --acute:oklch(0.53 0.20 25);
  --acute-bg:oklch(0.965 0.035 28);
  --acute-line:oklch(0.84 0.10 28);
  --acute-quote:oklch(0.34 0.07 30);
  --attention:oklch(0.52 0.12 66);
  --attention-bg:oklch(0.965 0.045 80);
  --attention-line:oklch(0.86 0.08 80);
  --ok:oklch(0.50 0.12 150);
  --ok-bg:oklch(0.94 0.05 150);
  --shadow:0 10px 28px -20px oklch(0.4 0.05 50 / .45);
  color-scheme:light;
}

*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}

/* ===== САЙДБАР ===== */
.rail{background:var(--rail);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:20px 14px}
.brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px;padding:6px 8px 22px;letter-spacing:-.01em}
.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}
.nav{display:flex;flex-direction:column;gap:2px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:7px;color:var(--ink-soft);font-weight:500;transition:background .14s,color .14s}
.nav a .ic{width:17px;font-size:14px;opacity:.85;text-align:center}
.nav a:hover{background:var(--surface);color:var(--ink)}
.nav a.on{background:var(--accent-bg);color:var(--accent);font-weight:600}
.nav a .badge{margin-left:auto;font-family:var(--mono);font-size:11px;background:var(--surface);border:1px solid var(--line);color:var(--ink-soft);padding:1px 7px;border-radius:20px}
.nav a.on .badge{background:var(--accent);color:var(--accent-ink);border-color:transparent}
.rail .who{margin-top:auto;display:flex;align-items:center;gap:10px;padding:12px 8px 2px;border-top:1px solid var(--line)}
.rail .who .av{width:32px;height:32px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:grid;place-items:center;font-weight:700;font-size:12px}
.rail .who .nm{font-weight:600;font-size:13px}
.rail .who .rl{font-size:12px;color:var(--ink-faint)}
.rail .who .out{margin-left:auto;font-size:12px;color:var(--ink-faint)}
.rail .who .out:hover{color:var(--accent)}

/* ===== СТАТУС-СТРОКА ===== */
.topbar{display:flex;align-items:center;gap:18px;padding:11px 30px;border-bottom:1px solid var(--line);background:var(--rail);font-family:var(--mono);font-size:12px;color:var(--ink-faint)}
.topbar .st{display:flex;align-items:center;gap:7px}
.topbar .st b{color:var(--ink);font-weight:500}
.topbar .live{width:7px;height:7px;border-radius:50%;background:var(--ok)}
.topbar .r{color:var(--acute)} .topbar .y{color:var(--attention)}
.seg{margin-left:auto;display:inline-flex;border:1px solid var(--line);border-radius:20px;overflow:hidden}
.seg button{font-family:var(--mono);font-size:12px;padding:4px 11px;background:transparent;border:none;color:var(--ink-faint);cursor:pointer;transition:background .14s,color .14s}
.seg button.on{background:var(--surface-2);color:var(--ink)}

/* ===== КОНТЕНТ ===== */
.main{padding:30px 36px 60px;max-width:var(--maxw)}
.head h1{font-size:24px;font-weight:700;letter-spacing:-.02em}
.head .sub{color:var(--ink-soft);margin-top:5px;font-size:14.5px}
.head .sub b{color:var(--ink);font-weight:600}
.section-h{font-size:13px;font-weight:600;color:var(--ink-faint);margin:30px 0 12px;text-transform:none}

/* чипы-фильтры */
.chips{display:flex;gap:8px;margin:20px 0 6px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border:1px solid var(--line);background:var(--surface);border-radius:20px;font-weight:500;font-size:13px;color:var(--ink-soft);cursor:pointer;transition:border-color .14s,color .14s}
.chip:hover{border-color:var(--ink-faint);color:var(--ink)}
.chip.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.chip .ct{font-family:var(--mono);font-size:12px;opacity:.85}
.chip .ldot{width:8px;height:8px;border-radius:50%}
.ldot.r{background:var(--acute)} .ldot.y{background:var(--attention)}

/* ===== ОЧЕРЕДЬ ===== */
.list{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.item{background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:16px 18px;transition:background .14s,border-color .14s,box-shadow .18s}
.item:hover{border-color:var(--ink-faint);box-shadow:var(--shadow)}
.item.acute{background:color-mix(in oklab,var(--surface) 80%,var(--acute-bg));border-color:var(--acute-line)}
.row1{display:flex;align-items:center;gap:11px;flex-wrap:wrap}
.lvl{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:7px}
.lvl.r{background:var(--acute);color:oklch(0.99 0.02 28)}
.lvl.y{background:var(--attention-bg);color:var(--attention);border:1px solid var(--attention-line)}
.lvl.ok{background:var(--ok-bg);color:var(--ok)}
.lvl.n{background:var(--surface-2);color:var(--ink-soft);border:1px solid var(--line)}
.lvl .d{width:7px;height:7px;border-radius:50%;background:currentColor}
.who2{font-weight:600;font-size:15px}
.meta{color:var(--ink-faint);font-size:13px;font-family:var(--mono)}
.age{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--ink-faint)}
.quote{margin:11px 0 0;color:var(--ink-soft);font-size:14.5px;line-height:1.55;max-width:64ch}
.item.acute .quote{color:var(--acute-quote)}
.urg{display:inline-flex;align-items:center;gap:8px;margin-top:12px;font-size:13px;font-weight:600;color:var(--acute)}
.actions{display:flex;gap:9px;margin-top:14px;flex-wrap:wrap}
.actions form{display:contents}
.btn{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;padding:8px 15px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--ink);cursor:pointer;transition:background .14s,border-color .14s}
.btn:hover{background:var(--surface-2);border-color:var(--ink-faint)}
.btn.pri{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.btn.pri:hover{filter:brightness(1.06)}
.done{display:flex;align-items:center;gap:10px;margin-top:20px;padding:13px 17px;border:1px solid var(--line-soft);border-radius:11px;color:var(--ink-soft);font-size:13.5px}
.done .ch{width:20px;height:20px;border-radius:50%;background:var(--ok-bg);color:var(--ok);display:grid;place-items:center;font-size:12px;font-weight:700}
.done b{color:var(--ink);font-weight:600}

/* пустое состояние */
.empty{margin-top:18px;padding:34px 24px;border:1px dashed var(--line);border-radius:12px;text-align:center;color:var(--ink-soft)}
.empty .big{font-size:16px;color:var(--ink);font-weight:600;margin-bottom:6px}

/* ===== ОБЗОР УЧАСТНИКОВ ===== */
.plist{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface);margin-top:6px}
.prow{display:flex;align-items:center;gap:14px;padding:14px 18px;border-top:1px solid var(--line-soft);transition:background .14s}
.prow:first-child{border-top:none}
.prow:hover{background:var(--surface-2)}
.prow .pname{font-weight:600;font-size:14.5px;min-width:160px}
.prow .pstats{display:flex;gap:8px 16px;flex-wrap:wrap;font-family:var(--mono);font-size:12.5px;color:var(--ink-faint)}
.prow .pstats b{color:var(--ink);font-weight:500}
.prow .pwheel{margin-left:auto;font-family:var(--mono);font-size:12.5px;color:var(--ink-soft);white-space:nowrap}
.prow .pwheel .drop{color:var(--acute)}
.tag{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px;border:1px solid var(--line)}
.tag.risk{background:var(--attention-bg);color:var(--attention);border-color:var(--attention-line)}
.risk-reasons{font-family:var(--mono);font-size:12px;color:var(--attention)}

/* ===== КАРТОЧКА УЧАСТНИКА ===== */
.crumb{font-size:13px;color:var(--ink-faint);margin-bottom:10px}
.crumb a:hover{color:var(--accent)}
.stat-row{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.stat{flex:1;min-width:150px;border:1px solid var(--line);border-radius:11px;padding:15px 17px;background:var(--surface)}
.stat .k{font-size:12.5px;color:var(--ink-faint)}
.stat .v{font-size:22px;font-weight:700;margin-top:4px;letter-spacing:-.01em}
.stat .v.money{color:var(--acute)}
.stat .v.credit{color:var(--ok)}
.stat .sub2{font-size:12px;color:var(--ink-faint);margin-top:3px;font-family:var(--mono)}

.wheel{margin-top:10px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface)}
.wheel .wrow{display:flex;align-items:center;gap:12px;padding:11px 16px;border-top:1px solid var(--line-soft)}
.wheel .wrow:first-child{border-top:none}
.wheel .wlabel{min-width:130px;font-size:14px}
.wheel .wbar{flex:1;height:8px;border-radius:6px;background:var(--surface-2);overflow:hidden}
.wheel .wbar i{display:block;height:100%;background:var(--accent);border-radius:6px}
.wheel .wscore{font-family:var(--mono);font-size:13px;min-width:28px;text-align:right;color:var(--ink)}
.wheel .wdelta{font-family:var(--mono);font-size:12px;min-width:42px;text-align:right}
.wdelta.up{color:var(--ok)} .wdelta.down{color:var(--acute)} .wdelta.zero{color:var(--ink-faint)}

.wk{margin-top:10px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface)}
.wk .wkrow{display:flex;align-items:flex-start;gap:11px;padding:11px 16px;border-top:1px solid var(--line-soft)}
.wk .wkrow:first-child{border-top:none}
.wk .box{width:18px;height:18px;border-radius:5px;border:1px solid var(--line);display:grid;place-items:center;font-size:12px;flex:none;margin-top:1px}
.wk .box.done{background:var(--ok-bg);color:var(--ok);border-color:transparent}
.wk .sph{min-width:120px;color:var(--ink-faint);font-size:13px}
.wk .txt{color:var(--ink-soft);font-size:14px}
.wk .txt.empty-txt{color:var(--ink-faint);font-style:italic}

.hist{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.hrow{display:flex;align-items:center;gap:11px;padding:11px 15px;border:1px solid var(--line);border-radius:10px;background:var(--surface);font-size:13.5px}
.hrow .hsub{font-weight:600}
.hrow .hdate{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--ink-faint)}

/* полный отчёт */
.report-body{margin-top:16px;border:1px solid var(--line);border-radius:12px;background:var(--surface);padding:20px 22px;white-space:pre-wrap;color:var(--ink);font-size:15px;line-height:1.6;max-width:70ch}

/* ===== ВХОД ===== */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login{width:100%;max-width:360px;border:1px solid var(--line);border-radius:14px;background:var(--surface);padding:30px 28px}
.login .brand{padding:0 0 18px}
.login h1{font-size:19px;font-weight:700;margin-bottom:4px}
.login p{color:var(--ink-soft);font-size:13.5px;margin-bottom:20px}
.login label{display:block;font-size:12.5px;color:var(--ink-faint);margin-bottom:7px}
.login input{width:100%;padding:10px 13px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px}
.login input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.login .btn.pri{width:100%;justify-content:center;margin-top:16px;padding:11px}
.login .err{margin-top:14px;font-size:13px;color:var(--acute);background:var(--acute-bg);border:1px solid var(--acute-line);border-radius:8px;padding:9px 12px}

@media(max-width:760px){
  .app{grid-template-columns:1fr}
  .rail{flex-direction:row;align-items:center;overflow-x:auto;padding:10px 12px}
  .rail .nav{flex-direction:row}
  .rail .who{display:none}
  .main{padding:22px 18px 50px}
}

/* ===== вид участника (/me, /app) ===== */
.me-wrap{max-width:640px;margin:0 auto;padding:34px 22px 60px}
.me-wrap .brand{padding:0 0 20px}
.me-wrap .head{margin-bottom:8px}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}

/* ---- админка v2: ссылки истории + форма ответа ---- */
.hist a.hrow{color:inherit;text-decoration:none}
.hist a.hrow:hover{background:var(--surface-2)}
.reply-form{display:flex;flex-direction:column;gap:10px;max-width:560px;margin-top:4px}
.reply-form textarea{padding:10px 13px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;resize:vertical}
.reply-form textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.reply-form .btn{align-self:flex-start}

/* ---- админка v2: созвоны-CRUD ---- */
.flash{margin:0 0 14px;padding:10px 14px;border:1px solid var(--line);border-radius:8px;font-size:13px;color:var(--ink-soft);background:var(--surface-2)}
.actions-cell{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-left:auto}
.actions-cell form{display:flex;gap:6px;align-items:center;margin:0}
.slot-add{display:flex;gap:8px;align-items:center;margin:0 0 12px;flex-wrap:wrap}
.slot-add input[type="number"]{width:84px}
input[type="datetime-local"],.slot-add input[type="number"]{padding:7px 10px;border:1px solid var(--line);border-radius:7px;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:13px}
input[type="datetime-local"]:focus,.slot-add input[type="number"]:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}

/* база знаний: форма лекции */
.lesson-form{display:flex;flex-direction:column;gap:14px;max-width:640px}
.lesson-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-soft)}
.lesson-form input[type="text"],.lesson-form textarea,.lesson-form input[type="number"],.lesson-form select{padding:10px 13px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;resize:vertical}
.lesson-form input:focus,.lesson-form textarea:focus,.lesson-form select:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.lesson-form label.check{flex-direction:row;align-items:center;gap:9px;color:var(--ink);font-size:13.5px}
.lesson-form label.check input{width:16px;height:16px;accent-color:var(--accent)}
.lesson-form-row{display:flex;gap:14px}
.lesson-form-row label{flex:1}
.lesson-form .btn{align-self:flex-start}
.rm-prac{gap:10px}
.rm-prac .pname{min-width:150px;flex:none}
.rm-line{flex:1;padding:8px 11px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:13px}
.rm-prac select{padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:13px}
