:root{color:#181818;font-synthesis:none;text-rendering:optimizelegibility;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{overscroll-behavior-y:none;background:#f4f4f4;min-width:320px;margin:0}html,body,#root{min-height:100%}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.62}.appShell{max-width:1220px;min-height:100vh;margin:0 auto;padding:22px}.topBar{justify-content:space-between;align-items:center;gap:18px;padding:8px 0 18px;display:flex}.brand{align-items:center;gap:16px;min-width:0;display:flex}.authLogo,.brandLogoMark,.brandLogoWordmark,.authLogoMark,.authLogoWordmark{object-fit:contain;height:auto;display:block}.brandLogoStack{place-items:center;width:64px;display:flex}.brandLogoMark{width:64px}.brandLogoWordmark{width:148px;margin-top:-7px}.brand h1,.sectionHeader h2,.authPanel h1,.loadingShell h1{letter-spacing:0;margin:0}.brand h1{font-size:28px;line-height:1.05}.eyebrow,.summaryLabel{color:#777;letter-spacing:0;text-transform:uppercase;font-size:12px;font-weight:800;display:block}.brand .eyebrow{color:#181818;font-size:15px;line-height:1.15}.topActions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.iconButton,.ghostButton,.viewSwitch button,.primaryButton,.googleButton,.linkButton,.primaryAction,.secondaryAction,.miniButton{white-space:nowrap;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;font-weight:850;display:inline-flex}.viewSwitch{background:#fff;border:1px solid #dedede;border-radius:8px;gap:3px;min-width:0;padding:3px;display:flex}.viewSwitch button{color:#333;text-overflow:ellipsis;background:0 0;flex:none;min-width:0;min-height:34px;padding:0 11px;overflow:hidden}.viewSwitch button.active{color:#fff;background:#111}.viewSwitch button .reservationTabIcon{width:17px;min-width:17px;height:17px}.navShortLabel{display:none}.iconButton,.ghostButton{color:#202020;background:#fff;border:1px solid #dedede;padding:0 14px}.iconButton{aspect-ratio:1;width:42px;padding:0}.summaryBand{color:#fff;background:#111;border-radius:8px;grid-template-columns:2fr 1fr;align-items:stretch;gap:1px;margin-bottom:18px;display:grid;overflow:hidden}.summaryBand>div{background:#171717;padding:17px 18px}.summaryBand strong{margin-top:4px;font-size:18px;display:block}.workspace{grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:18px;display:grid}.workspace.scheduleOnly{grid-template-columns:minmax(0,1fr);max-width:920px}.memberReservationsPanel{gap:12px;max-width:760px;display:grid}.mainColumn,.sideColumn{min-width:0}.sectionHeader{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:12px;display:flex}.sectionHeader h2{text-transform:uppercase;font-size:24px}.sectionHeader.compact h2{font-size:20px}.syncText{color:#777;font-size:13px;font-weight:750}.weekCalendar{grid-template-columns:42px minmax(0,1fr) 42px;align-items:stretch;gap:8px;margin-bottom:16px;display:grid}.weekNavButton{color:#1d1d1d;background:#fff;border:1px solid #dfdfdf;border-radius:8px;justify-content:center;align-items:center;min-height:74px;display:inline-flex}.weekNavButton:disabled{color:#b7b7b7;cursor:not-allowed;opacity:.55}.dayStrip{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;display:grid;overflow:visible}.dayButton{color:#1d1d1d;background:#fff;border:1px solid #dfdfdf;border-radius:8px;place-items:center;gap:4px;min-width:0;min-height:74px;padding:10px 8px;display:grid}.dayButton span{color:#777;text-transform:uppercase;font-size:12px;font-weight:800}.dayButton strong{font-size:24px;line-height:1}.dayButton.today{border-color:#f11212}.dayButton.active{color:#fff;background:#f11212;border-color:#f11212}.dayButton.active span{color:#ffffffd1}.scheduleRule{color:#6f6f6f;margin:-6px 0 14px;font-size:13px;font-weight:750;line-height:1.4}.classList,.reservationList{gap:12px;display:grid}.reservationOverview{grid-template-columns:minmax(0,1.6fr) .7fr .7fr;gap:8px;margin-bottom:14px;display:grid}.reservationOverview>div{color:#fff;background:#111;border-radius:8px;min-width:0;padding:12px}.reservationOverview span,.reservationDayHeader span{color:#818181;text-transform:uppercase;font-size:12px;font-weight:850;display:block}.reservationOverview strong{margin-top:4px;font-size:22px;line-height:1.1;display:block}.reservationOverview small{color:#ffffffb3;margin-top:4px;font-size:12px;font-weight:700;line-height:1.35;display:block}.reservationOverview>.nextReservationCard{background:#f11212}.reservationOverview>.nextReservationCard span,.reservationOverview>.nextReservationCard small{color:#ffffffd1}.memberReservationList{gap:16px}.reservationNotice{color:#737373;white-space:normal;background:0 0;border:0;border-radius:8px;margin:-10px 0 0;padding:0 2px;font-size:11px;font-weight:750;line-height:1.18}.reservationDayGroup{gap:8px;display:grid}.reservationDayHeader{justify-content:space-between;align-items:center;gap:12px;padding:0 2px;display:flex}.reservationDayHeader h3{color:#181818;text-transform:uppercase;margin:0;font-size:16px;line-height:1.2}.reservationCompactList{gap:8px;display:grid}.classCard,.reservationRow,.emptyState{background:#fff;border:1px solid #ddd;border-radius:8px}.classCard{padding:16px}.classHeader{grid-template-columns:46px minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.classIcon{color:#f11212;background:#fff1f1;border-radius:8px;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.classTitleBlock{min-width:0}.classTitleBlock h3,.reservationRow h3,.emptyState h3{color:#181818;margin:0;font-size:17px;line-height:1.25}.classTitleBlock p,.reservationRow p,.emptyState p{color:#707070;margin:5px 0 0;font-size:13px;line-height:1.45}.classTitleBlock p{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.classMeta{color:#666;flex-wrap:wrap;gap:8px;margin-top:14px;font-size:13px;font-weight:750;display:flex}.classMeta span{background:#f5f5f5;border-radius:8px;padding:7px 9px}.capacityTrack{background:#eee;border-radius:999px;height:8px;margin:14px 0;overflow:hidden}.capacityTrack div{border-radius:inherit;background:#f11212;height:100%}.primaryAction,.secondaryAction{width:100%;min-height:44px}.primaryAction{color:#fff;background:#f11212}.secondaryAction{color:#f11212;background:#fff;border:1px solid #d8d8d8}.primaryAction:disabled,.secondaryAction:disabled{cursor:not-allowed;opacity:.58}.statusBadge{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;gap:5px;min-height:30px;padding:6px 10px;font-size:12px;font-weight:850;display:inline-flex}.statusBadge.small{width:fit-content;min-height:28px;font-size:12px}.statusBadge.success{color:#12824f;background:#13a15e1f}.statusBadge.warning{color:#b76300;background:#f59e0b24}.statusBadge.danger{color:#c20c0c;background:#f112121a}.statusBadge.neutral{color:#444;background:#f0f0f0}.reservationRow{grid-template-columns:78px minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px 12px;display:grid}.reservationTimePill{background:#f5f5f5;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;min-height:56px;padding:7px 6px;display:flex}.reservationTimePill strong{color:#181818;font-size:16px;line-height:1.1}.reservationTimePill span{color:#777;margin-top:3px;font-size:11px;font-weight:800}.reservationInfo{min-width:0}.reservationInfo .statusBadge{margin-top:7px}.reservationActions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.miniButton{color:#333;background:#fff;border:1px solid #d8d8d8;min-height:36px;padding:0 12px;font-size:13px}.miniButton.positive{color:#fff;background:#12824f;border-color:#12824f}.miniButton.danger{color:#f11212}.adminWorkspace{gap:14px;display:grid}.adminMobileTabs{display:none}.adminGrid{grid-template-columns:minmax(0,1fr);align-items:start;gap:18px;display:grid}.adminCreatePanel,.adminEmailPanel,.adminMembersPanel,.adminRosterPanel,.adminNotice{background:#fff;border:1px solid #ddd;border-radius:8px}.adminCreatePanel,.adminEmailPanel,.adminMembersPanel,.adminRosterPanel{padding:16px}.adminCreatePanel,.adminEmailPanel,.adminMembersPanel{gap:13px;display:grid}.adminCreatePanel .primaryButton,.adminEmailPanel .primaryButton{margin-top:2px}.fieldStack{gap:7px;display:grid}.fieldStack span{color:#555;font-size:13px;font-weight:800}.fieldStack input,.fieldStack textarea{color:#181818;background:#f7f7f7;border:1px solid #dcdcdc;border-radius:8px;outline:0;width:100%;min-height:44px;padding:0 12px}.fieldStack textarea{resize:vertical;min-height:118px;padding:12px;line-height:1.45}.fieldStack input:focus,.fieldStack textarea:focus{border-color:#f11212;box-shadow:0 0 0 3px #f112121a}.formGrid{gap:10px;display:grid}.formGrid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.formGrid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.adminPlannerMeta{align-items:end}.weeklyPlanner{scrollbar-width:thin;border:1px solid #dedede;border-radius:8px;grid-template-columns:repeat(5,minmax(190px,1fr));display:grid;overflow-x:auto}.dayPlannerColumn{background:#fafafa;border-right:1px solid #dedede;grid-template-rows:auto minmax(0,1fr);min-width:0;display:grid}.dayPlannerColumn:last-child{border-right:0}.dayPlannerHeader{background:#e8e8e8;border-bottom:1px solid #dedede;gap:10px;padding:13px 12px;display:grid}.dayPlannerHeader span{color:#777;letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px;font-size:11px;font-weight:900;display:block}.dayPlannerHeader h3{color:#2c2c2c;margin:0;font-size:16px}.dayPlannerActions{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:7px;display:grid}.dayPlannerActions .miniButton{min-height:34px;padding:0 8px}.daySlotList{align-content:start;gap:10px;padding:12px;display:grid}.emptyDaySlots{color:#8a8a8a;text-align:center;border:1px dashed #d8d8d8;border-radius:8px;margin:0;padding:18px 10px;font-size:13px;font-weight:800}.draftSlotCard{background:#fff;border:1px solid #d8d8d8;border-radius:8px;gap:9px;padding:12px;display:grid;position:relative}.draftSlotCard.invalid{border-color:#f112128c}.savedSlotCard{color:#fff;background:#111;border:1px solid #111;border-radius:8px;position:relative;overflow:hidden}.savedSlotCard.deleting{opacity:.72}.savedSlotOpenButton{color:inherit;text-align:left;background:0 0;border:0;gap:4px;width:100%;padding:12px 42px 12px 12px;display:grid}.savedSlotOpenButton span{color:#fff9;letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:900}.savedSlotOpenButton strong{font-size:18px}.savedSlotOpenButton small{color:#ffffffb8;font-size:12px;font-style:normal;font-weight:800}.savedSlotOpenButton em{color:#fff;margin-top:2px;font-size:15px;font-style:normal;font-weight:900}.savedSlotDeleteButton{color:#fff;background:#ffffff1a;border:1px solid #ffffff29;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;padding:0;display:inline-flex;position:absolute;top:8px;right:8px}.savedSlotDeleteButton:hover{background:#f11212;border-color:#f11212}.savedSlotDeleteButton:disabled{cursor:wait}.slotRemoveButton{color:#f112127a;background:0 0;border:0;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:inline-flex;position:absolute;top:6px;right:6px}.slotRemoveButton:hover{color:#f11212}.slotTitleField,.slotTimeGrid label,.slotCapacityRow label{gap:5px;display:grid}.slotTitleField span,.slotTimeGrid span,.slotCapacityRow span{color:#777;letter-spacing:.04em;text-transform:uppercase;font-size:10px;font-weight:900}.slotTitleField input,.slotTimeGrid input,.slotCapacityRow input{color:#181818;background:#f7f7f7;border:1px solid #dcdcdc;border-radius:8px;outline:0;width:100%;min-height:38px;padding:0 10px}.slotTitleField input{padding-right:28px;font-weight:850}.slotTitleField input:focus,.slotTimeGrid input:focus,.slotCapacityRow input:focus{border-color:#f11212;box-shadow:0 0 0 3px #f112121a}.slotTimeGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;display:grid}.slotCapacityRow{grid-template-columns:34px minmax(0,1fr) 34px;align-items:end;gap:7px;display:grid}.slotCapacityRow button{color:#444;background:#eee;border:0;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;padding:0;font-size:20px;font-weight:900;display:inline-flex}.slotError{color:#b00a0a;margin:-2px 0 0;font-size:12px;font-weight:800}.plannerFooter{color:#555;background:#f7f7f7;border:1px solid #dedede;border-radius:8px;justify-content:space-between;align-items:center;gap:14px;padding:11px 12px;display:flex}.plannerFooter div{gap:2px;display:grid}.plannerFooter strong{color:#181818;font-size:18px}.plannerFooter span,.plannerFooter p{color:#666;margin:0;font-size:12px;font-weight:750;line-height:1.35}.plannerFooter p{max-width:520px}.weekdaySelector{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;display:grid}.weekdaySelector button{color:#4f4f4f;background:#fff;border:1px solid #d8d8d8;border-radius:8px;min-height:38px;font-size:12px;font-weight:850}.weekdaySelector button.active{color:#fff;background:#111;border-color:#111}.panelActions{align-items:center;gap:8px;display:flex}.adminRosterCalendar{gap:8px;margin-bottom:12px;display:grid}.adminRosterDayHeader{justify-content:space-between;align-items:end;gap:14px;display:flex}.adminRosterDayHeader h3{margin:2px 0 0;font-size:22px}.adminRosterDayHeader span{color:#555;background:#efefef;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900}.dayButton small{color:inherit;background:#1111111a;border-radius:999px;min-width:18px;padding:2px 5px;font-size:10px;font-weight:900}.dayButton.active small{background:#ffffff38}.adminDayClassList{gap:8px;margin-bottom:12px;display:grid}.adminDayClassList button{color:#181818;text-align:left;background:#fff;border:1px solid #dedede;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;min-height:62px;padding:12px;display:flex}.adminDayClassList button.active{border-color:#f11212;box-shadow:inset 0 0 0 1px #f11212}.adminDayClassList div{gap:4px;min-width:0;display:grid}.adminDayClassList strong,.adminDayClassList span,.adminDayClassList small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.adminDayClassList span,.adminDayClassList small{color:#696969;font-size:12px;font-weight:800}.adminClassStrip{grid-auto-columns:minmax(190px,230px);grid-auto-flow:column;gap:8px;margin-bottom:14px;padding-bottom:4px;display:grid;overflow-x:auto}.adminEmailGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.adminEmailGrid>.banner,.adminEmailHistoryPanel{grid-column:1/-1}.adminEmailHistoryPanel{background:#fff;border:1px solid #ddd;border-radius:8px;gap:13px;padding:16px;display:grid}.emailHistoryList{gap:9px;display:grid}.emailHistoryItem{background:#f8f8f8;border:1px solid #e2e2e2;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;padding:12px;display:grid}.emailHistoryMeta{color:#777;text-transform:uppercase;font-size:12px;font-weight:850;display:block}.emailHistoryItem h3{color:#171717;margin:3px 0 5px;font-size:17px}.emailHistoryItem p{color:#666;max-height:55px;margin:0;font-size:13px;line-height:1.35;overflow:hidden}.emailHistoryStats{color:#666;text-align:right;place-items:end;gap:3px;min-width:130px;font-size:12px;font-weight:850;display:grid}.emailHistoryStats strong{color:#12824f;font-size:15px}.dangerText{color:#f11212}.adminMembersPanel{margin-top:18px}.memberToolbar{grid-template-columns:minmax(220px,1fr) 140px 140px;align-items:end;gap:12px;display:grid}.memberStats{background:#f5f5f5;border:1px solid #e1e1e1;border-radius:8px;gap:2px;min-height:56px;padding:9px 12px;display:grid}.memberStats strong{color:#171717;font-size:20px;line-height:1}.memberStats span{color:#6b6b6b;text-transform:uppercase;font-size:12px;font-weight:850}.fitnessMemberList{gap:9px;display:grid}.fitnessMemberRow{border:1px solid #ddd;border-radius:8px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;padding:12px;display:grid}.memberActivity{place-items:flex-end end;gap:6px;display:grid}.memberActivity small,.lockedRole{color:#6d6d6d;font-size:12px;font-weight:850}.lockedRole{padding:8px 0}.panelHint{color:#666;margin:-4px 0 0;font-size:13px;font-weight:700;line-height:1.4}.adminClassStrip button{color:#181818;text-align:left;background:#fff;border:1px solid #dedede;border-radius:8px;gap:5px;min-height:104px;padding:12px;display:grid}.adminClassStrip button.active{border-color:#f11212;box-shadow:inset 0 0 0 1px #f11212}.adminClassStrip strong,.adminClassStrip span,.adminClassStrip small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.adminClassStrip span,.adminClassStrip small{color:#696969;font-size:12px;font-weight:750}.rosterSummary{color:#fff;background:#111;border-radius:8px;grid-template-columns:minmax(0,1fr) 120px 120px;gap:1px;margin-bottom:12px;display:grid;overflow:hidden}.selectedClassBlock{gap:8px;margin-bottom:12px;display:grid}.selectedClassBlock .rosterSummary{margin-bottom:0}.deleteClassButton{justify-self:start}.rosterSummary>div{background:#171717;min-width:0;padding:14px}.rosterSummary strong{margin-top:4px;font-size:18px;display:block}.rosterSummary p{color:#ffffffb8;margin:5px 0 0;font-size:13px}.rosterList{gap:10px;display:grid}.rosterRow{background:#fff;border:1px solid #ddd;border-radius:8px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;padding:12px;display:grid}.rosterPerson{align-items:center;gap:10px;min-width:0;display:flex}.rosterAvatar{color:#fff;background:#111;border-radius:8px;flex:none;justify-content:center;align-items:center;width:42px;height:42px;font-size:13px;font-weight:900;display:flex}.rosterPerson h3{margin:0;font-size:15px;line-height:1.25}.rosterPerson p{color:#707070;margin:4px 0 0;font-size:13px}.rosterActions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.adminNotice{color:#444;align-items:center;gap:9px;padding:12px 14px;font-size:13px;font-weight:750;display:flex}.adminNotice svg{color:#12824f;flex:none}.modalOverlay{z-index:50;background:#00000075;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.confirmModal{background:#fff;border:1px solid #ddd;border-radius:8px;gap:14px;width:min(100%,540px);max-width:540px;padding:18px;display:grid;box-shadow:0 22px 70px #00000038}.confirmEmailSummary{background:#f7f7f7;border:1px solid #dfdfdf;border-radius:8px;gap:7px;padding:12px;display:grid}.confirmEmailSummary span,.confirmEmailSummary small{color:#666;font-size:13px;font-weight:800}.confirmEmailSummary strong{color:#171717;font-size:19px}.confirmEmailSummary p{color:#444;white-space:pre-wrap;max-height:130px;margin:0;line-height:1.45;overflow:auto}.modalActions{justify-content:flex-end;gap:10px;display:flex}.compactButton{min-height:40px;padding:0 16px}.emptyState{color:#777;justify-items:start;min-height:180px;padding:22px;display:grid}.emptyState.compact{min-height:150px}.emptyState svg{color:#f11212}.banner{border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:12px 14px;font-size:14px;font-weight:800;display:flex}.banner button{color:currentColor;background:0 0;border:0;align-items:center;padding:0;display:flex}.banner.success{color:#116c43;background:#13a15e21}.banner.warning{color:#8a4d00;background:#f59e0b29}.banner.danger{color:#a40909;background:#f112121f}.banner.neutral{color:#333;background:#e9e9e9}.authShell,.loadingShell{background:#111;justify-content:center;align-items:center;min-height:100vh;padding:22px;display:flex}.authShell{min-height:100dvh}.authPanel{background:#fff;border-radius:8px;width:100%;max-width:430px;padding:44px 24px 24px;box-shadow:0 18px 55px #00000047}.authLogo{background:#111;border-radius:6px;width:190px;margin-bottom:22px;padding:9px 12px}.authLogoStack{justify-content:center;place-items:center;margin-bottom:22px;display:flex}.authLogoMark{width:112px}.authLogoWordmark{width:220px;margin-top:-8px}.authPanel h1{color:#181818;text-transform:uppercase;margin:5px 0 18px;font-size:30px}.authForm{gap:13px;display:grid}.authForm label{gap:7px;display:grid}.authForm label span{color:#555;font-size:13px;font-weight:800}.inputWrap{color:#777;background:#f6f6f6;border:1px solid #dcdcdc;border-radius:8px;align-items:center;gap:9px;min-height:48px;padding:0 12px;display:flex}.inputWrap input{color:#171717;background:0 0;border:0;outline:0;width:100%;min-width:0}.passwordToggle{color:#777;cursor:pointer;background:0 0;border:0;flex:none;justify-content:center;align-items:center;min-width:34px;min-height:34px;padding:0;display:inline-flex}.passwordToggle:hover,.passwordToggle:focus-visible{color:#171717}.primaryButton,.googleButton{width:100%;min-height:48px}.primaryButton{color:#fff;background:#f11212;margin-top:4px}.googleButton{color:#fff;background:#111;margin-top:12px}.googleButton span{color:#111;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-weight:900;display:inline-flex}.linkButton{color:#555;background:0 0;width:100%;margin-top:14px;font-size:15px}.linkButton.subtle{color:#777;min-height:34px;margin-top:2px;font-size:14px}.authHelper{color:#777;margin:0 0 1rem;font-weight:700;line-height:1.45}.loadingShell{color:#fff;text-align:center;flex-direction:column;gap:12px}.loadingShell p{color:#ffffffbf;max-width:620px;margin:0}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width>=901px){body{background:#eee}.appShell{max-width:1480px;padding:30px 36px 46px}.topBar{align-items:center;padding:12px 0 28px}.brandLogoStack,.brandLogoMark{width:76px}.brand .eyebrow{font-size:18px}.topActions{gap:12px}.viewSwitch,.ghostButton,.iconButton{box-shadow:0 1px #00000005}.viewSwitch{gap:4px;padding:4px}.viewSwitch button{gap:6px;min-height:42px;padding:0 16px;font-size:15px}.viewSwitch button svg,.viewSwitch button .reservationTabIcon{width:15px;min-width:15px;height:15px}.ghostButton{gap:6px;min-height:44px;padding:0 16px}.iconButton{width:44px;height:44px}.topActions .ghostButton svg,.topActions .iconButton svg,.primaryButton svg,.primaryAction svg,.secondaryAction svg,.miniButton svg,.passwordToggle svg,.banner button svg{width:15px;height:15px}.statusBadge svg{width:13px;height:13px}.classIcon{width:40px;height:40px}.classIcon svg,.emptyState svg{width:18px;height:18px}.adminNotice svg{width:17px;height:17px}.savedSlotDeleteButton svg,.slotRemoveButton svg{width:14px;height:14px}.banner{margin-bottom:20px}.workspace.scheduleOnly{max-width:none}.scheduleOnly .mainColumn,.memberReservationsPanel,.adminCreatePanel,.adminRosterPanel,.adminMembersPanel,.adminEmailPanel{box-shadow:0 10px 30px #0000000a}.scheduleOnly .mainColumn,.memberReservationsPanel{background:#fff;border:1px solid #ddd;border-radius:8px;padding:22px}.memberReservationsPanel{max-width:none}.sectionHeader{margin-bottom:18px}.sectionHeader h2{font-size:28px}.weekCalendar{grid-template-columns:50px minmax(0,1fr) 50px;gap:10px;margin-bottom:18px}.weekNavButton{min-height:86px}.dayStrip{gap:10px}.dayButton{min-height:86px}.dayButton strong{font-size:30px}.scheduleRule{margin-bottom:18px}.classList{grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:14px}.classCard{align-content:start;min-height:188px;padding:18px}.classTitleBlock h3,.reservationRow h3,.emptyState h3{font-size:19px}.classTitleBlock p,.reservationRow p,.emptyState p{font-size:14px}.reservationOverview{grid-template-columns:minmax(0,1.45fr) .6fr .6fr;margin-bottom:14px}.reservationOverview>div{padding:16px}.reservationOverview strong{font-size:26px}.reservationCompactList{grid-template-columns:repeat(auto-fit,minmax(390px,1fr));gap:10px}.reservationRow{grid-template-columns:72px minmax(0,1fr) auto;min-height:82px;padding:12px}.reservationTimePill{min-height:58px}.reservationActions .miniButton{min-width:112px}.adminWorkspace{grid-template-columns:minmax(0,1.2fr) minmax(380px,.8fr);align-items:start;gap:18px;display:grid}.adminGrid{display:contents}.adminCreatePanel{grid-column:1/-1;padding:20px}.adminRosterPanel{grid-column:1;padding:18px}.adminGrid.trainerGrid .adminRosterPanel{grid-column:1/-1}.adminMembersPanel{grid-column:2;margin-top:0;padding:18px;position:static}.adminEmailGrid,.adminNotice{grid-column:1/-1}.weeklyPlanner{grid-template-columns:repeat(5,minmax(0,1fr));overflow-x:visible}.dayPlannerHeader{min-height:122px}.daySlotList{min-height:220px}.adminDayClassList{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.rosterList,.fitnessMemberList{gap:10px}.authPanel{max-width:460px;padding:48px 28px 28px}}@media (width<=900px){.appShell{padding:16px;padding-top:max(16px, env(safe-area-inset-top))}.topBar,.brand{align-items:flex-start}.topBar,.workspace{grid-template-columns:1fr;display:grid}.adminGrid,.adminEmailGrid,.summaryBand,.rosterSummary{grid-template-columns:1fr}.sideColumn{order:0}}@media (width<=620px){body{background:#f6f6f6}.authShell{height:100dvh;min-height:0;padding:max(10px, env(safe-area-inset-top)) 14px max(10px, env(safe-area-inset-bottom));width:100%;position:fixed;inset:0;overflow:hidden}.authPanel{max-height:calc(100dvh - max(20px, env(safe-area-inset-top)) - max(20px, env(safe-area-inset-bottom)));border-radius:8px;max-width:390px;padding:36px 18px 18px;overflow:hidden}.authLogoStack{margin-bottom:18px}.authLogoWordmark{width:250px;margin-top:0}.authPanel h1{margin:4px 0 14px;font-size:29px}.authForm{gap:10px}.authForm label{gap:5px}.authForm label span{font-size:12px}.inputWrap{min-height:44px;padding:0 11px}.primaryButton,.googleButton{min-height:46px}.linkButton{min-height:34px;margin-top:9px;font-size:14px}.linkButton.subtle{margin-top:0;font-size:13px}.appShell{padding:12px;padding-top:max(14px, env(safe-area-inset-top))}.topBar{gap:10px;padding:0 0 12px}.brand{align-items:center;gap:10px;display:flex}.brandLogoStack{width:40px}.brandLogoMark{width:40px;margin-left:0}.eyebrow,.summaryLabel{font-size:10px}.brand .eyebrow{font-size:17px}.brand h1{font-size:22px}.topActions{grid-template-columns:minmax(0,1fr) 48px;gap:6px;width:100%;display:grid}.topActions .iconButton,.topActions .ghostButton{min-height:46px}.ghostButton{grid-column:2;width:100%;min-width:0;padding:0}.viewSwitch{grid-column:1;width:100%}.viewSwitch button{flex:1 1 0;gap:4px;min-width:0;min-height:38px;padding:0 3px;font-size:12px}.topActions .ghostButton{gap:0}.topActions .ghostButton span,.navFullLabel{display:none}.navShortLabel{display:inline}.viewSwitch button svg{width:15px;height:15px}.viewSwitch button .reservationTabIcon{width:15px;min-width:15px;height:15px}.summaryBand{border-radius:8px;grid-template-columns:1.45fr .8fr;margin-bottom:18px}.summaryBand>div{min-width:0;padding:12px 10px}.summaryBand strong{word-break:normal;margin-top:4px;font-size:16px;line-height:1.15}.summaryBand .summaryLabel{white-space:nowrap}.workspace{gap:22px}.sectionHeader{align-items:start;margin-bottom:10px}.sectionHeader h2{font-size:28px;line-height:1.05}.sectionHeader.compact h2{font-size:24px}.weekCalendar{grid-template-columns:34px minmax(0,1fr) 34px;gap:6px;margin-bottom:12px}.weekNavButton{min-height:64px}.dayStrip{gap:6px}.dayButton{min-width:0;min-height:64px;padding:8px 4px}.dayButton span{font-size:10px}.dayButton strong{font-size:24px}.classList{grid-template-columns:1fr;gap:5px}.classHeader{grid-column:1;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:5px}.classCard,.reservationRow,.emptyState{border-color:#e0e0e0}.classCard{grid-template-columns:minmax(0,1fr) 86px;align-items:center;gap:3px 7px;min-width:0;padding:6px 7px 6px 9px;display:grid}.classIcon{display:none}.classTitleBlock h3,.reservationRow h3,.emptyState h3{font-size:18px}.classTitleBlock h3{text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.classTitleBlock p{gap:3px;margin-top:1px;font-size:10px;line-height:1.2}.classTitleBlock p svg{display:none}.classMeta{grid-column:1;gap:3px;margin-top:0}.classMeta span{border-radius:5px;padding:3px 5px;font-size:9px}.capacityTrack{display:none}.classHeader .statusBadge{grid-column:auto;justify-self:end;min-height:20px;padding:2px 5px}.statusBadge{gap:3px;font-size:10px}.primaryAction,.secondaryAction{grid-area:1/2/span 2;align-self:stretch;gap:4px;min-height:32px;padding:0 4px;font-size:10px}.sideColumn{border-top:1px solid #e2e2e2;padding-top:20px}.reservationOverview{grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}.reservationOverview .wide{grid-column:1/-1}.reservationOverview>div{padding:8px}.reservationNotice{margin:-10px 0 0;padding:0 1px;font-size:11px}.reservationOverview strong{font-size:17px}.reservationOverview small{font-size:10px}.memberReservationList{gap:10px}.reservationDayHeader h3{font-size:14px}.reservationDayHeader span{font-size:10px}.reservationCompactList{gap:5px}.reservationRow{grid-template-columns:54px minmax(0,1fr) 76px;gap:6px;min-height:60px;padding:6px}.reservationTimePill{min-height:48px;padding:5px 3px}.reservationTimePill strong{font-size:13px}.reservationTimePill span{font-size:10px}.reservationInfo h3{text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.reservationInfo p{margin-top:1px;font-size:10px}.reservationInfo .statusBadge{min-height:20px;margin-top:4px;padding:2px 6px;font-size:9px}.reservationActions{flex-direction:column;gap:5px}.reservationActions .miniButton{justify-content:center;gap:4px;min-width:70px;min-height:30px;padding:0 5px;font-size:10px}.emptyState{min-height:128px;padding:18px}.emptyState.compact{min-height:112px}.fitnessMemberRow,.formGrid.two,.formGrid.three,.rosterRow{grid-template-columns:1fr}.fitnessMemberRow,.rosterRow{grid-template-columns:minmax(0,1fr) 86px}.adminWorkspace{gap:12px}.adminMobileTabs{top:max(8px, env(safe-area-inset-top));z-index:5;background:#fff;border:1px solid #dedede;border-radius:8px;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:3px;padding:3px;display:grid;position:sticky}.adminMobileTabs button{color:#505050;background:0 0;border:0;border-radius:7px;justify-content:center;align-items:center;gap:4px;min-height:34px;padding:0 6px;font-size:12px;font-weight:850;display:inline-flex}.adminMobileTabs button.active{color:#fff;background:#111}.adminMobileSection{display:none}.adminMobileSection.mobileActive{display:grid}.adminGrid,.adminEmailGrid{gap:12px}.adminMembersPanel{margin-top:0}.adminCreatePanel,.adminEmailPanel,.adminEmailHistoryPanel,.adminMembersPanel,.adminRosterPanel{padding:10px}.adminCreatePanel,.adminEmailPanel,.adminEmailHistoryPanel,.adminMembersPanel{gap:8px}.emailHistoryItem{grid-template-columns:1fr;gap:8px;padding:10px}.emailHistoryStats{text-align:left;grid-template-columns:repeat(2,minmax(0,1fr));place-items:start;min-width:0}.modalOverlay{align-items:end;padding:10px}.confirmModal{padding:12px}.modalActions{grid-template-columns:1fr;display:grid}.memberToolbar{grid-template-columns:1fr 1fr;align-items:stretch;gap:7px}.memberToolbar .fieldStack{grid-column:1/-1}.memberToolbar .fieldStack input{min-height:36px}.memberStats{min-height:46px;padding:7px 9px}.memberStats strong{font-size:17px}.memberStats span{font-size:10px}.weeklyPlanner{border-left:0;border-right:0;border-radius:0;grid-template-columns:repeat(5,minmax(154px,46vw));margin-left:-10px;margin-right:-10px}.dayPlannerHeader{gap:7px;padding:8px 7px}.dayPlannerHeader span{margin-bottom:1px;font-size:9px}.dayPlannerHeader h3{font-size:13px}.dayPlannerActions{gap:5px}.dayPlannerActions .miniButton{min-height:30px;padding:0 5px;font-size:11px}.daySlotList{gap:6px;padding:7px}.savedSlotOpenButton{gap:2px;padding:8px 34px 8px 9px}.savedSlotOpenButton span{font-size:8px}.savedSlotOpenButton strong{font-size:14px}.savedSlotOpenButton small{font-size:10px}.savedSlotOpenButton em{margin-top:1px;font-size:12px}.savedSlotDeleteButton{width:26px;height:26px;top:6px;right:6px}.emptyDaySlots{padding:14px 8px;font-size:11px}.draftSlotCard{gap:6px;padding:8px}.slotTitleField span,.slotTimeGrid span,.slotCapacityRow span{font-size:8px}.slotTitleField input,.slotTimeGrid input,.slotCapacityRow input{min-height:32px;padding:0 7px}.slotTimeGrid{gap:5px}.slotCapacityRow{grid-template-columns:28px minmax(0,1fr) 28px;gap:5px}.slotCapacityRow button{width:28px;height:28px}.plannerFooter{align-items:start;gap:5px;padding:9px 10px;display:grid}.adminRosterDayHeader{align-items:center;gap:8px}.adminRosterCalendar{gap:6px;margin-bottom:8px}.adminRosterCalendar .weekCalendar{grid-template-columns:28px minmax(0,1fr) 28px;gap:4px;margin-bottom:8px}.adminRosterCalendar .weekNavButton{min-height:52px}.adminRosterCalendar .dayStrip{gap:4px}.adminRosterCalendar .dayButton{min-height:52px;padding:5px 3px}.adminRosterCalendar .dayButton span{font-size:9px}.adminRosterCalendar .dayButton strong{font-size:20px}.adminRosterDayHeader h3{font-size:16px;line-height:1.1}.adminRosterDayHeader span{padding:5px 8px;font-size:10px}.adminDayClassList button{align-items:stretch;gap:5px;min-height:48px;padding:7px;display:grid}.adminDayClassList div{gap:2px}.adminDayClassList strong{font-size:14px}.adminDayClassList span,.adminDayClassList small{font-size:10px}.adminRosterPanel .sectionHeader,.adminCreatePanel .sectionHeader,.adminEmailPanel .sectionHeader,.adminMembersPanel .sectionHeader{align-items:center}.adminRosterPanel .sectionHeader.compact h2,.adminCreatePanel .sectionHeader.compact h2,.adminEmailPanel .sectionHeader.compact h2,.adminMembersPanel .sectionHeader.compact h2{font-size:18px;line-height:1.05}.adminRosterPanel .sectionHeader,.adminMembersPanel .sectionHeader{gap:8px;margin-bottom:6px}.adminRosterPanel .iconButton,.adminMembersPanel .iconButton{width:42px;min-height:42px}.fieldStack{gap:5px}.fieldStack input{min-height:42px}.fieldStack textarea{min-height:98px}.adminClassStrip{grid-auto-columns:minmax(164px,78vw);margin-left:-12px;margin-right:-12px;padding:0 12px 4px}.adminClassStrip button{min-height:74px;padding:8px}.rosterSummary{grid-template-columns:minmax(0,1.35fr) .72fr .72fr}.rosterSummary>div{padding:8px}.rosterSummary strong{margin-top:2px;font-size:14px}.rosterSummary p{margin-top:2px;font-size:10px}.rosterRow{gap:6px;padding:7px}.rosterRow>.statusBadge{grid-area:2/1;justify-self:start}.rosterRow>.rosterActions{grid-area:1/2/span 2;align-self:stretch}.fitnessMemberRow{gap:6px;padding:7px}.fitnessMemberRow>.rosterPerson{grid-area:1/1}.fitnessMemberRow>.memberActivity{grid-area:2/1}.fitnessMemberRow>.rosterActions{grid-area:1/2/span 2;align-self:center}.rosterPerson{align-items:center;gap:7px}.rosterAvatar{border-radius:7px;width:34px;height:34px;font-size:12px}.rosterPerson h3{font-size:14px}.rosterPerson p{margin-top:2px;font-size:11px}.adminNotice{align-items:flex-start;font-size:12px;line-height:1.4}.rosterActions{justify-content:stretch}.memberActivity{place-items:start;gap:4px}.rosterActions .miniButton{flex:1;min-width:0;min-height:32px;padding:0 5px;font-size:11px}.fitnessMemberRow .rosterActions .miniButton{width:86px}}
