/* ============================================================
   Belterra Eyecare — shared stylesheet
   Brand: dark editorial. Charcoal + gold/brass, serif display.
   ============================================================ */

:root{
  --charcoal:#2A2A28;
  --charcoal-2:#34332F;
  --ink:#26251f;
  --gold:#C6A15B;
  --brass:#9E7C3A;
  --warm:#F5F5F3;
  --paper:#FFFFFF;
  --line:#E3E1DB;
  --line-dark:#46443d;
  --muted:#6C6A64;
  --muted-light:#B7B4AB;

  --display:'Fraunces', Georgia, 'Times New Roman', serif;
  --body:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --maxw:1180px;
  --gutter:clamp(20px, 5vw, 64px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.1;margin:0;letter-spacing:-0.01em;}
p{margin:0 0 1.1em;}
p:last-child{margin-bottom:0;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter);}

/* ---------- Eyebrow (signature rule + label) ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--body);font-weight:600;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin-bottom:22px;
}
.eyebrow::before{content:"";width:34px;height:1.5px;background:var(--gold);display:inline-block;}
.eyebrow.on-dark{color:var(--gold);}
.eyebrow.centered{justify-content:center;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--body);font-weight:600;font-size:14px;letter-spacing:.04em;
  padding:15px 28px;border-radius:2px;text-decoration:none;cursor:pointer;
  border:1.5px solid transparent;transition:all .2s ease;white-space:nowrap;
}
.btn-primary{background:var(--gold);color:#231d11;border-color:var(--gold);}
.btn-primary:hover{background:var(--brass);border-color:var(--brass);color:#fff;}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line);}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass);}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.35);}
.btn-ghost.on-dark:hover{border-color:var(--gold);color:var(--gold);}

/* ---------- Header / Nav ---------- */
.site-header{
  background:var(--charcoal);color:#fff;position:sticky;top:0;z-index:50;
  border-bottom:1px solid var(--line-dark);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;}
.nav__logo img{height:44px;width:auto;}
.nav__links{display:flex;align-items:center;gap:24px;list-style:none;margin:0;padding:0;}
.nav__links a{
  text-decoration:none;color:#E9E7E1;font-size:14px;font-weight:500;letter-spacing:.02em;
  padding:6px 0;position:relative;transition:color .2s;
}
.nav__links a:hover{color:#fff;}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--gold);transition:width .25s;}
.nav__links a:hover::after,.nav__links a.active::after{width:100%;}
.nav__links a.active{color:#fff;}
.nav__cta{margin-left:6px;flex-shrink:0;}
.nav__cta .btn{white-space:nowrap;padding-left:30px;padding-right:30px;}
.nav__toggle{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:8px;}
.nav__toggle svg{display:block;}

/* ---------- Hero (home) ---------- */
.hero{position:relative;background:var(--charcoal);color:#fff;overflow:hidden;}
.hero__media{position:absolute;inset:0;}
.hero__media img{width:100%;height:100%;object-fit:cover;}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(28,27,25,.93) 0%, rgba(28,27,25,.78) 42%, rgba(28,27,25,.30) 100%);}
.hero__inner{position:relative;padding:clamp(70px,11vw,140px) 0;}
.hero__content{max-width:620px;}
.hero h1{font-size:clamp(2.5rem,5.4vw,4rem);font-weight:600;margin-bottom:24px;}
.hero h1 em{font-style:italic;color:var(--gold);font-weight:500;}
.hero__sub{font-size:1.12rem;color:#D8D5CD;max-width:50ch;margin-bottom:34px;}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;}

/* ---------- Generic section ---------- */
.section{padding:clamp(64px,9vw,116px) 0;}
.section--warm{background:var(--warm);}
.section--dark{background:var(--charcoal);color:#fff;}
.section--dark p{color:#CFCCC4;}
.section h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin-bottom:20px;}
.section__lead{font-size:1.08rem;max-width:60ch;}

/* ---------- Split (image + text) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,84px);align-items:center;}
.split--flip .split__media{order:2;}
.split__text{max-width:540px;}
.framed{position:relative;}
.framed img{position:relative;z-index:1;border-radius:2px;width:100%;height:100%;object-fit:cover;}
.framed::before{content:"";position:absolute;z-index:0;width:100%;height:100%;
  border:1.5px solid var(--gold);border-radius:2px;top:18px;left:18px;}
.split--flip .framed::before{left:-18px;}

/* ---------- Service cards ---------- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--line-dark);border:1px solid var(--line-dark);}
.card{background:var(--charcoal);padding:40px 38px;transition:background .25s;display:flex;flex-direction:column;}
.card:hover{background:var(--charcoal-2);}
.card__no{font-family:var(--display);font-size:.95rem;color:var(--gold);font-style:italic;margin-bottom:16px;}
.card h3{color:#fff;font-size:1.35rem;margin-bottom:12px;}
.card p{color:#C3C0B8;font-size:.97rem;margin-bottom:22px;flex:1;}
.card__link{color:var(--gold);text-decoration:none;font-weight:600;font-size:.9rem;letter-spacing:.03em;}
.card__link:hover{color:#fff;}

/* ---------- Visit / location ---------- */
.visit{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,80px);align-items:center;}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px 40px;margin:30px 0 34px;}
.info-block h4{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);margin-bottom:10px;font-family:var(--body);font-weight:700;}
.info-block p,.info-block a{font-size:1rem;color:var(--ink);text-decoration:none;margin:0;}
.info-block a:hover{color:var(--brass);}
.hours-row{display:flex;justify-content:space-between;max-width:280px;border-bottom:1px solid var(--line);padding:7px 0;font-size:.95rem;}
.hours-row span:last-child{color:var(--muted);}
.hours-note{font-size:.82rem;color:var(--muted);margin-top:10px;font-style:italic;}

/* ---------- Page hero (inner pages) ---------- */
.pagehero{background:var(--charcoal);color:#fff;position:relative;overflow:hidden;}
.pagehero__media{position:absolute;inset:0;}
.pagehero__media img{width:100%;height:100%;object-fit:cover;}
.pagehero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(28,27,25,.92),rgba(28,27,25,.55));}
.pagehero__inner{position:relative;padding:clamp(58px,8vw,104px) 0;}
.pagehero h1{font-size:clamp(2.2rem,4.4vw,3.3rem);max-width:18ch;margin-bottom:8px;}
.breadcrumb{font-size:.82rem;letter-spacing:.08em;color:var(--muted-light);text-transform:uppercase;margin-top:18px;}
.breadcrumb a{color:var(--gold);text-decoration:none;}

/* ---------- Prose / lists for content pages ---------- */
.prose h3{font-size:1.4rem;margin:0 0 14px;}
.prose .eyebrow{margin-bottom:14px;}
.checklist{list-style:none;margin:0 0 1.2em;padding:0;}
.checklist li{position:relative;padding-left:30px;margin-bottom:12px;color:var(--ink);}
.checklist li::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:8px;
  border-left:2px solid var(--gold);border-bottom:2px solid var(--gold);transform:rotate(-45deg);}
.section--dark .checklist li{color:#D2CFC7;}

/* feature stack */
.feature{padding:30px 0;border-top:1px solid var(--line);}
.feature:first-of-type{border-top:0;}
.feature h3{margin-bottom:10px;}
.section--dark .feature{border-color:var(--line-dark);}

/* pill list (brands/insurers) */
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;}
.pill{border:1px solid var(--line);border-radius:999px;padding:8px 18px;font-size:.9rem;color:var(--ink);}
.section--dark .pill{border-color:var(--line-dark);color:#D2CFC7;}

/* gallery strip */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.gallery img{aspect-ratio:1/1;object-fit:cover;border-radius:2px;}

/* team grid */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;}
.team-card{background:var(--paper);padding:32px 28px;border:1px solid var(--line);border-top:2px solid var(--gold);}
.team-card .name{font-family:var(--display);font-size:1.3rem;font-weight:600;color:var(--ink);margin:0 0 6px;}
.team-card .role{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brass);font-weight:700;margin:0;}
.team-card.lead{background:var(--charcoal);border-top-color:var(--gold);}
.team-card.lead .name{color:#fff;}
.team-card.lead .role{color:var(--gold);}
.team-card.lead .bio{color:#C3C0B8;font-size:.95rem;margin:14px 0 0;}

/* CTA band */
.cta-band{background:var(--charcoal);color:#fff;text-align:center;padding:clamp(56px,8vw,90px) 0;}
.cta-band h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:14px;}
.cta-band p{color:#CFCCC4;max-width:46ch;margin:0 auto 30px;}

/* ---------- Footer ---------- */
.site-footer{background:#1f1e1c;color:#C9C6BE;padding:64px 0 28px;border-top:3px solid var(--gold);}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:44px;}
.site-footer img{height:30px;margin-bottom:18px;}
.site-footer h5{color:#fff;font-family:var(--body);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 16px;}
.site-footer a{color:#C9C6BE;text-decoration:none;display:block;margin-bottom:10px;font-size:.95rem;}
.site-footer a:hover{color:var(--gold);}
.footer-about{font-size:.95rem;color:#A9A69E;max-width:34ch;}
.footer-bottom{border-top:1px solid #36342f;margin-top:46px;padding-top:22px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;color:#86837c;}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .nav__links{position:fixed;inset:74px 0 auto 0;background:var(--charcoal);flex-direction:column;
    gap:0;padding:8px 0 18px;border-bottom:1px solid var(--line-dark);transform:translateY(-120%);
    transition:transform .3s ease;align-items:stretch;}
  .nav__links.open{transform:translateY(0);}
  .nav__links li{padding:0 var(--gutter);}
  .nav__links a{display:block;padding:14px 0;border-bottom:1px solid var(--line-dark);}
  .nav__links a::after{display:none;}
  .nav__links .nav__cta{margin:14px var(--gutter) 0;}
  .nav__links .nav__cta .btn{width:100%;}
  .nav__toggle{display:block;}
  .split,.visit{grid-template-columns:1fr;}
  .split--flip .split__media{order:0;}
  .framed::before{display:none;}
  .cards{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:32px;}
  .gallery{grid-template-columns:repeat(2,1fr);}
  .info-grid{grid-template-columns:1fr;}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important;}
}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
