/* ============================================================
   Animals Productions 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}
}

/* ═══════ TRUST STRIP (under shop) ═══════ */
.trust-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}
.trust-strip .ti{display:flex;align-items:center;gap:12px;background:var(--card);
  border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:var(--sh)}
.trust-strip .ti .tic{font-size:1.7rem;line-height:1;flex-shrink:0}
.trust-strip .ti h4{font-family:var(--sans);font-weight:700;font-size:.98rem;color:var(--forest);margin:0 0 2px}
.trust-strip .ti p{font-size:.84rem;color:var(--muted);margin:0;line-height:1.4}
@media(max-width:760px){.trust-strip{grid-template-columns:1fr}}

/* ═══════ LEGAL / INFO PAGES ═══════ */
.legal-wrap{max-width:760px;margin:0 auto;padding:120px 22px 80px}
.legal-wrap .back{display:inline-flex;align-items:center;gap:6px;color:var(--gd);
  font-weight:600;font-size:.9rem;text-decoration:none;margin-bottom:22px}
.legal-wrap .back:hover{text-decoration:underline}
.legal-wrap h1{font-family:var(--serif);font-size:clamp(2rem,4vw,2.8rem);color:var(--forest);margin:0 0 6px}
.legal-wrap .upd{font-size:.84rem;color:var(--muted);margin:0 0 30px}
.legal-wrap h2{font-family:var(--serif);font-size:1.4rem;color:var(--forest);margin:34px 0 10px}
.legal-wrap p,.legal-wrap li{font-size:1rem;color:var(--ink);line-height:1.7}
.legal-wrap ul{padding-left:20px;margin:10px 0}
.legal-wrap li{margin:6px 0}
.legal-wrap a{color:var(--gd);font-weight:600}
.legal-card{background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:26px 28px;box-shadow:var(--sh);margin-top:18px}
.legal-contact{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.legal-contact a{display:flex;align-items:center;gap:12px;background:var(--card);
  border:1px solid var(--line);border-radius:14px;padding:15px 18px;text-decoration:none;
  color:var(--ink);font-weight:600;box-shadow:var(--sh);transition:transform .15s}
.legal-contact a:hover{transform:translateY(-2px)}
.legal-contact a .ci{font-size:1.4rem}

/* ═══════ NEAR-YOU PLACES FINDER ═══════ */
.pf-wrap{max-width:980px;margin:0 auto;padding:118px 22px 80px}
.pf-head{text-align:center;margin-bottom:24px}
.pf-head h1{font-family:var(--serif);font-size:clamp(2rem,4.4vw,3rem);color:var(--forest);margin:0 0 8px}
.pf-head p{color:var(--muted);font-size:1.05rem;max-width:620px;margin:0 auto}
.pf-search{display:flex;flex-wrap:wrap;gap:10px;background:var(--card);border:1px solid var(--line);
  border-radius:18px;padding:14px;box-shadow:var(--sh);margin-bottom:14px}
.pf-search input{flex:1 1 240px;min-width:0;border:1px solid var(--line);border-radius:12px;
  padding:13px 16px;font-family:var(--sans);font-size:1rem;color:var(--ink);background:#fff}
.pf-search input:focus{outline:2px solid var(--gold);outline-offset:1px}
.pf-search select{border:1px solid var(--line);border-radius:12px;padding:0 12px;font-family:var(--sans);
  font-size:.95rem;color:var(--ink);background:#fff;cursor:pointer}
.pf-search .btn-find{background:var(--gold);color:var(--ink);border:0;border-radius:12px;padding:13px 22px;
  font-family:var(--sans);font-weight:700;font-size:.97rem;cursor:pointer;box-shadow:var(--shg);transition:background .15s}
.pf-search .btn-find:hover{background:var(--gd);color:#fff}
.pf-search .btn-geo{background:transparent;color:var(--gd);border:1px solid var(--line);border-radius:12px;
  padding:13px 16px;font-family:var(--sans);font-weight:600;font-size:.92rem;cursor:pointer}
.pf-search .btn-geo:hover{background:var(--cream)}
.pf-msg{padding:14px 16px;border-radius:12px;font-size:.95rem;margin:6px 0 0}
.pf-msg.load{background:#fff;border:1px solid var(--line);color:var(--muted)}
.pf-msg.load::before{content:"⏳ "}
.pf-msg.warn{background:#FFF6E9;border:1px solid #E7C99A;color:#7a5a1f}
#pf-map{display:none;height:340px;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--sh);margin:14px 0;z-index:0}
.pf-summary{font-family:var(--serif);font-size:1.2rem;color:var(--forest);margin:18px 0 12px}
.pf-summary:empty{margin:0}
.pf-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.pf-chip{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 14px;
  font-family:var(--sans);font-size:.85rem;font-weight:600;color:var(--ink);cursor:pointer;transition:all .15s}
.pf-chip:hover{border-color:var(--gold)}
.pf-chip.on{background:var(--forest);color:#fff;border-color:var(--forest)}
.pf-results{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.pf-card{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);
  border-radius:16px;padding:15px 17px;box-shadow:var(--sh)}
.pf-card .pf-ico{font-size:1.7rem;flex-shrink:0}
.pf-card .pf-body{flex:1;min-width:0}
.pf-card .pf-name{font-family:var(--sans);font-weight:700;color:var(--forest);font-size:1rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pf-card .pf-meta{font-size:.82rem;color:var(--muted);margin-top:2px}
.pf-card .pf-right{text-align:right;flex-shrink:0}
.pf-card .pf-dist{font-weight:700;color:var(--gd);font-size:.9rem}
.pf-card .pf-dir{display:inline-block;margin-top:3px;font-size:.82rem;color:var(--gd);font-weight:600;text-decoration:none}
.pf-card .pf-dir:hover{text-decoration:underline}
@media(max-width:720px){.pf-results{grid-template-columns:1fr}.pf-search .btn-find,.pf-search .btn-geo{flex:1 1 100%}}

/* ═══════ CONTENT / ARTICLE PAGES (hubs, species, guides) ═══════ */
.art{max-width:820px;margin:0 auto;padding:112px 22px 70px}
.crumbs{font-size:.82rem;color:var(--muted);margin-bottom:14px}
.crumbs a{color:var(--gd);text-decoration:none}
.crumbs a:hover{text-decoration:underline}
.art h1{font-family:var(--serif);font-size:clamp(1.9rem,4vw,2.7rem);color:var(--forest);line-height:1.12;margin:0 0 14px}
.art .lede{font-size:1.12rem;line-height:1.65;color:var(--ink);margin:0 0 8px}
.art h2{font-family:var(--serif);font-size:1.5rem;color:var(--forest);margin:38px 0 12px}
.art h3{font-family:var(--sans);font-weight:700;font-size:1.12rem;color:var(--forest);margin:22px 0 8px}
.art p,.art li{font-size:1rem;line-height:1.72;color:var(--ink)}
.art ul,.art ol{padding-left:22px;margin:10px 0}
.art li{margin:7px 0}
.art a{color:var(--gd);font-weight:600}
.qcards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:18px 0}
.qcard{display:flex;gap:12px;align-items:flex-start;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:14px 16px;box-shadow:var(--sh)}
.qcard .qi{font-size:1.45rem;line-height:1;flex-shrink:0}
.qcard h4{font-family:var(--sans);font-weight:700;font-size:.86rem;color:var(--forest);margin:0 0 2px}
.qcard p{font-size:.9rem;color:var(--muted);margin:0;line-height:1.45}
@media(max-width:680px){.qcards{grid-template-columns:1fr}}
.callout{background:#FFF6E9;border:1px solid #E7C99A;border-radius:14px;padding:16px 18px;margin:20px 0}
.callout strong{color:#7a5a1f}
.steps-num{counter-reset:s;list-style:none;padding-left:0}
.steps-num li{counter-increment:s;position:relative;padding-left:42px;margin:12px 0}
.steps-num li::before{content:counter(s);position:absolute;left:0;top:0;width:28px;height:28px;
  background:var(--forest);color:#fff;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:.85rem;font-family:var(--sans)}
.src-list{list-style:none;padding-left:0}
.src-list li{padding:10px 0;border-bottom:1px solid var(--line)}
.related{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.related a{display:inline-block;background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:8px 14px;font-size:.85rem;font-weight:600;color:var(--forest);text-decoration:none}
.related a:hover{border-color:var(--gold)}
.money{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px 20px;margin:24px 0;box-shadow:var(--sh)}
.money h4{font-family:var(--sans);font-weight:700;color:var(--forest);margin:0 0 6px;font-size:1rem}
.money .mrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.money .mrow a{flex:1 1 auto;text-align:center;background:#fff;border:1px solid var(--gold);color:var(--gd);
  border-radius:12px;padding:10px 12px;font-weight:600;font-size:.85rem;text-decoration:none}
.money .mrow a:hover{background:var(--gold);color:var(--ink)}
.ad-slot{min-height:100px;margin:22px 0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(35,30,21,.02) 10px,rgba(35,30,21,.02) 20px);
  border:1px dashed var(--line);border-radius:12px;display:grid;place-items:center;color:var(--sand);font-size:.78rem}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:18px}
.cat-card{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:14px 16px;text-decoration:none;color:var(--ink);box-shadow:var(--sh);transition:transform .15s}
.cat-card:hover{transform:translateY(-2px);border-color:var(--gold)}
.cat-card .cf{font-size:1.5rem}
.cat-card .cn{font-weight:700;color:var(--forest);font-size:.95rem}
.updated{font-size:.84rem;color:var(--muted);margin-top:30px;padding-top:16px;border-top:1px solid var(--line)}
.byline{font-size:.85rem;color:var(--muted);margin:0 0 18px}
.byline a{color:var(--gd);font-weight:600}
footer .ft-bottom a{color:var(--gold);text-decoration:none}
footer .ft-bottom a:hover{text-decoration:underline}

/* ═══════ TRAVEL CONSULTANT WIDGET ═══════ */
.ag-root{position:fixed;right:20px;bottom:20px;z-index:9999;font-family:var(--sans)}
.ag-fab{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:var(--ink);
  border:0;border-radius:999px;padding:13px 20px 13px 16px;font-family:var(--sans);font-weight:700;
  font-size:.95rem;cursor:pointer;box-shadow:0 10px 30px rgba(35,30,21,.28);transition:transform .15s,background .15s}
.ag-fab:hover{background:var(--gd);color:#fff;transform:translateY(-2px)}
.ag-fab .ag-paw{font-size:1.25rem;line-height:1}
.ag-open .ag-fab{display:none}
.ag-panel{display:none;position:absolute;right:0;bottom:0;width:370px;max-width:calc(100vw - 32px);
  height:560px;max-height:calc(100vh - 40px);background:var(--cream);border:1px solid var(--line);
  border-radius:20px;overflow:hidden;flex-direction:column;box-shadow:0 24px 60px rgba(35,30,21,.34)}
.ag-open .ag-panel{display:flex}
.ag-head{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--forest);
  color:#fff;padding:15px 18px}
.ag-head .ag-ttl{font-family:var(--serif);font-size:1.12rem;font-weight:600}
.ag-head .ag-sub{font-size:.78rem;opacity:.82;margin-top:1px}
.ag-x{background:rgba(255,255,255,.14);color:#fff;border:0;border-radius:8px;width:30px;height:30px;
  font-size:.9rem;cursor:pointer;flex-shrink:0}
.ag-x:hover{background:rgba(255,255,255,.26)}
.ag-body{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:10px}
.ag-msg{max-width:88%;padding:11px 14px;border-radius:16px;font-size:.92rem;line-height:1.5}
.ag-bot{align-self:flex-start;background:var(--card);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:5px}
.ag-user{align-self:flex-end;background:var(--forest);color:#fff;border-bottom-right-radius:5px}
.ag-opts{display:flex;flex-direction:column;gap:7px;margin:2px 0 4px}
.ag-soft{font-size:.78rem;color:var(--muted);margin-bottom:2px}
.ag-opt{display:block;text-align:left;background:#fff;border:1px solid var(--gold);color:var(--gd);
  border-radius:12px;padding:10px 13px;font-family:var(--sans);font-weight:600;font-size:.88rem;
  cursor:pointer;text-decoration:none;transition:background .15s,color .15s}
.ag-opt:hover{background:var(--gold);color:var(--ink)}
.ag-opt.ag-link{border-color:var(--line);color:var(--forest);background:var(--card)}
.ag-opt.ag-link:hover{background:var(--cream);border-color:var(--gold)}
.ag-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--cream)}
.ag-input input{flex:1;min-width:0;border:1px solid var(--line);border-radius:12px;padding:11px 14px;
  font-family:var(--sans);font-size:.92rem;color:var(--ink);background:#fff}
.ag-input input:focus{outline:2px solid var(--gold);outline-offset:1px}
.ag-input button{background:var(--gold);color:var(--ink);border:0;border-radius:12px;width:44px;
  font-size:1rem;cursor:pointer}
.ag-input button:hover{background:var(--gd);color:#fff}
@media(max-width:480px){.ag-root{right:12px;bottom:12px}.ag-panel{width:calc(100vw - 24px);height:calc(100vh - 90px)}}
