/* ============================================================
   Farmacia de Tercia — estilos
   Estética: limpia, luminosa, sanitaria, cercana
   ============================================================ */

:root{
  /* color */
  --bg:        #ffffff;
  --bg-soft:   #f2f8f5;   /* verde muy claro */
  --bg-mint:   #e8f4ee;
  --ink:       #16302a;   /* texto principal, verde-grafito */
  --ink-soft:  #3c5650;
  --muted:     #6c827b;
  --line:      #e1ece7;
  --line-2:    #d3e3dc;

  --green:     #149267;   /* verde farmacia principal (CTA) */
  --green-700: #0d7a54;
  --green-600: #149267;
  --green-300: #7ecbab;
  --teal:      #2bb6a3;   /* turquesa suave acento */
  --teal-soft: #d8f0eb;
  --green-soft:#dcf0e6;
  --star:      #f5a623;

  --shadow-sm: 0 1px 2px rgba(20,48,42,.05), 0 2px 8px rgba(20,48,42,.04);
  --shadow-md: 0 8px 24px rgba(20,48,42,.08), 0 2px 6px rgba(20,48,42,.04);
  --shadow-lg: 0 24px 60px rgba(20,48,42,.13), 0 6px 16px rgba(20,48,42,.06);

  --r-sm: 10px;
  --r:    14px;
  --r-lg: 20px;
  --r-xl: 26px;

  --container: 1280px;
  --pad: clamp(20px, 4.5vw, 72px);

  --font: "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

h1,h2,h3,h4{ line-height:1.12; margin:0; letter-spacing:-.02em; font-weight:800; text-wrap:balance; }
p{ margin:0; text-wrap:pretty; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
ul{ margin:0; padding:0; list-style:none; }

.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--pad); }

.section{ padding-block: clamp(48px, 6vw, 88px); }
.section--soft{ background:var(--bg-soft); }
.section--mint{ background:linear-gradient(180deg,#eef7f2 0%, #e6f3ec 100%); }

/* ---------- eyebrow / headings ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:.82rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase;
  color:var(--green-700);
}
.eyebrow::before{
  content:""; width:22px; height:2px; border-radius:2px; background:var(--green-300);
}
.section-head{ max-width:660px; margin-bottom: clamp(30px, 4vw, 48px); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .eyebrow::before{ display:none; }
.section-head h2{ font-size: clamp(1.7rem, 3vw, 2.4rem); margin-top:12px; }
.section-head p{ font-size:1.05rem; color:var(--muted); margin-top:14px; }

/* ---------- buttons ---------- */
.btn{
  --bg-btn:var(--green); --fg-btn:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:inherit; font-size:.96rem; font-weight:700;
  padding:12px 22px; border-radius:999px; border:1.5px solid transparent;
  background:var(--bg-btn); color:var(--fg-btn); cursor:pointer;
  transition:transform .18s ease, box-shadow .2s ease, background .2s ease, border-color .2s;
  box-shadow:0 6px 18px rgba(20,146,103,.28);
  min-height:48px; white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 12px 26px rgba(20,146,103,.34); }
.btn:active{ transform:translateY(0); }
.btn svg{ width:19px; height:19px; }
.btn--ghost{
  --bg-btn:#fff; --fg-btn:var(--ink); border-color:var(--line-2);
  box-shadow:var(--shadow-sm);
}
.btn--ghost:hover{ border-color:var(--green-300); box-shadow:var(--shadow-md); background:#fff; }
.btn--white{ --bg-btn:#fff; --fg-btn:var(--green-700); box-shadow:var(--shadow-md); }
.btn--lg{ padding:14px 26px; font-size:1.02rem; min-height:52px; }

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .25s, box-shadow .25s, background .25s;
}
.header.is-stuck{ border-bottom-color:var(--line); box-shadow:0 4px 20px rgba(20,48,42,.05); }
.header__inner{ display:flex; align-items:center; gap:18px; height:70px; }

.brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.brand__mark{
  width:42px; height:42px; border-radius:12px;
  background:linear-gradient(135deg,var(--green) 0%, var(--teal) 100%);
  display:grid; place-items:center; flex:none;
  box-shadow:0 6px 16px rgba(20,146,103,.32);
}
.brand__mark svg{ width:24px; height:24px; }
.brand__name{ display:block; font-weight:800; font-size:1.12rem; letter-spacing:-.02em; line-height:1.05; }
.brand__name span{ color:var(--green-700); display:inline; }
.brand__sub{ display:block; font-size:.74rem; color:var(--muted); font-weight:600; letter-spacing:.02em; }

.nav{ display:flex; align-items:center; gap:4px; }
.nav a{
  padding:10px 15px; border-radius:999px; font-weight:600; font-size:.98rem; color:var(--ink-soft);
  transition:background .18s, color .18s; white-space:nowrap;
}
.nav a:hover{ background:var(--bg-mint); color:var(--green-700); }

.header__cta{ display:flex; align-items:center; gap:12px; margin-left:8px; }
.header__phone{
  display:inline-flex; align-items:center; gap:9px; font-weight:800; color:var(--ink);
  padding:10px 16px; border-radius:999px; border:1.5px solid var(--line-2);
  transition:border-color .2s, background .2s; font-size:1rem; white-space:nowrap;
}
.header__phone:hover{ border-color:var(--green-300); background:var(--bg-mint); }
.header__phone svg{ width:18px; height:18px; color:var(--green); }

.menu-toggle{
  display:none; width:46px; height:46px; border-radius:12px; border:1.5px solid var(--line-2);
  background:#fff; cursor:pointer; place-items:center; flex:none;
}
.menu-toggle svg{ width:22px; height:22px; }

/* mobile drawer */
.drawer{ display:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; overflow:hidden; }
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(60% 70% at 88% -10%, #dff1e9 0%, rgba(223,241,233,0) 60%),
    radial-gradient(50% 60% at -5% 10%, #e4f3ef 0%, rgba(228,243,239,0) 55%),
    linear-gradient(180deg,#f4faf7 0%, #ffffff 70%);
}
.hero__inner{
  display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(32px,5vw,72px);
  align-items:center; padding-block: clamp(40px,5.5vw,76px) clamp(48px,6vw,84px);
}
.hero__rating{
  display:inline-flex; align-items:center; gap:10px; margin-bottom:22px;
  background:#fff; border:1px solid var(--line); border-radius:999px;
  padding:8px 16px 8px 10px; box-shadow:var(--shadow-sm); font-size:.95rem; font-weight:600;
}
.hero__rating .stars{ color:var(--star); letter-spacing:1px; }
.hero__rating b{ font-weight:800; }
.hero__rating .gmark{ width:18px; height:18px; }
.hero h1{
  font-size: clamp(2.2rem, 4.5vw, 3.4rem); letter-spacing:-.03em;
}
.hero h1 em{ font-style:normal; color:var(--green-700); }
.hero__lead{ font-size:1.12rem; color:var(--ink-soft); margin-top:20px; max-width:38ch; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }
.hero__meta{
  display:flex; flex-wrap:wrap; gap:10px 26px; margin-top:30px; color:var(--muted);
  font-size:.96rem; font-weight:600;
}
.hero__meta li{ display:flex; align-items:center; gap:8px; }
.hero__meta svg{ width:17px; height:17px; color:var(--green); flex:none; }

/* hero image */
.hero__media{ position:relative; }
.hero__photo{
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  box-shadow:var(--shadow-lg); aspect-ratio: 4 / 4.4; background:#dfe9e5;
}
.hero__photo img{ width:100%; height:100%; object-fit:cover; object-position:center 35%; }
.hero__photo::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(13,60,44,.28));
}
.float-card{
  position:absolute; background:#fff; border-radius:var(--r); box-shadow:var(--shadow-lg);
  padding:14px 18px; display:flex; align-items:center; gap:12px; font-weight:700; z-index:2;
}
.float-card .dot{ width:10px; height:10px; border-radius:50%; background:var(--green); flex:none; box-shadow:0 0 0 4px rgba(20,146,103,.18); }
.float-card .dot.closed{ background:#c2554c; box-shadow:0 0 0 4px rgba(194,85,76,.18); }
.float-card small{ display:block; font-size:.78rem; color:var(--muted); font-weight:600; }
.float-card--status{ left:-14px; bottom:34px; }
.float-card--hours{ right:-14px; top:36px; flex-direction:column; align-items:flex-start; gap:2px; padding:16px 20px; }
.float-card--hours .big{ font-size:1.05rem; }

/* ============================================================
   PRESENTACIÓN
   ============================================================ */
.intro{ display:grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,72px); align-items:center; }
.intro__text h2{ font-size:clamp(1.6rem,2.8vw,2.2rem); margin-top:12px; }
.intro__text p{ font-size:1.05rem; color:var(--ink-soft); margin-top:18px; }
.intro__cross{
  position:relative; aspect-ratio:1; border-radius:var(--r-xl); overflow:hidden;
  background:linear-gradient(140deg,#eef7f2,#dcefe6);
  display:grid; place-items:center; box-shadow:var(--shadow-md);
}
.intro__cross .crossbig{ width:46%; height:46%; color:var(--green); opacity:.92; }
.intro__chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.chip{
  display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:999px;
  background:var(--bg-mint); color:var(--green-700); font-weight:700; font-size:.93rem;
  border:1px solid var(--green-soft);
}
.chip svg{ width:16px; height:16px; }

/* ============================================================
   SERVICIOS
   ============================================================ */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:26px;
  box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease, border-color .2s;
}
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--green-soft); }
.card__icon{
  width:48px; height:48px; border-radius:13px; display:grid; place-items:center; margin-bottom:16px;
  background:var(--bg-mint); color:var(--green-700);
}
.card__icon svg{ width:24px; height:24px; }
.card h3{ font-size:1.1rem; }
.card p{ color:var(--muted); margin-top:8px; font-size:.95rem; }
.cards-note{ text-align:center; margin-top:34px; color:var(--muted); font-size:1rem; }

/* ============================================================
   CONFIANZA
   ============================================================ */
.trust{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.trust__item{
  display:flex; align-items:center; gap:14px; padding:18px 22px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--shadow-sm); font-weight:700; font-size:1rem;
}
.trust__check{
  width:38px; height:38px; border-radius:50%; flex:none; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--green),var(--teal)); color:#fff;
}
.trust__check svg{ width:20px; height:20px; }

/* ============================================================
   RESEÑAS
   ============================================================ */
.reviews{ position:relative; }
.reviews__track{
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px;
}
.review{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:24px;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:13px; height:100%;
}
.review__stars{ color:var(--star); font-size:1.02rem; letter-spacing:2px; }
.review__text{ font-size:.98rem; color:var(--ink-soft); line-height:1.6; flex:1; }
.review__who{ display:flex; align-items:center; gap:12px; padding-top:6px; border-top:1px solid var(--line); }
.review__avatar{
  width:42px; height:42px; border-radius:50%; flex:none; display:grid; place-items:center;
  font-weight:800; color:#fff; font-size:1rem;
}
.review__name{ font-weight:800; font-size:1rem; }
.review__src{ font-size:.82rem; color:var(--muted); font-weight:600; display:flex; align-items:center; gap:5px; }
.review__src svg{ width:13px; height:13px; }

/* carousel controls (mobile) */
.reviews__nav{ display:none; }

.reviews__summary{
  display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap;
  margin-top:42px; text-align:center;
}
.reviews__summary .score{ font-size:3rem; font-weight:800; color:var(--ink); line-height:1; }
.reviews__summary .stars{ color:var(--star); font-size:1.3rem; letter-spacing:3px; }

/* ============================================================
   NUESTRA FARMACIA
   ============================================================ */
.place{ display:grid; grid-template-columns: 1.15fr .85fr; gap:clamp(28px,4vw,52px); align-items:stretch; }
.place__photo{ border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:1 / 1.04; min-height:420px; }
.place__photo img{ width:100%; height:100%; object-fit:cover; object-position:center 40%; }
.place__body{ display:flex; flex-direction:column; justify-content:center; }
.place__body p{ font-size:1.05rem; color:var(--ink-soft); margin-top:18px; }
.place__facts{ margin-top:30px; display:flex; flex-direction:column; gap:16px; }
.fact{ display:flex; align-items:flex-start; gap:14px; }
.fact__ic{ width:44px; height:44px; border-radius:12px; background:var(--bg-mint); color:var(--green-700); display:grid; place-items:center; flex:none; }
.fact__ic svg{ width:22px; height:22px; }
.fact b{ display:block; font-size:1.04rem; }
.fact span{ color:var(--muted); font-size:.98rem; }

/* ============================================================
   UBICACIÓN Y HORARIO
   ============================================================ */
.locate{ display:grid; grid-template-columns: 1fr 1fr; gap:26px; align-items:start; }
.panel{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,3vw,40px);
  box-shadow:var(--shadow-sm);
}
.panel h3{ font-size:1.4rem; }
.addr{ margin-top:20px; display:flex; flex-direction:column; gap:14px; }
.addr .fact b{ font-weight:700; }
.hours{ margin-top:8px; }
.hours__row{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:11px 0; border-bottom:1px dashed var(--line);
}
.hours__row:last-child{ border-bottom:0; }
.hours__row.today{
  background:var(--bg-mint); margin-inline:-14px; padding-inline:14px; border-radius:12px;
  border-bottom-color:transparent; font-weight:800;
}
.hours__day{ font-weight:700; display:flex; align-items:center; gap:8px; }
.hours__time{ color:var(--ink-soft); font-weight:600; font-variant-numeric:tabular-nums; text-align:right; }
.hours__time.closed{ color:#c2554c; }
.badge-today{ font-size:.68rem; background:var(--green); color:#fff; padding:2px 8px; border-radius:999px; font-weight:800; letter-spacing:.04em; }
.status-line{
  display:flex; align-items:center; gap:10px; margin-top:22px; padding:14px 18px;
  border-radius:14px; background:var(--bg-mint); font-weight:800;
}
.status-line .dot{ width:11px; height:11px; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px rgba(20,146,103,.2); }
.status-line.closed{ background:#fbeceb; color:#a8443c; }
.status-line.closed .dot{ background:#c2554c; box-shadow:0 0 0 4px rgba(194,85,76,.2); }
.panel__actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:26px; }

.map{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); min-height:480px; position:relative; background:var(--bg-mint); }
.map iframe{ width:100%; height:100%; min-height:480px; border:0; display:block; filter:saturate(.92); }

/* ============================================================
   CONTACTO
   ============================================================ */
.contact{ display:grid; grid-template-columns: .9fr 1.1fr; gap:clamp(28px,4vw,56px); align-items:center; }
.contact__intro h2{ font-size:clamp(1.7rem,3vw,2.4rem); margin-top:12px; }
.contact__intro p{ font-size:1.05rem; color:var(--ink-soft); margin-top:16px; }
.contact__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:28px; }

.form{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,3vw,40px); box-shadow:var(--shadow-md); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:700; font-size:.95rem; margin-bottom:8px; }
.field input, .field textarea{
  width:100%; font-family:inherit; font-size:1.02rem; color:var(--ink);
  padding:14px 16px; border:1.5px solid var(--line-2); border-radius:13px; background:#fcfefd;
  transition:border-color .18s, box-shadow .18s; resize:vertical;
}
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--green); box-shadow:0 0 0 4px rgba(20,146,103,.13); }
.field input.invalid, .field textarea.invalid{ border-color:#d9685f; box-shadow:0 0 0 4px rgba(217,104,95,.12); }
.field .err{ color:#c2554c; font-size:.84rem; font-weight:600; margin-top:6px; display:none; }
.field.show-err .err{ display:block; }
.check{ display:flex; align-items:flex-start; gap:11px; font-size:.92rem; color:var(--ink-soft); margin-bottom:20px; }
.check input{ width:20px; height:20px; margin-top:2px; accent-color:var(--green); flex:none; }
.check a{ color:var(--green-700); font-weight:700; text-decoration:underline; }
.form__note{ font-size:.84rem; color:var(--muted); margin-top:14px; text-align:center; }
.form__ok{
  display:none; text-align:center; padding:18px; border-radius:14px; background:var(--bg-mint);
  color:var(--green-700); font-weight:700; margin-top:14px;
}
.form__ok.show{ display:block; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:#0f2a23; color:#cfe0d9; padding-block:64px 30px; }
.footer a{ color:#cfe0d9; }
.footer__grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap:36px; }
.footer .brand__name{ color:#fff; }
.footer .brand__name span{ color:var(--green-300); }
.footer .brand__sub{ color:#8fab9f; }
.footer__about{ color:#9db8ac; margin-top:18px; font-size:.96rem; max-width:32ch; }
.footer h4{ font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; color:#80a094; font-weight:800; margin-bottom:16px; }
.footer__col li{ margin-bottom:11px; font-size:.97rem; }
.footer__col a:hover{ color:#fff; }
.footer__col li.muted{ color:#9db8ac; }
.footer__bottom{
  margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.1);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:.86rem; color:#8fab9f;
}
.footer__bottom a:hover{ color:#fff; text-decoration:underline; }
.footer__legal{ display:flex; gap:22px; flex-wrap:wrap; }

/* ============================================================
   STICKY MOBILE CALL BAR
   ============================================================ */
.callbar{ display:none; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
/* ============================================================
   REVEAL — el contenido es SIEMPRE visible por defecto.
   La entrada animada solo se aplica como mejora progresiva
   cuando el navegador puede animar (clase js-anim en <html>).
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  html.js-anim .reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.3,1); }
  html.js-anim .reveal.in{ opacity:1; transform:none; }
  html.js-anim .reveal-d1{ transition-delay:.08s; }
  html.js-anim .reveal-d2{ transition-delay:.16s; }
  html.js-anim .reveal-d3{ transition-delay:.24s; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1000px){
  .hero__inner{ grid-template-columns:1fr; gap:40px; }
  .hero__media{ max-width:520px; }
  .intro{ grid-template-columns:1fr; }
  .intro__cross{ order:-1; max-width:340px; aspect-ratio:1.4; }
  .cards{ grid-template-columns:repeat(2,1fr); }
  .trust{ grid-template-columns:repeat(2,1fr); }
  .place{ grid-template-columns:1fr; }
  .place__photo{ min-height:340px; }
  .locate{ grid-template-columns:1fr; }
  .contact{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr 1fr; gap:28px; }
}

@media (max-width: 720px){
  body{ font-size:16px; }
  .nav, .header__phone{ display:none; }
  .menu-toggle{ display:grid; }
  .header__inner{ height:66px; }

  /* mobile drawer */
  .drawer{
    display:block; position:fixed; inset:0 0 0 auto; width:min(82vw,340px); z-index:90;
    background:#fff; box-shadow:var(--shadow-lg); transform:translateX(100%);
    transition:transform .32s cubic-bezier(.3,.7,.3,1); padding:22px; overflow-y:auto;
  }
  .drawer.open{ transform:none; }
  .drawer__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
  .drawer__close{ width:42px; height:42px; border-radius:12px; border:1.5px solid var(--line-2); background:#fff; display:grid; place-items:center; cursor:pointer; }
  .drawer__close svg{ width:22px; height:22px; }
  .drawer nav a{ display:block; padding:15px 14px; border-radius:14px; font-weight:700; font-size:1.08rem; color:var(--ink); }
  .drawer nav a:hover{ background:var(--bg-mint); }
  .drawer .btn{ width:100%; margin-top:14px; }
  .scrim{ position:fixed; inset:0; background:rgba(15,42,35,.4); z-index:80; opacity:0; pointer-events:none; transition:opacity .3s; backdrop-filter:blur(2px); }
  .scrim.show{ opacity:1; pointer-events:auto; }

  .hero__lead{ font-size:1.1rem; }
  .hero__actions .btn{ flex:1 1 auto; }
  .float-card--hours{ display:none; }
  .float-card--status{ left:14px; bottom:14px; }

  .cards{ grid-template-columns:1fr; }
  .trust{ grid-template-columns:1fr; }

  /* reviews → swipe carousel */
  .reviews__track{
    display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory;
    margin-inline:calc(-1 * var(--pad)); padding-inline:var(--pad); padding-bottom:8px;
    -webkit-overflow-scrolling:touch; scrollbar-width:none;
  }
  .reviews__track::-webkit-scrollbar{ display:none; }
  .review{ scroll-snap-align:center; flex:0 0 86%; }
  .reviews__nav{ display:flex; justify-content:center; gap:10px; margin-top:22px; }
  .reviews__nav button{ width:44px; height:44px; border-radius:50%; border:1.5px solid var(--line-2); background:#fff; cursor:pointer; display:grid; place-items:center; }
  .reviews__nav button svg{ width:20px; height:20px; }

  .footer__grid{ grid-template-columns:1fr; gap:30px; }
  .footer__bottom{ flex-direction:column; gap:14px; }

  /* sticky call bar */
  .callbar{
    display:flex; position:fixed; left:0; right:0; bottom:0; z-index:70;
    gap:10px; padding:10px 14px calc(10px + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.94); backdrop-filter:blur(12px);
    border-top:1px solid var(--line);
  }
  .callbar .btn{ flex:1; min-height:50px; padding:13px; }
  body{ padding-bottom:74px; }
}

@media (max-width:420px){
  .hero__actions{ flex-direction:column; }
  .hero__actions .btn{ width:100%; }
  .reviews__summary .score{ font-size:2.4rem; }
}
