:root{color:#101513;background:#f6f8f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--accent: #0e7c66;--accent-strong: #075f4d;--danger: #c73552;--ink: #101513;--muted: #5b6561;--line: #d9e1dd;--panel: #ffffff;--surface: #eef4f1;--warning: #b08b21}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.62}input,select{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);min-height:46px;padding:.75rem .85rem;outline:none}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0e7c6629}label{display:grid;gap:.45rem;color:var(--muted);font-size:.9rem;font-weight:700}h1,h2,h3,p{margin:0}h1{font-size:clamp(2rem,4vw,4.25rem);line-height:1.02;letter-spacing:0}h2{font-size:clamp(1.3rem,2.2vw,2.2rem);letter-spacing:0}h3{font-size:1rem;letter-spacing:0}.auth-screen{min-height:100vh;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.65fr);align-items:stretch;background:linear-gradient(120deg,#0e7c6614,#c735520f),#f6f8f7}.auth-copy{display:flex;min-height:100vh;flex-direction:column;justify-content:center;gap:1.35rem;padding:7vw}.auth-copy p:not(.eyebrow):not(.pending-token){max-width:48rem;color:var(--muted);font-size:1.08rem;line-height:1.75}.pending-token{width:fit-content;max-width:100%;border:1px solid rgba(14,124,102,.25);border-radius:8px;background:#0e7c6614;color:var(--accent-strong);padding:.75rem .9rem;font-weight:800}.auth-panel{display:flex;flex-direction:column;justify-content:center;gap:1.15rem;min-height:100vh;border-left:1px solid var(--line);background:#ffffffe0;padding:3rem}.mode-switch{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:8px;overflow:hidden}.mode-switch button{border:0;background:#fff;color:var(--muted);min-height:46px;font-weight:800}.mode-switch button.active{background:var(--ink);color:#fff}.stack-form,.compact-form{display:grid;gap:1rem}.primary-action,.secondary-action,.oauth-action,.text-action{min-height:46px;border-radius:8px;padding:.78rem 1rem;font-weight:850}.primary-action{border:1px solid var(--accent);background:var(--accent);color:#fff}.primary-action:hover{background:var(--accent-strong)}.secondary-action{border:1px solid var(--line);background:#fff;color:var(--ink)}.secondary-action:hover{border-color:var(--accent);color:var(--accent-strong)}.oauth-action{width:100%;border:1px solid var(--ink);background:var(--ink);color:#fff}.oauth-action:hover{background:#25302c}.auth-divider{display:flex;align-items:center;gap:.8rem;color:var(--muted);font-size:.82rem;font-weight:800;text-transform:uppercase}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--line)}.text-action{border:0;background:transparent;color:var(--accent-strong);padding-inline:0}.fine-print{color:var(--muted);font-size:.9rem;line-height:1.5}.eyebrow{color:var(--accent-strong);font-size:.78rem;font-weight:900;letter-spacing:0;text-transform:uppercase}.loading-screen{display:grid;place-content:center;gap:1rem;min-height:100vh;padding:2rem;text-align:center}.app{min-height:100vh;background:#f6f8f7}.app-header{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:1rem;border-bottom:1px solid var(--line);background:#fffffff0;backdrop-filter:blur(14px);padding:1rem max(1rem,calc((100vw - 1220px)/2))}.app-header h1{font-size:1.55rem}.account-pill{display:flex;align-items:center;gap:.8rem;min-width:0;color:var(--muted);font-weight:800}.account-pill span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-pill button{border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);min-height:40px;padding:.55rem .85rem;font-weight:850}.view-switch{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:8px;overflow:hidden}.view-switch button{border:0;background:#fff;color:var(--muted);min-height:40px;padding:.5rem .8rem;font-weight:850}.view-switch button.active{background:var(--ink);color:#fff}.workspace{display:grid;gap:1.25rem;width:min(1220px,100%);margin:0 auto;padding:1.25rem 1rem 3rem}.admin-menu{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.65rem;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:.65rem}.admin-menu button{border:1px solid transparent;border-radius:8px;background:transparent;color:var(--muted);min-height:42px;padding:.6rem .7rem;font-weight:850}.admin-menu button.active{border-color:var(--accent);background:#0e7c661a;color:var(--accent-strong)}.toolbar-band,.mobile-status{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:1.2rem}.toolbar-actions{display:flex;align-items:end;gap:.8rem}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.stat-card{display:grid;min-height:112px;align-content:space-between;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:1rem}.stat-card span{color:var(--muted);font-weight:800}.stat-card strong{color:var(--ink);font-size:2.5rem;line-height:1}.split-layout{display:grid;grid-template-columns:minmax(320px,.85fr) minmax(0,1.4fr);gap:1rem;align-items:start}.panel{display:grid;gap:1rem;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:1rem}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:1rem}.panel-heading-actions{display:flex;align-items:center;gap:.6rem}.panel-heading--mobile-inline{align-items:flex-start}.session-list,.permanent-qr{display:grid;gap:.9rem}.permanent-qr{justify-items:center;border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:1rem}.session-card{display:grid;grid-template-columns:168px minmax(0,1fr);gap:1rem;align-items:center;border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:.9rem}.qr-image{width:100%;aspect-ratio:1;border:1px solid var(--line);border-radius:8px;background:#fff;object-fit:contain}.session-card p{color:var(--muted);line-height:1.55}.qr-link{max-width:100%;overflow-wrap:anywhere;font-size:.8rem}.search-field{max-width:420px}.manual-attendance-form{display:grid;grid-template-columns:minmax(160px,.7fr) minmax(220px,1fr) minmax(220px,1.2fr) auto;gap:.9rem;align-items:end}.filter-bar{display:grid;gap:.85rem}.filter-inline-controls{display:grid;grid-template-columns:minmax(220px,1fr) minmax(180px,.55fr) minmax(140px,.35fr);gap:.85rem;align-items:end}.filter-funnel-toggle{display:none;align-items:center;justify-content:center;width:40px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);min-height:40px;padding:.5rem;font-weight:850}.filter-funnel-toggle svg{width:16px;height:16px}.filter-drawer-layer{display:none}.filter-drawer{display:grid;gap:.8rem;border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:0 18px 40px #10151324;padding:.85rem}.filter-drawer-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.filter-drawer-body{display:grid;gap:.75rem}.filter-bar--toggle-only{width:auto}.history-controls{display:flex;align-items:end;gap:.8rem}.analytics-panel{gap:.95rem}.analytics-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem;align-items:end}.analytics-chart-wrap{display:grid;gap:.7rem;border:1px solid var(--line);border-radius:8px;background:#fff;padding:.75rem}.analytics-chart{display:block;width:100%;height:auto}.analytics-meta{display:flex;flex-wrap:wrap;gap:.7rem;color:var(--muted);font-size:.82rem;font-weight:800}.analytics-legend{display:flex;flex-wrap:wrap;gap:.45rem .9rem;color:var(--muted);font-size:.82rem;font-weight:800}.analytics-legend span{display:inline-flex;align-items:center;gap:.42rem}.analytics-legend i{display:inline-block;width:11px;height:11px;border-radius:999px;flex:0 0 auto}.student-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.85rem}.student-card{display:grid;gap:.8rem;border:1px solid var(--line);border-radius:8px;background:#fff;padding:.9rem}.student-card p{color:var(--muted);overflow-wrap:anywhere}.student-meta{display:flex;flex-wrap:wrap;gap:.45rem}.student-meta span{border:1px solid var(--line);border-radius:8px;color:var(--muted);padding:.35rem .5rem;font-size:.82rem;font-weight:800}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:8px}table{width:100%;border-collapse:collapse;background:#fff}th,td{border-bottom:1px solid var(--line);padding:.85rem;text-align:left;vertical-align:top}th{color:var(--muted);font-size:.82rem;text-transform:uppercase}td{color:var(--ink)}tr:last-child td{border-bottom:0}.record-list{display:none;gap:.8rem}.record-card{display:flex;justify-content:space-between;gap:1rem;border:1px solid var(--line);border-radius:8px;background:#fff;padding:.9rem}.record-card p,.record-card span{color:var(--muted);overflow-wrap:anywhere}.record-card div:last-child{display:grid;gap:.4rem;min-width:126px;text-align:right}.record-card strong{font-size:.88rem}.status-message{position:sticky;top:82px;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:1rem;width:min(1220px,calc(100% - 2rem));margin:1rem auto 0;border:1px solid var(--line);border-radius:8px;background:#fff;padding:.85rem 1rem;box-shadow:0 14px 34px #10151314}.status-message.success{border-color:#0e7c6659;color:var(--accent-strong)}.status-message.error{border-color:#c7355259;color:var(--danger)}.status-message.info{border-color:#b08b2159;color:#765f17}.status-message button{border:0;background:transparent;color:inherit;font-weight:850}.empty-state{display:grid;gap:.35rem;border:1px dashed var(--line);border-radius:8px;background:#fbfcfc;padding:1rem}.empty-state p{color:var(--muted);line-height:1.55}.flexie-workspace{max-width:760px}.profile-setup-workspace{max-width:560px}.mobile-status{display:grid;justify-content:stretch}.mobile-status p:not(.eyebrow){color:var(--muted);line-height:1.6}.scan-surface{min-height:430px;border:1px solid var(--line);border-radius:8px;background:#101513;color:#fff;overflow:hidden}.scan-ready{display:grid;min-height:430px;align-content:space-between;gap:2rem;padding:1.2rem}.scan-ready p{color:#ffffffbf;overflow-wrap:anywhere}.scan-ready .eyebrow{color:#7dd9c6}.scan-button{width:100%;min-height:58px}.scanner{display:grid;gap:1rem;padding:1rem}.scanner-frame{position:relative;min-height:320px;aspect-ratio:4 / 5;border:1px solid rgba(255,255,255,.2);border-radius:8px;overflow:hidden;background:#050605}.scanner-frame video{width:100%;height:100%;object-fit:cover}.scanner-guide{position:absolute;inset:12%;display:grid;place-items:end center;border:2px solid rgba(255,255,255,.86);border-radius:8px;padding:1rem;color:#fff;text-align:center}.scanner-guide span{border-radius:8px;background:#101513b8;padding:.5rem .7rem;font-weight:850}.scanner-note{color:#fff;line-height:1.6}.scanner .text-action{color:#fff}@media(max-width:980px){.auth-screen{grid-template-columns:1fr}.auth-copy{min-height:auto;padding:4rem 1.25rem 2rem}.auth-panel{min-height:auto;border-left:0;border-top:1px solid var(--line);padding:1.25rem}.split-layout{grid-template-columns:1fr}.toolbar-band{align-items:stretch;flex-direction:column}.toolbar-actions{align-items:stretch}.admin-menu,.manual-attendance-form,.filter-inline-controls{grid-template-columns:1fr}.history-controls{align-items:stretch;flex-direction:column}}@media(max-width:680px){input,select{min-height:40px;padding:.58rem .65rem}label{gap:.32rem;font-size:.78rem}h1{font-size:1.65rem}h2{font-size:1.05rem}h3{font-size:.9rem}p,td{font-size:.88rem}.app-header{align-items:flex-start;grid-template-columns:1fr auto;gap:.6rem;padding:.62rem .75rem}.app-header h1{font-size:1rem}.account-pill{flex-direction:column;align-items:flex-end;gap:.45rem;max-width:44vw}.account-pill button{min-height:32px;padding:.34rem .52rem;font-size:.8rem}.workspace{gap:.62rem;padding:.62rem .55rem 1.25rem}.view-switch{grid-column:1 / -1;width:100%;order:3}.view-switch button,.admin-menu button{min-height:34px;padding:.42rem .5rem;font-size:.8rem}.admin-menu{display:flex;gap:.45rem;overflow-x:auto;padding:.45rem;scrollbar-width:none}.admin-menu button{flex:0 0 auto}.toolbar-band,.mobile-status,.panel,.stat-card,.student-card,.record-card{padding:.72rem}.toolbar-band,.mobile-status{gap:.65rem}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.4rem}.stat-card{min-height:58px;padding:.6rem}.stat-card span{font-size:.78rem}.stat-card strong{font-size:1.85rem}.session-card{grid-template-columns:1fr}.qr-image{width:min(100%,210px);justify-self:center}.panel-heading,.toolbar-actions{align-items:stretch;flex-direction:column}.panel-heading-actions{width:auto;align-items:center;justify-content:flex-end}.panel-heading--mobile-inline{align-items:flex-start;flex-direction:row;justify-content:space-between}.panel-heading--mobile-inline>div{min-width:0}.search-field{max-width:none}.analytics-controls{grid-template-columns:1fr}.analytics-chart-wrap{overflow:hidden}.analytics-chart{min-width:0;width:100%}.analytics-chart text{font-size:10px}.analytics-legend{font-size:.74rem;gap:.35rem .65rem}.table-wrap{display:none}.record-list{display:grid;gap:.55rem}.record-card{flex-direction:column;gap:.55rem}.record-card div:last-child{min-width:0;text-align:left}.status-message{position:static;width:calc(100% - 1.5rem);margin-top:.75rem}.manual-attendance-form{grid-template-columns:1fr}.filter-inline-controls{display:none}.filter-funnel-toggle{display:inline-flex}.filter-bar--toggle-only{display:inline-flex;align-items:center;justify-content:flex-end;margin-left:auto;margin-top:0;gap:0}.filter-drawer-layer{position:fixed;inset:0;z-index:70;display:block;background:#1015132e}.filter-drawer{position:absolute;top:12vh;right:.75rem;width:min(75vw,320px);height:min(75vh,360px);overflow:auto}.scan-surface,.scan-ready{min-height:calc(100vh - 260px)}.scan-ready{gap:1rem;padding:.85rem}.scan-button{min-height:46px}.scanner{gap:.65rem;padding:.65rem}.scanner-frame{min-height:240px}.primary-action,.secondary-action,.oauth-action,.text-action{min-height:40px;padding:.58rem .68rem;font-size:.84rem}.auth-copy{gap:.75rem;padding:2rem .85rem 1rem}.auth-copy p:not(.eyebrow):not(.pending-token){font-size:.92rem;line-height:1.5}.auth-panel{gap:.8rem;padding:.85rem}.stack-form,.compact-form{gap:.68rem}}
