: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%,380px);min-height:780px;padding:14px 14px 18px;border-radius:34px;background:linear-gradient(180deg,#ffffffb8,#f4ebfff5),linear-gradient(180deg,var(--bg-strong),var(--bg));border:1px solid rgba(255,255,255,.78);box-shadow:0 28px 64px #5f3f9338}.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:20px}.attendance-icon-button{width:44px;height:44px;border:0;border-radius:999px;cursor:pointer;display:grid;place-items:center;background:#ffffffb8;color:var(--primary);box-shadow:0 12px 24px #5f3f9324}.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-teacher-block{gap:8px;color:var(--primary);font-size:.95rem;font-weight:700}.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-mobile-header{margin-bottom:20px}.attendance-mobile-header .eyebrow{margin-bottom:12px;color:var(--secondary);letter-spacing:.24em}.attendance-mobile-header h1{margin:0;font-size:clamp(2.2rem,8vw,2.7rem);line-height:.96}.attendance-mobile-header p{margin:6px 0 0;color:var(--primary);font-family:var(--font-display);font-size:clamp(1.8rem,6vw,2.15rem);font-style:italic;font-weight:800}.attendance-stat-grid{margin-top:22px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.attendance-stat-card{aspect-ratio:1 / 1;border-radius:50%;display:grid;place-items:center;padding:12px;text-align:center;background:#ffffffb8;border:1px solid rgba(255,255,255,.85);box-shadow:inset 0 1px #ffffffb8}.attendance-stat-card strong{display:block;font-family:var(--font-display);font-size:2rem}.attendance-stat-card span{color:var(--muted);font-size:.72rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.attendance-stat-card.present strong{color:var(--tertiary)}.attendance-stat-card.absent strong{color:var(--secondary)}.attendance-toolbar{gap:12px;margin-bottom:16px}.attendance-search{flex:1;height:52px;padding:0 16px;display:flex;align-items:center;gap:10px;border-radius:999px;background:#ede0ffdb;border:1px solid rgba(255,255,255,.74);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:420px;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 12px 10px;border-radius:24px;background:#f1e8fceb;border:1px solid rgba(255,255,255,.74);position:relative}.attendance-student-card:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;border-radius:999px;background:var(--tertiary)}.attendance-student-card.absent:before{background:var(--secondary)}.attendance-student-avatar{width:46px;height:46px;flex:none;border-radius:50%;display:grid;place-items:center;color:var(--text-on-accent);font-size:.78rem;font-weight:800}.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{flex:1;min-width:0;display:grid;gap:4px}.attendance-student-copy strong{display:block;font-size:.95rem;line-height:1.08}.attendance-student-copy span{color:var(--muted);font-size:.76rem;font-weight:700}.attendance-student-actions{margin-left:auto;gap:8px}.attendance-status-pill{padding:6px 9px;border-radius:999px;font-size:.58rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.attendance-status-pill.present{background:#d7f7d5eb;color:var(--tertiary)}.attendance-status-pill.absent{background:#ffdde8eb;color:var(--secondary)}.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}.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:#14902b}.attendance-toggle.on span{transform:translate(26px)}.attendance-toggle.off{background:#ddcaf8e6}.attendance-empty-state{padding:22px;border-radius:24px;text-align:center;color:var(--muted);background:#ffffff9e}.attendance-mobile-footer{margin-top:18px;width:100%;flex-direction:column;justify-content:flex-start;gap:14px}.attendance-submit-button,.attendance-tab-item{border:0;cursor:pointer}.attendance-submit-button{width:100%;height:58px;padding:0 22px;border-radius:999px;display:flex;align-items:center;justify-content:center;gap:12px;background:linear-gradient(135deg,var(--primary),#0f73ca);color:var(--text-on-accent);font-size:1rem;font-weight:800;box-shadow:0 18px 30px #005dac42}.attendance-submit-button.ready{background:linear-gradient(135deg,var(--tertiary),var(--primary))}.attendance-submit-icon{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:#ffffff2e}.attendance-tabbar{width:100%;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:10px 8px 4px;border-radius:24px;background:#ffffffb8}.attendance-tab-item{padding:0;background:transparent;color:var(--muted);display:grid;justify-items:center;gap:6px;font-size:.58rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.attendance-tab-icon{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:inherit}.attendance-tab-item.active{color:var(--accent-deep)}.attendance-tab-item.active .attendance-tab-icon{background:linear-gradient(135deg,var(--secondary),var(--accent-deep));color:var(--text-on-accent);box-shadow:0 16px 24px #e76b9e47}@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,.attendance-student-card,.attendance-student-actions{flex-direction:column;align-items:stretch}.attendance-student-actions{margin-left:0}.attendance-status-pill,.attendance-toggle{align-self:flex-start}.pwa-install-actions{flex-direction:column}}
