:root{color-scheme:light;--bg: #ede1fb;--bg-strong: #f7efff;--surface: rgba(243, 234, 255, .84);--surface-strong: #f5edff;--surface-deep: #5f3f93;--ink: #4f2c86;--muted: #8d73b7;--line: rgba(95, 63, 147, .16);--accent: #005dac;--accent-deep: #5f3f93;--primary: #005dac;--primary-haze: rgba(0, 93, 172, .18);--secondary: #e76b9e;--secondary-haze: rgba(231, 107, 158, .18);--tertiary: #50b848;--tertiary-haze: rgba(80, 184, 72, .18);--neutral: #5f3f93;--neutral-haze: rgba(95, 63, 147, .12);--positive: #3b9f3a;--negative: #bb3d74;--panel-border: rgba(255, 255, 255, .58);--nav-rail-bg: rgba(246, 238, 255, .74);--session-bg: rgba(249, 244, 255, .84);--metric-bg: rgba(239, 228, 252, .7);--input-bg: rgba(252, 248, 255, .94);--hero-copy: rgba(248, 243, 255, .84);--hero-start: #5f3f93;--hero-mid: #005dac;--hero-end: #e76b9e;--text-on-accent: #fff9ff;--shadow: 0 24px 48px rgba(95, 63, 147, .16);--radius-lg: 28px;--radius-md: 18px;--radius-sm: 12px;--safe-top: env(safe-area-inset-top, 0px);--safe-right: env(safe-area-inset-right, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--font-sans: "Aptos", "Segoe UI Variable", "Bahnschrift", "Trebuchet MS", sans-serif;--font-display: "Bahnschrift", "Aptos", "Segoe UI Variable", sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font-sans);color:var(--ink);padding:var(--safe-top) var(--safe-right) var(--safe-bottom) var(--safe-left);background:radial-gradient(circle at top left,var(--primary-haze),transparent 34%),radial-gradient(circle at top right,var(--secondary-haze),transparent 26%),linear-gradient(180deg,var(--bg-strong) 0%,var(--bg) 100%)}::selection{background:var(--secondary);color:var(--text-on-accent)}a{color:inherit;text-decoration:none}button,a{font:inherit}.app-shell{display:grid;grid-template-columns:minmax(260px,300px) 1fr;min-height:100vh}.pwa-install-banner{position:fixed;right:max(20px,calc(var(--safe-right) + 20px));bottom:max(20px,calc(var(--safe-bottom) + 20px));z-index:20;width:min(420px,calc(100vw - 32px));padding:18px;border-radius:24px;border:1px solid var(--panel-border);background:linear-gradient(135deg,#5f3f93f0,#005dacf0),#f3eaffeb;box-shadow:0 28px 56px #1f214d42;color:var(--text-on-accent);display:grid;gap:14px}.pwa-install-banner .eyebrow,.pwa-install-banner p{color:#f9f4ffe0}.pwa-install-copy{display:grid;gap:8px}.pwa-install-copy strong{font-size:1.05rem}.pwa-install-copy p{margin:0;line-height:1.6}.pwa-install-actions{display:flex;flex-wrap:wrap;gap:10px}.pwa-install-actions .primary-button{background:#fff9ff;color:var(--surface-deep)}.nav-rail{padding:32px 24px;border-right:1px solid var(--line);background:var(--nav-rail-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;flex-direction:column;gap:24px}.brand-block h1,.hero-card h1,.spotlight h2,.panel h2,.panel h3{margin:0;font-family:var(--font-display);letter-spacing:.01em}.brand-block p,.panel p,.lead,.module-card p,.module-card strong,.hero-banner p{color:var(--muted);line-height:1.6}.eyebrow{display:inline-flex;margin-bottom:10px;font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--accent-deep)}.nav-links{display:grid;gap:10px}.nav-link{display:grid;gap:4px;padding:14px 16px;border-radius:var(--radius-md);border:1px solid transparent;transition:transform .14s ease,border-color .14s ease,background .14s ease}.nav-link:hover,.nav-link.active{transform:translate(2px);background:var(--surface-strong);border-color:var(--line)}.nav-link span{font-weight:700}.nav-link small{color:var(--muted)}.session-card,.meta-panel,.panel,.hero-card,.hero-banner,.module-card,.metric-card{background:var(--surface);border:1px solid var(--panel-border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.meta-panel,.panel,.hero-card,.module-card,.metric-card{border-radius:var(--radius-lg)}.meta-panel{padding:18px;margin-top:auto}.session-card{padding:18px;display:grid;gap:14px;background:var(--session-bg);border-radius:var(--radius-lg);border:1px solid var(--line)}.session-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.role-chip-row{display:flex;flex-wrap:wrap;gap:8px}.content-shell{padding:28px;display:grid;gap:22px}.hero-banner,.hero-card,.panel,.spotlight{padding:24px}.hero-banner{display:flex;justify-content:space-between;gap:24px;border-radius:32px;background:linear-gradient(135deg,var(--hero-start),var(--hero-mid) 56%,var(--hero-end)),linear-gradient(135deg,var(--secondary-haze),transparent);color:var(--text-on-accent)}.hero-banner p,.hero-banner .eyebrow{color:var(--hero-copy)}.login-scene{min-height:100vh;padding:clamp(16px,4vw,34px);display:grid;place-items:center}.login-stage{position:relative;width:min(100%,980px);min-height:min(100vh - 32px,860px);padding:clamp(20px,4vw,42px);border-radius:36px;overflow:hidden;display:grid;justify-items:center;align-content:start;gap:clamp(18px,2.5vw,28px);background:radial-gradient(circle at 12% 52%,rgba(170,162,255,.44),transparent 18%),radial-gradient(circle at 86% 48%,rgba(132,222,255,.46),transparent 24%),linear-gradient(180deg,#0459aa,#0e75ca,#d8efff 72%,#fff7fb);border:10px solid rgba(177,186,197,.84);box-shadow:0 18px 48px #425e7a42}.login-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(255,255,255,.14) 1px,transparent 1px);background-size:20px 20px;opacity:.36;pointer-events:none}.login-stage:after{content:"";position:absolute;left:0;right:0;bottom:0;height:28px;background:#1263b2}.login-stage>*{position:relative;z-index:1}.login-stage-topline{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.login-stage-session{margin:0;display:grid;gap:4px;color:#f0f8ffdb;font-size:.96rem;text-align:right}.login-stage-session strong{color:#fff;font-size:1rem}.login-stage-brand{margin-top:clamp(10px,4vw,24px);display:grid;justify-items:center;gap:18px;text-align:center;color:#fff}.login-stage-brand h1{margin:0;font-family:var(--font-sans);font-size:clamp(2rem,3vw,3rem);line-height:1.06;font-weight:400;text-wrap:balance}.club-seven-wordmark{display:inline-flex;align-items:flex-start;gap:10px;color:#fff}.club-seven-badge{margin-top:8px;width:clamp(20px,2vw,28px);padding:6px 4px;border-radius:999px;background:#fffffff0;display:grid;justify-items:center;gap:0;box-shadow:0 10px 22px #0f4e8b38}.club-seven-badge span{color:#0f63b1;font-size:clamp(.42rem,.75vw,.56rem);font-weight:900;line-height:.82;text-transform:uppercase}.club-seven-stack{display:grid;justify-items:start;line-height:.82}.club-seven-word{font-family:"Arial Black",var(--font-display);font-weight:900;letter-spacing:-.08em;text-shadow:0 8px 20px rgba(8,58,114,.22)}.club-seven-word-top{font-size:clamp(3.2rem,6vw,5.6rem);transform:rotate(-4deg)}.club-seven-word-bottom{margin-top:-6px;font-size:clamp(3.1rem,5.8vw,5.4rem);transform:rotate(-3deg) translate(8px)}.seed-orb-card{width:min(100%,420px)}.seed-orb-shape{position:relative;min-height:clamp(250px,32vw,310px);display:grid;place-items:center;padding:28px 30px}.seed-orb-shape:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:46% 54% 50% 50%/36% 42% 58% 64%;background:#ea4d99;box-shadow:0 26px 54px #ea4d9957;transform:rotate(-10deg)}.seed-orb-outline{position:absolute;top:14px;right:14px;bottom:14px;left:14px;border:4px dashed rgba(255,186,214,.72);border-radius:46% 54% 50% 50%/36% 42% 58% 64%;transform:rotate(6deg)}.seed-orb-copy{position:relative;display:grid;justify-items:center;gap:14px;text-align:center;color:#fff}.seed-orb-copy h2{margin:0;font-family:var(--font-sans);font-size:clamp(2rem,3vw,2.6rem);line-height:.96;font-weight:800}.seed-orb-copy p{margin:0;max-width:17ch;font-size:clamp(.96rem,1.2vw,1.18rem);line-height:1.35;color:#fff2f9e6}.seed-orb-icon{width:clamp(60px,8vw,74px);height:clamp(60px,8vw,74px)}.login-action-stack{width:min(100%,420px);display:grid;gap:16px;justify-items:center}.seed-access-button,.login-switch-button{border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:12px;font-weight:800;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}.seed-access-button:hover,.login-switch-button:hover,.credential-demo-card:hover{transform:translateY(-1px)}.seed-access-button{min-width:min(100%,320px);padding:16px 26px;border-radius:999px;background:linear-gradient(180deg,#56c94f,#44b63e);color:#fff;box-shadow:0 12px 26px #49b94147}.login-switch-shell{width:min(100%,420px);padding:12px;border-radius:999px;background:#fff0fcbd;border:1px solid rgba(154,112,214,.14);box-shadow:inset 0 1px #ffffffad}.login-switch-button{width:100%;min-height:64px;padding:16px 24px;border-radius:999px;background:linear-gradient(180deg,#6e4aa8,#5f3f93);color:#fff;box-shadow:0 14px 30px #5f3f9333}.action-icon{width:22px;height:22px;flex:none}.credential-form-shell{width:min(100%,520px);display:grid;grid-template-rows:0fr;opacity:0;transform:translateY(-8px);transition:grid-template-rows .22s ease,opacity .22s ease,transform .22s ease}.credential-form-shell-open{grid-template-rows:1fr;opacity:1;transform:translateY(0)}.credential-form-shell>*{min-height:0;overflow:hidden}.credential-form-panel{padding:clamp(20px,3vw,26px);border-radius:30px;background:#fff8fecc;border:1px solid rgba(255,255,255,.74);box-shadow:0 18px 42px #567aa429;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;gap:18px}.credential-form-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.credential-form-heading h2{margin:0;color:#5f3f93;font-family:var(--font-sans);font-size:clamp(1.4rem,2vw,1.8rem);line-height:1}.credential-auth-form{gap:16px}.credential-form-panel .field span{color:#5f3f93}.credential-form-panel .field input{border-radius:22px;padding:16px 18px;border-color:#7062b72e;background:#ffffffe6}.credential-submit-button{min-height:58px;background:linear-gradient(180deg,#0d67b8,#005dac);box-shadow:0 16px 30px #005dac33}.helper-banner{border-radius:18px;padding:12px 14px;background:#50b8481f;color:#288b2e;font-weight:700}.credential-demo-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.credential-demo-card{min-height:86px;border-radius:20px;background:#ffffffdb;border-color:#6f54a024;color:#4f2c86}.credential-demo-card strong{font-size:1rem}.credential-demo-card span{color:#7d61ac}.login-shell,.panel-stack{display:grid;gap:22px}.login-shell{min-height:100vh;padding:28px;grid-template-columns:1.15fr .85fr;align-items:start}.hero-card{display:grid;gap:24px}.auth-hero{position:relative;overflow:hidden}.auth-hero:after{content:"";position:absolute;inset:auto -10% -18% auto;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,var(--secondary-haze),transparent 70%);pointer-events:none}.auth-hero-copy{display:grid;gap:12px}.lead{font-size:1.05rem;max-width:72ch}.banner-grid,.module-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.metric-card,.module-card{padding:18px}.metric-card{display:grid;gap:8px;background:var(--metric-bg)}.metric-value{font-family:var(--font-display);font-size:2rem;color:var(--surface-deep)}.metric-label{color:var(--muted)}.section-header,.module-header,.timeline-item{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.module-card h3{margin:14px 0 8px}.primary-link{display:inline-flex;align-items:center;justify-content:center;margin-top:16px;padding:12px 16px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:var(--text-on-accent);font-weight:700}.primary-link.secondary{background:transparent;border:1px solid var(--line);color:var(--surface-deep)}.primary-button,.ghost-button{border:0;cursor:pointer;transition:transform .14s ease,opacity .14s ease,background .14s ease}.primary-button{display:inline-flex;align-items:center;justify-content:center;padding:14px 16px;border-radius:999px;background:var(--primary);color:var(--text-on-accent);font-weight:800}.ghost-button{padding:10px 12px;border-radius:999px;background:transparent;color:var(--surface-deep);border:1px solid var(--line)}.ghost-button.active{background:var(--metric-bg);border-color:var(--primary);color:var(--primary)}.primary-button:hover,.ghost-button:hover,.quick-fill-card:hover{transform:translateY(-1px)}.primary-button:disabled{opacity:.72;cursor:wait}.auth-panel{display:grid;gap:18px}.auth-form{display:grid;gap:14px}.field{display:grid;gap:8px}.field span{font-weight:700}.field input{width:100%;border:1px solid var(--line);border-radius:16px;padding:14px 16px;background:var(--input-bg);color:var(--ink);outline:none}.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:16px;padding:14px 16px;background:var(--input-bg);color:var(--ink);outline:none;font:inherit}.field textarea{min-height:112px;resize:vertical}.field input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-haze)}.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-haze)}.error-banner{border-radius:16px;padding:12px 14px;background:var(--secondary-haze);color:var(--negative);font-weight:700}.helper-copy{margin:0;color:var(--muted)}.quick-fill-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.quick-fill-card{text-align:left;padding:14px;border-radius:18px;border:1px solid var(--line);background:var(--session-bg);cursor:pointer;display:grid;gap:6px}.boot-screen{min-height:100vh;display:grid;place-items:center;padding:24px}.boot-card{width:min(440px,100%);padding:28px;border-radius:32px;background:var(--session-bg);border:1px solid var(--line);box-shadow:var(--shadow)}.status-chip{display:inline-flex;align-items:center;padding:7px 11px;border-radius:999px;font-size:.8rem;font-weight:700}.status-chip.live{background:var(--primary-haze);color:var(--primary)}.status-chip.neutral{background:var(--neutral-haze);color:var(--surface-deep)}.status-chip.warning{background:#ffd16638;color:#9f6200}.status-chip.negative{background:var(--secondary-haze);color:var(--negative)}.status-chip.outline{border:1px solid var(--line);color:var(--muted)}.dashboard-link-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.split-grid{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.stack-list{display:grid;gap:12px}.selection-card{width:100%;padding:16px;border-radius:22px;border:1px solid var(--line);background:linear-gradient(180deg,var(--surface),var(--session-bg));display:grid;gap:12px;text-align:left;box-shadow:inset 0 1px #ffffff70}button.selection-card{cursor:pointer;transition:transform .14s ease,border-color .14s ease,background .14s ease}button.selection-card:hover{transform:translateY(-1px)}.selection-card.active{border-color:var(--primary);background:linear-gradient(180deg,var(--metric-bg),var(--surface))}.selection-card.pending{border-style:dashed}.selection-card-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.selection-card-title p,.selection-card p{margin:0;color:var(--muted);line-height:1.5}.selection-card-meta{display:flex;flex-wrap:wrap;gap:8px}.option-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.option-card{padding:14px;border-radius:20px;border:1px solid var(--line);background:var(--session-bg);display:grid;gap:6px;text-align:left;cursor:pointer;transition:transform .14s ease,border-color .14s ease,background .14s ease}.option-card:hover{transform:translateY(-1px)}.option-card.active{border-color:var(--secondary);background:linear-gradient(180deg,var(--secondary-haze),var(--surface))}.option-card strong,.selection-card strong{color:var(--surface-deep)}.roster-card{gap:16px}.compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.table-shell{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:14px 12px;text-align:left;border-bottom:1px solid var(--line)}.timeline{display:grid;gap:14px}.timeline-item{padding:14px 0;border-bottom:1px solid var(--line)}.timeline-badge{width:12px;height:12px;border-radius:50%;margin-top:6px;flex:none}.timeline-badge.positive,.points-pill.positive{background:var(--tertiary-haze);color:var(--positive)}.timeline-badge.negative,.points-pill.negative{background:var(--secondary-haze);color:var(--negative)}.points-pill{padding:8px 10px;border-radius:999px;font-weight:700}.attendance-mobile-shell{display:grid;place-items:center}.attendance-mobile-screen{width:min(100%,385px);min-height:780px;padding:16px 14px 18px;border-radius:38px;background:radial-gradient(circle at top left,rgba(255,247,233,.95),transparent 34%),radial-gradient(circle at top right,rgba(255,255,255,.92),transparent 28%),linear-gradient(180deg,#fff6ec,#f8f1ff 24%,#f7f2ff);border:1px solid rgba(255,255,255,.84);box-shadow:0 28px 64px #5f3f932e}.attendance-mobile-screen-expanded{display:grid;gap:18px}.attendance-mobile-screen svg{width:18px;height:18px;display:block}.attendance-mobile-topbar,.attendance-teacher-block,.attendance-toolbar,.attendance-student-card,.attendance-student-actions,.attendance-mobile-footer{display:flex;align-items:center}.attendance-mobile-topbar,.attendance-toolbar,.attendance-mobile-footer{justify-content:space-between}.attendance-mobile-topbar{gap:12px;margin-bottom:2px;padding-top:2px}.attendance-icon-button{width:46px;height:46px;border:0;border-radius:999px;cursor:pointer;display:grid;place-items:center;background:#ffffffeb;color:var(--primary);box-shadow:0 14px 28px #5f3f931f}.attendance-icon-button.active{background:var(--primary);color:var(--text-on-accent)}.attendance-club-label{flex:1;color:var(--secondary);font-family:var(--font-display);font-weight:800;text-align:center}.attendance-wordmark{flex:1;display:grid;justify-items:center;line-height:.76;color:#116dbe;font-family:"Arial Black",var(--font-display);font-weight:900;font-size:1.02rem;letter-spacing:-.04em;text-shadow:0 6px 16px rgba(17,109,190,.1)}.attendance-wordmark span:last-child{color:#4ebf4d}.attendance-teacher-block{gap:10px;padding:6px 7px 6px 14px;border-radius:999px;color:var(--primary);font-size:.95rem;font-weight:800;background:#ffffffe0;box-shadow:0 12px 24px #5f3f931a}.attendance-teacher-avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:var(--text-on-accent);font-size:.72rem;font-weight:800;background:linear-gradient(135deg,var(--neutral),var(--primary))}.attendance-title-card,.attendance-summary-card{padding:18px;border-radius:28px;background:#ffffffe0;border:1px solid rgba(214,198,243,.46);box-shadow:0 18px 30px #5f3f9314}.attendance-title-card .eyebrow{margin-bottom:10px;color:#f16c9d;letter-spacing:.3em}.attendance-title-card h1{margin:0;color:var(--accent-deep);font-size:clamp(2.15rem,7vw,2.65rem);line-height:.94}.attendance-title-card p{margin:6px 0 0;color:var(--primary);font-family:var(--font-display);font-size:clamp(1.82rem,6vw,2.12rem);font-style:italic;font-weight:800}.attendance-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.attendance-stat-grid-card{margin-bottom:14px;gap:14px}.attendance-summary-bubble{min-height:108px;padding:16px 16px 14px;border-radius:24px;display:grid;align-content:center;justify-items:start;border:1px solid rgba(255,255,255,.7)}.attendance-summary-bubble.present{background:linear-gradient(180deg,#e2f7dceb,#e8f9e4e0);color:#4aad43}.attendance-summary-bubble.absent{background:linear-gradient(180deg,#ffe7eef0,#fcedf3e6);color:#f06c9e}.attendance-summary-dot{width:10px;height:10px;border-radius:50%;background:currentColor}.attendance-summary-bubble strong{display:block;margin-top:10px;font-family:var(--font-display);font-size:2.15rem;line-height:1}.attendance-summary-bubble span:last-child{font-size:.76rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.attendance-summary-pills{display:flex;flex-wrap:wrap;gap:8px}.attendance-summary-pill{border:0;border-radius:999px;min-height:38px;padding:9px 14px;display:inline-flex;align-items:center;gap:7px;font-weight:800;cursor:pointer;box-shadow:inset 0 1px #ffffffb8}.attendance-summary-pill.blue{background:#dfeeff;color:#1b67b7}.attendance-summary-pill.green{background:#e3f7de;color:#4aad43}.attendance-summary-pill.purple{background:#efe3fa;color:#7a58b3}.attendance-toolbar{gap:12px;margin-bottom:4px;align-items:center}.attendance-search{flex:1;height:58px;padding:0 16px;display:flex;align-items:center;gap:10px;border-radius:20px;background:#fffffff5;border:1px solid rgba(214,198,243,.54);box-shadow:0 10px 22px #5f3f930f;color:var(--muted)}.attendance-search input{width:100%;border:0;background:transparent;color:var(--ink);font:inherit;outline:none}.attendance-search input::placeholder{color:var(--muted)}.attendance-student-list{display:grid;gap:12px;max-height:430px;overflow-y:auto;padding-right:4px}.attendance-student-list::-webkit-scrollbar{width:6px}.attendance-student-list::-webkit-scrollbar-thumb{background:#5f3f9333;border-radius:999px}.attendance-student-card{gap:12px;padding:12px 14px;border-radius:28px;background:linear-gradient(180deg,#fffffff0,#fbf6ffeb),#ffffffeb;border:1px solid rgba(214,198,243,.46);position:relative;cursor:pointer;box-shadow:0 14px 26px #5f3f9314}.attendance-student-card-rich{display:grid;grid-template-columns:5px 56px minmax(0,1fr) 96px;align-items:center;column-gap:10px}.attendance-student-accent{width:5px;height:92px;border-radius:999px;background:#cfc5e7}.attendance-student-accent.present{background:#4aad43}.attendance-student-accent.absent{background:#f06c9e}.attendance-student-accent.late{background:#f3aa34}.attendance-student-accent.excused{background:#7a58b3}.attendance-student-avatar{width:54px;height:54px;flex:none;border-radius:50%;display:grid;place-items:center;color:var(--text-on-accent);font-size:.78rem;font-weight:800;box-shadow:0 12px 24px #2959af2e}.attendance-student-avatar.sunrise{background:linear-gradient(135deg,#ff9867,#e76b9e)}.attendance-student-avatar.mist{background:linear-gradient(135deg,#9a9ab3,#6f7086)}.attendance-student-avatar.lagoon{background:linear-gradient(135deg,#2ab8ff,#005dac)}.attendance-student-avatar.plum{background:linear-gradient(135deg,#7d59c6,#3d2473)}.attendance-student-avatar.graphite{background:linear-gradient(135deg,#9494ab,#5c6073)}.attendance-student-avatar.rose{background:linear-gradient(135deg,#f8a06d,#e76b9e)}.attendance-student-copy{display:grid;gap:6px;min-width:0}.attendance-student-copy strong{display:block;color:var(--accent-deep);font-size:1.02rem;line-height:1.08}.attendance-card-menu{position:absolute;left:60px;top:54px;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:#d2bdeffa;color:#fff;border:2px solid rgba(255,255,255,.96);box-shadow:0 8px 14px #5f3f9329}.attendance-card-menu svg{width:12px;height:12px}.attendance-student-meta-row{display:flex;flex-wrap:wrap;gap:6px}.attendance-student-points,.attendance-student-hint{display:inline-flex;align-items:center;gap:4px;padding:6px 9px;border-radius:999px;font-size:.76rem;font-weight:800}.attendance-student-points{background:#ddebffdb;color:#4b69ae}.attendance-student-hint{background:#efe3fad1;color:#8f78bc}.attendance-student-hint.present{background:#e2f7dceb;color:#4aad43}.attendance-student-hint.absent{background:#ffe7eeeb;color:#f06c9e}.attendance-student-hint.late{background:#fff1d4f5;color:#d18b17}.attendance-student-hint.excused{background:#efe3faeb;color:#7a58b3}.attendance-student-note{width:100%;display:inline-flex;align-items:center;gap:5px;padding:7px 8px;border-radius:14px;color:var(--muted);font-size:.74rem;font-weight:700;background:#fffc;border:1px solid rgba(214,198,243,.38)}.attendance-student-note svg{flex:none;width:14px;height:14px}.attendance-student-note span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attendance-student-side{min-height:102px;padding:10px 8px;border-radius:20px;display:grid;justify-items:center;gap:10px;background:#efe3faa8;border:1px solid rgba(214,198,243,.34)}.attendance-student-side.present{background:#e2f7dce0}.attendance-student-side.absent{background:#ffe7eee6}.attendance-student-side.late{background:#fff1d4f5}.attendance-student-side.excused{background:#efe3fae6}.attendance-status-pill{padding:6px 10px;border-radius:999px;font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.attendance-status-pill.present,.attendance-status-pill.live{background:#d7f7d5eb;color:#2e9f28}.attendance-status-pill.absent{background:#ffdde8eb;color:#df5f92}.attendance-status-pill.pending{background:#efe3faf0;color:#988bb8}.attendance-status-pill.late{background:#fff1d4f5;color:#c98212}.attendance-status-pill.excused{background:#efe3faf5;color:#7a58b3}.attendance-toggle{width:56px;height:30px;padding:3px;border:0;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:flex-start;transition:background .14s ease;box-shadow:inset 0 0 0 2px #776c973d}.attendance-toggle span{width:24px;height:24px;border-radius:50%;background:#fff;box-shadow:0 4px 10px #5f3f932e;transition:transform .14s ease}.attendance-toggle.on{background:#97d98f}.attendance-toggle.on span{transform:translate(26px)}.attendance-toggle.off{background:#dacef1eb}.attendance-empty-state{padding:22px;border-radius:24px;text-align:center;color:var(--muted);background:#ffffff9e}.attendance-mobile-footer{margin-top:2px;width:100%;flex-direction:column;justify-content:flex-start;gap:10px}.attendance-save-pill{width:100%;padding:14px 16px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:var(--primary);font-weight:800;background:#efe3faf0}.attendance-submit-button{border:0;cursor:pointer;width:100%;height:58px;padding:0 22px;border-radius:999px;display:flex;align-items:center;justify-content:center;gap:12px;background:linear-gradient(180deg,#91c2ef,#72afe8);color:var(--text-on-accent);font-size:1rem;font-weight:800;box-shadow:0 18px 30px #418fd63d}.attendance-submit-button:disabled{opacity:.72;cursor:not-allowed}.attendance-submit-button.ready{background:linear-gradient(180deg,#84c7f7,#5ca6e6)}.attendance-submit-icon{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:#ffffff2e}.attendance-footer-note{margin:0;color:var(--muted);font-size:.8rem;font-weight:600;text-align:center}.attendance-filter-button{position:relative;width:54px;height:54px;border-radius:20px;background:var(--primary);color:#fff}.attendance-filter-badge{position:absolute;right:3px;bottom:3px;min-width:19px;padding:2px 5px;border-radius:999px;background:#f06c9e;color:#fff;font-size:.58rem;font-weight:900;letter-spacing:.08em}.attendance-filter-badge.all{background:#f16c9d}.attendance-filter-badge.pending{background:#a48dcf}.attendance-filter-badge.present{background:#4aad43}.attendance-filter-badge.absent{background:#f06c9e}.attendance-filter-badge.late{background:#e39b1f}.attendance-filter-badge.excused{background:#7a58b3}.attendance-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:20px;background:#1d122f52}.attendance-modal{width:min(460px,100%);padding:20px;border-radius:28px;background:#fffbfffa;border:1px solid rgba(214,198,243,.42);box-shadow:0 28px 54px #231c4738;display:grid;gap:16px}.attendance-status-choice-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-status-choice{padding:14px 12px;border:1px solid var(--line);border-radius:18px;background:#fffffff0;color:var(--surface-deep);font-weight:800;cursor:pointer}.attendance-status-choice.active{border-color:var(--primary);background:#ddebfff5;color:var(--primary)}.wallet-dialog-close{width:38px;height:38px;border:0;border-radius:50%;display:grid;place-items:center;cursor:pointer;background:#efe3fadb;color:var(--accent-deep)}.wallet-dialog-actions{display:flex;justify-content:flex-end;gap:10px}.wallet-primary-action{gap:8px}.wallet-spin-icon{animation:wallet-spin .9s linear infinite}@keyframes wallet-spin{to{transform:rotate(360deg)}}@media(max-width:960px){.app-shell{grid-template-columns:1fr}.login-stage{width:min(100%,680px);min-height:min(100vh - 24px,820px)}.pwa-install-banner{left:max(16px,calc(var(--safe-left) + 16px));right:max(16px,calc(var(--safe-right) + 16px));width:auto}.login-shell{grid-template-columns:1fr;padding:18px}.nav-rail{border-right:0;border-bottom:1px solid var(--line)}.hero-banner,.section-header,.module-header,.timeline-item,.session-head,.selection-card-title{flex-direction:column}.content-shell{padding:18px}.split-grid,.compact-grid{grid-template-columns:1fr}.attendance-mobile-screen{width:100%;min-height:auto}.attendance-student-list{max-height:none}}@media(max-width:720px){.login-scene{padding:0}.login-stage{width:100%;min-height:100vh;border-width:0;border-radius:0;box-shadow:none}.login-stage-topline,.credential-form-heading{grid-template-columns:1fr;display:grid}.login-stage-session{text-align:left}.club-seven-word-top{font-size:clamp(2.8rem,13vw,4.3rem)}.club-seven-word-bottom{font-size:clamp(2.7rem,12.5vw,4.1rem);transform:rotate(-3deg) translate(5px)}.login-stage-brand h1{font-size:clamp(1.7rem,10vw,2.5rem)}.seed-orb-shape{min-height:250px;padding:24px}.seed-orb-copy h2{font-size:clamp(1.8rem,9vw,2.4rem)}.seed-access-button,.login-switch-shell,.credential-form-shell{width:100%}.credential-demo-grid{grid-template-columns:1fr}.nav-links{grid-template-columns:repeat(2,minmax(0,1fr))}.nav-link{min-height:88px;align-content:center}.content-shell,.hero-banner,.hero-card,.panel,.spotlight{padding:18px}.banner-grid,.module-grid,.quick-fill-grid{grid-template-columns:1fr}.section-header p{margin:0}.attendance-toolbar{align-items:stretch}.attendance-toolbar,.attendance-student-card-rich{grid-template-columns:1fr}.attendance-card-menu{left:54px;top:50px}.attendance-student-accent{display:none}.attendance-student-side{justify-items:start}.attendance-status-choice-grid{grid-template-columns:1fr}.pwa-install-actions{flex-direction:column}}
