:root{--color-page:#f3f1f1;--color-surface:#fff;--color-ink:#232323;--color-muted:#626262;--color-muted-strong:#444;--color-line:#d9d6d6;--color-primary:#765a5e;--color-primary-strong:#654a4e;--color-accent:#6c5256;--color-soft:#f0ecec;--color-soft-surface:#f7f5f5;--color-focus:#765a5e47;--color-status-line:#d5d0d1;--color-status-bg:#f6f3f3;--color-status-ink:#5d5657;--color-warning-line:#d9cfd0;--color-warning-bg:#f7f1f1;--color-warning-ink:#655c5d;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--control-height-sm:36px;--control-height-md:40px;--font-size-meta:.85rem;--font-size-body:1rem;--font-size-section:1.08rem;--font-size-page:2.3rem;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--shadow-soft:0 18px 60px #14141414}*{box-sizing:border-box}html{background:var(--color-page);min-width:320px}body{min-height:100vh;color:var(--color-ink);background:var(--color-page);font-family:Arial,Helvetica,sans-serif;font-size:var(--font-size-body);letter-spacing:0;margin:0;line-height:1.5}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}.public-shell{flex-direction:column;min-height:100vh;display:flex}.access-hub-shell{justify-content:center;width:min(760px,100% - 32px);margin:0 auto;padding:48px 0}.access-hub-panel{border:1px solid var(--color-line);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-soft);background:linear-gradient(#fffffffa,#f8f6f6f5);padding:32px 28px}.access-hub-brand span,.auth-brand-copy{gap:2px;display:grid}.access-hub-brand strong,.auth-brand-copy strong{font-size:1rem}.access-hub-brand small,.auth-brand-copy small{color:var(--color-muted-strong);font-size:var(--font-size-meta);font-weight:var(--font-weight-semibold)}.access-hub-copy{max-width:560px;margin-top:28px}.access-hub-lead{max-width:520px;color:var(--color-muted);margin:20px 0 0;font-size:1.05rem;line-height:1.7}.access-hub-actions{flex-wrap:wrap;gap:12px;margin-top:28px;display:flex}.access-hub-return-link{min-height:var(--control-height-md);color:var(--color-muted-strong);font-weight:var(--font-weight-semibold);align-items:center;margin-top:18px;display:inline-flex}.public-page{padding:24px 0 56px}.public-anchor-section{scroll-margin-top:120px}.site-header-shell{z-index:20;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffeb;border-bottom:1px solid #d9d6d6e0;position:sticky;top:0}.site-header{justify-content:space-between;align-items:center;gap:20px;width:min(1120px,100% - 32px);min-height:84px;margin:0 auto;display:flex}.brand-link{min-height:var(--control-height-md);font-weight:var(--font-weight-bold);flex:none;align-items:center;gap:10px;display:inline-flex}.brand-link img{flex:none}.site-header-actions{justify-content:flex-end;align-items:center;gap:14px;min-width:0;display:flex}.site-nav{color:var(--color-muted-strong);font-weight:var(--font-weight-medium);align-items:center;gap:18px;display:flex}.site-nav a{min-height:var(--control-height-md);align-items:center;padding:0 4px;display:inline-flex}.site-header-cta{white-space:nowrap}.hero-section{grid-template-columns:minmax(0,1.15fr) minmax(240px,.85fr);align-items:center;gap:48px;width:min(1120px,100% - 32px);min-height:calc(100vh - 180px);margin:0 auto;padding:36px 0 44px;display:grid}.hero-copy{max-width:680px}.eyebrow{color:var(--color-accent);font-size:.82rem;font-weight:var(--font-weight-bold);letter-spacing:0;text-transform:uppercase;margin:0 0 12px}h1,h2,p{overflow-wrap:anywhere}h1{letter-spacing:0;margin:0;font-size:4rem;line-height:1}.hero-lead{max-width:620px;color:var(--color-muted);margin:24px 0 0;font-size:1.16rem;line-height:1.65}.hero-actions{flex-wrap:wrap;gap:12px;margin-top:32px;display:flex}.button{min-height:var(--control-height-md);border-radius:var(--radius-sm);font-size:.95rem;font-weight:var(--font-weight-semibold);border:1px solid #0000;justify-content:center;align-items:center;padding:0 14px;line-height:1.1;transition:background-color .16s,border-color .16s,color .16s,transform .16s;display:inline-flex}.button:hover{transform:translateY(-1px)}.button-primary{color:#fff;background:var(--color-primary)}.button-primary:hover{background:var(--color-primary-strong)}.button-secondary{color:var(--color-ink);background:var(--color-surface);border-color:var(--color-line)}.button-secondary:hover{border-color:#c6b9bb}.hero-visual{border:1px solid var(--color-line);min-height:400px;box-shadow:var(--shadow-soft);background:linear-gradient(135deg,#f5f1f1d6,#ffffffeb),repeating-linear-gradient(135deg,#765a5e14 0 1px,#0000 1px 18px);border-radius:24px;place-items:center;display:grid}.hero-visual img{width:min(156px,45%);height:auto}.public-section,.final-cta-section{width:min(1120px,100% - 32px);margin:0 auto}.public-section{gap:24px;padding:44px 0;display:grid}.public-section-heading{max-width:580px}.public-section h2,.final-cta-copy h2{margin:0;font-size:clamp(2rem,3vw,2.75rem);line-height:1.05}.public-card{border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface);min-height:164px;box-shadow:var(--shadow-soft);align-content:start;gap:14px;padding:24px;display:grid}.public-card h3{margin:0;font-size:1.25rem;line-height:1.2}.public-card p,.final-cta-copy p:not(.eyebrow){color:var(--color-muted);margin:0;line-height:1.65}.final-cta-section{padding-top:12px}.final-cta-panel{border:1px solid var(--color-line);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);background:linear-gradient(135deg,#f7f4f4f5,#fff);justify-content:space-between;align-items:center;gap:24px;padding:26px;display:flex}.final-cta-copy{max-width:520px}.final-cta-actions{align-items:center;display:flex}.page-shell{place-items:center;width:min(760px,100% - 32px);min-height:100vh;margin:0 auto;padding:48px 0;display:grid}.placeholder-panel{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);width:100%;box-shadow:var(--shadow-soft);padding:28px}.placeholder-panel h1{font-size:2.4rem}.placeholder-panel p:not(.eyebrow){color:var(--color-muted);line-height:1.65}.auth-panel{border:1px solid var(--color-line);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-soft);background:linear-gradient(#fffffffa,#f7f5f5f0);padding:28px}.auth-brand-row{margin-bottom:20px}.auth-heading{max-width:620px}.auth-panel h1{font-size:var(--font-size-page);letter-spacing:-.02em}.auth-copy{color:var(--color-muted);line-height:1.6}.auth-grid{gap:16px;margin-top:24px;display:grid}.auth-form{align-content:start;gap:12px;min-width:0;display:grid}.auth-form h2{font-size:var(--font-size-section);font-weight:var(--font-weight-semibold);margin:0}.auth-form label{color:var(--color-ink);font-size:.95rem;font-weight:var(--font-weight-medium);gap:6px;display:grid}.auth-form input{min-height:var(--control-height-md);border:1px solid var(--color-line);border-radius:var(--radius-sm);width:100%;color:var(--color-ink);background:#fff;padding:0 12px}.auth-form input:focus{outline:2px solid var(--color-focus);outline-offset:2px;border-color:var(--color-primary)}.auth-form .button{width:100%}.auth-form-secondary{border-top:1px solid var(--color-line);margin-top:14px;padding-top:16px}.auth-single-form{margin-top:24px}.auth-inline-link{color:var(--color-muted);font-weight:var(--font-weight-medium)}.auth-register-disclosure{border:1px solid var(--color-line);border-radius:var(--radius-md);background:#ffffffb8;min-width:0;padding:14px 16px}.auth-register-prompt{color:var(--color-muted-strong);margin:0;line-height:1.5}.auth-register-toggle{appearance:none;color:var(--color-primary);font:inherit;font-weight:var(--font-weight-semibold);text-underline-offset:.18em;cursor:pointer;background:0 0;border:0;padding:0;text-decoration:underline}.auth-register-toggle:focus-visible{outline:2px solid var(--color-focus);outline-offset:3px}.auth-invite-grid{grid-template-columns:minmax(0,1.05fr) minmax(240px,.95fr)}.auth-invite-form{align-content:start}.auth-actions{flex-wrap:wrap;gap:12px;margin-top:24px;display:flex}.form-message{border:1px solid var(--color-line);border-radius:var(--radius-sm);color:var(--color-ink);background:var(--color-soft-surface);margin:18px 0 0;padding:12px 14px;font-size:.95rem;line-height:1.5}.form-message-error{border-color:var(--color-warning-line);background:var(--color-warning-bg);color:var(--color-warning-ink)}.invite-context{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-soft-surface);gap:4px;margin-top:18px;padding:12px 14px;display:grid}.invite-context span{color:var(--color-muted);font-size:var(--font-size-meta);font-weight:var(--font-weight-semibold)}.invite-context strong{overflow-wrap:anywhere}.auth-return-link{min-height:var(--control-height-md);color:var(--color-muted-strong);font-weight:var(--font-weight-semibold);align-items:center;margin-top:18px;display:inline-flex}.account-panel{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);width:100%;box-shadow:var(--shadow-soft);padding:24px}.account-heading{max-width:720px}.account-heading h1{font-size:var(--font-size-page)}.account-heading p:not(.eyebrow){color:var(--color-muted);line-height:1.6}.account-layout{align-items:start;gap:22px;margin-top:24px;display:grid}.account-section{border-top:1px solid var(--color-line);min-width:0;padding-top:18px}.account-section-primary{gap:18px;display:grid}.account-section-secondary{max-width:420px}.account-section-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.account-section-heading h2,.account-section-heading h3{font-size:var(--font-size-section);margin:0}.account-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:22px;display:grid}.account-form{border-top:1px solid var(--color-line);align-content:start;gap:14px;min-width:0;padding-top:18px;display:grid}.account-form h2,.account-form h3{font-size:var(--font-size-section);margin:0}.account-form label{color:var(--color-ink);font-size:.95rem;font-weight:var(--font-weight-medium);gap:7px;display:grid}.account-form input,.account-form select{min-height:var(--control-height-md);border:1px solid var(--color-line);border-radius:var(--radius-sm);width:100%;color:var(--color-ink);background:#fff;padding:0 12px}.account-form input:focus,.account-form select:focus{outline:2px solid var(--color-focus);outline-offset:2px;border-color:var(--color-primary)}.account-readonly-input{color:var(--color-muted);background:var(--color-soft-surface)}.account-form-secondary{gap:12px}.account-form-patient{gap:18px}.account-form-block{gap:14px;min-width:0;display:grid}.account-form-nested{border-top:0;gap:14px;padding-top:0}.account-password-disclosure{min-width:0}.account-password-toggle{appearance:none;color:var(--color-primary);font:inherit;font-weight:var(--font-weight-medium);text-underline-offset:.18em;cursor:pointer;background:0 0;border:0;padding:0;text-decoration:underline}.account-password-toggle:focus-visible{outline:2px solid var(--color-focus);outline-offset:3px}.insurance-options{border:0;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;min-width:0;margin:0;padding:0;display:grid}.insurance-options legend{color:var(--color-ink);font-size:.95rem;font-weight:var(--font-weight-medium);margin-bottom:8px}.insurance-option{border:1px solid var(--color-line);border-radius:var(--radius-sm);min-height:42px;font-size:.92rem;font-weight:var(--font-weight-medium);background:#fff;align-items:center;gap:6px;padding:7px 10px;display:flex}.insurance-option input{width:14px;height:14px;margin:0}.role-list{flex-wrap:wrap;gap:8px;display:flex}.role-list span{border:1px solid var(--color-line);color:var(--color-muted-strong);font-size:var(--font-size-meta);font-weight:var(--font-weight-medium);background:#fcfbfb;border-radius:999px;padding:4px 9px}.patient-shell{width:min(1120px,100% - 32px);min-height:100vh;margin:0 auto;padding:24px 0 48px}.patient-nav{justify-content:space-between;align-items:center;gap:16px;min-height:64px;display:flex}.patient-nav-links{color:var(--color-muted-strong);font-weight:var(--font-weight-medium);flex-wrap:wrap;align-items:center;gap:10px;display:flex}.patient-nav-links a,.patient-nav-links button{min-height:var(--control-height-sm);color:inherit;cursor:pointer;font-weight:var(--font-weight-semibold);background:0 0;border:0;align-items:center;padding:0 4px;display:inline-flex}.patient-panel{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);width:100%;box-shadow:var(--shadow-soft);padding:24px}.patient-heading{max-width:720px}.patient-heading h1{font-size:var(--font-size-page)}.patient-heading p:not(.eyebrow){color:var(--color-muted);line-height:1.6}.booking-layout{grid-template-columns:minmax(240px,.85fr) minmax(0,1.6fr);align-items:start;gap:22px;margin-top:26px;display:grid}.booking-progress{gap:18px;margin-top:22px;display:grid}.booking-progress .booking-step{margin-top:0}.booking-column,.booking-step,.appointments-section{border-top:1px solid var(--color-line);min-width:0;padding-top:16px}.booking-column h2,.booking-step h2,.appointments-section h2{font-size:var(--font-size-section);margin:0}.selector-form{gap:10px;margin-top:12px;display:grid}.selector-form label,.detail-field{color:var(--color-ink);font-size:.95rem;font-weight:var(--font-weight-medium);gap:7px;display:grid}.selector-form select,.detail-field textarea{border:1px solid var(--color-line);border-radius:var(--radius-sm);width:100%;color:var(--color-ink);background:#fff;padding:9px 12px}.selector-form select{min-height:var(--control-height-md);appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--color-muted-strong) 50%), linear-gradient(135deg, var(--color-muted-strong) 50%, transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-repeat:no-repeat;background-size:6px 6px,6px 6px;padding-right:32px}.selector-form select:focus,.detail-field textarea:focus{outline:2px solid var(--color-focus);outline-offset:2px;border-color:var(--color-primary)}.section-heading-row{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.section-heading-row span{color:var(--color-muted-strong);font-size:.88rem;font-weight:var(--font-weight-medium);text-align:right}.calendar-stack{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:12px;display:grid}.calendar-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-top:12px;display:flex}.calendar-toolbar-caption{color:var(--color-muted);font-size:.84rem;font-weight:var(--font-weight-medium)}.calendar-toolbar-actions{align-items:center;gap:8px;display:inline-flex}.calendar-nav-button{border:1px solid var(--color-line);border-radius:var(--radius-sm);min-height:36px;color:var(--color-ink);font-size:.88rem;font-weight:var(--font-weight-medium);background:#fff;justify-content:center;align-items:center;padding:0 12px;display:inline-flex}.calendar-nav-button-disabled{color:var(--color-muted);background:var(--color-page)}.calendar-month{min-width:0}.calendar-month h3{font-size:.95rem;font-weight:var(--font-weight-semibold);text-transform:capitalize;margin:0 0 10px}.calendar-weekdays,.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;display:grid}.calendar-weekdays{color:var(--color-muted);font-size:.74rem;font-weight:var(--font-weight-medium);text-align:center;margin-bottom:6px}.calendar-day{aspect-ratio:1/.92;border:1px solid var(--color-line);border-radius:var(--radius-sm);min-width:0;color:var(--color-muted);font-size:.94rem;font-weight:var(--font-weight-medium);background:#fff;place-items:center;display:grid}.calendar-day-available{color:#295b3d;background:#eef8f0;border-color:#b9d8c2}.calendar-day-unavailable{color:var(--color-muted);background:var(--color-page)}.calendar-day-selected{color:#fff;border-color:var(--color-primary);background:var(--color-primary)}.calendar-day-overbook-only:not(.calendar-day-selected){border-color:var(--color-warning-line);background:var(--color-warning-bg);color:var(--color-warning-ink)}.calendar-day-disabled,.calendar-day-empty{color:#aaa;background:#f4f3f3}.booking-step,.appointments-section{margin-top:22px}.slot-list{grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:8px;margin-top:12px;display:grid}.slot-button{min-height:var(--control-height-md);border:1px solid var(--color-line);border-radius:var(--radius-sm);color:var(--color-ink);font-weight:var(--font-weight-medium);background:#fff;justify-content:center;align-items:center;display:inline-flex}.slot-button-selected{color:#fff;border-color:var(--color-primary);background:var(--color-primary)}.booking-form{gap:14px;margin-top:12px;display:grid}.booking-summary{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;display:grid}.booking-summary div{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:#fff;min-width:0;padding:10px 12px}.booking-summary span,.booking-summary strong{display:block}.booking-summary span{color:var(--color-muted-strong);font-size:var(--font-size-meta);font-weight:var(--font-weight-medium)}.booking-summary strong{color:var(--color-ink);margin-top:4px}.reason-options{border:0;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;min-width:0;margin:0;padding:0;display:grid}.reason-options legend{font-weight:var(--font-weight-medium);margin-bottom:8px}.reason-option{border:1px solid var(--color-line);border-radius:var(--radius-sm);min-height:46px;font-weight:var(--font-weight-medium);background:#fff;align-items:center;gap:10px;padding:8px 12px;display:flex}.empty-state{color:var(--color-muted);margin:14px 0 0;line-height:1.6}.appointment-list{gap:10px;margin-top:12px;display:grid}.appointment-list-history{gap:8px}.appointment-card{border:1px solid var(--color-line);border-radius:var(--radius-md);background:#fff;grid-template-columns:minmax(0,1.15fr) minmax(168px,.85fr);align-items:start;gap:14px;min-width:0;padding:12px 14px;display:grid}.appointment-card-upcoming{border-color:#d9d0e4;box-shadow:0 10px 24px #3e27540f}.appointment-card-history{background:#fcfbfc;grid-template-columns:minmax(0,1fr) minmax(150px,auto);gap:10px;padding:10px 12px}.appointment-card h3,.appointment-card p{margin:0}.appointment-time{font-size:1.35rem;font-weight:var(--font-weight-semibold);margin-top:4px}.appointment-card p{color:var(--color-muted-strong);line-height:1.5}.appointment-date{font-weight:var(--font-weight-semibold);text-transform:capitalize}.appointment-dentist{margin-top:4px!important}.appointment-card-history .appointment-time{font-size:1rem}.appointment-card-history .appointment-date,.appointment-card-history .appointment-dentist{font-size:.94rem}.appointment-reason{font-weight:var(--font-weight-bold);margin-top:10px!important}.appointment-detail{margin-top:6px!important}.appointment-card-tags{flex-wrap:wrap;justify-content:flex-end;align-self:start;gap:8px;display:flex}.status-pill{border:1px solid var(--color-status-line);min-height:24px;color:var(--color-status-ink);background:var(--color-status-bg);font-size:.76rem;font-weight:var(--font-weight-medium);border-radius:999px;align-items:center;padding:0 8px;display:inline-flex}.status-pill-warning{border-color:var(--color-warning-line);color:var(--color-warning-ink);background:var(--color-warning-bg)}.status-pill-success{border-color:var(--color-status-line);color:var(--color-status-ink);background:var(--color-status-bg)}.staff-action-danger{color:#7a4c52;background:#fffafb;border-color:#dec8cb}.staff-action-danger:hover{color:#6d4247;background:#fff3f5;border-color:#d2b3b8}.form-message-warning{border-color:var(--color-warning-line);background:var(--color-warning-bg);color:var(--color-warning-ink)}.staff-shell{background:var(--color-page);grid-template-columns:240px minmax(0,1fr);min-height:100vh;display:grid}.staff-sidebar{box-sizing:border-box;border-right:1px solid var(--color-line);background:var(--color-surface);flex-direction:column;justify-content:space-between;align-self:start;gap:20px;height:100vh;padding:20px 18px;display:flex;position:sticky;top:0;overflow-y:auto}.staff-sidebar-main{gap:20px;display:grid}.staff-sidebar-header{gap:14px;display:grid}.staff-nav{gap:6px;display:grid}.staff-nav-link{min-height:var(--control-height-sm);border-radius:var(--radius-sm);color:var(--color-muted-strong);font-size:.95rem;font-weight:var(--font-weight-medium);border:1px solid #0000;align-items:center;padding:0 10px;display:flex}.staff-nav-link-active,.staff-nav-link:hover{color:var(--color-ink);background:#f5f2f2;border-color:#d8d2d3}.staff-sidebar-footer{gap:12px;display:grid}.staff-plain-button,.staff-plain-link{min-height:var(--control-height-sm);color:var(--color-muted-strong);cursor:pointer;font-weight:var(--font-weight-medium);text-align:left;background:0 0;border:0;padding:0}.staff-content{width:min(1180px,100%);min-width:0;padding:24px}.staff-control-grow{min-width:min(420px,100%)}.staff-panel{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);min-width:0;box-shadow:var(--shadow-soft);padding:22px}.staff-heading{max-width:760px}.staff-heading h1{font-size:var(--font-size-page)}.staff-heading p:not(.eyebrow){color:var(--color-muted);line-height:1.6}.staff-message-stack{margin-bottom:16px}.staff-message-stack .form-message{margin-top:10px}.staff-toolbar-grid{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;margin-top:20px;display:grid}.staff-toolbar,.staff-date-links,.staff-inline-form{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.staff-toolbar-compact{gap:12px}.staff-toolbar-group,.staff-toolbar-actions{flex-wrap:wrap;align-items:center;gap:10px;min-width:0;display:flex}.staff-toolbar-group{flex:auto}.staff-toolbar-actions{flex:none}.staff-toolbar-filters{justify-content:space-between}.staff-control{min-width:170px}.staff-control-stack{gap:6px;display:grid}.staff-control-label{color:var(--color-ink);font-size:.9rem;font-weight:var(--font-weight-semibold)}.staff-toolbar label,.staff-inline-form label,.staff-form-grid label,.staff-confirm-form label{color:var(--color-ink);font-size:.9rem;font-weight:var(--font-weight-semibold);gap:6px;display:grid}.staff-toolbar input,.staff-toolbar select,.staff-inline-form input,.staff-form-grid input,.staff-form-grid select,.staff-confirm-form input{min-height:var(--control-height-sm);border:1px solid var(--color-line);border-radius:var(--radius-sm);width:100%;color:var(--color-ink);background:#fff;padding:0 11px}.staff-toolbar input:focus,.staff-toolbar select:focus,.staff-inline-form input:focus,.staff-form-grid input:focus,.staff-form-grid select:focus,.staff-confirm-form input:focus{outline:2px solid var(--color-focus);outline-offset:2px;border-color:var(--color-primary)}.staff-date-picker{position:relative}.staff-date-picker-trigger{min-height:var(--control-height-sm);border:1px solid var(--color-line);border-radius:var(--radius-sm);width:100%;color:var(--color-ink);text-align:left;cursor:pointer;background:#fff;align-items:center;padding:7px 11px;display:flex}.staff-date-picker-trigger:focus-visible,.staff-date-picker-nav:focus-visible,.staff-date-picker-day:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.staff-date-picker-trigger-value{font-size:.92rem;line-height:1.3}.staff-date-picker-popover{z-index:20;border:1px solid var(--color-line);background:#fff;border-radius:14px;width:min(276px,100vw - 48px);padding:11px;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 20px 45px #221b1c29}.staff-date-picker-header,.staff-date-picker-weekdays{align-items:center;display:grid}.staff-date-picker-header{grid-template-columns:auto 1fr auto;gap:8px;margin-bottom:10px}.staff-date-picker-month{text-align:center;font-size:.94rem;font-weight:var(--font-weight-semibold);text-transform:capitalize;margin:0}.staff-date-picker-nav{border:1px solid var(--color-line);background:var(--color-soft-surface);min-width:32px;min-height:32px;color:var(--color-ink);cursor:pointer;border-radius:999px}.staff-date-picker-nav:disabled,.staff-date-picker-day:disabled{cursor:default;opacity:.45}.staff-date-picker-weekdays,.staff-date-picker-grid{grid-template-columns:repeat(7,minmax(0,1fr))}.staff-date-picker-weekdays{gap:4px;margin-bottom:6px}.staff-date-picker-weekday{text-align:center;font-size:.75rem;font-weight:var(--font-weight-semibold);color:var(--color-muted-strong)}.staff-date-picker-grid{gap:4px;display:grid}.staff-date-picker-day{min-height:34px;color:var(--color-ink);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;font-size:.86rem}.staff-date-picker-day:hover:not(:disabled){background:var(--color-soft-surface)}.staff-date-picker-day-outside{color:var(--color-muted)}.staff-date-picker-day-today{border-color:var(--color-primary)}.staff-date-picker-day-selected{background:var(--color-primary);color:#fff;font-weight:var(--font-weight-semibold)}.staff-date-picker-day-selected.staff-date-picker-day-today{border-color:var(--color-primary)}.staff-form-grid{grid-template-columns:repeat(4,minmax(150px,1fr));align-items:end;gap:12px;margin-top:18px;display:grid}.staff-form-grid-compact{gap:10px}.staff-form-wide{grid-column:span 2}.staff-list{gap:10px;margin-top:16px;display:grid}.staff-card{border:1px solid var(--color-line);border-radius:var(--radius-md);min-width:0;color:inherit;background:#fff;padding:12px}.staff-appointment-card{grid-template-columns:112px minmax(0,1fr) auto;align-items:start;gap:14px;display:grid}.staff-appointment-time h3,.staff-card p,.staff-card-title{margin:0}.staff-appointment-time h3{margin-bottom:8px;font-size:1.55rem}.staff-card p,.staff-patient-link span:not(.staff-card-title){color:var(--color-muted-strong);line-height:1.42}.staff-card-title{color:var(--color-ink);font-weight:var(--font-weight-bold);display:block}.staff-appointment-body{gap:4px;display:grid}.staff-card-tags{flex-wrap:wrap;gap:6px;display:flex}.staff-card-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.staff-reschedule-panel{border-top:1px solid var(--color-line);grid-column:1/-1;padding-top:12px}.staff-inline-form-compact{gap:8px 10px}.staff-context-note{color:var(--color-muted-strong);font-weight:var(--font-weight-medium);margin:8px 0 0;font-size:.94rem}.staff-slot-actions form{min-width:0}.staff-slot-actions .slot-button{cursor:pointer;width:100%}.staff-action{white-space:nowrap;min-height:32px;padding:0 11px;font-size:.88rem;line-height:1}.staff-action-compact{min-height:30px;padding:0 10px}.staff-action-muted{color:var(--color-muted-strong)}.staff-action-ghost{background:var(--color-soft-surface);border-color:#0000}.staff-action-ghost:hover{background:#f2ecec;border-color:#ddd4d5}.staff-row-card{grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;display:grid}.staff-confirm-form{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.staff-split{grid-template-columns:minmax(260px,.85fr) minmax(0,1.15fr);align-items:start;gap:16px;margin-top:20px;display:grid}.staff-split h2{font-size:var(--font-size-section);margin:0}.staff-patient-link{gap:5px;display:grid}.staff-patients-results{min-width:0;margin-top:20px}.staff-patient-results-table{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);margin-top:12px;overflow:hidden}.staff-patient-results-head,.staff-patient-row{grid-template-columns:minmax(180px,1.3fr) minmax(220px,1.45fr) minmax(140px,1fr) 88px;align-items:center;gap:12px;display:grid}.staff-patient-results-head{border-bottom:1px solid var(--color-line);background:var(--color-soft-surface);color:var(--color-muted-strong);font-size:.84rem;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.04em;padding:12px 16px}.staff-patient-row{border-bottom:1px solid var(--color-line);color:inherit;background:var(--color-surface);padding:14px 16px}.staff-patient-row:last-child{border-bottom:0}.staff-patient-row:hover{background:#f7f3f3}.staff-patient-cell{min-width:0;color:var(--color-muted-strong);overflow-wrap:anywhere;line-height:1.4}.staff-patient-cell-primary{color:var(--color-ink)}.staff-patient-cell-count{color:var(--color-ink);font-weight:var(--font-weight-semibold);text-align:right}.staff-heading-detail{gap:8px}.staff-patient-summary{gap:4px;display:grid}.staff-patient-summary p{color:var(--color-muted-strong);margin:0}.staff-patient-detail-layout{gap:16px;margin-top:20px;display:grid}.staff-patient-history{gap:12px;display:grid}.staff-patient-history h2{font-size:var(--font-size-section);margin:0}.staff-patient-history-table{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden}.staff-patient-history-head,.staff-patient-history-row{grid-template-columns:minmax(150px,1.15fr) 92px minmax(160px,1.1fr) minmax(220px,1.4fr) 100px;align-items:start;gap:12px;display:grid}.staff-patient-history-head{border-bottom:1px solid var(--color-line);background:var(--color-soft-surface);color:var(--color-muted-strong);font-size:.84rem;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.04em;padding:12px 16px}.staff-patient-history-row{border-bottom:1px solid var(--color-line);padding:14px 16px}.staff-patient-history-row:last-child{border-bottom:0}.staff-patient-history-cell{min-width:0;color:var(--color-muted-strong);overflow-wrap:anywhere;line-height:1.4}.staff-patient-history-cell-tags{gap:6px;display:grid}.staff-patient-history-cell-tags p{margin:0}.staff-detail-list{gap:8px;margin:12px 0 0;display:grid}.staff-detail-list div{grid-template-columns:minmax(120px,.45fr) minmax(0,1fr);gap:10px;display:grid}.staff-detail-list dt{color:var(--color-muted-strong);font-weight:var(--font-weight-semibold)}.staff-detail-list dd{color:var(--color-ink);margin:0}@media (max-width:760px){.public-page{padding:12px 0 40px}.public-anchor-section{scroll-margin-top:92px}.site-header{flex-wrap:nowrap;gap:12px;width:min(100% - 24px,1120px);min-height:76px}.site-header-actions{flex:none}.site-nav{display:none}.site-header-cta{min-height:var(--control-height-md);padding:0 14px}.site-brand-name{display:none}.hero-section{grid-template-columns:1fr;gap:28px;width:min(100% - 24px,1120px);min-height:auto;padding:28px 0}h1{font-size:2.6rem}.hero-lead{font-size:1.04rem}.hero-actions{grid-template-columns:1fr;display:grid}.hero-visual{min-height:220px}.public-section,.final-cta-section{width:min(100% - 24px,1120px)}.public-section{padding:28px 0}.public-card,.final-cta-panel{border-radius:var(--radius-lg);padding:24px}.final-cta-panel{flex-direction:column;align-items:stretch}.final-cta-actions .button{width:100%}.page-shell{width:min(100% - 24px,760px);padding:24px 0}.placeholder-panel{padding:24px}.placeholder-panel h1{font-size:2rem}.auth-panel{padding:24px}.auth-panel h1{font-size:2rem}.auth-grid,.account-grid{grid-template-columns:1fr}.patient-shell{width:min(100% - 24px,1120px);padding:16px 0 28px}.patient-nav{flex-direction:column;align-items:flex-start}.patient-panel{padding:22px}.patient-heading h1{font-size:2rem}.booking-layout,.calendar-stack,.appointment-card,.staff-shell,.staff-toolbar-grid,.staff-form-grid,.staff-appointment-card,.staff-row-card,.staff-split{grid-template-columns:1fr}.staff-shell{display:block}.staff-sidebar{border-right:0;border-bottom:1px solid var(--color-line);z-index:10;gap:12px;height:auto;min-height:auto;padding:12px;position:sticky;top:0;overflow:hidden}.staff-sidebar-main{gap:12px}.staff-sidebar-header{gap:10px}.staff-nav{-webkit-overflow-scrolling:touch;scrollbar-width:thin;grid-auto-columns:max-content;grid-auto-flow:column;gap:8px;padding-bottom:2px;overflow:auto hidden}.staff-nav-link{white-space:nowrap}.staff-sidebar-footer{justify-content:flex-start;display:flex}.staff-content{padding:20px 12px 28px}.staff-panel{padding:22px}.staff-heading h1{font-size:2rem}.staff-control-grow{min-width:0}.staff-form-wide,.staff-reschedule-panel{grid-column:auto}.staff-card-actions,.staff-confirm-form{justify-content:flex-start}.section-heading-row{flex-direction:column;align-items:flex-start}.section-heading-row span{text-align:left}.staff-patient-results-head,.staff-patient-row,.staff-patient-history-head,.staff-patient-history-row{grid-template-columns:1fr}.staff-patient-results-head,.staff-patient-history-head{display:none}.staff-patient-row{gap:4px}.staff-patient-cell-count{text-align:left}.calendar-toolbar{flex-direction:column;align-items:flex-start}}
