:root{--bg: #fafafa;--surface: #ffffff;--surface-2: #f4f4f5;--surface-hover: #f3f4f6;--text: #18181b;--text-muted: #71717a;--border: #e4e4e7;--border-strong: #d4d4d8;--accent: #3b82f6;--accent-hover: #2563eb;--accent-fg: #ffffff;--danger: #ef4444;--danger-hover: #dc2626;--scrollbar-thumb: rgba(113, 113, 122, .28);--scrollbar-thumb-hover: rgba(113, 113, 122, .45);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--radius: 8px;--radius-sm: 6px}[data-theme=dark]{--bg: #09090b;--surface: #18181b;--surface-2: #1f1f23;--surface-hover: #27272a;--text: #fafafa;--text-muted: #a1a1aa;--border: #27272a;--border-strong: #3f3f46;--accent: #60a5fa;--accent-hover: #93c5fd;--accent-fg: #0a0a0a;--danger: #f87171;--danger-hover: #ef4444;--scrollbar-thumb: rgba(161, 161, 170, .24);--scrollbar-thumb-hover: rgba(161, 161, 170, .42);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 1px 3px rgba(0, 0, 0, .5), 0 1px 2px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Helvetica Neue,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{transition:background .2s ease,color .2s ease}html,header .tabs,.grid-wrap,.table-scroll{scrollbar-color:var(--scrollbar-thumb) transparent;scrollbar-width:thin}html::-webkit-scrollbar,header .tabs::-webkit-scrollbar,.grid-wrap::-webkit-scrollbar,.table-scroll::-webkit-scrollbar{width:8px;height:8px}html::-webkit-scrollbar-track,header .tabs::-webkit-scrollbar-track,.grid-wrap::-webkit-scrollbar-track,.table-scroll::-webkit-scrollbar-track{background:transparent}html::-webkit-scrollbar-thumb,header .tabs::-webkit-scrollbar-thumb,.grid-wrap::-webkit-scrollbar-thumb,.table-scroll::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);background-clip:padding-box;border:2px solid transparent;border-radius:999px}html::-webkit-scrollbar-thumb:hover,header .tabs::-webkit-scrollbar-thumb:hover,.grid-wrap::-webkit-scrollbar-thumb:hover,.table-scroll::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover);background-clip:padding-box}button{font:inherit;font-weight:500;background:var(--surface);color:var(--text);border:1px solid var(--border);padding:.5rem .875rem;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease;display:inline-flex;align-items:center;gap:.375rem}button:hover{background:var(--surface-hover);border-color:var(--border-strong)}button:active{transform:translateY(1px)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}button.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}button.danger{color:var(--danger);border-color:var(--border)}button.danger:hover{background:var(--danger);color:var(--accent-fg);border-color:var(--danger)}button.icon{padding:.45rem;width:36px;height:36px;justify-content:center}button.ghost{background:transparent;border-color:transparent;padding:.35rem .5rem}button.ghost:hover{background:var(--surface-hover)}input[type=text],input[type=password],input[type=number],input[type=date]{font:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);padding:.5rem .75rem;border-radius:var(--radius-sm);transition:border-color .15s ease,box-shadow .15s ease}input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f626}[data-theme=dark] input:focus{box-shadow:0 0 0 3px #60a5fa33}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}header{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 1.25rem;display:flex;align-items:center;gap:1rem;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px)}header h1{font-size:1rem;font-weight:700;letter-spacing:-.01em}header .tabs{display:flex;gap:.25rem;background:var(--surface-2);padding:.25rem;border-radius:999px;overflow-x:auto}header .tabs button{border:none;background:transparent;padding:.4rem .9rem;border-radius:999px;font-size:13px;color:var(--text-muted)}header .tabs button:hover{background:var(--surface-hover);color:var(--text)}header .tabs button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}[data-theme=dark] header .tabs button.active{background:var(--border-strong)}header .spacer{flex:1}header .user{color:var(--text-muted);font-size:.85rem;font-weight:500}.app-switcher{position:fixed;top:calc(.75rem + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:200;width:min(340px,calc(100vw - 5rem));touch-action:pan-y}.switch-pill{position:relative;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));padding:3px;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:999px;box-shadow:var(--shadow)}.switch-indicator{position:absolute;top:3px;bottom:3px;left:3px;width:calc((100% - 6px)/4);background:var(--accent);border-radius:999px;transition:transform .28s cubic-bezier(.2,.8,.2,1)}.switch-pill.dragging .switch-indicator{transition:none}.switch-pill button{position:relative;z-index:1;justify-content:center;border:none;background:transparent;color:var(--text-muted);padding:.4rem .35rem;border-radius:999px;box-shadow:none;font-size:.85rem}.switch-pill button:hover{background:transparent;color:var(--text)}.switch-pill button.active{color:var(--accent-fg)}.utility-menu{position:fixed;right:calc(1rem + env(safe-area-inset-right));top:calc(.9rem + env(safe-area-inset-top));z-index:210}.utility-trigger{width:32px;height:32px;padding:0;justify-content:center;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:999px;box-shadow:var(--shadow-sm);opacity:.46}.utility-trigger:hover,.utility-trigger[aria-expanded=true]{opacity:1}.utility-popover{position:absolute;top:calc(100% + .5rem);right:0;min-width:144px;padding:.35rem;display:grid;gap:.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.utility-popover span{color:var(--text-muted);font-size:.85rem;padding:.4rem .5rem .25rem}.utility-popover button{justify-content:flex-start;white-space:nowrap}main{padding:1.5rem 1.25rem;max-width:100%}.login-shell{min-height:100vh;padding:1rem}.app-shell{padding:calc(4.75rem + env(safe-area-inset-top)) 1.25rem calc(1.5rem + env(safe-area-inset-bottom));max-width:100%;min-height:100dvh;overflow-x:hidden;touch-action:pan-y}.app-shell.dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.screen-track{display:flex;align-items:flex-start;width:100%;transition:transform .32s cubic-bezier(.2,.8,.2,1);will-change:transform}.screen-track.dragging{transition:none}.screen{flex:0 0 100%;min-width:0;opacity:.35;transform:scale(.985);transition:opacity .22s ease,transform .32s cubic-bezier(.2,.8,.2,1)}.screen.active,.screen.is-visible{opacity:1;transform:scale(1)}.screen:not(.is-visible){height:0;overflow:hidden;pointer-events:none}.screen:not(.active){pointer-events:none}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;max-width:1280px;margin:0 auto 1rem}.page-head h1{font-size:1.25rem;line-height:1.2}.page-head p{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.member-head{max-width:960px}.toolbar{display:flex;gap:.5rem;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap}.entry-panel{max-width:1280px;margin-left:auto;margin-right:auto;margin-bottom:1rem}.entry-panel .toolbar{margin-bottom:0}.cohort-input{width:6rem}.member-entry{max-width:960px}.member-add-form{display:grid;grid-template-columns:minmax(180px,1fr) 6rem auto auto;gap:.5rem;align-items:center}.member-add-form .cohort-input,.member-add-form .member-name-input{width:100%}.member-grade{color:var(--text-muted);font-size:.85rem;white-space:nowrap;justify-self:end}.today-empty{background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius);padding:1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:760px;margin:0 auto}.today-empty h2{font-size:1rem;line-height:1.25}.today-empty p{color:var(--text-muted);margin-top:.25rem}.today-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);max-width:960px;margin:0 auto;overflow:hidden}.today-summary{border-bottom:1px solid var(--border);padding:1rem 1.25rem;display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,.8fr);gap:1rem;align-items:center;background:var(--surface-2)}.today-summary span{color:var(--text-muted);font-size:.85rem;font-weight:600}.today-summary strong{display:block;font-size:1.8rem;line-height:1.15;margin-top:.15rem}.today-rate{display:grid;gap:.4rem}.today-rate span{color:var(--text);text-align:right}.today-list{display:grid;gap:0}.today-cohort{border-bottom:1px solid var(--border)}.today-cohort:last-child{border-bottom:none}.today-cohort h2{background:var(--surface-2);color:var(--text-muted);font-size:.8rem;padding:.55rem 1.25rem}.today-members{display:grid}.today-member{min-height:52px;padding:.75rem 1.25rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer}.today-member:hover{background:var(--surface-hover)}.today-member span{font-weight:600}.today-member .checkbox{margin:0}.grid-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:auto;touch-action:pan-y;max-width:1280px;max-height:calc(100vh - 220px);margin:0 auto;background:var(--surface);box-shadow:var(--shadow)}table.grid{border-collapse:separate;border-spacing:0;font-size:13px}table.grid th,table.grid td{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:.5rem .75rem;background:var(--surface);white-space:nowrap}table.grid thead th{position:sticky;top:0;background:var(--surface-2);z-index:2;text-align:center;font-weight:600;font-size:12px;padding:.5rem .75rem;color:var(--text)}table.grid thead th.name-col{left:0;z-index:3;text-align:left;min-width:140px;text-transform:uppercase;font-size:11px;letter-spacing:.05em;color:var(--text-muted);background:var(--surface-2)}table.grid tbody td.name-col{position:sticky;left:0;background:var(--surface);z-index:1;font-weight:500;text-align:left;border-right:1px solid var(--border-strong);min-width:140px}table.grid tbody tr:not(.cohort-row):hover td{background:var(--surface-hover)}table.grid tbody tr.cohort-row td{background:var(--surface-2);font-weight:700;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:.5rem .75rem;border-right:none}table.grid tbody tr.cohort-row td .cohort-label{position:sticky;left:.75rem;display:inline-block}table.grid td.cell{text-align:center;padding:0;width:52px;min-width:52px}.checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:22px;height:22px;border:1.5px solid var(--border-strong);border-radius:5px;cursor:pointer;position:relative;margin:.5rem auto;display:block;background:var(--surface);transition:all .15s ease}.checkbox:hover{border-color:var(--accent)}.checkbox:checked{background:var(--accent);border-color:var(--accent)}.checkbox:checked:after{content:"";position:absolute;left:6px;top:2px;width:6px;height:11px;border:solid var(--accent-fg);border-width:0 2px 2px 0;transform:rotate(45deg)}.date-head{display:flex;flex-direction:column;align-items:center;gap:2px}.date-head .date-main{font-weight:600;font-size:13px}.date-head .date-title{font-size:10px;font-weight:500;color:var(--text-muted)}.date-head .date-del{background:transparent;border:none;color:var(--text-muted);font-size:14px;width:20px;height:20px;border-radius:4px;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.date-head .date-del:hover{background:var(--danger);color:var(--accent-fg)}table.list{border-collapse:separate;border-spacing:0;width:100%;max-width:960px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.list-wrap{max-width:960px;margin:0 auto}table.list th,table.list td{border-bottom:1px solid var(--border);padding:.75rem 1rem;text-align:left}table.list tr:last-child td{border-bottom:none}table.list th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;background:var(--surface-2)}table.list tbody tr:hover{background:var(--surface-hover)}table.list .actions{display:flex;gap:.375rem}table.list .actions button{padding:.35rem .65rem;font-size:12px}.empty-cell{color:var(--text-muted);padding:2rem 1rem;text-align:center}.analytics-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;max-width:1280px;margin:0 auto 1rem}.analytics-header h1{font-size:1.25rem;line-height:1.2;margin-bottom:.25rem}.analytics-header p{color:var(--text-muted);font-size:.9rem}.analytics-dashboard{max-width:1280px;margin:0 auto;min-width:0}.summary-strip{display:grid;grid-template-columns:minmax(220px,1.4fr) repeat(3,minmax(150px,1fr));gap:.75rem;margin-bottom:1rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:.875rem;min-height:88px;display:flex;flex-direction:column;justify-content:center;gap:.2rem}.stat-card.primary-stat{background:var(--accent);border-color:var(--accent);color:var(--accent-fg)}.stat-card.primary-stat span,.stat-card.primary-stat small{color:var(--accent-fg);opacity:.82}.stat-card.primary-stat strong{font-size:2rem}.stat-card span{color:var(--text-muted);font-size:.78rem;font-weight:600}.stat-card strong{font-size:1.45rem;line-height:1.15}.stat-card small{color:var(--text-muted);font-size:.78rem}.analytics-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem;min-width:0}.chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1rem}.chart-grid .chart-wide{grid-column:1 / -1}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.875rem}.panel-head h2{font-size:.95rem;line-height:1.25}.panel-head p,.panel-head span{color:var(--text-muted);font-size:.8rem}.panel-head strong{color:var(--accent);font-size:1.35rem;line-height:1.1}.chart-box{height:280px;position:relative}.chart-box canvas{width:100%!important;height:100%!important}.member-chart{height:220px}.member-detail-grid{display:grid;grid-template-columns:minmax(320px,.8fr) minmax(0,1.2fr);gap:1rem;align-items:start}.member-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.625rem;margin-bottom:1rem}.member-metrics .stat-card{background:transparent;border:none;box-shadow:none;min-height:76px;padding:.75rem}.member-metrics .stat-card strong{font-size:1.15rem}.member-screen{margin-top:0}.detail-back{margin:-.35rem 0 .5rem}.table-scroll{overflow:auto;touch-action:pan-y}table.analytics-table{border-collapse:separate;border-spacing:0;width:100%;min-width:560px;font-size:13px}table.analytics-table th,table.analytics-table td{border-bottom:1px solid var(--border);padding:.65rem .75rem;text-align:left;vertical-align:middle}table.analytics-table tr:last-child td{border-bottom:none}table.analytics-table th{color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:0;text-transform:uppercase}table.analytics-table tbody tr:hover{background:var(--surface-hover)}table.analytics-table.history{min-width:420px}.link-button{background:transparent;border-color:transparent;color:var(--accent);padding:.15rem 0;font-weight:700}.link-button:hover{background:transparent;border-color:transparent;color:var(--accent-hover);text-decoration:underline}.rate-cell{display:grid;grid-template-columns:4rem minmax(72px,1fr);gap:.5rem;align-items:center}.rate-track{height:8px;background:var(--surface-2);border-radius:999px;overflow:hidden}.rate-fill{height:100%;background:var(--accent);border-radius:999px}.status-pill{display:inline-flex;align-items:center;min-width:3rem;justify-content:center;border-radius:999px;padding:.15rem .45rem;font-size:.75rem;font-weight:700}.status-pill.present{background:#3b82f624;color:var(--accent)}.status-pill.late{background:#f59e0b29;color:#b45309}.status-pill.absent{background:#ef444424;color:var(--danger)}.status-pill.excused{background:#10b98124;color:#059669}[data-theme=dark] .status-pill.late{color:#fbbf24}[data-theme=dark] .status-pill.excused{color:#34d399}.login-wrap{max-width:360px;margin:8vh auto;padding:2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.login-wrap h2{margin-bottom:1.25rem;font-size:1.25rem;font-weight:700;letter-spacing:-.01em}.login-wrap .form-row{margin-bottom:.875rem}.login-wrap label{display:block;font-size:12px;margin-bottom:.375rem;color:var(--text-muted);font-weight:500}.login-wrap input{width:100%}.login-wrap button{width:100%;padding:.625rem;margin-top:.25rem;background:var(--accent);color:var(--accent-fg);border-color:var(--accent);font-weight:600}.login-wrap button:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.error{background:var(--surface);border:1px solid var(--danger);color:var(--danger);padding:.625rem .875rem;margin-bottom:.875rem;font-size:.85rem;border-radius:var(--radius-sm)}.muted{color:var(--text-muted);font-size:.85rem}.empty{color:var(--text-muted);padding:3rem 1rem;text-align:center;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}.loading{color:var(--text-muted);padding:2rem;text-align:center}@media (max-width: 640px){header{flex-wrap:wrap;padding:.75rem}header h1{width:100%}header .user{display:none}main{padding:1rem .75rem}.app-shell{padding:calc(4.5rem + env(safe-area-inset-top)) .75rem calc(1rem + env(safe-area-inset-bottom))}.utility-menu{top:calc(.95rem + env(safe-area-inset-top));right:calc(.75rem + env(safe-area-inset-right))}.utility-trigger{width:28px;height:28px}.utility-popover span{display:none}.grid-wrap{max-height:calc(100vh - 240px)}.analytics-header{flex-direction:column}.chart-box{height:240px}.rate-cell{grid-template-columns:3.5rem minmax(64px,1fr)}.today-empty{align-items:stretch;flex-direction:column}.today-summary{grid-template-columns:1fr}.today-rate span{text-align:left}.today-member{padding:.8rem 1rem}.member-add-form{grid-template-columns:minmax(0,1fr) 5.75rem auto}.member-add-form .member-grade{grid-column:1 / -1;justify-self:start}}@media (max-width: 980px){.summary-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.member-detail-grid{grid-template-columns:1fr}}@media (max-width: 820px){.chart-grid{grid-template-columns:1fr}.chart-grid .chart-wide{grid-column:auto}}@media (max-width: 560px){.summary-strip,.member-metrics,.member-add-form{grid-template-columns:1fr}.member-add-form .cohort-input{width:100%}.member-add-form button{justify-content:center}}
