
:root{
  --bg:#eef2f7;--card:#fff;--ink:#0f172a;--muted:#64748b;--border:#d7dce5;
  --green:#16a34a;--green-bg:#dcfce7;--red:#dc2626;--red-bg:#fee2e2;
  --yellow:#ca8a04;--yellow-bg:#fef9c3;--blue:#2563eb;--blue-bg:#dbeafe;
  --purple:#7c3aed;--purple-bg:#ede9fe;--gray:#64748b;--gray-bg:#e5e7eb;
  --shadow:0 8px 24px rgba(15,23,42,.08);--radius:18px;--tap:46px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,Arial,Helvetica,sans-serif;-webkit-font-smoothing:antialiased}
a{color:#1d4ed8}.topbar{background:#0f172a;color:#fff;padding:10px 12px;display:flex;gap:12px;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:0 4px 18px rgba(0,0,0,.18)}
.brand{font-weight:900;color:#fff;text-decoration:none;font-size:17px;line-height:1.1}.sub{color:#cbd5e1;font-size:11px;margin-top:2px}.top-actions{display:flex;align-items:center;gap:8px}.hamburger{display:none;background:#1e293b;color:#fff;border:1px solid #334155;border-radius:12px;min-height:42px;padding:8px 11px;font-size:20px}.desktop-nav{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}.desktop-nav a{color:#fff;text-decoration:none;background:#1f2937;padding:8px 10px;border-radius:999px;font-size:13px;white-space:nowrap}.desktop-nav a:hover{background:#334155}.container{max-width:1240px;margin:0 auto;padding:14px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin:0 0 14px;box-shadow:var(--shadow)}.card.compact{padding:12px}.hero{background:linear-gradient(135deg,#0f172a,#1d4ed8);color:#fff;border:none}.hero p,.hero .muted{color:#e2e8f0}.hstack{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}h1{font-size:26px;line-height:1.1;margin:0 0 10px}h2{font-size:20px;margin:4px 0 10px}h3{font-size:16px;margin:10px 0 7px}.lead{font-size:17px;line-height:1.45}.muted{color:var(--muted);font-size:13px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}.grid.tight{grid-template-columns:repeat(auto-fit,minmax(145px,1fr))}.metric{background:#fff;border:1px solid var(--border);border-radius:16px;padding:13px;box-shadow:0 2px 8px rgba(15,23,42,.04)}.metric .num{font-size:29px;font-weight:900;letter-spacing:-.02em;overflow-wrap:anywhere}.metric .label{color:#475569;font-size:13px}.metric.green{background:var(--green-bg);border-color:#86efac}.metric.red{background:var(--red-bg);border-color:#fca5a5}.metric.yellow{background:var(--yellow-bg);border-color:#fde047}.metric.blue{background:var(--blue-bg);border-color:#93c5fd}.metric.purple{background:var(--purple-bg);border-color:#c4b5fd}.metric.gray{background:var(--gray-bg)}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.row>*{flex:1;min-width:160px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}.field{min-width:0}label{font-weight:800;font-size:13px;display:block;margin:8px 0 4px}input,select,textarea{width:100%;min-height:var(--tap);padding:11px 12px;border:1px solid var(--border);border-radius:13px;font:inherit;background:#fff;color:var(--ink)}textarea{min-height:92px;resize:vertical}input:focus,select:focus,textarea:focus{outline:3px solid #bfdbfe;border-color:#60a5fa}.checkline{display:flex;gap:8px;align-items:center;padding:8px 0}.checkline input{width:auto;min-height:auto}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:var(--tap);background:#0f172a;color:#fff;border:none;border-radius:13px;padding:10px 14px;text-decoration:none;cursor:pointer;font:inherit;font-weight:800;margin:3px 2px;line-height:1.1}button:hover,.btn:hover{filter:brightness(1.08)}.btn.secondary,button.secondary{background:#475569}.btn.danger,button.danger{background:#b91c1c}.btn.good,button.good{background:#15803d}.btn.warn,button.warn{background:#a16207}.btn.light,button.light{background:#e2e8f0;color:#0f172a}.btn.small,button.small{min-height:34px;padding:7px 9px;font-size:12px;border-radius:10px}.btn.block,button.block{width:100%;display:flex}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-top:10px}.quick-actions .btn{width:100%;margin:0}.flashes{margin-bottom:12px}.flash{padding:12px;border-radius:13px;margin:7px 0;font-weight:700}.success{background:var(--green-bg);border:1px solid #86efac}.danger{background:var(--red-bg);border:1px solid #fca5a5}.warning{background:var(--yellow-bg);border:1px solid #fde047}.info{background:var(--blue-bg);border:1px solid #93c5fd}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:900}.pill.green{background:var(--green-bg);color:#14532d}.pill.red{background:var(--red-bg);color:#7f1d1d}.pill.yellow{background:var(--yellow-bg);color:#713f12}.pill.blue{background:var(--blue-bg);color:#1e3a8a}.pill.purple{background:var(--purple-bg);color:#4c1d95}.pill.gray{background:var(--gray-bg);color:#374151}.tabs{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0 12px}.tabs a{background:#e2e8f0;padding:9px 11px;border-radius:999px;text-decoration:none;color:#111827;font-weight:800}.calendar{display:grid;grid-template-columns:repeat(7,minmax(82px,1fr));gap:7px}.day{border:1px solid var(--border);border-radius:14px;min-height:84px;padding:9px;text-decoration:none;color:#0f172a;background:#fff;display:flex;flex-direction:column;gap:4px;box-shadow:0 2px 8px rgba(15,23,42,.04)}.day .n{font-weight:900;font-size:18px}.day .mini{font-size:12px;color:#475569}.day.green{background:var(--green-bg);border-color:var(--green)}.day.red{background:var(--red-bg);border-color:var(--red)}.day.gray{background:var(--gray-bg);border-color:#94a3b8}.day.selected{outline:3px solid #1d4ed8}.cal-header{font-weight:900;font-size:12px;text-align:center;color:#475569;padding:3px 0;letter-spacing:.06em;text-transform:uppercase}.cal-header.weekend-header{color:#7c3aed}.day .dow{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.day.weekend{background:#f5f3ff;border-color:#c4b5fd}.day.weekend .dow{color:#7c3aed}.day.blank{background:transparent;border:none;box-shadow:none;pointer-events:none;min-height:0}.day.past{opacity:0.5}.day.today{outline:3px solid #2563eb;outline-offset:1px}.tabs a.active{background:#0f172a;color:#fff}.section{border-radius:16px;border:1px solid var(--border);padding:11px;margin:11px 0}.section.green{background:var(--green-bg)}.section.yellow{background:var(--yellow-bg)}.section.red{background:var(--red-bg)}.section.blue{background:var(--blue-bg)}.section.gray{background:var(--gray-bg)}.section.purple{background:var(--purple-bg)}.person{display:flex;justify-content:space-between;gap:10px;align-items:center;background:#fff;border:1px solid rgba(0,0,0,.08);padding:10px;border-radius:13px;margin:7px 0}.person-main{min-width:0}.person-title{font-weight:900}.person-meta{color:#64748b;font-size:12px;margin-top:3px}.candidate-filter{position:sticky;top:70px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:10px;z-index:20;box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden}th,td{border:1px solid var(--border);padding:9px;font-size:13px;text-align:left;vertical-align:top}th{background:#e2e8f0;font-weight:900}.table-wrap{overflow:auto;-webkit-overflow-scrolling:touch;border-radius:14px}.progress{height:14px;border-radius:999px;overflow:hidden;background:#e5e7eb}.bar{height:14px;background:#0f172a}.qrgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.qr{text-align:center}.qr img{max-width:230px;width:100%;height:auto}.wizard-steps{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0 12px}.wizard-step-btn{background:#e2e8f0;color:#0f172a;border-radius:999px;min-height:38px;font-size:13px}.wizard-step-btn.active{background:#0f172a;color:#fff}.wizard-panel{display:none}.wizard-panel.active{display:block}.mobile-menu{display:none;position:fixed;inset:0;background:rgba(15,23,42,.62);z-index:80}.mobile-menu.open{display:block}.mobile-drawer{background:#fff;color:#0f172a;position:absolute;right:0;top:0;width:min(360px,88vw);height:100%;padding:16px;box-shadow:-10px 0 30px rgba(0,0,0,.2);overflow:auto}.mobile-drawer a{display:flex;align-items:center;min-height:48px;color:#0f172a;text-decoration:none;border-bottom:1px solid #e2e8f0;font-weight:800}.mobile-close{float:right;background:#e2e8f0;color:#0f172a;min-height:36px}.bottom-nav{display:none}.print-actions{margin-bottom:10px}.row-warn{background:var(--yellow-bg) !important}
.back-btn{background:#e2e8f0;color:#0f172a;min-height:36px;font-size:13px}
.roster-split{display:grid;grid-template-columns:240px 1fr;gap:12px;align-items:start}
.roster-slots{position:sticky;top:70px}
.slot-group-label{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin-bottom:6px}
.slot-row{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:12px;cursor:pointer;margin-bottom:4px;border:2px solid transparent;transition:background .12s}
.slot-row:hover{background:#f1f5f9}
.slot-row.slot-active{background:#0f172a;border-color:#0f172a}
.slot-row.slot-active .slot-row-name{color:#fff}
.slot-row.slot-active .slot-row-person{color:#cbd5e1}
.slot-row-info{flex:1;min-width:0}
.slot-row-name{font-weight:900;font-size:13px;color:#0f172a}
.slot-row-person{font-size:12px;color:#64748b;margin-top:2px}
.slot-remove-btn{min-height:26px!important;padding:3px 7px!important;font-size:11px!important;border-radius:8px!important}
.tutorial-wrap{max-width:580px;margin:0 auto}.tutorial-header{margin-bottom:14px}.tutorial-progress-bar{height:7px;background:#e2e8f0;border-radius:999px;overflow:hidden}.tutorial-progress-fill{height:7px;background:#2563eb;border-radius:999px;transition:width .35s ease}.tutorial-progress-text{text-align:center;font-size:13px;font-weight:900;color:#64748b;margin:6px 0 0}.tutorial-slide{display:none}.tutorial-slide.active{display:block}.tutorial-slide h2{font-size:22px;color:#0f172a;margin:0 0 12px;line-height:1.2}.tutorial-slide p{font-size:16px;line-height:1.65;color:#374151;margin:0 0 10px}.tutorial-slide ul{padding-left:20px;margin:8px 0 12px}.tutorial-slide ul li{font-size:15px;line-height:1.65;color:#374151;margin:5px 0}.tut-action{margin-top:16px}.tutorial-nav{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px;padding-top:14px;border-top:1px solid #e2e8f0}.tutorial-nav>*{flex:1;min-width:110px}.tutorial-nav form{flex:1;min-width:110px}.tutorial-nav form button{width:100%}
@media(max-width:820px){.tutorial-wrap{max-width:none}.tutorial-slide h2{font-size:20px}.tutorial-slide p,.tutorial-slide ul li{font-size:15px}.tutorial-nav{gap:6px}.tutorial-nav>*,.tutorial-nav form{min-width:0}}.hide-mobile{display:block}.show-mobile{display:none}
@media(max-width:820px){
  body{padding-bottom:78px}.topbar{padding:9px 10px}.brand{font-size:15px}.sub{display:none}.desktop-nav{display:none}.hamburger{display:inline-flex}.container{padding:10px}.card{padding:13px;border-radius:16px;margin-bottom:10px}h1{font-size:22px}h2{font-size:18px}.grid,.grid.tight{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.metric{padding:11px}.metric .num{font-size:24px}.row{display:block}.row>*{min-width:0}.form-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.calendar{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory}.day{min-width:88px;min-height:86px;scroll-snap-align:start}.candidate-filter{top:58px}.person{display:block}.person form{margin-top:8px}.person form input{margin-bottom:6px}.hide-mobile{display:none!important}.show-mobile{display:block}.bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--border);z-index:60;box-shadow:0 -8px 22px rgba(15,23,42,.12)}.bottom-nav a{min-height:62px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:#0f172a;font-size:11px;font-weight:900}.bottom-nav span{font-size:20px;line-height:1}table.responsive thead{display:none}table.responsive,table.responsive tbody,table.responsive tr,table.responsive td{display:block;width:100%}table.responsive tr{border:1px solid var(--border);border-radius:14px;margin:10px 0;background:#fff;box-shadow:0 2px 8px rgba(15,23,42,.04);overflow:hidden}table.responsive td{border:none;border-bottom:1px solid #eef2f7;padding:9px 10px}table.responsive td:last-child{border-bottom:none}table.responsive td::before{content:attr(data-label);display:block;font-size:11px;font-weight:900;text-transform:uppercase;color:#64748b;margin-bottom:2px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.flashes{position:sticky;top:58px;z-index:30}.flash{font-size:13px}.qrgrid{grid-template-columns:1fr}.hero{border-radius:0;margin:-10px -10px 10px}.hero .quick-actions{grid-template-columns:1fr}.hstack{flex-direction:column;align-items:stretch}.hstack form{width:100%}.tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}.tabs a{white-space:nowrap;flex-shrink:0}.section{padding:9px}.btn.block,button.block{width:100%}.roster-split{grid-template-columns:1fr}.roster-slots{position:static}
}
@media(max-width:420px){.grid,.grid.tight,.quick-actions{grid-template-columns:1fr}.calendar .day{min-width:82px}.metric .num{font-size:22px}}
@media print{.topbar,.print-actions,.flashes,.no-print,.bottom-nav,.mobile-menu,.candidate-filter{display:none!important}body{background:#fff;padding:0}.container{max-width:none;padding:0}.card{border:none;box-shadow:none}.day{break-inside:avoid}table{page-break-inside:auto}tr{page-break-inside:avoid}.responsive thead{display:table-header-group!important}.responsive tr{display:table-row!important}.responsive td,.responsive th{display:table-cell!important;border:1px solid #999}.responsive td::before{display:none!important}}
