/* ============================================================
   IQ КОФЕ — знаковый стиль портала (shared)
   Один источник правды для оформления всех экранов.
   Меняешь токены в :root — меняется весь портал.
   Текущая рабочая тема: светлый минимал.
   ============================================================ */

:root{
  /* поверхности */
  --bg:#ffffff;
  --bg-soft:#F8F8FA;
  --surface:#ffffff;
  --border:#EAEAEF;
  --border-soft:#F1F1F4;

  /* текст */
  --ink:#1B1B22;
  --ink-2:#5B5B67;
  --muted:#90909C;
  --faint:#BCBCC6;

  /* акцент (знаковый фиолетовый) */
  --violet:#6D5CE7;
  --violet-ink:#5A48D6;
  --violet-soft:#F1EEFC;

  /* цвета точек */
  --iq:#6E7BF2;
  --grusha:#79AE3F;
  --bravo:#E5903B;
  --neva:#3AA3C0;

  /* грейды */
  --g-senior:#E0A92E;
  --g-cert:#6D5CE7;
  --g-uncert:#A2A2AE;

  /* флаги */
  --plan:#5C8A2C;
  --record:#B07F1E;

  /* типографика */
  --font-brand:'Wix Madefor Display';  /* бренд-вордмарк, близко к Google Sans */
  --font-display:'Onest';
  --font-body:'Manrope';
  --font-mono:'JetBrains Mono';

  --r:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--font-body),sans-serif;color:var(--ink);background:var(--bg);min-height:100vh;letter-spacing:.1px}
/* ── APP SHELL + SIDEBAR (стиль Google AI Studio) ── */
.app{display:flex;min-height:100vh}
.sidebar{width:194px;flex:none;border-right:1px solid var(--border);background:var(--surface);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:16px 11px}
.sb-brand{display:flex;align-items:center;gap:9px;padding:4px 6px 14px}
.sb-brand .logo{height:32px;width:auto;display:block}
.sb-brand .bt{display:flex;flex-direction:column;gap:1px;min-width:0}
.sb-brand .bt b{font-family:var(--font-brand),sans-serif;font-weight:600;font-size:14px;color:var(--ink)}
.sb-brand .bt span{font-size:11px;color:var(--muted);font-weight:500}
.sb-nav{display:flex;flex-direction:column;gap:2px;margin-top:2px}
.sb-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;text-decoration:none;color:var(--ink-2);font-weight:600;font-size:13px;cursor:pointer;transition:.14s;white-space:nowrap}
.sb-item svg{width:18px;height:18px;flex:none;fill:none;stroke:var(--muted);transition:.14s}
.sb-item:hover{background:var(--bg-soft);color:var(--ink)}
.sb-item:hover svg{stroke:var(--ink-2)}
.sb-item.active{background:var(--violet-soft);color:var(--violet-ink)}
.sb-item.active svg{stroke:var(--violet-ink)}
.sb-foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--border-soft)}
.sb-foot .user{width:100%;border:none;background:transparent;padding:6px 6px}
.main{flex:1;min-width:0}

.wrap{max-width:1240px;margin:0 auto;padding:20px 22px 44px}

/* ── TOPBAR ─────────────────────────── */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:24px}
.brand{display:flex;align-items:center;gap:14px}
.mark{display:inline-flex;align-items:center}
.mark .logo{height:44px;width:auto;display:block;border-radius:6px}
.brand h1{font-family:var(--font-brand),sans-serif;font-weight:600;font-size:17px;letter-spacing:0;color:var(--ink)}
.brand .sub{font-size:12.5px;color:var(--muted);font-weight:500;margin-top:2px}
.user{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}
.ava{width:28px;height:28px;border-radius:50%;background:var(--violet-soft);display:grid;place-items:center;font-weight:700;font-size:12px;color:var(--violet-ink)}
.user .who{font-size:12.5px;font-weight:600;color:var(--ink-2)}

/* ── CONTROLS ───────────────────────── */
.controls{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.weeknav{display:flex;align-items:center;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:4px}
.weeknav button{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--ink-2);font-size:16px;cursor:pointer;transition:.15s}
.weeknav button:hover{background:var(--bg-soft)}
.weeknav .range{font-size:13.5px;font-weight:600;padding:0 14px;color:var(--ink);letter-spacing:0}
.weeknav .range b{font-weight:700}
.controls-mid{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.seg{display:flex;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:11px;padding:3px;gap:2px}
.seg button{border:none;background:transparent;color:var(--muted);font-family:var(--font-body);font-weight:600;font-size:13px;padding:7px 16px;border-radius:8px;cursor:pointer;transition:.15s}
.seg button.on{color:var(--violet-ink);background:var(--surface);box-shadow:0 1px 3px rgba(20,20,40,.08),0 0 0 1px var(--border)}
.seg button:not(.on):hover{color:var(--ink-2)}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:600;font-size:13px;padding:9px 15px;border-radius:10px;cursor:pointer;transition:.15s}
.btn-ghost{background:var(--surface);border:1px solid var(--border);color:var(--ink-2)}
.btn-ghost:hover{border-color:var(--violet);color:var(--violet-ink);background:var(--violet-soft)}
.btn-primary{background:var(--violet);border:none;color:#fff;box-shadow:0 2px 8px -2px rgba(109,92,231,.5)}
.btn-primary:hover{background:var(--violet-ink)}
.btn svg{width:14px;height:14px}

/* ── QUICK NAV ──────────────────────── */
.barline{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:14px}
.qnav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.qnav .lab{font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--faint);font-weight:700;margin-right:2px}
.qnav a{display:inline-flex;align-items:center;gap:7px;text-decoration:none;font-size:12.5px;font-weight:600;color:var(--ink-2);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 13px 6px 11px;transition:.15s}
.qnav a:hover{border-color:var(--cc);background:color-mix(in srgb,var(--cc) 7%,white);color:var(--ink)}
.qnav a .dot{width:8px;height:8px;border-radius:50%;background:var(--cc)}

/* ── LEGEND ─────────────────────────── */
.legend{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:11.5px;color:var(--muted);font-weight:500}
.legend .grp{display:flex;align-items:center;gap:9px}
.legend .lab{text-transform:uppercase;letter-spacing:.8px;font-size:10px;color:var(--faint);font-weight:700}
.chip{display:inline-flex;align-items:center;gap:6px}
.gdot{width:8px;height:8px;border-radius:50%}
.gdot.ring{background:transparent;border:1.5px solid var(--g-uncert)}
.pill.demo{font-size:10px;font-weight:700;padding:1px 6px;border-radius:5px;background:var(--violet-soft);color:var(--violet-ink)}

/* ── GRID ───────────────────────────── */
.board{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);overflow:hidden;box-shadow:0 1px 2px rgba(20,20,40,.03)}
.scroll{overflow-x:auto}
.grid,.pgrid{display:grid;grid-template-columns:minmax(120px,1.5fr) repeat(7,minmax(40px,1fr)) minmax(52px,.7fr);min-width:0;width:100%}
.grid>div,.pgrid>div{border-bottom:1px solid var(--border-soft);border-right:1px solid var(--border-soft);padding:6px 5px;display:flex;align-items:center;min-width:0}

.gh{position:sticky;top:0;z-index:5;background:var(--bg-soft);font-weight:600;font-size:11px;color:var(--ink-2);letter-spacing:.1px;flex-direction:column;align-items:flex-start;gap:1px;padding-top:9px;padding-bottom:8px}
.gh .dnum{font-size:9.5px;color:var(--muted);font-weight:500}
.gh.weekend{color:var(--violet-ink)}
.gh-corner{position:sticky;left:0;z-index:7;background:var(--bg-soft);text-transform:uppercase;font-size:10.5px;letter-spacing:.6px;color:var(--faint);font-weight:700;justify-content:flex-start}
.gh-end{justify-content:center;align-items:center;text-align:center;text-transform:uppercase;font-size:10.5px;letter-spacing:.5px;color:var(--faint);font-weight:700}

.loc{grid-column:1/-1;justify-content:space-between;padding:9px 14px;background:color-mix(in srgb,var(--c) 5%,white);border-bottom:1px solid var(--border);border-top:1px solid var(--border-soft);position:sticky;left:0;scroll-margin-top:52px}
.loc .lname{display:flex;align-items:center;gap:10px;font-family:var(--font-display),sans-serif;font-weight:600;font-size:13.5px;color:var(--ink)}
.loc .bar{width:4px;height:16px;border-radius:3px;background:var(--c)}
.loc .meta{display:flex;gap:12px;font-size:11px;color:var(--muted);font-weight:500;align-items:center}
.loc .meta b{color:var(--ink-2);font-weight:600}
.loc .meta .rec{color:var(--record)}
.loc .top{font-size:13px;color:var(--faint);text-decoration:none;font-weight:700}
.loc .top:hover{color:var(--violet-ink)}

.nm{position:sticky;left:0;z-index:3;background:var(--surface);gap:8px}
.nm .gdot{flex:none}
.nm .who{display:flex;flex-direction:column;gap:0;min-width:0}
.nm .who b{font-weight:600;font-size:11.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nm .who span{font-size:9.5px;color:var(--muted);font-weight:500;letter-spacing:.2px}

.cell{justify-content:center;font-family:var(--font-mono),monospace;font-size:11px;font-weight:500;cursor:pointer;transition:.12s}
.cell .t{padding:3px 5px;border-radius:6px;background:var(--bg-soft);border:1px solid var(--border-soft);color:var(--ink);letter-spacing:-.5px;white-space:nowrap}
.cell:hover .t{background:color-mix(in srgb,var(--c) 9%,white);border-color:color-mix(in srgb,var(--c) 35%,white)}
.cell.off{color:var(--faint);font-size:10.5px;font-weight:600;cursor:default}
.cell.empty{cursor:default}
.cell.empty::after{content:"";width:4px;height:4px;border-radius:50%;background:var(--border)}

.hrs{justify-content:center;font-family:var(--font-mono),monospace;font-weight:600;font-size:13px;color:var(--ink-2);background:#FCFCFD}
.hrs.head{color:var(--faint)}

.mrow{background:#FCFCFD}
.mlabel{position:sticky;left:0;z-index:3;background:#FCFCFD;gap:6px;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.live{display:inline-flex;align-items:center;gap:5px}
.live i{width:6px;height:6px;border-radius:50%;background:var(--neva);box-shadow:0 0 0 3px color-mix(in srgb,var(--neva) 20%,white);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.mcell{flex-direction:column;align-items:center;gap:3px;justify-content:center;padding:6px 4px}
.mcell .rev{font-family:var(--font-mono),monospace;font-size:10px;color:var(--ink-2);letter-spacing:-.4px;white-space:nowrap}
.mcell .none{color:var(--faint);font-size:10px}
.pill{font-family:var(--font-mono),monospace;font-size:9px;font-weight:700;padding:1px 5px;border-radius:5px;letter-spacing:-.2px}
.pill.p0{background:var(--violet-soft);color:var(--violet-ink)}
.pill.p1{background:#E7E2FB;color:var(--violet-ink)}
.pill.p2{background:var(--violet);color:#fff}
.flag{font-size:9.5px;font-weight:700;letter-spacing:.2px;display:inline-flex;align-items:center;gap:3px}
.flag.plan{color:var(--plan)}
.flag.rec{color:var(--record)}

/* ── FOOTER (сводка + легенда) ──────── */
.foot{display:flex;flex-direction:column;gap:13px;margin-top:16px;padding:15px 20px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface)}
.foot-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap}
.cover{display:flex;gap:28px;flex-wrap:wrap}
.cv{display:flex;flex-direction:column;gap:2px}
.cv .k{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--faint);font-weight:700}
.cv .v{font-family:var(--font-mono),monospace;font-weight:600;font-size:15px;color:var(--ink)}
.cv .v small{color:var(--muted);font-weight:400;font-size:11px}
.foot .note{font-size:11.5px;color:var(--muted);max-width:330px;line-height:1.5}
.foot-legend{border-top:1px solid var(--border-soft);padding-top:12px}

/* ── PEOPLE VIEW ────────────────────── */
.pcell{justify-content:center;gap:6px;font-family:var(--font-mono),monospace;font-size:12px;font-weight:500;cursor:pointer}
.ptag{font-family:var(--font-body);font-size:9px;font-weight:700;padding:1px 5px;border-radius:4px;letter-spacing:.3px;color:#fff}
.pcell .t2{color:var(--ink);letter-spacing:-.3px}
.hidden{display:none}

.tip{margin-top:18px;text-align:center;font-size:11px;color:var(--faint);letter-spacing:.2px}
.tip b{color:var(--muted)}

/* ── АДАПТИВ: узкий экран → меню сворачивается в иконки, сетка получает место ── */
@media (max-width:1024px){
  .sidebar{width:60px;padding:18px 8px}
  .sb-brand{justify-content:center;padding:4px 0 14px}
  .sb-brand .bt{display:none}
  .sb-brand .logo{height:32px}
  .sb-item{justify-content:center;padding:10px 0;gap:0}
  .sb-item span{display:none}
  .sb-foot .user{justify-content:center;padding:6px 0}
  .sb-foot .user .who{display:none}
  .wrap{padding:20px 18px 44px}
}
