/* ============================================================
   PetBorder v3 — Sunset Terminal Design System
   Palette: warm cream + golden amber + forest anchor
   ============================================================ */
:root{
  --cream:#F7EFE3; --card:#FFFBF4; --sand:#BEB19E;
  --peach:#EBC7A3; --sunset:#F4DBC6;
  --gold:#BE8B4E; --gd:#9A6E36;
  --ink:#231E15; --muted:#595247; --forest:#234034;
  --slate:#5E6E80; --line:rgba(35,30,21,.12);
  --sh-sm:0 4px 16px rgba(35,30,21,.09);
  --sh:0 12px 36px rgba(35,30,21,.15);
  --sh-lg:0 24px 60px rgba(35,30,21,.22);
  --shg:0 10px 28px rgba(154,110,54,.48);
  --r:18px; --rl:26px; --rp:999px;
  --maxw:1180px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Plus Jakarta Sans",system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:#E8EFE3;color:var(--ink);line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ── STICKY NAV (appears after hero) ─────────────────── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:72px;background:rgba(35,64,52,.96);
  backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,251,244,.10);
  transform:translateY(-100%);transition:transform .4s ease;
}
.site-header.vis{transform:translateY(0)}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;padding:0 28px;
}
.brand{
  display:flex;align-items:center;gap:11px;
  font-family:var(--serif);font-weight:600;font-size:1.35rem;
  letter-spacing:-.02em;color:#FFFBF4;
}
.brand:hover .mark{transform:rotate(-8deg) scale(1.06)}
.mark{
  width:38px;height:38px;border-radius:12px;
  background:var(--gold);color:var(--ink);
  display:grid;place-items:center;font-size:1.2rem;
  box-shadow:var(--shg);transition:transform .2s;
}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.9rem;font-weight:600;color:rgba(255,251,244,.75);transition:color .2s}
.nav-links a:hover{color:#FFFBF4}
.langs{
  display:flex;gap:3px;border:1px solid rgba(255,251,244,.18);
  border-radius:var(--rp);padding:3px;background:rgba(255,251,244,.08);
}
.langs a{
  font-size:.76rem;font-weight:700;padding:6px 12px;
  border-radius:var(--rp);color:rgba(255,251,244,.7);transition:all .2s;
}
.langs a.active{background:var(--gold);color:var(--ink)}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:#FFFBF4}

/* ── HERO ─────────────────────────────────────────────── */
.hero{
  position:relative;height:100svh;min-height:700px;
  display:flex;flex-direction:column;overflow:hidden;
}
.hv{position:absolute;inset:0;z-index:0}
.hv video,.hv img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.hov{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(106deg,
      rgba(35,64,52,.95) 0%,rgba(35,64,52,.82) 26%,
      rgba(35,64,52,.54) 48%,rgba(35,64,52,.22) 66%,
      transparent 86%),
    linear-gradient(to top,rgba(35,64,52,.72) 0%,transparent 32%),
    linear-gradient(to bottom,rgba(35,64,52,.42) 0%,transparent 18%);
}
.hov::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 90% at 88% 35%,rgba(190,139,78,.13) 0%,transparent 60%);
}

/* hero inline nav */
.hero-nav{
  position:relative;z-index:10;flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 52px;
  opacity:0;animation:slideDown .65s .1s ease both;
}
.hero-nav .brand{color:#FFFBF4}
.hero-nav .nav-links a{color:rgba(255,251,244,.72);transition:color .2s}
.hero-nav .nav-links a:hover{color:#FFFBF4}
.hero-nav .langs{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}
.hero-nav .langs a{color:rgba(255,251,244,.65)}
.hero-nav .langs a.active{background:var(--gold);color:var(--ink)}
.hero-nav .nav-toggle{color:#FFFBF4}

/* hero body */
.hbody{
  position:relative;z-index:5;flex:1;
  display:flex;align-items:center;padding:0 52px;
}
.hcontent{max-width:560px}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.7rem;font-weight:800;letter-spacing:.20em;text-transform:uppercase;
  color:var(--peach);margin-bottom:20px;
  opacity:0;animation:slideUp .6s .35s ease both;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);border-radius:2px;flex-shrink:0}
.hh1{
  font-family:var(--serif);font-size:clamp(2.9rem,5.8vw,5.2rem);
  font-weight:600;line-height:1.0;letter-spacing:-.032em;color:#FFFBF4;margin-bottom:24px;
}
.hh1 .ln{display:block}
.l1{opacity:0;animation:slideUp .65s .48s ease both}
.l2{opacity:0;animation:slideUp .65s .60s ease both}
.l3{opacity:0;animation:slideUp .65s .72s ease both}
.hh1 em{font-style:italic;color:var(--gold)}
.hlead{
  font-size:1.06rem;color:rgba(255,251,244,.70);
  max-width:42ch;line-height:1.65;margin-bottom:32px;
  opacity:0;animation:slideUp .65s .84s ease both;
}
.hlead strong{color:#FFFBF4;font-weight:700}

/* cta buttons */
.ctarow{display:flex;gap:11px;flex-wrap:wrap;margin-bottom:36px;opacity:0;animation:slideUp .65s .96s ease both}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-weight:700;font-size:.97rem;
  padding:15px 26px;border-radius:var(--rp);border:0;cursor:pointer;text-decoration:none;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
}
.btn:hover{transform:translateY(-3px)}
.btn-gold{background:var(--gold);color:var(--ink);box-shadow:var(--shg)}
.btn-gold:hover{background:var(--gd);box-shadow:0 16px 36px rgba(154,110,54,.62)}
.btn-gold .arr{transition:transform .2s}.btn-gold:hover .arr{transform:translateX(5px)}
.btn-outline{background:rgba(255,251,244,.08);color:#FFFBF4;border:1.5px solid rgba(255,255,255,.22);backdrop-filter:blur(8px)}
.btn-outline:hover{background:rgba(255,251,244,.15)}
.btn-forest{background:var(--forest);color:#fff;box-shadow:var(--sh)}
.btn-forest:hover{background:#1a3028}
.btn-primary{background:var(--gold);color:var(--ink);box-shadow:var(--shg);border-radius:var(--rp)}
.btn-primary:hover{background:var(--gd);color:#fff}

/* hero species chips */
.hspecies{display:flex;flex-wrap:wrap;gap:8px;opacity:0;animation:slideUp .65s 1.08s ease both}
.hsp{
  position:relative;display:inline-flex;align-items:center;gap:6px;
  font-family:var(--sans);font-size:.82rem;font-weight:600;
  padding:9px 16px;border-radius:var(--rp);
  border:1.5px solid rgba(255,255,255,.16);
  background:rgba(255,251,244,.08);color:rgba(255,251,244,.70);
  cursor:pointer;backdrop-filter:blur(6px);transition:all .22s ease;
}
.hsp:hover,.hsp.on{background:var(--gold);border-color:var(--gold);color:var(--ink);transform:translateY(-2px);box-shadow:var(--shg)}
.hsptip{
  position:absolute;bottom:calc(100% + 10px);left:50%;
  transform:translateX(-50%) translateY(6px);
  background:var(--card);color:var(--ink);
  border:1px solid var(--line);border-radius:10px;
  padding:8px 13px;font-size:.74rem;font-weight:600;white-space:nowrap;
  box-shadow:var(--sh);opacity:0;pointer-events:none;z-index:30;
  transition:opacity .18s ease,transform .18s ease;
}
.hsptip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--card)}
.hsp:hover .hsptip{opacity:1;transform:translateX(-50%) translateY(0)}

/* animal portrait circle */
.pet-circle{
  position:absolute;z-index:7;left:39%;top:50%;transform:translateY(-50%);
  width:clamp(190px,18vw,260px);height:clamp(190px,18vw,260px);
  border-radius:50%;overflow:hidden;
  border:4px solid var(--gold);
  box-shadow:0 0 0 10px rgba(190,139,78,.18),0 0 0 20px rgba(190,139,78,.07),0 24px 60px rgba(35,30,21,.5);
  opacity:0;animation:pcIn .8s 1.3s ease both;
}
.pet-circle img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:opacity .35s ease,transform .4s ease}
.pet-circle img.sw{opacity:0;transform:scale(1.06)}
@keyframes pcIn{from{opacity:0;transform:translateY(-50%) scale(.88)}to{opacity:1;transform:translateY(-50%) scale(1)}}
@keyframes pcInM{from{opacity:0;transform:translateX(-50%) scale(.88)}to{opacity:1;transform:translateX(-50%) scale(1)}}

/* floating labels */
.floats{position:absolute;inset:0;z-index:8;pointer-events:none}
.fl{position:absolute;pointer-events:none;opacity:0;animation:flIn .7s var(--d,1.4s) ease both}
@keyframes flIn{from{opacity:0;transform:translateY(18px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}
.fli{position:relative;pointer-events:auto;display:inline-flex;flex-direction:column;align-items:flex-start;cursor:default}
.fli.r{align-items:flex-end}
.fa1{animation:fa1 7.0s 0.0s ease-in-out infinite}
.fa2{animation:fa2 8.2s 0.6s ease-in-out infinite}
.fa3{animation:fa3 6.4s 1.1s ease-in-out infinite}
.fa4{animation:fa4 9.0s 1.8s ease-in-out infinite}
.fa5{animation:fa5 7.6s 0.9s ease-in-out infinite}
@keyframes fa1{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes fa2{0%,100%{transform:translateY(-8px)}50%{transform:translateY(8px)}}
@keyframes fa3{0%,100%{transform:translateY(0)}50%{transform:translateY(-11px)}}
@keyframes fa4{0%,100%{transform:translateY(-5px)}50%{transform:translateY(9px)}}
@keyframes fa5{0%,100%{transform:translateY(0)}50%{transform:translateY(-13px)}}
.fpill{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,251,244,.87);backdrop-filter:blur(22px) saturate(1.5);
  -webkit-backdrop-filter:blur(22px) saturate(1.5);
  border:1px solid rgba(255,255,255,.55);border-radius:var(--rp);
  padding:10px 18px;box-shadow:var(--sh);white-space:nowrap;
  transition:transform .2s ease,box-shadow .2s ease;
}
.fli:hover .fpill{transform:scale(1.04)}
.fico{font-size:1.05rem;line-height:1}.fname{font-size:.83rem;font-weight:700;color:var(--ink)}
.fcnt{font-size:.7rem;font-weight:800;color:var(--gd);background:rgba(190,139,78,.15);padding:3px 8px;border-radius:var(--rp)}
.ftip{
  position:absolute;top:calc(100% + 10px);left:0;
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:14px 16px;min-width:205px;
  box-shadow:var(--sh);color:var(--ink);
  opacity:0;pointer-events:none;z-index:25;
  transform:translateY(8px) scale(.96);
  transition:all .24s cubic-bezier(.34,1.56,.64,1);
}
.ftip.up{top:auto;bottom:calc(100% + 10px);transform:translateY(-8px) scale(.96)}
.fli.r .ftip{left:auto;right:0}
.fli:hover .ftip,.fli:hover .ftip.up{opacity:1;transform:translateY(0) scale(1)}
.fth{font-family:var(--serif);font-weight:500;font-size:.97rem;color:var(--ink);margin-bottom:9px;padding-bottom:9px;border-bottom:1px solid var(--line)}
.ftlist{list-style:none;display:flex;flex-direction:column;gap:6px}
.ftlist li{display:flex;align-items:center;gap:9px;font-size:.79rem;color:var(--muted);font-weight:500}
.ftd{width:22px;height:22px;border-radius:7px;background:rgba(190,139,78,.13);display:grid;place-items:center;font-size:.73rem;flex-shrink:0}
.ftflags{display:flex;flex-wrap:wrap;gap:5px;margin-top:3px}.ftflags span{font-size:1.1rem}
.ftnote{font-size:.73rem;font-weight:700;color:var(--gd);margin-top:9px;padding-top:8px;border-top:1px solid rgba(35,30,21,.07)}
.fbg{display:inline-flex;padding:3px 9px;border-radius:var(--rp);font-size:.7rem;font-weight:700}
.fbg-g{background:#E2EBE2;color:#2c5440}.fbg-a{background:#F6E6C9;color:#8a5a1a}

/* hero stats bar */
.hero-stats{
  position:relative;z-index:7;flex-shrink:0;
  display:flex;align-items:stretch;
  border-top:1px solid rgba(255,255,255,.09);
  background:rgba(35,64,52,.56);backdrop-filter:blur(28px);
  opacity:0;animation:slideUp .7s 1.18s ease both;
}
.hstat{flex:1;padding:16px 24px;border-right:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:3px}
.hstat:last-child{border-right:0}
.hstat-n{font-family:var(--serif);font-size:1.5rem;font-weight:500;color:#FFFBF4;letter-spacing:-.02em;line-height:1}
.hstat-n em{color:var(--gold);font-style:italic}
.hstat-l{font-size:.66rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:rgba(255,251,244,.45)}

/* ── PAGE SECTIONS ──────────────────────────────────── */
.block{padding:72px 0}
.sec-head{text-align:center;max-width:38rem;margin:0 auto 44px}
.sec-head .eyebrow{justify-content:center;color:var(--gold);animation:none;opacity:1}
.sec-head .eyebrow::before{background:var(--gold)}
.sec-head h2{font-family:var(--serif);font-size:clamp(1.9rem,3.5vw,2.7rem);letter-spacing:-.025em;line-height:1.08;margin-bottom:12px;font-weight:600;color:var(--forest)}
.sec-head p{color:var(--muted);font-size:1.05rem}

/* checker */
.checker{background:var(--card);border:1px solid var(--line);border-radius:var(--rl);box-shadow:var(--sh-lg);overflow:hidden}
.checker-top{background:var(--forest);color:#fff;padding:20px 24px;display:flex;align-items:center;justify-content:space-between}
.checker-top .ttl{font-family:var(--serif);font-weight:500;font-size:1.1rem;display:flex;align-items:center;gap:10px}
.checker-top .stamp{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;border:1.5px solid var(--gold);color:var(--gold);padding:5px 10px;border-radius:7px}
.checker-body{padding:24px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.field select{width:100%;font-family:var(--sans);font-size:1rem;padding:13px 15px;border:1.5px solid var(--line);border-radius:13px;background:var(--cream);color:var(--ink);cursor:pointer;transition:border-color .2s,box-shadow .2s}
.field select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(190,139,78,.18)}
.route-arrow{text-align:center;color:var(--gd);font-size:1.4rem;margin:-6px 0 10px;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
.btn-check{background:var(--gold);color:var(--ink);width:100%;box-shadow:var(--shg);border-radius:var(--rp);font-size:1rem}
.btn-check:hover{background:var(--gd);color:#fff}
.results{max-height:0;opacity:0;overflow:hidden;transition:max-height .55s ease,opacity .4s ease}
.results.open{max-height:4000px;opacity:1}
.result-inner{border-top:1px dashed var(--line);padding:22px 24px}
.result-head{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:500;font-size:1.18rem;margin-bottom:3px}
.result-sub{font-size:.88rem;color:var(--muted);margin-bottom:18px}
.req{display:flex;gap:13px;padding:13px 0;border-bottom:1px solid var(--line);animation:fadeUp .5s both}
.req:last-of-type{border-bottom:0}
.req .ico{flex:0 0 38px;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:1.05rem;background:var(--cream)}
.req .ico.yes{background:rgba(35,64,52,.14)}.req .ico.no{background:rgba(89,82,71,.12)}.req .ico.warn{background:rgba(190,139,78,.18)}
.req .txt h4{font-size:.96rem;font-weight:700;margin-bottom:2px}
.req .txt p{font-size:.87rem;color:var(--muted)}
.source-box{margin-top:20px;background:linear-gradient(135deg,rgba(35,64,52,.06),rgba(190,139,78,.06));border:1px solid var(--line);border-radius:14px;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.source-box .lbl{font-size:.82rem;color:var(--muted)}.source-box .lbl strong{color:var(--forest);font-weight:700}
.source-link{font-weight:700;font-size:.88rem;color:var(--gd);display:inline-flex;align-items:center;gap:6px;border-bottom:2px solid transparent;transition:border-color .2s}
.source-link:hover{border-color:var(--gd)}

/* animals */
.animals{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.animal-chip{display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:var(--rp);padding:11px 20px;font-weight:600;font-size:.95rem;box-shadow:var(--sh-sm);transition:transform .2s,box-shadow .2s,border-color .2s,background .2s;cursor:default}
.animal-chip:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:var(--sh);background:var(--sunset)}
.animal-chip .e{font-size:1.3rem}

/* destinations */
.dest-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:18px}
.dest{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;min-height:175px;box-shadow:var(--sh-sm);transition:transform .25s,box-shadow .25s}
.dest:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.dest img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.dest:hover img{transform:scale(1.07)}
.dest .ov{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 30%,rgba(35,64,52,.88) 100%)}
.dest .cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:16px 18px;color:#fff;display:flex;flex-direction:column;align-items:flex-start}
/* Flag emojis render as overlapping 2-letter codes (US/ES…) on Windows — hide
   on cards; the country name identifies each. (Flags still show inline in the
   checker dropdowns, where they render fine.) */
.dest .fl{display:none}
.dest h3{font-family:var(--serif);font-weight:500;font-size:1.1rem;margin-bottom:2px}
.dest .st{font-size:.75rem;font-weight:600;opacity:.85}

/* trust badges */
.badges{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.bdg-card{text-align:center;padding:26px 16px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);transition:transform .2s,box-shadow .2s}
.bdg-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.bdg-card .bi{font-size:1.9rem;margin-bottom:10px}
.bdg-card h4{font-family:var(--serif);font-weight:500;font-size:1.05rem;margin-bottom:5px}
.bdg-card p{font-size:.84rem;color:var(--muted)}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
.step{counter-increment:s;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;box-shadow:var(--sh-sm);transition:transform .2s,box-shadow .2s}
.step:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.step .n{font-family:var(--serif);font-size:2.4rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:12px}
.step .n::before{content:"0" counter(s)}
.step h3{font-family:var(--serif);font-weight:500;font-size:1.2rem;margin-bottom:8px}
.step p{font-size:.92rem;color:var(--muted)}

/* shop */
.shop-blk{background:#1a3028;color:#fff;border-radius:var(--rl);padding:52px 48px;display:grid;grid-template-columns:1.15fr 1fr;gap:40px;align-items:center;position:relative;overflow:hidden;box-shadow:var(--sh-lg);border:1px solid rgba(255,251,244,.10)}
.shop-blk::before{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(190,139,78,.22),transparent 70%)}
.shop-blk h2{font-family:var(--serif);font-weight:500;font-size:2rem;letter-spacing:-.02em;margin-bottom:14px;line-height:1.1}
.shop-blk p{color:rgba(255,255,255,.72);margin-bottom:24px;max-width:28rem}
.shop-items{display:grid;grid-template-columns:1fr 1fr;gap:13px;position:relative;z-index:2}
.shop-item{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:16px;transition:background .2s,transform .2s;color:inherit}
.shop-item:hover{background:rgba(255,255,255,.13);transform:translateY(-3px)}
.shop-item .em{font-size:1.7rem}.shop-item h4{font-size:.92rem;margin:7px 0 2px;font-weight:600}.shop-item .pr{font-size:.84rem;color:var(--gold)}

/* partners */
.partners{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.partner{background:var(--card);border:1.5px dashed var(--sand);border-radius:var(--r);padding:28px;text-align:center}
.partner .pi{font-size:1.8rem;margin-bottom:10px}
.partner h4{font-family:var(--serif);font-weight:500;font-size:1.08rem;margin-bottom:5px}
.partner p{font-size:.86rem;color:var(--muted)}

/* checklist banner */
.cl-banner{
  background:linear-gradient(135deg,var(--sunset),var(--peach),var(--gold));
  border-radius:var(--rl);padding:52px 48px;
  display:flex;align-items:center;justify-content:space-between;
  gap:32px;flex-wrap:wrap;box-shadow:var(--sh-lg);position:relative;overflow:hidden;
}
.cl-banner::before{content:"";position:absolute;right:-40px;bottom:-40px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.15)}
.cl-banner h2{font-family:var(--serif);font-weight:600;font-size:2rem;color:var(--ink);margin-bottom:10px;line-height:1.1}
.cl-banner p{color:var(--muted);font-size:1.05rem}

/* faq */
.faq{max-width:44rem;margin:0 auto}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;text-align:left;background:none;border:0;padding:22px 0;font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;gap:16px;align-items:center;transition:color .2s}
.qa button:hover{color:var(--gd)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .35s ease}
.qa .ans p{color:var(--muted);padding-bottom:22px;font-size:.96rem;line-height:1.7}
.qa.open .ans{max-height:320px}
.qa .ic{color:var(--gold);transition:transform .3s;flex-shrink:0;font-size:1.3rem}
.qa.open .ic{transform:rotate(45deg)}

/* ── MODAL ──────────────────────────────────────────── */
.modal-ov{
  position:fixed;inset:0;z-index:500;
  background:rgba(35,30,21,.75);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.modal-ov.open{opacity:1;pointer-events:auto}
.modal{
  background:var(--card);border-radius:var(--rl);padding:44px 40px;
  max-width:480px;width:100%;position:relative;box-shadow:var(--sh-lg);
  transform:scale(.94) translateY(16px);
  transition:transform .35s cubic-bezier(.34,1.56,.64,1);
}
.modal-ov.open .modal{transform:scale(1) translateY(0)}
.mclose{position:absolute;top:16px;right:18px;background:none;border:0;font-size:1.4rem;cursor:pointer;color:var(--muted);width:34px;height:34px;border-radius:50%;display:grid;place-items:center;transition:background .2s}
.mclose:hover{background:var(--sunset)}
.mico{font-size:2.5rem;margin-bottom:14px}
.modal h2{font-family:var(--serif);font-weight:600;font-size:1.6rem;margin-bottom:10px;line-height:1.15}
.modal > p{color:var(--muted);margin-bottom:18px}
.mbullets{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.mbullets span{display:flex;align-items:center;gap:9px;font-size:.88rem;font-weight:500}
.mform{display:flex;flex-direction:column;gap:10px}
.mform input{font-family:var(--sans);font-size:1rem;padding:14px 16px;border:1.5px solid var(--line);border-radius:13px;background:var(--cream);color:var(--ink);transition:border-color .2s,box-shadow .2s}
.mform input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(190,139,78,.18)}
.mnote{font-size:.76rem;color:var(--muted);text-align:center;margin-top:10px}
.msuccess{text-align:center;display:none}
.msuccess .sico{font-size:3rem;margin-bottom:14px}
.msuccess h3{font-family:var(--serif);font-size:1.4rem;margin-bottom:8px}
.msuccess p{color:var(--muted);margin-bottom:20px}

/* ── FOOTER ──────────────────────────────────────────── */
footer{background:var(--ink);color:rgba(255,251,244,.6);padding:56px 0 30px;margin-top:24px}
.ft-grid{display:flex;justify-content:space-between;gap:36px;flex-wrap:wrap;margin-bottom:30px}
footer .brand{color:#FFFBF4}.footer-brand .mark{background:var(--gold)}
footer .col h5{color:#FFFBF4;font-family:var(--serif);font-weight:500;font-size:.96rem;margin-bottom:14px}
footer .col a{display:block;font-size:.89rem;margin-bottom:9px;transition:color .2s}
footer .col a:hover{color:var(--gold)}
.disclaimer{font-size:.79rem;color:rgba(255,251,244,.38);max-width:24rem;line-height:1.6;margin-top:10px}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;color:rgba(255,251,244,.65)}
.socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--ink);transform:translateY(-3px)}
.socials a svg{width:17px;height:17px;fill:currentColor}
.ft-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;font-size:.82rem;color:rgba(255,251,244,.32);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* ── ANIMATIONS ─────────────────────────────────────── */
@keyframes slideDown{from{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ── RESPONSIVE ─────────────────────────────────────── */
@media(max-width:960px){
  .hero-nav{padding:20px 28px}
  .hero-nav .nav-links{display:none}
  .hbody{padding:0 28px}
  .floats{display:none}
  /* circle floats top-centre over the sky on small screens (never over faces) */
  .pet-circle{left:50%;right:auto;top:86px;transform:translateX(-50%);width:150px;height:150px;animation:pcInM .8s 1.1s ease both}
  .badges{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr}
  .partners{grid-template-columns:1fr}
  .shop-blk{grid-template-columns:1fr;padding:36px 28px}
  .cl-banner{flex-direction:column;text-align:center;padding:40px 28px}
  .nav-inner{padding:0 20px}
  .nav-links{display:none;flex-direction:column;position:fixed;inset:72px 0 auto;background:var(--card);padding:24px;gap:18px;border-bottom:1px solid var(--line);z-index:50;transform:translateY(-110%);transition:transform .3s}
  .nav-links.open{display:flex;transform:translateY(0)}
  .nav-toggle{display:block}
}
@media(max-width:700px){
  .hero-nav .nav-toggle{display:block}
  .hstat{padding:12px 16px}
  .hstat-n{font-size:1.2rem}
  .pet-circle{top:80px;width:128px;height:128px}
  .hero-stats{overflow-x:auto;scrollbar-width:none}
  .hstat{min-width:95px}
}
@media(max-width:520px){
  .badges{grid-template-columns:1fr}
  .modal{padding:32px 22px}
  .cl-banner{padding:32px 22px}
  .cl-banner h2{font-size:1.6rem}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
