:root{font-family:Inter,system-ui,Arial,sans-serif;color:#152031;background:#f2f5fb}*{box-sizing:border-box}body{margin:0}.customer-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.card{width:min(920px,100%);background:#fff;border:1px solid #d7dfec;border-radius:14px;padding:20px;box-shadow:0 10px 30px #0a192d14}.customer-logo-wrap{margin-bottom:10px}.customer-logo{display:block;max-width:min(320px,100%);max-height:90px;object-fit:contain}.muted{color:#6a768a}.section+.section{margin-top:14px}.row{display:grid;gap:6px;margin-bottom:10px}.row-inline{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.portal-header{display:flex;justify-content:flex-start;align-items:flex-start;gap:12px}.portal-identity{display:grid;gap:3px}.portal-identity strong{margin-bottom:2px}.portal-topbar{display:flex;justify-content:space-between;align-items:center;gap:12px}.portal-online-booking-link{border:0;background:transparent;color:#2f69c7;padding:2px 0;border-radius:0;text-decoration:underline;font-weight:600}.portal-online-booking-link:hover{color:#234f98}.portal-menu-wrap{position:relative;display:inline-flex}.portal-menu-button{width:44px;min-width:44px;height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-color:#9fb3d1;background:#f7faff;font-size:1.35rem;line-height:1;font-weight:700}@media (max-width: 640px){.portal-menu-button{width:50px;min-width:50px;height:50px}}.portal-menu-popover{position:absolute;top:calc(100% + 6px);right:0;display:grid;gap:6px;min-width:180px;background:#fff;border:1px solid #c8d1e0;border-radius:10px;padding:8px;box-shadow:0 10px 22px #0c1b3224;z-index:10}.appointment-head{display:inline-flex;align-items:center;gap:8px}.calendar-icon-btn{border:1px solid #c8d1e0;background:#fff;color:#1f2e45;border-radius:8px;padding:2px 7px;line-height:1.2;font-size:.95rem}.calendar-icon-btn:hover{border-color:#9fb3d1;background:#f7faff}.portal-appointment-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.portal-action-btn{border-radius:9px;font-size:.86rem;padding:7px 10px}.portal-action-btn--confirm{border-color:#15803d;background:#16a34a;color:#fff}.portal-action-btn--reschedule{border-color:#c2410c;background:#f59e0b;color:#1f2e45}.portal-action-btn--cancel{border-color:#b91c1c;background:#dc2626;color:#fff}@media (max-width: 640px){.portal-appointment-actions{display:grid;grid-template-columns:1fr;gap:8px}.portal-action-btn{width:100%;min-height:44px;font-size:.95rem;padding:10px 12px}}.input{width:100%;border:1px solid #c8d1e0;border-radius:10px;padding:10px 12px;font:inherit;background:#fff;color:#1f2e45}select.input,input.input[type=date]{background:#fff;color:#1f2e45;border-color:#9fb3d1;cursor:pointer}.portal-date-nav{display:flex;align-items:stretch;gap:8px;width:100%}.portal-date-arrow{flex:0 0 auto;min-width:44px;padding-left:10px;padding-right:10px;font-size:1.35rem;line-height:1}.portal-date-input{flex:1 1 auto;min-width:0}.portal-choice-group{display:flex;flex-wrap:wrap;gap:8px;width:100%}.portal-choice-btn{flex:1 1 auto;min-width:min(100%,148px);text-align:center}@media (max-width: 640px){.portal-choice-btn{min-width:100%}}.portal-waitlist-list{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:12px}.portal-waitlist-item{border:1px solid #c8d1e0;border-radius:10px;padding:12px 14px;background:#fbfcfe}.portal-waitlist-item-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px}.portal-waitlist-status{font-size:.88rem;color:#3d4e66;border:1px solid #d5deeb;background:#fff;border-radius:999px;padding:2px 10px}.portal-waitlist-meta{margin-top:8px;font-size:.92rem;display:grid;gap:4px}.portal-waitlist-remove{margin-top:10px}.portal-waitlist-cta-right{margin-left:auto;display:block}button{border:1px solid #244b8a;background:#2f69c7;color:#fff;border-radius:10px;padding:9px 14px;cursor:pointer;font:inherit}button.secondary{border-color:#c8d1e0;background:#fff;color:#1f2e45}button.secondary.is-selected{border-color:#2f69c7;color:#2f69c7;background:#eff5ff}button:disabled{opacity:.5;cursor:not-allowed}.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(94px,1fr));gap:8px}.slot{border:1px solid #d0d8e6;background:#fff;color:#23324c}.slot.slot--flex{border-color:#d98a1d;background:#fff6ea}.mode-switch{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.goodie-box{border:1px solid #d6e3fb;background:#f5f9ff;border-radius:10px;padding:10px 12px;margin-bottom:10px}.portal-forgot-row{justify-items:end;margin-top:-6px}.portal-forgot-btn{border:1px solid #d7dfec;background:#fff;color:#6a768a;border-radius:8px;padding:4px 8px;font-size:.75rem;line-height:1.1}.portal-forgot-btn:hover{color:#41506a;border-color:#c8d1e0}.slot.is-active{border-color:#2f69c7;background:#2f69c7;color:#fff}.error{color:#b02727}.success{color:#20642b}.portal-alert{scroll-margin-top:12px;padding:12px 14px;border-radius:10px;margin:0 0 14px;line-height:1.45}.portal-alert--error{background:#fef2f2;border:1px solid #f1b4b4}.portal-alert--success{background:#f0fdf4;border:1px solid #9dc7a4}.portal-slot-area{position:relative;min-height:88px}.portal-slot-area__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#080f1c38;display:grid;place-items:center;z-index:2;border-radius:10px;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.portal-engine-loading-box{min-width:260px;max-width:min(92vw,360px);background:#fff;border:1px solid #d7dfec;border-radius:12px;padding:14px 16px;box-shadow:0 10px 24px #0a192d2e;text-align:center}.portal-engine-loading-gear{font-size:2rem;line-height:1;margin-bottom:10px;display:inline-block;animation:portal-gear-spin 1s linear infinite}.portal-engine-loading-box p{margin:0;color:#1f2e45;font-weight:600}@keyframes portal-gear-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
