:root{--gold:#f4c430;--black:#111827;--gray:#f3f4f6;--line:#e5e7eb;--red:#b91c1c;--green:#047857;--warn:#d97706;--blue:#1d4ed8}*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--gray);color:#111}.topbar{background:var(--black);color:white;padding:16px 22px;border-bottom:5px solid var(--gold);display:flex;justify-content:space-between;align-items:center}.brand{font-weight:900;font-size:25px;letter-spacing:.2px}.brand span{color:var(--gold)}.brand.big{font-size:48px}.container{max-width:1250px;margin:24px auto;padding:0 16px}.card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;margin-bottom:18px;box-shadow:0 4px 14px rgba(0,0,0,.06)}.no-margin{margin:0}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.stat{font-size:42px;font-weight:900}.muted{color:#6b7280}.btn{display:inline-block;background:var(--black);color:#fff;text-decoration:none;border:0;border-radius:12px;padding:11px 15px;cursor:pointer;font-weight:800}.btn.gold{background:var(--gold);color:#111}.btn.red{background:var(--red)}.btn.full{width:100%}.small-btn{padding:8px 11px;border-radius:10px}input,select{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:12px;margin:6px 0 14px}label{font-weight:800}table{width:100%;border-collapse:collapse;background:white}th,td{text-align:left;border-bottom:1px solid var(--line);padding:11px}th{background:#fafafa}.nav a{color:#fff;margin-left:14px;text-decoration:none;font-weight:700}.alert{padding:13px 15px;border-radius:13px;margin-bottom:15px}.success{background:#ecfdf5;color:#065f46}.error{background:#fef2f2;color:#991b1b}.footer{text-align:center;color:#6b7280;margin:30px 0}.pill{border-radius:999px;padding:5px 10px;background:#eef2ff;font-size:12px;font-weight:900}.pill.danger{background:#fee2e2;color:#991b1b}.pill.warning{background:#fef3c7;color:#92400e}.pill.active{background:#dcfce7;color:#166534}.wide{overflow:auto}.dashboard-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.stat-card{border-left:9px solid var(--gold)}.stat-card.danger{border-left-color:var(--red)}.stat-card.warn{border-left-color:var(--warn)}
/* Kiosk */
.kiosk-body{background:#f8fafc}.kiosk-shell{min-height:100vh}.kiosk-header{background:var(--black);border-bottom:6px solid var(--gold);color:#fff;padding:18px 26px;display:flex;align-items:center;justify-content:space-between}.room-line{font-size:24px;font-weight:900;margin-top:4px}.header-actions{display:flex;gap:10px;flex-wrap:wrap}.ghost-link{color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:9px 13px}.kiosk-main{display:grid;grid-template-columns:minmax(0,2fr) minmax(310px,420px);gap:20px;max-width:1400px;margin:22px auto;padding:0 18px}.kiosk-left h1{font-size:38px;margin:0 0 12px}.big-input{font-size:34px;padding:20px;border:4px solid #d1d5db;border-radius:18px}.huge-btn{font-size:25px;padding:18px 22px;border-radius:18px}.massive-btn{font-size:30px;padding:18px 26px;border-radius:20px}.jumbo-alert{font-size:22px;font-weight:900}.student-panel{margin-top:18px;border-top:1px solid var(--line);padding-top:18px}.student-panel h2{font-size:38px;margin:0}.dest-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:14px}.dest-btn{width:100%;border:4px solid #111827;background:white;border-radius:22px;padding:25px;cursor:pointer;min-height:130px;box-shadow:0 4px 14px rgba(0,0,0,.08)}.dest-btn strong{display:block;font-size:26px}.dest-btn span{display:block;margin-top:11px;color:#6b7280;font-weight:900}.dest-btn:hover{background:#fffbeb;border-color:var(--gold);transform:translateY(-1px)}.pass-active{text-align:center;border:5px solid var(--gold);border-radius:24px;padding:24px;background:#fffbeb}.small-label{text-transform:uppercase;letter-spacing:.12em;font-weight:900;color:#6b7280}.giant-timer{font-size:76px;font-weight:900;margin:14px 0}.side-title{display:flex;align-items:center;justify-content:space-between}.mini-count{display:inline-block;border-radius:999px;background:#111827;color:#fff;padding:6px 12px;font-weight:900}.empty-state{background:#f9fafb;border:1px dashed #d1d5db;border-radius:16px;padding:22px;text-align:center;color:#6b7280;font-weight:800}.active-pass{border:1px solid var(--line);border-left:8px solid var(--gold);padding:13px;margin:11px 0;border-radius:15px;background:#fff}.active-pass strong{font-size:18px}.id-line{margin-left:6px}.pass-dest{font-size:22px;font-weight:900;margin:6px 0}.timer{font-size:20px;font-weight:900}.timer-warning{color:#92400e}.timer-overdue{color:#991b1b}.warning-live{background:#fffbeb!important;border-left-color:var(--warn)!important}.overdue-live{background:#fef2f2!important;border-left-color:var(--red)!important}.student-pick{display:block;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px;margin:8px 0;cursor:pointer}.student-pick span{float:right;color:#6b7280}.inline-form{margin:0}.kiosk-footer{text-align:center;color:#6b7280;margin:8px 0 22px}.kiosk-select-page{max-width:780px;margin:50px auto;padding:0 16px}.brand-panel{text-align:center;margin-bottom:18px}.select-card h1{font-size:34px}
/* Monitor */
.monitor-container{max-width:1500px}.monitor-hero{background:linear-gradient(135deg,#111827,#1f2937);color:#fff;border-bottom:6px solid var(--gold);border-radius:22px;padding:24px 28px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.monitor-hero h1{margin:0;font-size:40px}.monitor-hero p{margin:7px 0 0;color:#d1d5db}.hero-clock{font-size:34px;font-weight:900;color:var(--gold)}.big-stats .card{margin-bottom:0}.monitor-cards{display:grid;grid-template-columns:1fr;gap:12px;margin:16px 0}.hall-card{display:grid;grid-template-columns:1.25fr 1fr 1.4fr 1fr auto auto;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-left:10px solid var(--gold);border-radius:18px;padding:16px;box-shadow:0 4px 14px rgba(0,0,0,.05)}.student-name{font-size:25px;font-weight:900}.student-meta{color:#6b7280;font-weight:700}.hall-dest span,.hall-from span{display:block;color:#6b7280;font-size:12px;text-transform:uppercase;font-weight:900;letter-spacing:.09em}.hall-dest strong,.hall-from strong{font-size:19px}.hall-time .timer{display:block;font-size:26px}.hall-time small{color:#6b7280}.empty-monitor{text-align:center;padding:40px}.compact-table h2{margin-top:0}.row-warning{background:#fffbeb}.row-overdue{background:#fef2f2}
@media(max-width:950px){.kiosk-main{grid-template-columns:1fr}.kiosk-header{display:block}.header-actions{margin-top:12px}.giant-timer{font-size:52px}.hall-card{grid-template-columns:1fr}.monitor-hero{display:block}.hero-clock{margin-top:10px}.topbar{display:block}.nav a{display:inline-block;margin:8px 10px 0 0}table{min-width:900px}}
/* Phase 7 Reports */
.filter-row{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.filter-row label{font-weight:700}.filter-row input{min-width:160px}.report-stats .stat{font-size:2rem}.two-col{grid-template-columns:1fr 1fr}.btn.small{padding:6px 10px;font-size:.9rem}.card.wide table td,.card.wide table th{vertical-align:top}.muted{color:#666}.warn .stat{color:#b45309}@media(max-width:900px){.two-col{grid-template-columns:1fr}.filter-row{display:block}.filter-row label,.filter-row a,.filter-row button{display:block;margin-top:10px}}
