/* ===== Tokens ===== */
:root{
  --ink:        #21142F;
  --purple:     #4B1F73;
  --purple-deep:#2A0F49;
  --purple-soft:#7C4DA8;
  --lemon:      #C9DE1E;
  --lemon-deep: #8FA013;
  --cream:      #FBF8F2;
  --lilac:      #F2EAF9;
  --white:      #FFFFFF;
  --line:       rgba(33,20,47,0.12);

  --font-display: 'Space Grotesk', sans-serif;
  --font-body: 'Inter', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;

  --max: 1180px;
  --pad: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
section{ padding: clamp(56px,9vw,120px) 0; }
.wrap{ max-width:var(--max); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }
.eyebrow{
  font-family:var(--font-mono);
  font-size:0.72rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--purple);
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.eyebrow::before{
  content:"";
  width:18px; height:1px;
  background:var(--lemon-deep);
  display:inline-block;
}
h1,h2,h3{ font-family:var(--font-display); font-weight:600; color:var(--ink); }
h2{ font-size:clamp(1.7rem,3.4vw,2.6rem); letter-spacing:-0.01em; }
.lede{ font-size:clamp(1rem,1.4vw,1.15rem); color:#4a3a5c; max-width:640px; }

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 26px;
  border-radius:3px;
  font-family:var(--font-body); font-weight:600; font-size:0.95rem;
  border:1.5px solid transparent;
  transition: transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn-primary{ background:var(--lemon); color:var(--purple-deep); }
.btn-primary:hover{ transform:translateY(-2px); background:#d8ec3a; }
.btn-outline{ border-color:rgba(255,255,255,0.4); color:var(--white); }
.btn-outline:hover{ border-color:var(--white); background:rgba(255,255,255,0.08); }
.btn-dark-outline{ border-color:var(--purple); color:var(--purple); }
.btn-dark-outline:hover{ background:var(--purple); color:var(--white); }
@media (prefers-reduced-motion: reduce){
  .btn{ transition:none; }
  html{ scroll-behavior:auto; }
}

/* ===== Nav ===== */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(251,248,242,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; padding-top:16px; padding-bottom:16px; }
.logo{ display:flex; align-items:center; gap:10px; }
.logo-img{ height:40px; width:auto; display:block; }
footer .logo-img{ background:var(--white); padding:10px 16px; border-radius:4px; }
.nav-links{ display:flex; align-items:center; gap:32px; }
.nav-links a{ font-size:0.92rem; font-weight:500; color:var(--ink); position:relative; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-4px; width:0; height:1.5px; background:var(--purple); transition:width .2s ease; }
.nav-links a:hover::after{ width:100%; }
.nav-links a.active{ color:var(--purple); font-weight:700; }
.nav-links a.active::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-cta .btn{ padding:10px 18px; font-size:0.85rem; }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle span{ display:block; width:22px; height:2px; background:var(--ink); margin:5px 0; transition:.2s; }

@media (max-width: 860px){
  .nav-links{
    position:fixed; inset:0 0 0 30%; top:64px; left:auto;
    background:var(--white); flex-direction:column; align-items:flex-start;
    padding:32px 28px; gap:22px; transform:translateX(100%);
    transition:transform .25s ease; box-shadow:-8px 0 30px rgba(0,0,0,0.08);
    width:70%; height:calc(100vh - 64px);
  }
  .nav-links.open{ transform:translateX(0); }
  .nav-toggle{ display:block; }
}

/* ===== Page header (non-home pages) ===== */
.page-header{
  background: linear-gradient(160deg, var(--purple) 0%, var(--purple-deep) 100%);
  color: var(--white);
  padding: 56px 0 64px;
}
.page-header .eyebrow{ color: var(--lemon); }
.page-header .eyebrow::before{ background: var(--lemon); }
.page-header h1{ color: var(--white); margin-top:14px; font-size: clamp(2rem,4vw,2.8rem); }
.page-header p{ color: rgba(255,255,255,0.78); margin-top:14px; max-width:560px; }

/* ===== Hero (home only) — full-bleed photo ===== */
.hero{
  position:relative;
  overflow:hidden;
  color:var(--white);
  padding-top:clamp(90px,14vw,150px);
  padding-bottom:clamp(70px,11vw,120px);
  min-height:560px;
  display:flex;
  align-items:center;
}
.hero-bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 35%;
  z-index:0;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(100deg, var(--purple-deep) 0%, rgba(42,15,73,0.94) 30%, rgba(42,15,73,0.72) 52%, rgba(42,15,73,0.38) 75%, rgba(42,15,73,0.18) 100%),
    linear-gradient(0deg, rgba(20,8,38,0.55) 0%, rgba(20,8,38,0) 35%);
  z-index:1;
}
.hero .wrap{ position:relative; z-index:2; }
.hero-content{ max-width:640px; }
.hero-eyebrow{ color:var(--lemon); }
.hero-eyebrow::before{ background:var(--lemon); }
.hero h1{ color:var(--white); font-size:clamp(2.3rem,5.4vw,3.8rem); line-height:1.04; margin-top:18px; letter-spacing:-0.02em; font-weight:700; }
.hero .tagline{ font-style:italic; font-weight:500; color:var(--lemon); display:block; font-size:0.5em; margin-top:10px; letter-spacing:0; }
.hero p.lede{ color:rgba(255,255,255,0.86); margin-top:22px; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }
.hero-badges{ display:flex; gap:28px; margin-top:48px; flex-wrap:wrap; }
.hero-badge b{ display:block; font-family:var(--font-display); font-weight:700; font-size:1.5rem; color:var(--lemon); }
.hero-badge span{ font-size:0.78rem; color:rgba(255,255,255,0.7); }

@media (max-width: 700px){
  .hero{ min-height:480px; align-items:flex-end; }
  .hero::before{
    background:
      linear-gradient(180deg, rgba(42,15,73,0.55) 0%, rgba(42,15,73,0.88) 55%, var(--purple-deep) 100%);
  }
  .hero-content{ max-width:100%; }
}

/* ===== About ===== */
.about .wrap{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:56px; align-items:start; }
.about-photo{
  aspect-ratio:4/5; border-radius:4px; overflow:hidden;
  background:linear-gradient(160deg,var(--lilac),var(--white));
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  position:relative;
}
.about-photo img{ width:100%; height:100%; object-fit:cover; object-position:center 20%; display:block; }
.about-photo .ph-icon{ width:64px; height:64px; color:var(--purple-soft); opacity:0.5; }
.about-photo .ph-label{
  position:absolute; bottom:16px; left:16px; right:16px;
  font-family:var(--font-mono); font-size:0.68rem; color:var(--purple-soft);
  text-align:center; opacity:0.7;
}
.credentials{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:28px; }
.credential{
  border:1px solid var(--line); border-radius:3px; padding:16px 18px;
  background:var(--white);
}
.credential .label{ font-family:var(--font-mono); font-size:0.66rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--lemon-deep); font-weight:600; }
.credential p{ font-size:0.88rem; margin-top:6px; color:var(--ink); font-weight:500; }

@media (max-width:860px){
  .about .wrap{ grid-template-columns:1fr; }
  .about-photo{ max-width:280px; }
}

/* ===== Services ===== */
.services{ background:var(--white); }
.service-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); margin-top:48px; border:1px solid var(--line); }
.service-card{ background:var(--white); padding:28px 24px; min-height:180px; display:flex; flex-direction:column; gap:14px; }
.service-card .icon{ width:30px; height:30px; color:var(--purple); }
.service-card h3{ font-size:1rem; font-family:var(--font-body); font-weight:600; }
.service-card p{ font-size:0.84rem; color:#5b4d6b; }

@media (max-width:900px){ .service-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .service-grid{ grid-template-columns:1fr; } }

/* ===== Vitals / Health check signature section ===== */
.vitals{
  background:var(--purple-deep);
  color:var(--white);
  position:relative;
}
.vitals .eyebrow{ color:var(--lemon); }
.vitals .eyebrow::before{ background:var(--lemon); }
.vitals h2{ color:var(--white); margin-top:14px; }
.vitals .lede{ color:rgba(255,255,255,0.75); }
.vitals-strip{
  margin-top:48px;
  display:grid;
  grid-template-columns:repeat(6,1fr);
  border:1px solid rgba(255,255,255,0.16);
  border-radius:4px;
  overflow:hidden;
}
.vital{
  padding:24px 16px;
  border-right:1px solid rgba(255,255,255,0.16);
  text-align:center;
}
.vital:last-child{ border-right:none; }
.vital .reading{
  font-family:var(--font-mono); font-size:1.5rem; color:var(--lemon); font-weight:600;
  display:flex; align-items:center; justify-content:center; gap:4px;
}
.vital .reading::before{ content:"●"; font-size:0.5rem; animation:pulse 1.8s infinite ease-in-out; }
.vital .unit{ font-family:var(--font-mono); font-size:0.62rem; color:rgba(255,255,255,0.5); display:block; margin-top:2px; }
.vital .name{ font-size:0.82rem; margin-top:14px; color:rgba(255,255,255,0.88); font-weight:500; }
@keyframes pulse{ 0%,100%{ opacity:0.3; } 50%{ opacity:1; } }
@media (prefers-reduced-motion: reduce){ .vital .reading::before{ animation:none; } }

@media (max-width:900px){ .vitals-strip{ grid-template-columns:repeat(3,1fr); } .vital{ border-bottom:1px solid rgba(255,255,255,0.16);} }
@media (max-width:520px){ .vitals-strip{ grid-template-columns:repeat(2,1fr); } }

/* ===== Store photo gallery (Services page) ===== */
.gallery-strip{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.gallery-strip figure{ margin:0; }
.gallery-strip img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:4px; border:1px solid var(--line); display:block; }
.gallery-strip figcaption{ font-size:0.78rem; color:#5b4d6b; margin-top:8px; }
@media (max-width:760px){ .gallery-strip{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .gallery-strip{ grid-template-columns:1fr; } }

/* ===== Single shelf photo (Health Checks page) ===== */
.shelf-photo{ max-width:480px; margin:40px auto 0; }
.shelf-photo img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:4px; border:1px solid rgba(255,255,255,0.18); display:block; }
.shelf-photo figcaption{ font-size:0.8rem; color:rgba(255,255,255,0.6); margin-top:10px; text-align:center; }

/* ===== Storefront photo (Contact page) ===== */
.storefront-photo{ margin-bottom:20px; }
.storefront-photo img{ width:100%; aspect-ratio:16/10; object-fit:cover; border-radius:4px; border:1px solid var(--line); display:block; }

/* ===== Process steps (health checks page) ===== */
.process{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.process-step{ background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.14); border-radius:4px; padding:28px 24px; }
.process-step .num{ font-family:var(--font-mono); color:var(--lemon); font-size:0.78rem; letter-spacing:0.08em; }
.process-step h3{ font-family:var(--font-body); color:var(--white); font-size:1rem; margin-top:10px; }
.process-step p{ font-size:0.85rem; color:rgba(255,255,255,0.7); margin-top:6px; }
@media (max-width:760px){ .process{ grid-template-columns:1fr; } }

/* ===== Why us ===== */
.why .wrap{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:56px; align-items:center; }
.why-list{ display:flex; flex-direction:column; gap:22px; margin-top:32px; }
.why-item{ display:flex; gap:16px; align-items:flex-start; }
.why-item .icon{ width:26px; height:26px; color:var(--lemon-deep); flex-shrink:0; margin-top:2px; }
.why-item h3{ font-family:var(--font-body); font-size:1rem; font-weight:600; }
.why-item p{ font-size:0.88rem; color:#5b4d6b; margin-top:4px; }
.why-quote{
  background:var(--lilac); border-radius:4px; padding:40px;
  font-family:var(--font-display); font-style:italic; font-size:1.3rem; color:var(--purple-deep);
  border-left:3px solid var(--lemon-deep); line-height:1.5;
}
@media (max-width:860px){ .why .wrap{ grid-template-columns:1fr; } }

/* ===== Hours & location / contact ===== */
.visit{ background:var(--white); }
.visit .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:48px; }
.panel{ border:1px solid var(--line); border-radius:4px; padding:32px; }
.panel h3{ font-family:var(--font-body); font-size:0.95rem; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; color:var(--purple); }
.hours-row{ display:flex; justify-content:space-between; padding:14px 0; border-bottom:1px solid var(--line); font-size:0.92rem; }
.hours-row:last-child{ border-bottom:none; }
.hours-row .time{ font-family:var(--font-mono); color:var(--ink); font-weight:600; }
.addr-line{ font-size:0.92rem; color:#4a3a5c; margin-top:14px; line-height:1.6; }
.contact-list{ margin-top:20px; display:flex; flex-direction:column; gap:10px; }
.contact-list a{ font-size:0.92rem; display:flex; gap:10px; align-items:center; }
.contact-list .icon{ width:18px; height:18px; color:var(--purple-soft); }
.social-row{ display:flex; gap:12px; margin-top:20px; flex-wrap:wrap; }
.social-pill{ border:1px solid var(--line); border-radius:30px; padding:8px 16px; font-size:0.8rem; font-weight:600; color:var(--purple); }
.map-frame{ border:1px solid var(--line); border-radius:4px; overflow:hidden; aspect-ratio:4/3; margin-top:24px; }
.map-frame iframe{ width:100%; height:100%; border:0; display:block; }

@media (max-width:860px){ .visit .wrap{ grid-template-columns:1fr; } }

/* ===== CTA band ===== */
.cta-band{
  background:var(--lemon);
  text-align:center;
}
.cta-band h2{ color:var(--purple-deep); }
.cta-band .lede{ color:#4a3a5c; margin:14px auto 28px; }
.cta-band .btn-primary{ background:var(--purple-deep); color:var(--white); }
.cta-band .btn-primary:hover{ background:var(--purple); }

/* ===== Footer ===== */
footer{ background:var(--purple-deep); color:rgba(255,255,255,0.7); padding:48px 0 28px; }
footer .wrap{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px; align-items:flex-start; }
footer .logo{ color:var(--white); }
footer .foot-cols{ display:flex; gap:56px; flex-wrap:wrap; }
footer .foot-col h4{ font-family:var(--font-mono); font-size:0.68rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--lemon); margin-bottom:12px; }
footer .foot-col a, footer .foot-col p{ font-size:0.85rem; display:block; margin-bottom:8px; color:rgba(255,255,255,0.75); }
.foot-bottom{ border-top:1px solid rgba(255,255,255,0.15); margin-top:36px; padding-top:20px; text-align:center; font-size:0.76rem; }

/* fade-in utility */
.reveal-section{ opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease; }
.reveal-section.in{ opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce){ .reveal-section{ opacity:1; transform:none; transition:none; } }
