:root{--background:#f5f8f8;--surface:#ffffff;--surface-subtle:#eef4f5;--surface-selected:#ddf2f0;--border:#d7e2e4;--border-strong:#9fb2b7;--text-primary:#152436;--text-secondary:#5b6875;--text-muted:#7c8996;--primary:#183e64;--primary-hover:#123252;--primary-container:#dcecf2;--accent:#29b7ae;--accent-container:#ddf6f4;--focus:#2563eb;--success:#16803c;--success-container:#dff3e6;--warning:#9a5f12;--warning-container:#fff1cf;--danger:#c65335;--danger-container:#ffe6de;--danger-hover-container:#ffd9cd;--neutral-container:#e8edf1;--shadow:0 18px 48px rgba(21,36,54,0.1);--soft-shadow:0 10px 24px rgba(21,36,54,0.08);--on-primary:#ffffff;--page-wash-start:rgba(41,183,174,0.16);--page-wash-end:rgba(245,248,248,0);--header-background:rgba(247,248,248,0.96);--mobile-nav-background:rgba(255,255,255,0.96);--highlight-gradient-start:rgba(220,242,240,0.88);--highlight-gradient-end:rgba(255,255,255,0.92);--highlight-accent:rgba(41,183,174,0.12);--logo-surface:rgba(255,255,255,0.94);--logo-border:rgba(24,62,100,0.1);--logo-shadow:0 8px 18px rgba(24,62,100,0.08);--modal-backdrop:rgba(21,36,54,0.32);color-scheme:only light}:root[data-theme=dark]{--background:#0d1720;--surface:#132333;--surface-subtle:#1b2e40;--surface-selected:#173c45;--border:#2d4354;--border-strong:#526b7e;--text-primary:#eef6f8;--text-secondary:#b8c8d2;--text-muted:#89a0af;--primary:#7eddd4;--primary-hover:#9be8e1;--primary-container:#1a4a52;--accent:#33c7bd;--accent-container:#173c45;--focus:#93c5fd;--success:#74d793;--success-container:#173722;--warning:#f0c36b;--warning-container:#423315;--danger:#ffad95;--danger-container:#4c271e;--danger-hover-container:#5e3024;--neutral-container:#223747;--shadow:0 22px 58px rgba(0,0,0,0.36);--soft-shadow:0 14px 30px rgba(0,0,0,0.22);--on-primary:#071d27;--page-wash-start:rgba(51,199,189,0.11);--page-wash-end:rgba(13,23,32,0);--header-background:rgba(14,24,33,0.96);--mobile-nav-background:rgba(14,24,33,0.96);--highlight-gradient-start:rgba(26,74,82,0.9);--highlight-gradient-end:rgba(19,35,51,0.94);--highlight-accent:rgba(51,199,189,0.12);--logo-surface:#f9fbfb;--logo-border:rgba(255,255,255,0.12);--logo-shadow:0 10px 24px rgba(0,0,0,0.2);--modal-backdrop:rgba(2,8,7,0.58);color-scheme:dark}*{box-sizing:border-box}body{min-height:100vh;margin:0;background:linear-gradient(180deg,var(--page-wash-start),var(--page-wash-end) 260px),var(--background);color:var(--text-primary);font-family:Inter,Google Sans Text,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.46;letter-spacing:0;-webkit-tap-highlight-color:transparent}button,input{font:inherit}button{min-height:44px}.srOnly{position:absolute;width:1px;height:1px;overflow:hidden;padding:0;border:0;margin:-1px;clip:rect(0,0,0,0);white-space:nowrap}a:focus-visible,button:focus-visible,input:focus-visible,summary:focus-visible{outline:3px solid rgba(37,99,235,.28);outline-offset:2px}h1,h2,p{margin:0}h1{font-size:24px;line-height:32px}h2{font-size:18px;line-height:26px}.authHeader,.bookingSteps,.brandLogo,.buttonHint,.calendarMenuPanel a,.calendarMenuPanel button,.checkboxRow,.desktopNav,.eyebrow,.mobileNav,.offerButton,.panelDismissButton,.portalHeader,.primaryButton,.quickDateChips,.secondaryButton,.sectionTitle,.settingsPanel .fieldHelp,.settingsPanel .mutedText,.settingsPanel .notice,.settingsPanel label,.settingsPanel legend,.settingsPanelHeader,.stateIllustration,.statusPill,.successBadge,.textButton,.textDangerButton,.themeChoice,.tipIcon,.weekDateButton,button,h1,h2,summary,svg{-webkit-touch-callout:none;-moz-user-select:none;user-select:none;-webkit-user-select:none}a,button,input{transition:background-color .18s ease,border-color .18s ease,box-shadow .18s ease,color .18s ease,transform .18s ease}button:active{transform:translateY(1px)}@keyframes logoSettle{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes enterSoft{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes backdropEnter{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}@keyframes dialogEnter{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes menuEnter{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes panelDismiss{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-8px) scale(.985)}}@keyframes pulseSurface{0%,to{opacity:.62}50%{opacity:1}}@keyframes spin{to{transform:rotate(1turn)}}.spin{animation:spin .9s linear infinite}.authPage{display:grid;min-height:100vh;min-height:100dvh;place-items:center;padding:24px}.authPanel{display:grid;width:min(100%,460px);grid-gap:22px;gap:22px;padding:30px;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);animation:enterSoft .26s ease both}.authPanel button,.authPanel h1,.authPanel p{overflow-wrap:anywhere}.brandCluster,.fieldHeader,.heroIntro,.inlineLoading{display:inline-flex;align-items:center;gap:10px}.heroIntro{align-items:flex-start}.brandMark,.softIcon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:42px;height:42px;border-radius:8px;background:var(--accent-container);color:var(--accent)}.brandMark{width:38px;height:38px;background:var(--primary-container);color:var(--primary)}.brandLogo{display:inline-flex;align-items:center;justify-content:center;width:min(182px,58vw);padding:10px 12px;border:1px solid var(--logo-border);border-radius:8px;background:var(--logo-surface);box-shadow:var(--logo-shadow);animation:logoSettle .26s ease both}.brandLogo img{display:block;width:100%;height:auto}.brandLogoCompact{width:98px;padding:6px 8px}.authPanel>.brandLogo{justify-self:center;margin-bottom:-4px}.authPanel>.authBrandLogo{width:min(164px,48vw);padding:0;border-color:transparent;background:transparent;box-shadow:none;margin-bottom:-2px}:root[data-theme=dark] .authPanel>.authBrandLogo img{filter:invert(1) hue-rotate(180deg) brightness(1.12) saturate(.9)}.authHeader{display:grid;justify-items:center;grid-gap:6px;gap:6px;margin-bottom:6px;text-align:center}.authHeader .eyebrow{color:var(--text-secondary);font-size:12px}.authHeader .mutedText{max-width:30ch}.suspendedPanel .authHeader .mutedText{max-width:36ch}.suspensionReasonPanel{display:grid;grid-gap:6px;gap:6px;padding:14px;border:1px solid var(--border);border-radius:8px;background:var(--surface-subtle);color:var(--text-secondary)}.suspensionReasonPanel span{color:var(--text-primary);font-size:13px;font-weight:800}.suspensionReasonPanel p{color:var(--text-primary);overflow-wrap:anywhere}.suspensionReasonPanel small{color:var(--text-muted);font-size:12px}.suspendedProfileSwitcher{display:grid;grid-gap:8px;gap:8px}.suspendedProfileSwitcher .profileSwitchButton{width:100%;justify-content:flex-start}.stateIllustration{display:block;width:min(148px,46vw);height:auto;border-radius:8px;object-fit:contain}.authPanel>.stateIllustration{justify-self:center;width:min(128px,44vw);margin:-6px 0 -8px}.emptyState>.stateIllustration{width:min(136px,52vw)}.confirmDialog>.stateIllustration{justify-self:center;width:112px;margin-bottom:-4px}.noticeStack{display:grid;grid-gap:10px;gap:10px}.eyebrow{color:var(--primary);font-size:13px;font-weight:700;line-height:18px;text-transform:uppercase}.mutedText{color:var(--text-secondary)}.formStack{display:grid;grid-gap:10px;gap:10px}.datePanel label,.formStack label{color:var(--text-primary);font-size:13px;font-weight:700}.fieldHelp{margin-top:-4px;font-size:13px}.fieldHelp,.inputWithIcon{color:var(--text-secondary)}.inputWithIcon{display:grid;grid-template-columns:22px 1fr;align-items:center;grid-gap:10px;gap:10px;min-height:48px;padding:0 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.dateInputWrap:focus-within,.inputWithIcon:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px rgba(36,95,84,.12)}.authPanel .formStack input[type=password],.datePanel input,.inputWithIcon input,.inputWithIcon textarea{width:100%;min-height:44px;border:0;background:transparent;color:var(--text-primary);outline:0}.inputWithIcon textarea{min-height:96px;padding:8px 0;font:inherit;line-height:1.5;resize:vertical}.detailsInput{align-items:start;padding-top:8px;padding-bottom:8px}.detailsInput>svg{margin-top:12px}.detailsCounter{justify-self:end}.datePanel input{min-height:50px;padding:0}.formStack>input[type=password]{width:100%;min-height:48px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);outline:0}.formStack>input[type=password]:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(36,95,84,.12)}.checkboxRow{display:flex;align-items:center;min-height:44px;gap:12px;color:var(--text-secondary)}.avatarButton,.calendarMenuSummary,.iconOnlyButton,.iconTextButton,.mobileNavButton,.navButton,.primaryButton,.profileOption,.profileSwitchButton,.secondaryButton,.textButton,.textDangerButton{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:0;border-radius:8px;border:1px solid transparent;cursor:pointer;font-weight:700;letter-spacing:0;line-height:1.2;text-decoration:none;text-align:center}.avatarButton svg,.calendarMenuSummary svg,.iconOnlyButton svg,.iconTextButton svg,.mobileNavButton svg,.navButton svg,.primaryButton svg,.secondaryButton svg,.textButton svg,.textDangerButton svg{flex:0 0 auto}.primaryButton{min-height:48px;padding:0 16px;background:var(--primary);color:var(--on-primary);box-shadow:0 8px 18px rgba(36,95,84,.18)}.primaryButton:hover{background:var(--primary-hover);transform:translateY(-1px)}.primaryButton:disabled,.secondaryButton:disabled{cursor:not-allowed;opacity:.58}.primaryButton.compact{min-height:44px;white-space:nowrap}.iconTextButton,.secondaryButton{min-height:48px;padding:0 14px;border-color:var(--border);background:var(--surface);color:var(--text-primary)}.avatarButton:hover,.iconOnlyButton:hover,.iconTextButton:hover,.mobileNavButton:hover,.navButton:hover,.secondaryButton:hover,.textButton:hover,.textDangerButton:hover{border-color:var(--border-strong);background:var(--surface-subtle)}.whatsAppButton{border-color:color-mix(in srgb,#128c7e 26%,var(--border));background:color-mix(in srgb,#e8f5e9 78%,var(--surface));color:#0f6844}.whatsAppButton:active,.whatsAppButton:hover{border-color:color-mix(in srgb,#128c7e 42%,var(--border-strong));background:color-mix(in srgb,#dcf8e7 84%,var(--surface));color:#075e54}:root[data-theme=dark] .whatsAppButton{border-color:color-mix(in srgb,#25d366 34%,var(--border));background:color-mix(in srgb,#062f25 46%,var(--surface));color:#25d366}:root[data-theme=dark] .whatsAppButton:active,:root[data-theme=dark] .whatsAppButton:hover{border-color:color-mix(in srgb,#25d366 54%,var(--border-strong));background:color-mix(in srgb,#063b2d 62%,var(--surface));color:#5df29a}.avatarButton{width:48px;min-height:48px;padding:0;border-color:var(--border);border-radius:999px;background:var(--surface);color:var(--primary);box-shadow:0 8px 18px rgba(21,36,54,.06)}.avatarButton span{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:999px;background:var(--primary-container);font-size:13px;font-weight:800}.settingsNavButton{white-space:nowrap}.settingsNavButton.active{border-color:color-mix(in srgb,var(--primary) 24%,var(--border));background:var(--primary-container);color:var(--primary)}.iconOnlyButton{width:42px;min-height:42px;padding:0;border-color:var(--border);border-radius:999px;background:color-mix(in srgb,var(--surface) 86%,transparent);color:var(--text-secondary)}.textButton,.textDangerButton{min-height:40px;padding:0 12px;border:1px solid transparent;border-radius:8px;background:transparent}.textButton{color:var(--primary)}.textDangerButton{color:var(--danger)}.textDangerButton:active,.textDangerButton:hover{border-color:transparent;background:color-mix(in srgb,var(--danger-container) 46%,transparent)}.textDangerButton:disabled{cursor:not-allowed;opacity:.58}.dangerButton{border-color:rgba(194,65,12,.24);color:var(--danger)}.dangerButton:hover{border-color:rgba(194,65,12,.4);background:var(--danger-container)}.dangerActionButton{border-color:rgba(194,65,12,.36);background:var(--danger-container);color:var(--danger)}.dangerActionButton:hover{border-color:rgba(194,65,12,.52);background:var(--danger-hover-container)}.dangerIconHeader .eyebrow,.dangerIconHeader .softIcon,.dangerIconHeader h2{color:var(--danger)}.fullWidth{width:100%}.textLink{color:var(--primary);font-weight:700}.notice{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface-subtle);color:var(--text-primary);animation:enterSoft .22s ease both}.notice.success{border-color:rgba(22,128,60,.22);background:var(--success-container);color:var(--success)}.notice.warning{border-color:rgba(183,121,31,.28);background:var(--warning-container);color:var(--warning)}.portalShell{min-height:100vh;padding-bottom:88px}.portalHeader{position:-webkit-sticky;position:sticky;z-index:10;top:0;display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:12px;gap:12px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--header-background);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden}.headerActions{display:inline-flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0}.desktopProfileSwitcher{display:none}.mobileProfileSelectorRow{display:grid;grid-column:1/-1;min-width:0}.mobileProfileSelectorRow .profileSwitchButton{width:100%;justify-content:flex-start}.brandCluster{display:grid;grid-template-columns:auto minmax(0,1fr);grid-gap:10px;gap:10px;align-items:center;min-width:0;min-height:48px}.brandText{min-width:0}.brandText strong{display:block;overflow:hidden;line-height:22px;text-overflow:ellipsis;white-space:nowrap}.profileSwitchButton{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;max-width:100%;overflow:hidden;padding:6px 12px;border-color:var(--border);background:var(--surface);color:var(--text-primary);box-shadow:0 8px 18px rgba(21,36,54,.06)}.profileSwitchIcon{flex:0 0 auto;color:var(--primary)}.profileSwitchButton:hover{border-color:var(--border-strong);background:var(--surface-subtle)}.profileSwitchButton span{display:grid;flex:1 1 auto;min-width:0;text-align:left}.profileSwitchButton small{color:var(--text-secondary);font-size:11px;font-weight:800;line-height:14px;text-transform:uppercase}.profileSwitchButton small,.profileSwitchButton strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profileSwitchButton strong{font-size:13px;line-height:18px}.profileSwitchButton em{flex:0 0 auto;color:var(--primary);font-size:13px;font-style:normal;font-weight:800;white-space:nowrap}.profileSwitchButton.compact span{display:none}.profileDialog{width:min(calc(100vw - 28px),440px);max-height:min(680px,calc(100dvh - 32px));overflow:auto}.profileDialogHelper{margin-top:4px}.profileOptionList{display:grid;grid-gap:8px;gap:8px}.profileOption{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;min-height:58px;grid-gap:10px;gap:10px;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);cursor:pointer;text-align:left}.profileOption:hover:not(:disabled){border-color:var(--border-strong);background:var(--surface-subtle)}.profileOption.selected{border-color:var(--primary);background:var(--primary-container);color:var(--primary)}.profileOption.suspended{border-color:color-mix(in srgb,var(--warning) 28%,var(--border))}.profileOption:disabled{cursor:not-allowed;opacity:.62}.profileOption span{display:grid;grid-gap:2px;gap:2px}.profileOption small{color:var(--text-secondary);font-size:13px;line-height:18px}.profileOption .profileOptionHint{color:var(--warning);font-weight:800}.portalHeader .headerBrandLogo{width:clamp(58px,17vw,66px);padding:0;border-color:transparent;background:transparent;align-self:center;box-shadow:none}:root[data-theme=dark] .portalHeader .headerBrandLogo img{filter:invert(1) hue-rotate(180deg) brightness(1.12) saturate(.9)}.desktopNav{display:none}.navButton{padding:0 14px;background:transparent;color:var(--text-secondary)}.avatarButton.active,.mobileNavButton.active,.navButton.active{background:var(--primary-container);color:var(--primary)}.portalMain{width:min(100%,1080px);margin:0 auto;padding:18px 14px 32px}.viewTransition{animation:enterSoft .24s ease both}.screenStack{display:grid;grid-gap:14px;gap:14px}.screenHeader{display:flex;gap:16px;align-items:flex-start;justify-content:space-between}.bookingProfilePanel,.confirmPanel,.datePanel,.devicePrompt,.educationPanel,.emptyState,.highlightPanel{display:grid;grid-gap:16px;gap:16px;padding:20px;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--soft-shadow)}.bookingProfilePanel{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px}.bookingProfileSummary{display:inline-flex;align-items:center;min-width:0;gap:10px}.bookingProfileSummary>svg{color:var(--primary)}.bookingProfileSummary div{min-width:0}.bookingProfileSummary small,.bookingProfileSummary strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bookingProfileSummary small{color:var(--text-secondary);font-size:13px;font-weight:700;line-height:18px}.buttonRow{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.buttonRow .primaryButton,.buttonRow .secondaryButton{flex:0 1 auto}.bookingDetailsNote{display:grid;grid-gap:4px;gap:4px;padding:10px 12px;border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));border-radius:8px;background:color-mix(in srgb,var(--accent-container) 42%,var(--surface));color:var(--text-primary)}.bookingDetailsNote span{color:var(--primary);font-size:12px;font-weight:800;line-height:16px;text-transform:uppercase}.bookingDetailsNote p{color:var(--text-primary);overflow-wrap:anywhere}.buttonHint{color:var(--text-secondary);font-size:13px;font-weight:700}.calendarMenu{position:relative;min-width:190px;isolation:isolate}.calendarMenuSummary{min-height:48px;padding:0 16px;border-color:transparent;background:var(--primary);color:var(--on-primary);box-shadow:0 8px 18px rgba(36,95,84,.18);list-style:none}.calendarMenuSummary::-webkit-details-marker{display:none}.calendarMenuSummary:hover,.calendarMenu[open] .calendarMenuSummary{background:var(--primary-hover)}.calendarMenuSummary:hover{transform:translateY(-1px)}.calendarMenu[open] .calendarMenuSummary svg:last-child{transform:rotate(180deg)}.calendarMenuPanel{position:absolute;z-index:30;top:calc(100% + 8px);right:0;display:grid;min-width:min(260px,calc(100vw - 32px));grid-gap:4px;gap:4px;padding:8px;margin-top:8px;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);transform-origin:top right;animation:menuEnter .16s ease both}.calendarMenuPanel a,.calendarMenuPanel button{display:inline-flex;align-items:center;justify-content:flex-start;min-height:42px;gap:8px;padding:0 10px;border:0;border-radius:8px;background:transparent;color:var(--text-primary);cursor:pointer;font-weight:700;text-align:left;text-decoration:none}.calendarMenuPanel a:hover,.calendarMenuPanel button:hover{background:var(--surface-subtle)}.buttonStack{display:grid;grid-gap:10px;gap:10px}.successPrompt{display:grid;grid-template-columns:38px 1fr;grid-gap:12px;gap:12px;align-items:start;padding:16px;border:1px solid rgba(22,128,60,.22);border-radius:8px;background:var(--success-container);color:var(--success)}.successPrompt .mutedText{margin-top:4px;color:var(--text-secondary)}.successPanel{position:relative;z-index:1;display:grid;grid-template-columns:64px 1fr;grid-gap:18px;gap:18px;align-items:center;padding:18px;border:1px solid rgba(22,128,60,.24);border-radius:8px;background:var(--success-container);color:var(--text-primary);box-shadow:var(--soft-shadow);animation:enterSoft .22s ease both}.highlightPanel:has(.calendarMenu[open]),.successPanel:has(.calendarMenu[open]){z-index:20}.successPanel.isDismissing{pointer-events:none;animation:panelDismiss .19s ease both}.successBadge{display:inline-flex;width:62px;height:62px;align-items:center;justify-content:center;border-radius:8px;background:color-mix(in srgb,var(--success-container) 78%,var(--surface));color:var(--success);box-shadow:inset 0 0 0 1px rgba(22,128,60,.16)}.successPanelBody{display:grid;grid-gap:8px;gap:8px}.panelDismissButton{position:absolute;top:10px;right:10px;display:inline-grid;width:32px;min-height:32px;place-items:center;border:1px solid rgba(22,128,60,.18);border-radius:999px;background:color-mix(in srgb,var(--surface) 54%,transparent);color:var(--text-secondary);cursor:pointer;font-size:22px;line-height:1}.panelDismissButton:hover{background:var(--surface);color:var(--text-primary)}.highlightPanel{position:relative;overflow:visible;border-color:rgba(36,95,84,.24);background:linear-gradient(135deg,var(--highlight-gradient-start),var(--highlight-gradient-end)),var(--surface)}.cardEyebrowRow{display:flex;align-items:center;justify-content:space-between;gap:12px}.metaLine{flex-wrap:wrap;gap:6px;color:var(--text-secondary);overflow-wrap:anywhere}.metaLine,.statusPill{display:inline-flex;align-items:center}.statusPill{width:-moz-fit-content;width:fit-content;min-height:28px;padding:3px 10px;border-radius:999px;background:var(--success-container);color:var(--success);font-size:13px;font-weight:700}.statusPill.cancelled{background:var(--danger-container);color:var(--danger)}.statusPill.noShow{background:var(--warning-container);color:var(--warning)}.statusPill.completed{background:var(--success-container);color:var(--success)}.sessionActions{display:inline-flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-end}.modalBackdrop{position:fixed;z-index:1000;inset:0;display:grid;place-items:center;min-height:100dvh;overflow-y:auto;padding:20px max(14px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(14px,env(safe-area-inset-left));background:var(--modal-backdrop);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:backdropEnter .18s ease both}.confirmDialog{width:min(100%,440px);grid-gap:16px;gap:16px;padding:22px;background:var(--surface);box-shadow:var(--shadow);animation:dialogEnter .22s cubic-bezier(.2,.82,.2,1) both}.confirmDialog,.dialogBookingSummary{display:grid;border:1px solid var(--border);border-radius:8px}.dialogBookingSummary{grid-gap:4px;gap:4px;padding:14px;background:var(--surface-subtle);color:var(--text-secondary)}.dialogBookingSummary strong{color:var(--text-primary)}.dialogActions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.dialogIconHeader{display:grid;grid-template-columns:42px 1fr;grid-gap:12px;gap:12px;align-items:center}.sessionList{display:grid;grid-gap:10px;gap:10px}.sectionTitle{font-size:16px;line-height:22px}.sessionRow{display:grid;grid-template-columns:1fr auto;grid-gap:12px;gap:12px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);animation:enterSoft .22s ease both}.offerButton:hover:not(:disabled),.sessionRow:hover,.weekDateButton:hover:not(:disabled){transform:translateY(-1px)}.historyFilterBar{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.historyFilterBar::-webkit-scrollbar{display:none}.historyFilterBar button{min-height:38px;flex:0 0 auto;padding:0 13px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-primary);cursor:pointer;font-weight:800}.historyFilterBar button.selected,.historyFilterBar button:hover{border-color:var(--primary);background:var(--primary-container);color:var(--primary)}.historyGroup{display:grid;grid-gap:10px;gap:10px}.historyRow{align-items:start}.historyRow>.statusPill{justify-self:end}.historyNotice{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.historyLoadMoreButton{justify-self:center}.emptyStateIcon{color:var(--primary)}.emptyState{justify-items:start}.educationPanel{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:14px 16px;border-color:rgba(41,183,174,.22);background:linear-gradient(135deg,var(--accent-container),var(--surface) 88%),var(--surface);overflow:hidden}.educationCompact{display:grid;grid-template-columns:36px minmax(0,1fr);grid-gap:10px;gap:10px;align-items:center;min-width:0}.educationCompact h2{font-size:16px;line-height:22px}.tipIcon{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border-radius:999px;background:var(--surface);color:var(--primary);box-shadow:inset 0 0 0 1px var(--border)}.tipActions{display:flex;align-items:center;justify-content:flex-end;gap:6px}.rotated{transform:rotate(180deg)}.educationDetails{display:grid;grid-column:1/-1;grid-template-rows:0fr;opacity:0;transform:translateY(-4px);transition:grid-template-rows .22s ease,opacity .18s ease,transform .22s ease}.educationDetails.open{grid-template-rows:1fr;opacity:1;transform:translateY(0)}.educationList{display:grid;min-height:0;grid-gap:12px;gap:12px;overflow:hidden;padding:0;margin:0;list-style:none}.educationPanel .fieldHelp{grid-column:1/-1;margin-top:-2px}.educationList li{display:grid;grid-template-columns:22px 1fr;grid-gap:9px;gap:9px;align-items:start;color:color-mix(in srgb,var(--text-primary) 84%,var(--text-secondary));line-height:24px}.educationList svg{margin-top:1px;color:var(--primary)}.datePanel input{color-scheme:light}.dateInputWrap{display:grid;align-items:center;min-height:54px;padding:0 14px;border:1px solid color-mix(in srgb,var(--border-strong) 70%,var(--border));border-radius:8px;background:color-mix(in srgb,var(--surface) 88%,var(--surface-subtle));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--surface) 70%,transparent)}:root[data-theme=dark] .datePanel input{color-scheme:dark}.bookingSteps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px;padding:0;margin:0;list-style:none}.bookingSteps li{display:flex;min-height:44px;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.bookingSteps li,.bookingSteps li>span{align-items:center;color:var(--text-secondary)}.bookingSteps li>span{display:inline-flex;justify-content:center;flex:0 0 auto;width:24px;height:24px;border:1px solid var(--border);border-radius:999px;font-size:12px;font-weight:800}.bookingSteps strong{min-width:0;overflow:hidden;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.bookingSteps li.active{border-color:rgba(36,95,84,.28);background:var(--primary-container);color:var(--primary)}.bookingSteps li.active>span,.bookingSteps li.complete>span{border-color:var(--primary);background:var(--primary);color:var(--on-primary)}.bookingSteps li.complete{color:var(--primary)}.quickDateChips{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.quickDateChips::-webkit-scrollbar{display:none}.quickDateChips button{min-height:36px;flex:0 0 auto;padding:0 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-primary);font-weight:700;cursor:pointer}.quickDateChips button:hover{border-color:var(--primary);color:var(--primary)}.selectedDateSummary{display:grid;grid-gap:2px;gap:2px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface-subtle)}.selectedDateSummary span{color:var(--text-secondary);font-size:13px;font-weight:700}.selectedDateSummary strong{color:var(--text-primary)}.weekDateStrip{display:grid;grid-template-columns:repeat(7,minmax(64px,1fr));grid-gap:6px;gap:6px;overflow-x:auto;padding:2px 2px 12px;scrollbar-width:none}.weekDateStrip::-webkit-scrollbar{display:none}.weekDateButton{display:grid;min-width:64px;min-height:66px;grid-gap:2px;gap:2px;justify-items:center;padding:7px 4px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-secondary);cursor:pointer}.weekDateButton span{font-size:12px;font-weight:700;text-transform:capitalize}.weekDateButton strong{color:var(--text-primary);font-size:17px;line-height:22px}.weekDateButton em{color:var(--text-muted);font-size:11px;font-style:normal;font-weight:700;line-height:14px;text-align:center}.weekDateButton:hover{border-color:var(--border-strong);background:var(--surface-subtle)}.weekDateButton.selected{border-color:var(--primary);background:var(--primary-container);color:var(--primary)}.weekDateButton.available em,.weekDateButton.selected strong{color:var(--primary)}.weekDateButton.booked,.weekDateButton.unavailable,.weekDateButton.unknown{background:var(--surface-subtle);color:var(--text-muted)}.weekDateButton.booked strong,.weekDateButton.unavailable strong,.weekDateButton.unknown strong{color:var(--text-secondary)}.weekDateButton.loading em{letter-spacing:1px}.weekDateButton:disabled{cursor:not-allowed;opacity:.42}.offerGrid{display:grid;grid-gap:10px;gap:10px}.offerButton{position:relative;display:grid;grid-template-columns:28px 1fr;grid-gap:10px;gap:10px;align-items:center;min-height:64px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);cursor:pointer;text-align:left;animation:enterSoft .22s ease both}.offerButton>span:not(.offerSelectMark){display:grid;width:100%;grid-gap:4px;gap:4px}.offerButton span span{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);min-width:0;overflow-wrap:anywhere}.offerButton.selected{border-color:var(--primary);background:var(--surface-selected);box-shadow:0 10px 24px rgba(36,95,84,.14);transform:translateY(-1px)}.offerButton:disabled{cursor:not-allowed;background:var(--neutral-container);color:var(--text-secondary)}.offerButton.unavailable{background:var(--surface-subtle)}.offerButton.unavailable strong{color:var(--text-secondary)}.offerSelectMark{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--border-strong);border-radius:999px;color:var(--primary)}.offerButton.selected .offerSelectMark{border-color:var(--primary);background:var(--primary-container)}.offerButton:disabled .offerSelectMark{opacity:.48}.offerUnavailableMark{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text-muted)}.emptyActions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.emptyActions .secondaryButton{min-height:40px;padding-inline:14px}.offerSkeleton,.sessionSkeleton{min-height:72px;border:1px solid var(--border);border-radius:8px;background:linear-gradient(90deg,var(--surface),var(--surface-subtle),var(--surface));animation:pulseSurface 1.1s ease-in-out infinite}.offerSkeleton{display:flex;align-items:center;padding:0 16px;color:var(--text-muted);font-weight:700}.loadingStack{display:grid;grid-gap:10px;gap:10px}.sessionSkeleton{min-height:148px}.sessionSkeleton.small{min-height:74px}.confirmPanel{align-items:center}.confirmPanel,.settingsPanel{animation:enterSoft .22s ease both}.settingsPanel{display:grid;grid-gap:16px;gap:16px;padding:18px;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--soft-shadow)}.settingsPanelHeader{display:grid;grid-template-columns:28px 1fr;grid-gap:10px;gap:10px;align-items:start}.settingsPanelHeader>svg{margin-top:3px;color:var(--primary)}.dangerZonePanel{border-color:color-mix(in srgb,var(--danger) 32%,var(--border));background:color-mix(in srgb,var(--danger-container) 14%,var(--surface))}.dangerZonePanel .settingsPanelHeader>svg{color:var(--danger)}.dangerZoneAction{justify-self:start}.lockedInput{background:var(--surface-subtle)}.lockedInput input{color:var(--text-secondary)}.inputWithIcon input:disabled,.inputWithIcon textarea:disabled{color:var(--text-secondary);opacity:1}.inputWithIcon textarea:disabled{resize:none}.bookedDayPanel{border-color:rgba(22,128,60,.24)}.compactEmpty{padding:16px}.choicePanel{display:grid;grid-gap:10px;gap:10px;margin:0;padding:12px;border:1px solid var(--border);border-radius:8px}.choicePanel legend{padding:0 4px;color:var(--text-primary);font-size:13px;font-weight:700}.choicePanel label{display:flex;align-items:center;min-height:36px;gap:10px;color:var(--text-secondary)}.themePicker{display:grid;grid-gap:10px;gap:10px;margin:0;padding:0;border:0}.themePicker legend{color:var(--text-primary);font-size:13px;font-weight:700}.themeChoiceGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px}.themeChoice{position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:44px;gap:8px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-secondary);cursor:pointer;font-weight:700}.themeChoice:hover{border-color:var(--border-strong);background:var(--surface-subtle)}.themeChoice:focus-within{outline:3px solid rgba(37,99,235,.28);outline-offset:2px}.themeChoice input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.themeChoice.selected{border-color:var(--primary);background:var(--primary-container);color:var(--primary)}.mobileNav{position:fixed;z-index:20;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:4px;gap:4px;padding:10px 12px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:var(--mobile-nav-background);box-shadow:0 -12px 30px rgba(23,32,29,.08);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobileNavButton{min-height:56px;padding:6px 2px;border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:12px;flex-direction:column;gap:4px}.mobileNavButton span{overflow-wrap:anywhere}@media (max-width:640px){.authPage{align-items:stretch;place-items:start stretch;padding:max(12px,env(safe-area-inset-top)) 14px max(14px,env(safe-area-inset-bottom))}.authPanel{align-self:start;gap:20px;width:100%;padding:22px 18px}.authPanel .primaryButton,.authPanel .secondaryButton{width:100%;min-height:52px;padding-block:10px}.authPanel input{font-size:16px}.screenHeader{display:grid;grid-gap:12px;gap:12px}.screenHeader .primaryButton{width:100%}.portalHeader{grid-template-columns:minmax(0,1fr) auto}.profileSwitchButton.compact{width:44px;padding:0}.profileSwitchButton.compact em{display:none}.settingsNavButton{width:48px;padding:0}.settingsNavButton span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.bookingProfilePanel{display:grid;grid-gap:16px;gap:16px;padding:18px}.bookingProfilePanel .profileSwitchButton{width:-moz-fit-content;width:fit-content;max-width:100%;justify-content:center;padding-inline:12px}.bookingProfilePanel .profileSwitchButton.compact span{display:none}.bookingProfilePanel .profileSwitchButton.compact em{display:inline}.iconTextButton span{display:none}.confirmPanel,.datePanel,.emptyState,.highlightPanel{padding:18px}.successPanel{grid-template-columns:1fr;justify-items:start;padding:18px}.successBadge{justify-self:center}.bookingSteps{gap:6px}.bookingSteps li{display:grid;justify-items:center;grid-gap:5px;gap:5px;padding:8px 4px}.bookingSteps strong{font-size:12px}.weekDateStrip{margin-inline:0;padding-inline:2px}.sessionRow{grid-template-columns:1fr}.sessionActions{display:grid;justify-content:stretch}.buttonRow .calendarMenu,.buttonRow .calendarMenuSummary,.buttonRow .primaryButton,.buttonRow .secondaryButton,.sessionActions .calendarMenu,.sessionActions .calendarMenuSummary,.sessionActions .primaryButton,.sessionActions .secondaryButton,.sessionActions .textDangerButton{width:100%}.dialogActions{display:grid}.dialogActions .primaryButton,.dialogActions .secondaryButton{width:100%}.stickyConfirmPanel{position:-webkit-sticky;position:sticky;z-index:8;bottom:calc(88px + env(safe-area-inset-bottom));box-shadow:var(--shadow)}.educationPanel,.themeChoiceGrid{grid-template-columns:1fr}.educationPanel{padding:18px}.tipActions{justify-content:space-between}}@media (prefers-reduced-motion:reduce){*,:after,:before{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (min-width:760px){.portalShell{padding-bottom:0}.portalHeader{grid-template-columns:auto 1fr auto;padding:16px 24px}.desktopProfileSwitcher{display:contents}.desktopProfileSwitcher .profileSwitchButton{max-width:min(280px,30vw)}.mobileProfileSelectorRow{display:none}.portalHeader .headerBrandLogo{width:78px;padding:0}.desktopNav{display:flex;gap:8px;justify-self:center}.mobileNav{display:none}.portalMain{padding:32px 24px 48px}.offerGrid{grid-template-columns:repeat(3,minmax(0,1fr))}.confirmPanel{grid-template-columns:1fr auto}}