@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600&display=swap');
:root{
  --bg:#eaeef3;--panel:#fff;--ink:#1b2336;--ink2:#5a6478;--line:#dde3ec;
  --brand:#22356b;--brand2:#2f4d9e;--accent:#0e8090;--good:#1f9d62;--bad:#c2413a;
  --warn:#e9a200;--pre:#ffd23f;--radius:14px;--shadow:0 1px 2px rgba(20,30,60,.06),0 8px 24px rgba(20,30,60,.06);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.45}
h1,h2,h3,.disp{font-family:'Space Grotesk',Inter,sans-serif;letter-spacing:-.01em}
button{font-family:inherit;cursor:pointer}
a{color:var(--brand2)}
.hidden{display:none!important}
/* layout */
.app{display:flex;min-height:100vh}
.side{width:232px;background:var(--brand);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;flex-shrink:0}
.brand{padding:20px 18px;border-bottom:1px solid rgba(255,255,255,.12)}
.brand .logo{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk';font-weight:700;font-size:17px}
.brand .logo .mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),#19b0c4);display:grid;place-items:center;font-weight:700}
.brand small{display:block;color:rgba(255,255,255,.6);margin-top:6px;font-size:11.5px}
.nav{padding:10px;display:flex;flex-direction:column;gap:2px;flex:1;overflow:auto}
.nav button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:none;border:0;color:rgba(255,255,255,.78);padding:10px 12px;border-radius:9px;font-size:13.5px;font-weight:500}
.nav button .ic{width:20px;text-align:center}
.nav button:hover{background:rgba(255,255,255,.08);color:#fff}
.nav button.on{background:#fff;color:var(--brand);font-weight:600}
.nav .sec{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.4);padding:14px 12px 6px}
.side .foot{padding:12px 16px;font-size:11px;color:rgba(255,255,255,.5);border-top:1px solid rgba(255,255,255,.12)}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.top{background:var(--panel);border-bottom:1px solid var(--line);padding:14px 26px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:30}
.top h1{font-size:18px;margin:0}.top .sub{color:var(--ink2);font-size:12.5px;margin-top:2px}.top .spacer{flex:1}
.who{font-size:12.5px;color:var(--ink2);text-align:right}.who b{color:var(--ink);display:block}
.wrap{padding:24px 26px;max-width:1180px;width:100%}
/* components */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card .hd{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.card .hd h2{font-size:15px;margin:0}.card .bd{padding:18px}
.grid{display:grid;gap:16px}.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
label.f{display:block;font-size:12px;font-weight:600;color:var(--ink2);margin:0 0 5px}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:#fbfcfe;font:inherit;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--brand2);outline-offset:-1px}
.btn{border:1px solid var(--brand);background:var(--brand);color:#fff;padding:9px 15px;border-radius:9px;font-weight:600;font-size:13px}
.btn:hover{background:var(--brand2)}.btn[disabled]{opacity:.5;cursor:not-allowed}
.btn.ghost{background:#fff;color:var(--brand);border-color:var(--line)}.btn.ghost:hover{background:#f4f6fb}
.btn.sm{padding:6px 10px;font-size:12px}.btn.danger{background:var(--bad);border-color:var(--bad)}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.kpi .n{font-family:'Space Grotesk';font-size:30px;font-weight:700;line-height:1}.kpi .l{color:var(--ink2);font-size:12px;margin-top:6px}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink2);padding:9px 12px;border-bottom:2px solid var(--line)}
td{padding:10px 12px;border-bottom:1px solid var(--line)}tr:hover td{background:#fafbfe}
.muted{color:var(--ink2)}.dot{width:9px;height:9px;border-radius:99px;display:inline-block}
.pill{font-size:11px;padding:2px 8px;border-radius:99px;font-weight:600}
.tag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:99px;border:1px solid transparent}
.empty{text-align:center;color:var(--ink2);padding:34px 10px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-size:12px;padding:5px 10px;border-radius:99px;border:1px solid var(--line);background:#fff;cursor:pointer;user-select:none;display:inline-flex;align-items:center;gap:6px}
.chip.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.note{background:#fff8e1;border:1px solid #f3df9a;color:#7a5c00;padding:10px 12px;border-radius:10px;font-size:12.5px}
.note.info{background:#eef5ff;border-color:#cfe0ff;color:#274b8f}.note.bad{background:#fdeceb;border-color:#f3c4c0;color:#8c2c27}
/* agenda grid */
.weekgrid{display:grid;grid-template-columns:84px repeat(5,1fr);border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--panel)}
.weekgrid .gh{background:#f3f6fb;padding:10px 8px;font-weight:600;font-size:12px;border-bottom:1px solid var(--line);text-align:center}
.weekgrid .gh.dim{color:var(--ink2);font-weight:500;font-size:11px}
.weekgrid .tcol{background:#f9fafd;font-weight:600;font-size:12px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line);border-right:1px solid var(--line);color:var(--ink2)}
.cell{min-height:62px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);padding:6px}
.slot{font-size:11.5px;border-radius:8px;padding:7px 8px;cursor:pointer;height:100%}
.slot.free{border:1px dashed var(--line);color:var(--ink2);display:flex;align-items:center;justify-content:center;background:#fff}
.slot.free:hover{border-color:var(--brand2);color:var(--brand2);background:#f4f7ff}
.slot.busy{color:#11151f;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.slot .nm{font-weight:600;line-height:1.25}.slot .meta{font-size:10px;opacity:.8;margin-top:3px}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;margin-top:14px;align-items:center}
.legend .it{display:flex;align-items:center;gap:6px}
/* modal + toast */
.scrim{position:fixed;inset:0;background:rgba(20,28,50,.45);display:none;align-items:center;justify-content:center;z-index:60;padding:18px}
.scrim.on{display:flex}
.modal{background:#fff;border-radius:16px;width:520px;max-width:100%;max-height:92vh;overflow:auto;box-shadow:0 24px 60px rgba(0,0,0,.28)}
.modal .mh{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal .mh h3{margin:0;font-size:16px}.modal .mb{padding:20px}
.modal .mf{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.x{background:none;border:0;font-size:22px;color:var(--ink2)}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:12px 18px;border-radius:10px;font-size:13px;opacity:0;transition:.25s;z-index:90}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
.help{font-size:11.5px;color:var(--ink2);margin-top:5px}
/* auth / public */
.authwrap{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(160deg,#eef1f6,#dde6f3)}
.authcard{background:#fff;border-radius:18px;box-shadow:var(--shadow);width:400px;max-width:100%;padding:28px}
.authcard .logo{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk';font-weight:700;font-size:18px;margin-bottom:4px}
.authcard .logo .mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--accent),#19b0c4);display:grid;place-items:center;color:#fff}
.authcard h2{margin:14px 0 2px}.authcard .sub{color:var(--ink2);font-size:13px;margin-bottom:18px}
.field{margin-bottom:14px}
@media(max-width:820px){.side{position:fixed;left:-232px;transition:.2s;z-index:80}.side.open{left:0}.menubtn{display:inline-flex!important}}
.menubtn{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:18px}
