/* ============================================================
   Del Mar Medical - Concept 1: "Trusted Local"
   Refined editorial. Serif display + clean sans on warm paper.
   ============================================================ */

:root{
  /* Locked brand */
  --primary:#053F67;     /* deep teal-navy */
  --accent:#293990;      /* logo indigo */
  --secondary:#51A20E;   /* pharmacy green */
  --neutral:#3A4452;     /* body text */
  --ink-navy:#04263E;    /* deep dark sections */

  /* Editorial paper palette */
  --paper:#FAF7F1;       /* warm off-white / cream */
  --paper-2:#F3EEE4;     /* slightly deeper cream */
  --card:#FFFFFF;
  --wash:#F2F5F8;
  --line:#E6DFD2;        /* warm hairline */
  --line-cool:#DCE3EB;

  --accent-soft:rgba(41,57,144,.08);
  --primary-soft:rgba(5,63,103,.07);
  --green-soft:rgba(81,162,14,.12);

  --shadow-sm:0 1px 2px rgba(4,38,62,.06);
  --shadow:0 18px 50px -28px rgba(5,63,103,.45);
  --shadow-lg:0 40px 90px -40px rgba(4,38,62,.55);

  --r-sm:8px;
  --r:16px;
  --r-lg:26px;

  --wrap:1180px;
  --gut:clamp(1.1rem,4vw,2.5rem);

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Source Sans 3",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--neutral);
  background:var(--paper);
  line-height:1.65;
  font-size:clamp(1rem,.96rem + .25vw,1.085rem);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0;line-height:1.12;color:var(--primary);font-family:var(--serif);font-weight:600}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit;cursor:pointer}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding-inline:var(--gut)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--accent);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 var(--r-sm) 0}
.skip-link:focus{left:0}

/* visible focus everywhere */
a:focus-visible,button:focus-visible,input:focus-visible,
.nav__drop-toggle:focus-visible{
  outline:3px solid var(--secondary);
  outline-offset:3px;
  border-radius:4px;
}

.ic{width:1.1em;height:1.1em;fill:currentColor;flex:none}
.ic--caret{width:1.25em;height:1.25em}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--accent);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:.98rem;letter-spacing:.01em;
  padding:.78rem 1.35rem;border-radius:999px;border:1.5px solid transparent;
  background:var(--bg);color:var(--fg);
  transition:transform .18s ease,box-shadow .25s ease,background .2s ease,border-color .2s ease,color .2s ease;
  text-decoration:none;white-space:nowrap;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn--lg{padding:.95rem 1.7rem;font-size:1.05rem}
.btn--accent{background:var(--accent);color:#fff;box-shadow:0 12px 28px -14px rgba(41,57,144,.8)}
.btn--accent:hover{background:#212f7c;box-shadow:0 16px 34px -14px rgba(41,57,144,.85)}
.btn--secondary{background:var(--secondary);color:#fff;box-shadow:0 12px 26px -14px rgba(81,162,14,.7)}
.btn--secondary:hover{background:#458a0c}
.btn--quiet{background:transparent;color:var(--primary);border-color:var(--line-cool)}
.btn--quiet:hover{background:#fff;border-color:var(--primary);color:var(--primary)}
.btn--ghost-line{background:transparent;color:var(--accent);border-color:rgba(41,57,144,.35);padding:.6rem 1.1rem;font-size:.92rem}
.btn--ghost-line:hover{background:var(--accent-soft);border-color:var(--accent)}

/* ---------- eyebrow / section heads ---------- */
.eyebrow{
  display:flex;align-items:center;gap:.65rem;
  font-family:var(--sans);font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;font-size:.78rem;color:var(--secondary);
  margin:0 0 1rem;
}
.eyebrow__rule{height:1.5px;width:2rem;background:var(--secondary);border-radius:2px;flex:none}
.eyebrow--center{justify-content:center;text-align:center}
.eyebrow--light{color:#9fd36b}
.eyebrow--light .eyebrow__rule{background:#9fd36b}

.section{padding-block:clamp(3.5rem,8vw,6.5rem)}
.section__head{max-width:46rem;margin:0 auto clamp(2.2rem,5vw,3.5rem)}
.section__title{
  font-size:clamp(1.9rem,1.3rem + 2.4vw,3.1rem);
  letter-spacing:-.015em;text-align:center;
}
.section__title--left{text-align:left}
.section__title--light{color:#fff}
.section__head .eyebrow{justify-content:center}

.lead{font-size:clamp(1.06rem,1rem + .35vw,1.22rem);color:var(--neutral);margin-top:1rem;max-width:42rem}
.lead--light{color:rgba(255,255,255,.85)}

/* ============================================================
   UTILITY BAR
   ============================================================ */
.utilbar{background:var(--primary);color:rgba(255,255,255,.92);font-size:.85rem}
.utilbar__inner{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;align-items:center;justify-content:space-between;padding-block:.5rem}
.utilbar__contact,.utilbar__links{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;align-items:center}
.utilbar__contact li{display:flex;align-items:center;gap:.4rem}
.utilbar .ic{color:#9fd36b}
.utilbar a{color:#fff}
.utilbar a:hover{color:#cfe9b4}
.utilbar__muted{color:rgba(255,255,255,.7)}
.utilbar__links a{display:flex;align-items:center;gap:.4rem;font-weight:600}
@media (max-width:860px){
  .utilbar__muted{display:none}
  .utilbar__inner{justify-content:center}
}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:sticky;top:0;z-index:100;
  background:rgba(250,247,241,.86);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;
  transition:box-shadow .3s ease,border-color .3s ease,background .3s ease;
}
.header.is-scrolled{
  background:rgba(250,247,241,.96);
  border-bottom-color:var(--line);
  box-shadow:0 10px 30px -22px rgba(4,38,62,.5);
}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.7rem}
.brand{display:inline-flex;align-items:center}
.brand img{height:clamp(44px,5vw,58px);width:auto}

.nav{display:flex;align-items:center}
.nav__menu{display:flex;align-items:center;gap:.2rem}
.nav__menu>li>a,.nav__drop-toggle{
  display:inline-flex;align-items:center;gap:.25rem;
  font-weight:600;font-size:.97rem;color:var(--primary);
  padding:.55rem .7rem;border-radius:var(--r-sm);
  background:none;border:none;
  transition:color .18s ease,background .18s ease;
}
.nav__menu>li>a:hover,.nav__drop-toggle:hover{color:var(--accent);background:var(--accent-soft);text-decoration:none}
.nav__cta-mobile{display:none}

/* dropdown */
.nav__dropdown{position:relative}
.nav__submenu{
  position:absolute;top:calc(100% + .5rem);left:0;min-width:13rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);padding:.5rem;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
}
.nav__dropdown.is-open .nav__submenu{opacity:1;visibility:visible;transform:translateY(0)}
.nav__submenu a{display:block;padding:.55rem .8rem;border-radius:var(--r-sm);font-weight:500;color:var(--neutral)}
.nav__submenu a:hover{background:var(--accent-soft);color:var(--accent);text-decoration:none}
.ic--caret{transition:transform .2s ease}
.nav__dropdown.is-open .ic--caret{transform:rotate(180deg)}

.header__cta{display:flex;align-items:center;gap:.6rem}

/* hamburger */
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:.5rem;border-radius:var(--r-sm)}
.nav__toggle-bar{display:block;width:26px;height:2.5px;background:var(--primary);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media (max-width:980px){
  .header__cta{display:none}
  .nav__toggle{display:flex}
  .nav__menu{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:.15rem;
    background:var(--paper);border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);
    padding:1rem var(--gut) 1.6rem;
    max-height:0;overflow:hidden;visibility:hidden;
    transition:max-height .35s ease,visibility .35s,padding .35s ease;
  }
  .nav__menu.is-open{max-height:90vh;visibility:visible;overflow:auto}
  .nav__menu>li>a,.nav__drop-toggle{padding:.8rem .6rem;font-size:1.05rem;width:100%;justify-content:space-between}
  .nav__submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;
    max-height:0;overflow:hidden;padding:0 0 0 1rem;transition:max-height .3s ease}
  .nav__dropdown.is-open .nav__submenu{max-height:20rem;padding:.25rem 0 .5rem 1rem}
  .nav__cta-mobile{display:block;margin-top:.5rem}
  .nav__cta-mobile .btn{width:100%}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(60rem 40rem at 85% -10%,var(--primary-soft),transparent 60%),
    linear-gradient(180deg,var(--paper) 0%,var(--paper) 60%,var(--paper-2) 100%);
}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--line)}
.hero__inner{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);
  align-items:center;padding-block:clamp(3rem,7vw,5.5rem);
}
.hero__title{
  font-size:clamp(2.6rem,1.7rem + 4.4vw,4.6rem);
  letter-spacing:-.022em;margin:.2rem 0 0;font-weight:600;
}
.hero__title em{font-style:italic;color:var(--accent);font-weight:500}
.hero__sub{margin-top:1.4rem;font-size:clamp(1.06rem,1rem + .4vw,1.22rem);max-width:34rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:2rem}
.hero__assurance{
  display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;
  margin-top:1.6rem;font-size:.92rem;font-weight:600;color:var(--primary);
}
.ic--check{color:var(--secondary);width:1.25em;height:1.25em}

.hero__media{position:relative;margin:0}
.hero__frame{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-lg);
  background:#fff;
}
.hero__frame::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(5,63,103,.18));mix-blend-mode:multiply}
.hero__frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.hero__badge{
  position:absolute;left:-14px;bottom:24px;
  background:var(--primary);color:#fff;border-radius:var(--r);
  padding:.85rem 1.2rem;box-shadow:var(--shadow);
  display:flex;flex-direction:column;line-height:1.15;
  border:1px solid rgba(255,255,255,.12);
}
.hero__badge-year{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:#9fd36b}
.hero__badge-label{font-size:.78rem;letter-spacing:.04em;color:rgba(255,255,255,.85)}

@media (max-width:860px){
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .hero__media{order:-1;max-width:32rem}
  .hero__badge{left:auto;right:16px}
}

/* ============================================================
   PILLARS
   ============================================================ */
.pillars{background:var(--paper)}
.pillars__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,1.8rem)}
.pillar{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.6rem,2.5vw,2.2rem);box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  transition:transform .25s ease,box-shadow .3s ease,border-color .25s ease;
}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-cool)}
.pillar__icon{
  width:60px;height:60px;border-radius:18px;display:grid;place-items:center;
  background:linear-gradient(145deg,var(--accent),var(--primary));color:#fff;
  margin-bottom:1.3rem;box-shadow:0 14px 26px -14px rgba(41,57,144,.7);
}
.pillar__icon svg{width:30px;height:30px;fill:currentColor}
.pillar__title{font-size:1.45rem;margin-bottom:.6rem}
.pillar__text{flex:1;font-size:1rem}
.link-arrow{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.3rem;font-weight:700;color:var(--accent);font-size:.95rem}
.link-arrow .ic{transition:transform .2s ease}
.link-arrow:hover{text-decoration:none}
.link-arrow:hover .ic{transform:translateX(4px)}
@media (max-width:820px){.pillars__grid{grid-template-columns:1fr;max-width:34rem;margin-inline:auto}}

/* ============================================================
   DELIVERY / SAFETY
   ============================================================ */
.delivery{background:var(--paper-2)}
.delivery__inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.delivery__media{margin:0;position:relative}
.delivery__media img{
  border-radius:var(--r-lg);border:6px solid #fff;box-shadow:var(--shadow);
  width:100%;max-width:400px;
}
.delivery__media::before{content:"";position:absolute;inset:auto auto -18px -18px;width:55%;height:60%;
  background:var(--green-soft);border-radius:var(--r-lg);z-index:-1}
.checklist{margin:1.6rem 0;display:grid;gap:.7rem}
.checklist li{display:flex;align-items:center;gap:.6rem;font-weight:600;color:var(--primary)}
@media (max-width:820px){
  .delivery__inner{grid-template-columns:1fr;gap:2.2rem}
  .delivery__media{max-width:24rem}
}

/* ============================================================
   WHY (dark trust band)
   ============================================================ */
.why{
  background:
    radial-gradient(50rem 35rem at 12% 0%,rgba(41,57,144,.5),transparent 55%),
    linear-gradient(160deg,var(--primary),var(--ink-navy));
  color:rgba(255,255,255,.85);
}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.1rem,2vw,1.6rem)}
.why__card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r);padding:1.7rem 1.4rem;
  transition:transform .25s ease,background .25s ease,border-color .25s ease;
}
.why__card:hover{transform:translateY(-5px);background:rgba(255,255,255,.085);border-color:rgba(159,211,107,.5)}
.why__icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  background:rgba(159,211,107,.15);color:#9fd36b;margin-bottom:1.1rem}
.why__icon svg{width:28px;height:28px;fill:currentColor}
.why__title{color:#fff;font-size:1.22rem;margin-bottom:.5rem}
.why__text{font-size:.97rem;color:rgba(255,255,255,.78)}
@media (max-width:980px){.why__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.why__grid{grid-template-columns:1fr}}

/* ============================================================
   WHAT WE DELIVER
   ============================================================ */
.deliver{background:var(--paper)}
.deliver__inner{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.deliver__intro{position:sticky;top:6rem}
.deliver__list{display:grid;gap:1.4rem;counter-reset:d}
.deliver__item{
  display:flex;gap:1.2rem;align-items:flex-start;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm);
  transition:transform .22s ease,box-shadow .25s ease;
}
.deliver__item:hover{transform:translateX(5px);box-shadow:var(--shadow)}
.deliver__num{
  font-family:var(--serif);font-size:1.4rem;font-weight:600;color:#fff;flex:none;
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(145deg,var(--secondary),#3f8409);
}
.deliver__title{font-size:1.18rem;margin-bottom:.3rem;color:var(--primary)}
.deliver__item p{font-size:.97rem}
@media (max-width:860px){
  .deliver__inner{grid-template-columns:1fr;gap:2rem}
  .deliver__intro{position:static}
}

/* ============================================================
   STATS
   ============================================================ */
.stats{background:var(--paper-2);border-block:1px solid var(--line)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center}
.stat{padding:1rem}
.stat__num{
  display:block;font-family:var(--serif);font-weight:600;
  font-size:clamp(2.6rem,1.8rem + 3vw,4rem);line-height:1;
  color:var(--primary);letter-spacing:-.02em;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat__label{display:block;margin-top:.7rem;font-weight:600;font-size:.92rem;color:var(--neutral);
  text-transform:uppercase;letter-spacing:.06em}
@media (max-width:760px){.stats__grid{grid-template-columns:repeat(2,1fr);gap:1.8rem 1rem}}

/* ============================================================
   MEDICAL SUPPLY
   ============================================================ */
.supply{background:var(--paper)}
.supply__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.supply__tags{display:flex;flex-wrap:wrap;gap:.7rem}
.supply__tags li{
  background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:.6rem 1.15rem;font-weight:600;color:var(--primary);font-size:.95rem;
  box-shadow:var(--shadow-sm);
  transition:transform .2s ease,border-color .2s ease,color .2s ease;
}
.supply__tags li:hover{transform:translateY(-3px);border-color:var(--secondary);color:var(--accent)}
@media (max-width:820px){.supply__inner{grid-template-columns:1fr;gap:2rem}}

/* ============================================================
   APP (dark)
   ============================================================ */
.app{
  background:
    radial-gradient(40rem 30rem at 85% 110%,rgba(81,162,14,.22),transparent 55%),
    linear-gradient(150deg,var(--ink-navy),var(--primary));
  color:rgba(255,255,255,.85);overflow:hidden;
}
.app__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.app__feats{display:grid;gap:.7rem;margin:1.5rem 0 2rem}
.app__feats li{display:flex;align-items:center;gap:.6rem;font-weight:600;color:#fff}
.app__feats .ic--check{color:#9fd36b}
.app__stores{display:flex;flex-wrap:wrap;gap:.8rem}
.store{
  display:inline-flex;align-items:center;gap:.7rem;
  background:#fff;color:var(--primary);border-radius:14px;
  padding:.7rem 1.2rem;font-weight:700;
  transition:transform .2s ease,box-shadow .25s ease;box-shadow:var(--shadow-sm);
}
.store:hover{transform:translateY(-3px);text-decoration:none;box-shadow:var(--shadow)}
.store svg{width:26px;height:26px;fill:var(--primary)}
.store span{display:flex;flex-direction:column;line-height:1.1;font-size:1.05rem}
.store small{font-weight:600;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--neutral)}

/* phone mock */
.app__phone{display:grid;place-items:center}
.phone{
  position:relative;width:230px;height:460px;border-radius:38px;
  background:linear-gradient(160deg,#0a3354,#04263e);
  border:8px solid #0a3a5e;box-shadow:var(--shadow-lg);padding:14px;
}
.phone__notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:90px;height:18px;background:#04263e;border-radius:0 0 12px 12px}
.phone__screen{
  width:100%;height:100%;border-radius:26px;
  background:linear-gradient(180deg,#fff,var(--wash));
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;
}
.phone__logo{font-family:var(--serif);font-weight:600;font-size:1.4rem;color:var(--accent)}
.phone__pill{width:74px;height:74px;border-radius:50%;background:var(--green-soft);
  border:2px dashed var(--secondary)}
.phone__line{width:80%;height:11px;border-radius:6px;background:var(--line-cool)}
.phone__line--short{width:55%}
.phone__btn{margin-top:8px;background:var(--accent);color:#fff;font-weight:700;font-size:.9rem;
  padding:.6rem 1.6rem;border-radius:999px}
@media (max-width:860px){
  .app__inner{grid-template-columns:1fr;gap:2.5rem}
  .app__phone{order:-1}
}

/* ============================================================
   HOURS
   ============================================================ */
.hours{background:var(--paper)}
.hours__inner{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.8rem,4vw,3rem);box-shadow:var(--shadow-sm)}
.hours__list{display:grid;gap:.2rem;width:100%}
.hours__list li{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1rem .25rem;border-bottom:1px solid var(--line);font-size:1.1rem}
.hours__list li:last-child{border-bottom:none}
.hours__list li span:first-child{font-weight:600;color:var(--primary)}
.hours__list li span:last-child{font-weight:600;color:var(--neutral)}
.hours__oncall span:last-child{color:#fff;background:var(--secondary);
  padding:.3rem 1rem;border-radius:999px;font-weight:700}
@media (max-width:760px){.hours__inner{grid-template-columns:1fr}}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter{
  background:linear-gradient(135deg,var(--accent),var(--primary));color:#fff;
}
.newsletter__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
.newsletter .section__title{text-align:left}
.newsletter__form{display:flex;gap:.7rem;flex-wrap:wrap}
.newsletter__form input{
  flex:1;min-width:0;padding:.95rem 1.2rem;border-radius:999px;border:1.5px solid transparent;
  background:rgba(255,255,255,.95);color:var(--neutral);font-size:1rem;font-family:inherit;
}
.newsletter__form input::placeholder{color:#8893a3}
.newsletter__form input:focus{outline:3px solid #9fd36b;outline-offset:2px}
@media (max-width:760px){.newsletter__inner{grid-template-columns:1fr}}

/* ============================================================
   FINAL CTA
   ============================================================ */
.finalcta{background:var(--paper-2);text-align:center}
.finalcta__inner{max-width:44rem;margin:0 auto}
.finalcta .eyebrow{justify-content:center}
.finalcta__title{font-size:clamp(2rem,1.4rem + 2.6vw,3.2rem);letter-spacing:-.02em;margin:.3rem 0 0}
.finalcta__sub{font-size:1.12rem;margin:1.1rem auto 0;max-width:34rem}
.finalcta__actions{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center;margin-top:2rem}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink-navy);color:rgba(255,255,255,.72);font-size:.97rem}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:clamp(1.8rem,4vw,3rem);
  padding-block:clamp(3rem,6vw,4.5rem)}
.footer__chip{display:inline-block;background:#fff;padding:.7rem .9rem;border-radius:var(--r);box-shadow:var(--shadow-sm)}
.footer__chip img{height:50px;width:auto;display:block}
.footer__tag{margin-top:1.1rem;max-width:24rem;color:rgba(255,255,255,.72)}
.footer__social{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.1rem;font-weight:600;color:#9fd36b}
.footer__social:hover{color:#bfe39a}
.footer__head{font-family:var(--sans);font-size:.82rem;text-transform:uppercase;letter-spacing:.13em;
  color:#9fd36b;font-weight:700;margin:0 0 1rem}
.footer__nav ul{display:grid;gap:.55rem}
.footer__nav a{color:rgba(255,255,255,.78)}
.footer__nav a:hover{color:#fff}
.footer__contact address{font-style:normal;display:grid;gap:.9rem}
.footer__contact a{color:rgba(255,255,255,.85)}
.footer__contact a:hover{color:#fff}
.footer__muted{color:rgba(255,255,255,.6)}
.footer__hours{color:rgba(255,255,255,.65);font-size:.9rem}
.footer__bar{border-top:1px solid rgba(255,255,255,.12)}
.footer__bar-inner{display:flex;flex-wrap:wrap;gap:.4rem 1.5rem;justify-content:space-between;
  padding-block:1.3rem;font-size:.86rem;color:rgba(255,255,255,.55)}
@media (max-width:880px){.footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer__grid{grid-template-columns:1fr}.footer__bar-inner{justify-content:center;text-align:center}}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);
  transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.pillar,.why__card,.deliver__item,.store,.supply__tags li{transition:none}
  *{scroll-behavior:auto !important}
}
