/* =================================================================
   V5 BUILD, Cosmetic Nurse Alicia, SHARED STYLES (monochrome)
   This file controls the look of ALL pages in /v5-build/.
   Edit colors, fonts, spacing here once → affects every page.
   For content text edits, open the individual .html files instead.

   Palette is intentionally black-and-white only, no gold, no
   emerald, no sand. Distinction comes from typography (italic,
   weight, size) and spacing, not color.
================================================================= */

:root{
  /* Palette, monochrome editorial */
  --black:#0a0a0a;
  --charcoal:#141414;
  --ink:#1a1a1a;
  --muted:#555555;        /* body text on light bg */
  --stone:#878787;        /* labels, metadata */
  --rule:rgba(0,0,0,.12); /* hairline dividers on light bg */
  --rule-light:rgba(255,255,255,.20); /* hairline dividers on dark bg */
  --bone:#ebebeb;         /* alt section background */
  --ivory:#f7f7f6;        /* primary page background */
  --paper:#ffffff;

  /* Fonts */
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--ivory);color:var(--ink)}
body{font-family:var(--sans);font-weight:300;-webkit-font-smoothing:antialiased;line-height:1.7;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit;transition:.3s}
em{font-style:italic}

/* ==== NAV (shared on every page) ==== */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;height:72px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:0 6vw;background:rgba(10,10,10,.78);backdrop-filter:blur(12px);
  color:rgba(255,255,255,.92)}
.brand{font-family:var(--serif);font-size:20px;font-weight:300;letter-spacing:.18em;text-transform:uppercase}
.navlinks{display:flex;gap:28px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7);white-space:nowrap}
.navlinks a{padding:8px 0}
.navlinks a:hover,.navlinks a.active{color:#fff}
.navlinks a.active{border-bottom:1px solid rgba(255,255,255,.5)}
.navcta{justify-self:end;display:inline-flex;align-items:center;justify-content:center;
  padding:10px 22px;line-height:1;
  font-size:12px;letter-spacing:.26em;text-transform:uppercase;font-weight:500;
  color:#fff;background:transparent;
  border:1.5px solid rgba(255,255,255,.55);
  transition:.25s ease}
.navcta:hover{background:#fff;color:var(--charcoal);border-color:#fff}

/* hamburger button, hidden on desktop, shown via responsive media query */
.nav-toggle{display:none;position:absolute;right:5vw;top:50%;transform:translateY(-50%);
  background:none;border:0;padding:0;cursor:pointer;
  width:32px;height:32px;flex-direction:column;justify-content:center;align-items:center;gap:6px}
.nav-toggle span{display:block;width:22px;height:1px;background:#fff;transition:transform .3s ease, opacity .2s ease}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ==== HERO ==== */
.hero{position:relative;min-height:100svh;color:var(--ivory);
  display:grid;grid-template-columns:1.05fr 1fr;align-items:end;
  padding:0;overflow:hidden;background:var(--black)}
.hero-copy{position:relative;z-index:2;padding:170px 6vw 110px;
  background:linear-gradient(180deg,rgba(10,10,10,.6) 0%,rgba(10,10,10,.88) 70%,var(--black) 100%)}
.hero-copy>div{max-width:680px}
.hero-img{position:relative;z-index:0;min-height:100svh;
  background-size:cover;background-position:center top;background-repeat:no-repeat;
  background-color:var(--black);
  filter:saturate(1) contrast(1.04)}
.hero-img:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,10,10,.6) 0%,transparent 30%)}
.dateline{display:inline-flex;align-items:center;gap:12px;font-size:15px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:36px;font-weight:500}
.dateline .dot{width:6px;height:6px;border-radius:50%;background:#fff;box-shadow:0 0 0 5px rgba(255,255,255,.18);animation:pulse 2.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
.hero h1{font-family:var(--serif);font-size:clamp(60px,7.5vw,118px);line-height:.9;font-weight:300;letter-spacing:-.035em;color:#fff}
.hero h1 em{font-style:italic;font-weight:300;color:rgba(255,255,255,.78)}
.hero .lead{margin-top:42px;font-family:var(--serif);font-size:clamp(20px,1.7vw,26px);line-height:1.5;color:rgba(255,255,255,.82);max-width:540px;font-style:italic;font-weight:300}
.hero .cta{margin-top:44px;display:flex;gap:10px;flex-wrap:wrap}
.hero .cta a{display:inline-flex;align-items:center;justify-content:center;
  padding:15px 22px;line-height:1;text-align:center;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  background:transparent;color:rgba(255,255,255,.95);
  border:1.5px solid rgba(255,255,255,.6);
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  white-space:nowrap}
.hero .cta a:hover{background:#fff;color:var(--charcoal);border-color:#fff;transform:translateY(-2px)}
.hero .cta a.primary{background:#fff;color:var(--charcoal);border-color:#fff}
.hero .cta a.primary:hover{background:transparent;color:#fff;border-color:#fff}

/* ==== PAGE HEADER (smaller hero for non-home pages) ==== */
.page-header{padding:160px 6vw 90px;background:var(--black);color:var(--ivory);text-align:left}
.page-header .label{font-size:12px;letter-spacing:.36em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:24px}
.page-header h1{font-family:var(--serif);font-size:clamp(52px,7vw,104px);line-height:.95;font-weight:300;letter-spacing:-.035em;color:#fff;max-width:14ch}
.page-header h1 em{font-style:italic;color:rgba(255,255,255,.78)}
.page-header p{margin-top:32px;font-family:var(--serif);font-style:italic;font-size:clamp(20px,1.7vw,26px);line-height:1.5;color:rgba(255,255,255,.78);max-width:640px;font-weight:300}
.page-header p.context{margin-top:24px;font-family:var(--serif);font-style:normal;font-size:clamp(17px,1.4vw,21px);line-height:1.65;color:rgba(255,255,255,.62);font-weight:300;letter-spacing:.005em;max-width:640px}

/* ==== SECTION BASE ==== */
section{padding:130px 7vw}
.section-label{font-size:12px;letter-spacing:.36em;text-transform:uppercase;color:var(--stone);font-weight:500;margin-bottom:24px}
.display{font-family:var(--serif);font-size:clamp(44px,5.6vw,86px);line-height:.96;font-weight:300;letter-spacing:-.035em;color:var(--charcoal);max-width:18ch}
.display em{font-style:italic;color:var(--charcoal)}

/* ==== TWO-COL CONTENT (label/heading | copy) ==== */
.two-col .grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:9vw;align-items:start}
.two-col .copy p{font-size:18px;line-height:1.85;color:var(--muted);margin-bottom:24px;font-weight:300}
.two-col .copy p:last-child{margin-bottom:0}
.two-col .copy strong{font-weight:400;color:var(--charcoal)}
.two-col .pull{margin-top:80px;padding-left:32px;border-left:1px solid var(--charcoal);font-family:var(--serif);font-size:clamp(28px,3.2vw,44px);line-height:1.18;color:var(--charcoal);font-weight:300;letter-spacing:-.02em;font-style:italic}
.two-col .pull-credit{display:block;margin-top:22px;font-family:var(--sans);font-size:13px;letter-spacing:.26em;text-transform:uppercase;color:var(--stone);font-style:normal;font-weight:500}

/* alt backgrounds */
.bg-bone{background:var(--bone)}
.bg-ivory{background:var(--ivory)}
.bg-paper{background:var(--paper)}
.bg-charcoal{background:var(--black);color:var(--ivory)}

/* ==== SERVICES LIST (collapsible) ==== */
.services .intro{max-width:760px;margin-bottom:96px}
.services .intro h2{font-family:var(--serif);font-size:clamp(40px,5vw,72px);line-height:1;font-weight:300;letter-spacing:-.03em;color:var(--charcoal);max-width:18ch}
.services .intro h2 em{font-style:italic;color:var(--charcoal)}
.services .intro p{margin-top:28px;font-size:18px;line-height:1.85;color:var(--muted);max-width:580px}
.services-list{border-top:1px solid var(--rule);max-width:1100px}
.svc{border-bottom:1px solid var(--rule);padding:0}
.svc summary{list-style:none;display:grid;grid-template-columns:auto 1fr auto;gap:36px;align-items:baseline;padding:38px 0;cursor:pointer}
.svc summary::-webkit-details-marker{display:none}
.svc .svc-num{font-family:var(--serif);font-size:18px;color:var(--stone);font-style:italic;line-height:1}
.svc .svc-title{font-family:var(--serif);font-size:clamp(26px,2.4vw,36px);line-height:1.1;color:var(--charcoal);font-weight:300}
.svc .svc-title sup{font-size:13px;color:var(--stone);font-weight:500;vertical-align:super;margin-left:2px}
.svc .svc-toggle{display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border:1px solid var(--rule);border-radius:50%;
  font-family:var(--serif);font-size:24px;font-weight:300;line-height:1;color:var(--charcoal);
  transition:.25s ease}
.svc summary:hover .svc-toggle{background:var(--charcoal);color:#fff;border-color:var(--charcoal)}
.svc[open] .svc-toggle{background:var(--charcoal);color:#fff;border-color:var(--charcoal)}
.svc[open] .svc-toggle:before{content:"\2212"} /* minus */
.svc:not([open]) .svc-toggle:before{content:"+"}
.svc .svc-body{padding:0 0 44px 72px;max-width:680px}
.svc .svc-body .summary-line{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--charcoal);margin-bottom:18px}
.svc .svc-body ul{list-style:none;padding:0;margin:0}
.svc .svc-body li{font-size:18px;line-height:1.85;color:var(--muted);padding-left:24px;position:relative}
.svc .svc-body li:before{content:",";position:absolute;left:0;color:var(--charcoal)}
.svc .svc-body .areas{margin-top:18px;font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone)}

/* category section header inside the services list */
.svc-category{padding:64px 0 36px;max-width:820px}
.svc-category h3{font-family:var(--serif);font-size:clamp(28px,3vw,40px);font-weight:300;color:var(--charcoal);letter-spacing:-.015em;margin-bottom:24px}
.svc-category p{font-size:18px;line-height:1.85;color:var(--muted);margin-bottom:14px;font-weight:300}
.svc-category-footer{padding:16px 0 28px;max-width:820px;border-bottom:1px solid var(--rule);margin-bottom:8px}
.svc-category-footer p{font-size:18px;line-height:1.85;color:var(--muted);font-style:italic}

/* "Includes consideration of: ..." list */
.includes{margin-top:22px}
.includes-label{display:block;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone);margin-bottom:10px}
.includes ul{list-style:none;padding:0;margin:0}
.includes li{font-size:17px;line-height:1.8;color:var(--ink);padding-left:18px;position:relative}
.includes li:before{content:"·";position:absolute;left:0;color:var(--charcoal);font-size:22px;line-height:1.4}

/* small inline note (e.g. Botulinum included) */
.svc-note{margin-top:24px;padding:14px 18px;background:rgba(0,0,0,.03);border-left:2px solid var(--charcoal);font-size:15px;line-height:1.7;color:var(--muted);font-style:italic}

/* nested sub-services inside a parent card (Feature Refinement, Maintenance) */
.sub-service{margin-top:26px;padding-top:22px;border-top:1px solid var(--rule)}
.sub-service h4{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--charcoal);margin-bottom:10px;letter-spacing:-.005em}
.sub-service h4 sup{font-size:12px;color:var(--stone);font-weight:500;vertical-align:super;margin-left:1px}
.sub-service .sub-desc{font-size:17px;line-height:1.8;color:var(--muted);margin-bottom:0}

/* inline CTA button, for contact cards & content callouts */
.btn-text{display:inline-flex;align-items:center;gap:10px;
  padding:12px 24px;line-height:1;
  font-size:13px;letter-spacing:.26em;text-transform:uppercase;font-weight:500;
  background:transparent;color:var(--charcoal);
  border:1.5px solid var(--charcoal);
  transition:.25s ease;margin-top:18px}
.btn-text:hover{background:var(--charcoal);color:#fff;transform:translateY(-1px)}
.btn-text.btn-filled{background:var(--charcoal);color:#fff}
.btn-text.btn-filled:hover{background:transparent;color:var(--charcoal)}

/* contact form modal overlay */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:100;
  display:none;align-items:flex-start;justify-content:center;
  padding:60px 20px;overflow-y:auto;backdrop-filter:blur(6px);
  animation:fadeIn .25s ease}
.modal-overlay.open{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-content{background:#ffffff;max-width:880px;width:100%;
  padding:72px 8vw 60px;position:relative;margin:auto;
  border:1px solid rgba(0,0,0,.10);
  outline:3px solid var(--charcoal);
  outline-offset:8px;
  box-shadow:0 30px 80px -10px rgba(0,0,0,.45),
             0 10px 28px -10px rgba(0,0,0,.25);
  animation:slideUp .35s ease}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-close{position:absolute;top:18px;right:22px;
  background:none;border:none;font-size:34px;color:var(--charcoal);
  cursor:pointer;line-height:1;padding:6px 12px;font-weight:300;
  transition:.2s;font-family:var(--sans);z-index:2}
.modal-close:hover{opacity:.5;transform:rotate(90deg)}
body.modal-open{overflow:hidden}
@media(max-width:900px){
  .modal-overlay{padding:28px 22px}
  .modal-content{padding:56px 28px 40px;margin:0;max-width:100%;
    outline-width:2px;outline-offset:5px}
  .modal-close{top:14px;right:16px;font-size:30px}
}

/* contact page: FAQ accordion */
.faq-list{max-width:820px;margin:0 auto;border-top:1px solid var(--charcoal)}
.faq-row{border-bottom:1px solid var(--rule)}
.faq-row summary{list-style:none;display:flex;justify-content:space-between;align-items:baseline;
  gap:24px;padding:26px 0;cursor:pointer;
  font-family:var(--serif);font-size:clamp(20px,1.9vw,26px);font-weight:300;color:var(--charcoal);
  letter-spacing:-.005em;line-height:1.3}
.faq-row summary::-webkit-details-marker{display:none}
.faq-row summary:after{content:"+";font-family:var(--sans);font-size:26px;color:var(--charcoal);font-weight:300;flex-shrink:0;line-height:1;transition:transform .25s}
.faq-row[open] summary:after{content:"\2212"}
.faq-row .faq-body{padding:0 0 28px;max-width:680px}
.faq-row .faq-body p{font-size:18px;line-height:1.85;color:var(--muted);font-weight:300}
.faq-row .faq-body p strong{color:var(--charcoal);font-weight:400}
.faq-row summary:hover{color:#000}
@media (max-width:900px){
  .faq-row summary{font-size:18px;padding:22px 0;gap:14px}
  .faq-row summary:after{font-size:22px}
  .faq-row .faq-body p{font-size:17px}
}

/* contact page: two-column path cards (New Clients / Existing Clients) */
.contact-paths{display:grid;grid-template-columns:1fr 1fr;gap:40px;max-width:1100px;margin:0 auto;align-items:stretch}
.contact-path{display:flex;flex-direction:column;padding:48px 40px;background:var(--paper);border:1px solid var(--rule)}
.contact-path .section-label{display:inline-block;width:fit-content;padding:9px 18px;margin-bottom:24px;
  background:var(--charcoal);color:#fff;
  font-size:13px;letter-spacing:.28em;text-transform:uppercase;font-weight:500}
.contact-path h3{font-family:var(--serif);font-size:clamp(28px,3vw,40px);font-weight:300;letter-spacing:-.015em;color:var(--charcoal);margin:0 0 20px;line-height:1.1}
.contact-path h3 em{font-style:italic}
.contact-path p{font-size:18px;line-height:1.85;color:var(--muted);font-weight:300;margin-bottom:18px}
.contact-checklist{list-style:none;padding:0;margin:18px 0 24px;border-top:1px solid var(--rule);padding-top:18px}
.contact-checklist li{font-size:17px;line-height:1.95;color:var(--ink);padding-left:22px;position:relative;font-weight:300}
.contact-checklist li:before{content:"·";position:absolute;left:0;color:var(--charcoal);font-size:24px;line-height:1.3}
.contact-path-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:auto;padding-top:24px}
.contact-path-buttons .btn-text{margin-top:0}

@media (max-width:900px){
  .contact-paths{grid-template-columns:1fr;gap:24px}
  .contact-path{padding:36px 26px}
}

/* maintenance pathways list (compact) */
.pathway{margin-top:14px;padding-left:18px;border-left:1px solid var(--rule)}
.pathway-name{display:block;font-family:var(--serif);font-size:19px;color:var(--charcoal);font-weight:400;margin-bottom:4px}
.pathway p{font-size:16px;line-height:1.7;color:var(--muted)}

/* ==== CALENDAR / WHERE TO FIND ME (under hero) ==== */
.calendar-section{padding:90px 7vw;background:var(--bone);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.calendar-section .section-label{margin-bottom:14px}
.calendar-section h2{font-family:var(--serif);font-size:clamp(42px,5vw,68px);line-height:1;font-weight:300;letter-spacing:-.025em;color:var(--charcoal);margin-bottom:48px}
.calendar-section h2 em{font-style:italic}

.calendar-current{display:flex;align-items:center;gap:18px;padding:22px 28px;background:var(--charcoal);color:var(--ivory);max-width:fit-content;margin-bottom:32px;flex-wrap:wrap}
.calendar-current .cur-dot{width:10px;height:10px;border-radius:50%;background:#fff;box-shadow:0 0 0 6px rgba(255,255,255,.2);animation:pulse 2.6s ease-in-out infinite;flex-shrink:0}
.calendar-current .cur-label{font-size:13px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.7);font-weight:500}
.calendar-current .cur-loc{font-family:var(--serif);font-size:24px;font-weight:400;color:#fff;letter-spacing:-.005em}

/* month grouping */
.calendar-month-group{max-width:1000px;margin-bottom:48px}
.calendar-month-group:last-of-type{margin-bottom:24px}
.calendar-month{font-family:var(--serif);font-size:clamp(34px,3.6vw,52px);font-weight:300;letter-spacing:-.02em;color:var(--charcoal);margin:0 0 8px;padding-bottom:14px;border-bottom:1px solid var(--charcoal)}

.calendar-list{max-width:1000px}
.calendar-item{display:grid;grid-template-columns:minmax(80px,120px) 1fr;gap:32px;align-items:baseline;padding:20px 4px;border-bottom:1px solid var(--rule)}
.calendar-item:last-child{border-bottom:none}
.calendar-date{font-family:var(--serif);font-size:clamp(24px,2.2vw,30px);font-weight:400;color:var(--charcoal);letter-spacing:-.01em;line-height:1.1}
.calendar-location{font-family:var(--sans);font-size:14px;letter-spacing:.2em;text-transform:uppercase;color:var(--charcoal);font-weight:500}
.calendar-status{display:none}
.status-soldout{background:var(--charcoal);color:#fff;border:1px solid var(--charcoal)}
.status-accepting{border:1px solid var(--charcoal);color:var(--charcoal);background:var(--paper)}
.status-consult{border:1px solid var(--charcoal);color:var(--charcoal);background:var(--paper)}
.status-tba{color:var(--stone);font-style:italic;letter-spacing:.18em;background:transparent;border:1px solid var(--rule)}

@media (max-width:900px){
  .calendar-section{padding:64px 6vw}
  .calendar-current{padding:18px 22px;gap:14px}
  .calendar-current .cur-loc{font-size:20px}
  .calendar-item{grid-template-columns:1fr;gap:6px;padding:18px 0}
  .calendar-date{font-size:24px}
  .calendar-month{font-size:30px}
}

/* ==== TEAM (medical director + concierge) ==== */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:60px;max-width:900px}
.team-card{display:flex;flex-direction:column;gap:24px}
.team-photo{aspect-ratio:4/5;background-size:cover;background-position:center top;background-color:#1a1a1a}
.team-info .role{display:block;font-size:13px;letter-spacing:.26em;text-transform:uppercase;color:var(--stone);margin-bottom:12px}
.team-info h3{font-family:var(--serif);font-size:clamp(24px,2.2vw,32px);font-weight:300;color:var(--charcoal);letter-spacing:-.01em;margin-bottom:14px}
.team-info p{font-size:17px;line-height:1.8;color:var(--muted);font-weight:300}

@media (max-width:900px){
  .team-grid{grid-template-columns:1fr;gap:48px}
}

/* ==== BIO / MEDICAL LEADERSHIP ==== */
.bio-lead{font-family:var(--serif);font-style:italic;font-size:clamp(22px,2vw,30px);line-height:1.4;color:var(--charcoal);font-weight:300;margin:32px 0 40px;letter-spacing:-.005em;max-width:520px}
.bio-copy>p{font-size:19px;line-height:1.9;color:var(--muted);margin-bottom:28px;font-weight:300}
.bio-copy>p:last-child{margin-bottom:0}
.bio-copy strong{font-weight:400;color:var(--charcoal)}

/* credentials definition list */
.credentials{margin:56px 0;padding:32px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.credential{display:grid;grid-template-columns:1fr 1.4fr;gap:32px;padding:18px 0;border-bottom:1px solid var(--rule)}
.credential:last-child{border-bottom:none}
.credential dt{font-size:13px;letter-spacing:.26em;text-transform:uppercase;color:var(--stone);font-weight:500;align-self:start;padding-top:4px}
.credential dd{font-family:var(--serif);font-size:20px;line-height:1.35;color:var(--charcoal);font-weight:300;letter-spacing:-.005em}
.credential dd em{color:var(--muted);font-style:italic;display:block;font-size:16px;margin-top:4px;letter-spacing:0}

/* pull quote variant used in bio */
.bio-copy .pull{margin:48px 0;padding-left:32px;border-left:1px solid var(--charcoal);font-family:var(--serif);font-size:clamp(24px,2.4vw,34px);line-height:1.25;color:var(--charcoal);font-weight:300;letter-spacing:-.015em;font-style:italic;max-width:520px}

/* cities list inside bio */
.bio-cities{list-style:none;padding:0;margin:0 0 28px;
  display:grid;grid-template-columns:1fr 1fr;gap:8px 32px;max-width:480px}
.bio-cities li{font-family:var(--serif);font-size:20px;line-height:1.5;color:var(--charcoal);font-weight:400;padding-left:18px;position:relative;font-style:italic}
.bio-cities li:before{content:"·";position:absolute;left:0;color:var(--charcoal);font-size:24px;line-height:1.2;font-style:normal}

/* bio closing signature line */
.bio-signature{margin-top:40px;font-family:var(--serif);font-style:italic;
  font-size:clamp(22px,2vw,28px);line-height:1.3;color:var(--charcoal);
  letter-spacing:.04em;padding-top:24px;border-top:1px solid var(--rule)}

@media (max-width:900px){
  .bio-cities{grid-template-columns:1fr;gap:6px}
}

@media (max-width:900px){
  .credential{grid-template-columns:1fr;gap:8px}
  .credentials{margin:40px 0;padding:24px 0}
}

/* ==== STAT NUMBERS (numbered credentials) ==== */
.stats{margin-top:80px;display:grid;grid-template-columns:repeat(3,1fr);gap:34px 60px;padding-top:48px;border-top:1px solid var(--rule)}
.stat span{display:block;font-family:var(--serif);font-size:48px;line-height:1;color:var(--charcoal);font-weight:300}
.stat p{margin-top:10px;font-size:13px;letter-spacing:.26em;text-transform:uppercase;color:var(--stone);font-weight:400}

/* ==== LOCATIONS ==== */
.locations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px;margin-top:60px}
.location{padding:36px;border:1px solid var(--rule);background:var(--paper)}
.location .loc-flag{font-size:22px;margin-bottom:12px;color:var(--charcoal)}
.location h3{font-family:var(--serif);font-size:24px;color:var(--charcoal);font-weight:400;margin-bottom:12px}
.location p{font-size:17px;line-height:1.7;color:var(--muted)}

/* ==== TREATMENTS CATALOG (editorial numbered menu) ==== */
.treatments-catalog{margin-top:60px;display:grid;grid-template-columns:1fr 1fr;gap:64px}
.catalog-group{}
.catalog-heading{font-family:var(--serif);font-size:clamp(24px,2.4vw,32px);font-weight:300;color:var(--charcoal);letter-spacing:-.01em;margin-bottom:8px;padding-bottom:20px;border-bottom:1px solid var(--charcoal)}
.catalog-list{margin-top:0}
.catalog-item{display:grid;grid-template-columns:36px 1fr;gap:24px;padding:26px 0;border-bottom:1px solid var(--rule);align-items:start}
.catalog-item:last-child{border-bottom:none}
.catalog-num{font-family:var(--serif);font-size:16px;font-style:italic;color:var(--stone);font-weight:400;padding-top:6px;letter-spacing:.02em}
.catalog-item h4{font-family:var(--serif);font-size:clamp(20px,1.9vw,24px);font-weight:300;color:var(--charcoal);letter-spacing:-.005em;margin-bottom:8px;line-height:1.25}
.catalog-item h4 sup{font-size:12px;color:var(--stone);font-weight:500;vertical-align:super;margin-left:1px}
.catalog-item .catalog-desc{font-size:16px;line-height:1.75;color:var(--muted);font-weight:300;margin-top:6px}
.catalog-item .catalog-meta{display:block;margin-top:8px;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone)}

/* legacy class kept as alias if anything still uses it */
.treatments-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:50px}

@media (max-width:900px){
  .treatments-catalog{grid-template-columns:1fr;gap:48px}
}

/* ==== CONSULTATION CTA ==== */
.consult{background:var(--black);color:var(--ivory);text-align:center}
.consult .label{color:rgba(255,255,255,.6)}
.consult h2{font-family:var(--serif);font-size:clamp(40px,5vw,72px);line-height:1.05;font-weight:300;letter-spacing:-.03em;color:#fff;max-width:18ch;margin:0 auto}
.consult h2 em{font-style:italic;color:rgba(255,255,255,.78)}
.consult p{margin-top:32px;font-size:18px;line-height:1.85;color:rgba(255,255,255,.72);max-width:520px;margin-left:auto;margin-right:auto}
.consult .cta-row{margin-top:56px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.consult .cta-row a{display:inline-flex;align-items:center;justify-content:center;
  padding:18px 36px;line-height:1;text-align:center;
  font-size:13px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  background:transparent;color:rgba(255,255,255,.92);
  border:1.5px solid rgba(255,255,255,.55);
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease}
.consult .cta-row a:hover{background:#fff;color:var(--charcoal);border-color:#fff;transform:translateY(-2px)}
.consult .cta-row a.primary{background:#fff;color:var(--charcoal);border-color:#fff}
.consult .cta-row a.primary:hover{background:transparent;color:#fff;border-color:#fff}

/* ==== CONTACT FORM ==== */
.contact-form{max-width:680px;margin:56px auto 0}
.contact-form .form-required-note{text-align:center;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone);margin:0 0 40px;font-weight:500}
.contact-form .form-required-note .req{margin:0 4px 0 0}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:36px}
.contact-form > div{margin-bottom:36px}
.contact-form > div:last-of-type{margin-bottom:0}
.contact-form label{display:block;font-size:16px;letter-spacing:.12em;text-transform:uppercase;color:var(--charcoal);margin-bottom:14px;font-weight:600}
.contact-form .req{color:var(--charcoal);font-weight:600;font-family:var(--sans);font-size:1em;letter-spacing:0;display:inline-block;margin-left:2px}
/* radio-group: Yes/No, Nurse/Doctor selectors */
.contact-form .radio-group{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.contact-form .radio-option{position:relative;cursor:pointer;display:block}
.contact-form .radio-option input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.contact-form .radio-option span{display:block;padding:20px 16px;text-align:center;border:1.5px solid var(--rule);background:#fff;font-family:var(--sans);font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);font-weight:500;transition:.2s}
.contact-form .radio-option:hover span{border-color:var(--charcoal);color:var(--charcoal)}
.contact-form .radio-option input:checked + span{background:var(--charcoal);color:#fff;border-color:var(--charcoal)}
.contact-form .radio-option input:focus-visible + span{outline:2px solid var(--charcoal);outline-offset:3px}
/* form-note: explanatory block (e.g. when 'No' to medical pro) */
.contact-form .form-note{padding:20px 24px;background:rgba(20,20,20,.04);border-left:3px solid var(--charcoal);font-size:14px;line-height:1.7;color:var(--charcoal);font-style:italic;margin:0}
.contact-form input,
.contact-form textarea,
.contact-form select{width:100%;padding:18px 0;border:none;border-bottom:1.5px solid var(--charcoal);background:transparent;font-family:var(--sans);font-size:20px;color:var(--charcoal);font-weight:400;transition:.3s}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:var(--stone);font-weight:300;font-style:italic}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus{outline:none;border-bottom-color:var(--charcoal);border-bottom-width:2px}

/* select: native arrow + match form look */
.contact-form select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23141414' stroke-width='1.5'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 6px center;background-size:18px;padding-right:32px}

/* file upload field */
.contact-form .file-field{margin-top:0}
.contact-form .file-field .help{font-size:15px;color:var(--muted);line-height:1.7;margin-top:10px;font-style:italic}
.contact-form input[type="file"]{padding:20px 16px;font-size:16px;border:1px dashed var(--rule);background:rgba(0,0,0,.02);cursor:pointer}
.contact-form input[type="file"]::file-selector-button{
  margin-right:14px;padding:10px 16px;border:1px solid var(--charcoal);
  background:var(--charcoal);color:#fff;
  font-family:var(--sans);font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  cursor:pointer;transition:.2s}
.contact-form input[type="file"]::file-selector-button:hover{background:transparent;color:var(--charcoal)}
.contact-form .file-required{display:none}
.contact-form .file-required.show{display:block}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form button[type="submit"]{display:block;margin:32px auto 0;background:var(--charcoal);color:#fff;border:none;padding:22px 72px;font-family:var(--sans);font-size:15px;letter-spacing:.28em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:.3s;min-width:280px}
.contact-form button[type="submit"]:hover{background:#000;transform:translateY(-1px)}
@media(max-width:600px){
  .contact-form .row{grid-template-columns:1fr;gap:0;margin-bottom:0}
  .contact-form > div{margin-bottom:28px}
  .contact-form button[type="submit"]{width:100%;min-width:0;padding:20px 24px}
}

/* ==== BLOG ==== */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:48px;margin-top:60px}
.blog-card{background:var(--paper);border:1px solid var(--rule);transition:.3s}
.blog-card:hover{transform:translateY(-2px);border-color:var(--charcoal)}
.blog-card .thumb{aspect-ratio:4/3;background-size:cover;background-position:center}
.blog-card .body{padding:32px}
.blog-card .meta{font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone);margin-bottom:14px}
.blog-card h3{font-family:var(--serif);font-size:24px;line-height:1.25;font-weight:400;color:var(--charcoal);margin-bottom:14px}
.blog-card p{font-size:17px;line-height:1.75;color:var(--muted)}
.blog-card .read-more{display:inline-block;margin-top:18px;font-size:13px;letter-spacing:.26em;text-transform:uppercase;color:var(--charcoal);padding-bottom:4px;border-bottom:1px solid var(--charcoal)}

/* ==== BLOG POST (single article) ==== */
.article{max-width:720px;margin:0 auto;padding:130px 6vw}
.article .meta{font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone);margin-bottom:24px}
.article h1{font-family:var(--serif);font-size:clamp(40px,5.2vw,68px);line-height:1.05;font-weight:300;letter-spacing:-.02em;color:var(--charcoal);margin-bottom:40px}
.article .hero-img-inline{aspect-ratio:4/3;background-size:cover;background-position:center 65%;margin-bottom:48px}
.article .article-img-inline{display:block;width:100%;height:auto;margin:48px 0}
.article .lyrical{font-family:var(--serif);font-style:italic;font-size:clamp(20px,1.9vw,26px);line-height:1.55;color:var(--charcoal);font-weight:300;margin-bottom:28px}
.article p{font-size:18px;line-height:1.85;color:var(--ink);margin-bottom:28px;font-weight:300}
.article p strong{font-weight:400;color:var(--charcoal)}
.article h2{font-family:var(--serif);font-size:32px;font-weight:300;color:var(--charcoal);margin-top:48px;margin-bottom:20px;letter-spacing:-.01em}

/* ==== PORTRAITS (used across pages), full color ==== */
.bio-portrait,.bbl-img,.consult-portrait{filter:none}

/* ==== FOOTER ==== */
footer{background:var(--black);color:rgba(255,255,255,.6);padding:80px 6vw 40px;border-top:1px solid rgba(255,255,255,.08)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px;max-width:1300px}
.footer-brand .brand-name{font-family:var(--serif);font-size:22px;letter-spacing:.16em;text-transform:uppercase;color:#fff;font-weight:300;margin-bottom:20px}
.footer-brand .brand-tagline{font-family:var(--serif);font-style:italic;font-size:18px;color:rgba(255,255,255,.55);max-width:280px;line-height:1.5}
.footer-col-label{display:block;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:18px;font-weight:500}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{font-size:14px;line-height:2.1;color:rgba(255,255,255,.7);font-weight:300}
.footer-col li a{color:rgba(255,255,255,.7);transition:.25s}
.footer-col li a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;padding-top:28px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.footer-bottom a{color:rgba(255,255,255,.55)}
.footer-bottom a:hover{color:#fff}

@media (max-width:900px){
  footer{padding:60px 6vw 30px}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px;margin-bottom:40px}
  .footer-brand{grid-column:1 / -1;margin-bottom:8px}
  .footer-bottom{font-size:10px;letter-spacing:.18em}
}

/* ==== TRAINING BANNER (About page) ==== */
.training-banner{padding:72px 7vw;background:var(--ivory);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.training-content{max-width:1100px;display:grid;grid-template-columns:1.6fr auto;gap:56px;align-items:center}
.training-banner .section-label{margin-bottom:14px}
.training-banner h2{font-family:var(--serif);font-size:clamp(28px,3vw,42px);font-weight:300;letter-spacing:-.015em;color:var(--charcoal);margin:0 0 16px;line-height:1.15}
.training-banner h2 em{font-style:italic}
.training-banner p{font-size:17px;line-height:1.8;color:var(--muted);font-weight:300;max-width:600px}
.training-banner .btn-text{white-space:nowrap}

@media (max-width:900px){
  .training-banner{padding:56px 6vw}
  .training-content{grid-template-columns:1fr;gap:24px}
}

/* ==== RESPONSIVE ==== */
@media (max-width: 900px){
  .nav{grid-template-columns:1fr;padding:0 5vw;height:64px}
  .navcta{display:none}
  .nav-toggle{display:flex}
  /* mobile drawer, slides down from under the fixed nav */
  .navlinks{display:flex;flex-direction:column;
    position:fixed;top:64px;left:0;right:0;
    max-height:calc(100vh - 64px);overflow-y:auto;
    padding:32px 8vw 60px;gap:4px;
    background:rgba(10,10,10,.97);backdrop-filter:blur(20px);
    transform:translateY(-110%);opacity:0;visibility:hidden;
    transition:transform .35s ease, opacity .2s ease;z-index:40;white-space:normal}
  body.nav-open .navlinks{transform:translateY(0);opacity:1;visibility:visible}
  .navlinks a{font-size:15px;letter-spacing:.18em;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.1)}
  .navlinks a.active{color:#fff;border-bottom-color:rgba(255,255,255,.4)}
  body.nav-open{overflow:hidden}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-img{min-height:52svh;order:-1;background-position:center 24px !important}
  .hero-copy{padding:48px 6vw 72px}
  .dateline{font-size:14px;margin-bottom:24px}
  .page-header{padding:120px 6vw 70px}
  section{padding:90px 6vw}
  .two-col .grid{grid-template-columns:1fr;gap:50px}
  .two-col .pull{margin-top:40px}
  .svc summary{grid-template-columns:auto 1fr auto;gap:16px;padding:28px 0}
  .svc .svc-num{font-size:16px}
  .svc .svc-title{font-size:20px}
  .svc .svc-toggle{justify-self:end;width:36px;height:36px;flex-shrink:0}
  .svc .svc-body{padding-left:0}
  .stats{grid-template-columns:1fr;gap:30px}
  .locations-grid{grid-template-columns:1fr}
  .treatments-grid{grid-template-columns:1fr;gap:50px}
  .treatments-catalog{gap:40px}
  .catalog-item{grid-template-columns:28px 1fr;gap:14px;padding:20px 0}
  .catalog-num{font-size:15px;padding-top:4px}
  .catalog-item h4{font-size:19px}
  .contact-form .row{grid-template-columns:1fr}
  .hero .cta{gap:10px;flex-direction:column;align-items:stretch}
  .hero .cta a{width:100%;padding:16px 24px;font-size:13px}
  .consult .cta-row{gap:12px;flex-direction:column;align-items:stretch}
  .consult .cta-row a{width:100%;max-width:340px;margin:0 auto;padding:16px 24px}
  .svc-category{padding:48px 0 24px}
  .svc-note{padding:12px 14px;font-size:15px}
}
