/* ============================================================
   Dynamic Animal Chiropractic & Coaching — Brand stylesheet
   Palette: deep sage + salmon-cream · earthy rural warmth
   Type: Parisienne (script wordmark/accents) · Cormorant Garamond
         (display serif) · Mulish (body + UI)
   ============================================================ */

:root{
  --cream:#F4E7D9;
  --cream-2:#FBF4EC;
  --paper:#FEFBF6;
  --sage:#4F5A3F;
  --sage-2:#3A4330;
  --sage-soft:#6E7958;
  --salmon:#D89B80;
  --salmon-deep:#C5856A;
  --taupe:#97876F;
  --ink:#2C2822;
  --line:rgba(44,40,34,.12);
  --line-cream:rgba(251,244,236,.22);
  --shadow:0 24px 60px rgba(58,67,48,.14);
  --shadow-sm:0 12px 30px rgba(58,67,48,.10);
  --maxw:1240px;
  --nav-h:78px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 16px);}
body{
  margin:0;
  font-family:'Mulish',system-ui,sans-serif;
  font-weight:400;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.65;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

/* ---------- type ---------- */
.serif{font-family:'Cormorant Garamond',serif;}
.script{font-family:'Parisienne',cursive;font-weight:400;}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:500;color:var(--ink);margin:0;line-height:1.06;letter-spacing:.005em;}
h1{font-size:clamp(42px,6vw,78px);}
h2{font-size:clamp(30px,4.4vw,54px);}
h3{font-size:clamp(22px,2.4vw,30px);}
p{margin:0;}
.lead{font-size:clamp(17px,1.4vw,20px);line-height:1.75;font-weight:300;color:#5a5347;}
.kicker{
  font-family:'Mulish',sans-serif;text-transform:uppercase;
  letter-spacing:.34em;font-weight:700;font-size:12px;color:var(--salmon-deep);
}
.script-accent{font-family:'Parisienne',cursive;color:var(--sage);}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.section{padding:clamp(64px,9vw,128px) 0;}
.center{text-align:center;}
.eyebrow-block{max-width:680px;}
.eyebrow-block.center{margin:0 auto;}

/* ---------- buttons ---------- */
.btn{
  font-family:'Mulish',sans-serif;font-weight:700;font-size:14px;letter-spacing:.04em;
  border-radius:999px;padding:16px 32px;display:inline-flex;align-items:center;gap:10px;
  cursor:pointer;border:1.5px solid transparent;transition:.22s ease;line-height:1;
}
.btn svg{width:16px;height:16px;}
.btn-solid{background:var(--sage);color:var(--cream-2);}
.btn-solid:hover{background:var(--sage-2);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.btn-salmon{background:var(--salmon);color:var(--sage-2);}
.btn-salmon:hover{background:var(--salmon-deep);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.btn-ghost{background:transparent;border-color:var(--sage);color:var(--sage);}
.btn-ghost:hover{background:var(--sage);color:var(--cream-2);}
.btn-ghost-cream{background:transparent;border-color:var(--cream-2);color:var(--cream-2);}
.btn-ghost-cream:hover{background:var(--cream-2);color:var(--sage);}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;height:var(--nav-h);
  background:rgba(251,244,236,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:.25s ease;
}
.nav.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(58,67,48,.07);}
.nav-inner{max-width:var(--maxw);margin:0 auto;height:100%;padding:0 32px;display:flex;align-items:center;justify-content:space-between;}
.brand{display:flex;flex-direction:column;line-height:1;}
.brand .brand-kicker{font-family:'Mulish',sans-serif;text-transform:uppercase;letter-spacing:.3em;font-size:8px;font-weight:700;color:var(--sage-soft);margin-bottom:1px;}
.brand .brand-name{font-family:'Parisienne',cursive;font-size:27px;color:var(--sage);line-height:.9;}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a.navlink{font-weight:600;font-size:14.5px;letter-spacing:.01em;color:var(--ink);opacity:.78;transition:.18s;position:relative;padding:6px 0;}
.nav-links a.navlink:hover{opacity:1;}
.nav-links a.navlink.active{opacity:1;color:var(--sage);}
.nav-links a.navlink.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--salmon);border-radius:2px;}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--sage);}
.nav-toggle svg{width:26px;height:26px;}

/* mobile drawer */
.mobile-menu{display:none;position:fixed;inset:var(--nav-h) 0 auto 0;background:var(--cream-2);border-bottom:1px solid var(--line);box-shadow:var(--shadow);z-index:49;padding:18px 32px 30px;}
.mobile-menu.open{display:block;}
.mobile-menu a{display:block;font-weight:600;font-size:18px;padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink);}
.mobile-menu a:last-of-type{border-bottom:none;}
.mobile-menu .btn{margin-top:18px;width:100%;justify-content:center;}

/* ---------- page header band ---------- */
.page-head{background:var(--sage);color:var(--cream-2);padding:clamp(70px,9vw,120px) 0 clamp(60px,8vw,104px);position:relative;overflow:hidden;}
.page-head .kicker{color:var(--salmon);}
.page-head h1{color:var(--cream-2);margin-top:16px;}
.page-head p{color:rgba(251,244,236,.82);font-weight:300;font-size:clamp(16px,1.4vw,19px);max-width:560px;margin-top:18px;line-height:1.7;}
.page-head .deco{position:absolute;right:-60px;bottom:-90px;font-size:340px;line-height:1;color:rgba(216,155,128,.10);font-family:'Parisienne',cursive;pointer-events:none;user-select:none;}

/* ---------- cards ---------- */
.card{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:34px;transition:.24s ease;}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent;}
.grid{display:grid;gap:26px;}
.g-2{grid-template-columns:repeat(2,1fr);}
.g-3{grid-template-columns:repeat(3,1fr);}
.g-4{grid-template-columns:repeat(4,1fr);}

/* ---------- placeholder imagery ---------- */
.ph{
  position:relative;background:
    radial-gradient(120% 120% at 30% 20%, rgba(216,155,128,.18), transparent 60%),
    linear-gradient(135deg, #E7DAC9, #D8C9B4);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  color:var(--sage);overflow:hidden;border-radius:18px;
}
.ph::after{content:"";position:absolute;inset:10px;border:1.5px dashed rgba(79,90,63,.35);border-radius:12px;pointer-events:none;}
.ph svg{width:42px;height:42px;opacity:.55;margin-bottom:10px;}
.ph .ph-label{font-family:'Mulish',sans-serif;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;opacity:.7;text-align:center;padding:0 20px;max-width:260px;line-height:1.5;}

/* ---------- pill / chip ---------- */
.chip{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.03em;color:var(--sage);background:rgba(79,90,63,.08);border:1px solid rgba(79,90,63,.16);padding:8px 16px;border-radius:999px;}

/* ---------- list with ticks ---------- */
.ticks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:13px;}
.ticks li{display:flex;gap:13px;align-items:flex-start;font-size:16px;color:#4a4438;line-height:1.55;}
.ticks li svg{width:20px;height:20px;flex-shrink:0;margin-top:2px;color:var(--salmon-deep);}

/* ---------- footer ---------- */
.footer{background:var(--sage-2);color:rgba(251,244,236,.8);padding:72px 0 36px;font-size:15px;}
.footer a{color:rgba(251,244,236,.8);transition:.18s;}
.footer a:hover{color:var(--salmon);}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--line-cream);}
.footer .brand-name{font-family:'Parisienne',cursive;font-size:34px;color:var(--cream-2);line-height:1;}
.footer .brand-kicker{text-transform:uppercase;letter-spacing:.3em;font-size:9px;font-weight:700;color:var(--salmon);margin-bottom:4px;}
.footer h4{color:var(--cream-2);font-family:'Mulish',sans-serif;font-size:12px;text-transform:uppercase;letter-spacing:.18em;font-weight:700;margin-bottom:18px;}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;}
.footer .foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:28px;font-size:13px;color:rgba(251,244,236,.55);flex-wrap:wrap;}
.foot-contact{display:flex;flex-direction:column;gap:10px;margin-top:20px;}
.foot-contact a{display:flex;align-items:center;gap:11px;}
.foot-contact svg{width:17px;height:17px;color:var(--salmon);flex-shrink:0;}

/* ---------- misc ---------- */
.divider-script{font-family:'Parisienne',cursive;color:var(--salmon);font-size:30px;text-align:center;}
.rule{height:1px;background:var(--line);border:none;}

/* ---------- reveal on scroll ---------- */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1);}
[data-reveal].in{opacity:1;transform:none;}

/* ---------- testimonials ---------- */
.t-stage{position:relative;min-height:230px;}
.t-slide{position:absolute;inset:0;opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease;pointer-events:none;display:flex;flex-direction:column;align-items:center;text-align:center;}
.t-slide.active{opacity:1;transform:none;pointer-events:auto;}
.t-quote{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(24px,3vw,36px);line-height:1.32;color:var(--cream-2);max-width:880px;}
.t-author{margin-top:26px;font-weight:700;letter-spacing:.04em;font-size:14px;color:var(--salmon);text-transform:uppercase;}
.t-role{font-weight:400;letter-spacing:.02em;font-size:13px;color:rgba(251,244,236,.6);text-transform:none;margin-top:4px;}
.t-dots{display:flex;gap:10px;justify-content:center;margin-top:40px;}
.t-dot{width:9px;height:9px;border-radius:50%;background:rgba(251,244,236,.3);border:none;cursor:pointer;padding:0;transition:.2s;}
.t-dot.active{background:var(--salmon);transform:scale(1.25);}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .g-3,.g-4{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
}
@media(max-width:760px){
  .nav-links{display:none;}
  .nav-toggle{display:block;}
  .g-2,.g-3,.g-4{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .wrap{padding:0 22px;}
}
