/* =========================================================================
   whatpetshouldiget.com — "Polished Playful" refresh
   Shared styles for every static page (home, find, pets/, guides/,
   category/, compare). Same class names as before, so all pages restyle.
   Changes vs. original:
     • Fredoka (display) + Nunito (body) instead of Comic Sans
     • Warm plum "ink" (#3A3340) instead of pure black for text + outlines
     • A real spacing / radius / shadow scale via tokens
     • Lighter 1–2px borders + softer tinted offset shadow (kept the bounce)
     • Heading text-shadow removed by default; opt-in via .tshadow
   ========================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Nunito:ital,wght@0,400;0,600;0,700;0,800;0,900;1,600&display=swap');

:root{
  color-scheme:only light; /* lock the light theme ("only" = opt out of browser auto-darkening);
                              the one exception — Firefox on phones/tablets — is handled at the
                              bottom of this file, since it force-darkens pages regardless */
  /* palette */
  --bg:#FFF8EF;            /* warm paper */
  --card:#FFFFFF;
  --ink:#3A3340;           /* text + outlines (was #2b2b40 pure-ish black) */
  --muted:#8A8390;
  --pop:#FF7A59;           /* coral — primary */
  --pop-d:#F1603C;         /* coral shadow */
  --pop2:#FFC23D;          /* sun — highlight only */
  --blue:#52C4DF;          /* sky — info */
  --green:#5FCF8E;         /* mint — success */
  --purple:#9C6BD6;        /* grape — links/accents */
  /* outlines + shadows */
  --line:rgba(58,51,64,.14);
  --line-2:rgba(58,51,64,.22);
  --sh:0 5px 0 rgba(58,51,64,.16);
  --sh-sm:0 3px 0 rgba(58,51,64,.12);
  --sh-lg:0 8px 0 rgba(58,51,64,.16);
  /* radius */
  --r-sm:12px; --r:16px; --r-lg:20px; --r-xl:26px;
}

*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:"Nunito",system-ui,sans-serif;color:var(--ink);line-height:1.6;font-weight:600;
  -webkit-font-smoothing:antialiased;
  background:
    radial-gradient(circle at 8% 6%,#ffe6cf 0,transparent 42%),
    radial-gradient(circle at 92% 14%,#d9f1fb 0,transparent 42%),
    var(--bg);
}
a{color:inherit}
.wrap{max-width:960px;margin:0 auto;padding:18px}
img,iframe{max-width:100%}
.muted{color:var(--muted);font-size:.92rem;font-weight:700}

/* ---------- display type ---------- */
h1,h2,h3,h4,.cathead,.section-title{font-family:"Fredoka",sans-serif;font-weight:600;letter-spacing:-.01em;line-height:1.08}
h1{font-size:2.4rem;margin:6px 0}
h2{font-size:1.6rem;margin:26px 0 10px}
.lead{font-size:1.12rem;margin:12px 0;color:#5a545f;font-weight:600}
.tagline{font-size:1.1rem;color:var(--muted)}
/* a single playful accent — opt-in, not on every heading */
.tshadow{text-shadow:3px 3px 0 var(--pop2)}

/* ---------- header ---------- */
header.bar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;
  background:rgba(255,255,255,.97);border-bottom:1px solid var(--line);
  padding:12px 20px;position:sticky;top:0;z-index:50}
header .logo{font-family:"Fredoka",sans-serif;font-weight:600;font-size:1.1rem;text-decoration:none;display:flex;align-items:center;gap:10px;color:var(--ink)}
header .paw{width:34px;height:34px;border-radius:11px;background:var(--pop);display:grid;place-items:center;font-size:1.05rem;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.12)}
header nav{display:flex;gap:7px;flex-wrap:wrap;align-items:center}
header nav a,header nav .navdrop-btn{text-decoration:none;color:var(--ink);border-radius:999px;padding:7px 14px;font-weight:800;font-size:.85rem;white-space:nowrap;cursor:pointer;font-family:inherit;
  display:inline-flex;align-items:center;gap:6px;
  transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,background-color .18s,color .18s}
header nav a .ni,header nav .navdrop-btn .ni{display:inline-block;line-height:1}
/* candy-pill containers — one flavor per link */
header nav a.nl,header nav .navdrop-btn.nl{background:var(--nb,var(--card));border:1.5px solid var(--nc,var(--line-2));box-shadow:0 3px 0 var(--nc,var(--line-2))}
.nl-sun{--nc:#FFC23D;--nb:#FFF3D6}
.nl-sky{--nc:#52C4DF;--nb:#E3F6FB}
.nl-mint{--nc:#5FCF8E;--nb:#E4F8EC}
.nl-grape{--nc:#9C6BD6;--nb:#F1E9FB}
.nl-coral{--nc:#FF7A59;--nb:#FFEAE3}
.nl-rose{--nc:#F06292;--nb:#FCE3EC}
header nav a.nl:hover,header nav .navdrop:hover .navdrop-btn.nl,header nav .navdrop.open .navdrop-btn.nl{background:var(--nc,var(--line-2));box-shadow:0 6px 0 var(--nc,var(--line-2))}
header nav a.nl:hover{transform:translateY(-3px) rotate(-2deg)}
header nav a.nl:nth-child(even):hover{transform:translateY(-3px) rotate(2deg)}
header nav a.nl:active{transform:translateY(1px) rotate(0);box-shadow:0 1px 0 var(--nc,var(--line-2))}
header nav a.navcta{background:var(--ink);color:#fff;border:1.5px solid var(--ink);box-shadow:0 3px 0 var(--pop-d)}
header nav a.navcta:hover{background:var(--ink);color:#fff;transform:translateY(-3px) rotate(2deg);box-shadow:0 6px 0 var(--pop-d)}
header nav a.navcta:active{transform:translateY(1px) rotate(0);box-shadow:0 1px 0 var(--pop-d)}
@media (prefers-reduced-motion: no-preference){
  header nav a:hover .ni{animation:navwiggle .5s ease}
  @keyframes navwiggle{0%{transform:rotate(0) scale(1)}30%{transform:rotate(-14deg) scale(1.3)}65%{transform:rotate(10deg) scale(1.15)}100%{transform:rotate(0) scale(1.1)}}
}
@media (prefers-reduced-motion: reduce){
  header nav a,header nav a:hover{transform:none !important}
}

/* ---------- nav dropdowns ---------- */
.navdrop{position:relative;display:inline-flex}
.navdrop .caret{font-size:.68em;margin-left:1px;transition:transform .18s}
.navdrop.open .caret{transform:rotate(180deg)}
.navdrop-menu{display:none;position:absolute;left:0;top:100%;z-index:60;min-width:215px;
  /* transparent strut keeps hover unbroken between the pill and the menu */
  border-top:8px solid transparent;background-clip:padding-box;
  flex-direction:column;gap:2px;padding:8px;background:var(--card);
  border-left:1.5px solid var(--nc,var(--line-2));border-right:1.5px solid var(--nc,var(--line-2));border-bottom:1.5px solid var(--nc,var(--line-2));
  border-radius:16px;box-shadow:0 10px 24px rgba(40,30,60,.16),0 3px 0 var(--nc,var(--line-2))}
.navdrop.open .navdrop-menu{display:flex}
header nav .navdrop-menu a{border-radius:10px;padding:9px 12px;width:100%;justify-content:flex-start}
header nav .navdrop-menu a:hover{background:var(--nb,rgba(125,110,160,.14))}

/* ---------- mobile hamburger ---------- */
.navtoggle{display:none;align-items:center;gap:7px;cursor:pointer;font-family:inherit;font-weight:800;font-size:.9rem;color:var(--ink);
  background:var(--card);border:1.5px solid var(--line-2);border-radius:999px;padding:7px 14px;box-shadow:0 3px 0 var(--line-2)}
.navtoggle:active{transform:translateY(1px);box-shadow:0 1px 0 var(--line-2)}
.navtoggle-ic{display:inline-block;line-height:1;font-size:1rem}
@media(max-width:820px){
  .navtoggle{display:inline-flex}
  header nav{display:none;flex-basis:100%;flex-direction:column;align-items:stretch;gap:8px;padding:10px 0 4px}
  header.bar.nav-open nav{display:flex}
  header nav a,header nav .navdrop-btn{justify-content:center;padding:10px 14px;font-size:.95rem}
  /* dropdowns become accordions inside the hamburger menu */
  .navdrop{display:flex;flex-direction:column;gap:8px}
  .navdrop-menu{position:static;min-width:0;border:none;border-top:none;box-shadow:none;background:transparent;padding:0 0 2px;gap:6px}
  header nav .navdrop-menu a{justify-content:center;background:var(--nb,var(--card));border:1.5px dashed var(--nc,var(--line-2));border-radius:999px}
  header nav .navdrop-menu a:hover{background:var(--nc,var(--line-2))}
}

/* ---------- breadcrumb ---------- */
.crumbs{font-size:.85rem;margin:6px 0 14px;color:var(--muted);font-weight:700}
.crumbs a{color:var(--purple);text-decoration:none;font-weight:800}
.crumbs span{opacity:.55}

/* ---------- buttons ---------- */
.bigbtn{display:inline-flex;align-items:center;justify-content:center;gap:9px;text-decoration:none;text-align:center;
  font-family:"Fredoka",sans-serif;font-weight:500;border:none;background:var(--pop);color:#fff;cursor:pointer;
  border-radius:var(--r);padding:13px 22px;font-size:1.05rem;box-shadow:0 5px 0 var(--pop-d);transition:.1s}
.bigbtn:hover{transform:translateY(-2px);box-shadow:0 7px 0 var(--pop-d)}
.bigbtn:active{transform:translateY(2px);box-shadow:0 2px 0 var(--pop-d)}
.bigbtn.alt{background:var(--blue);color:#fff;box-shadow:0 5px 0 #36a7c2}
.bigbtn.alt:hover{box-shadow:0 7px 0 #36a7c2}.bigbtn.alt:active{box-shadow:0 2px 0 #36a7c2}
.bigbtn.alt2{background:var(--purple);color:#fff;box-shadow:0 5px 0 #7e4fbd}
.bigbtn.alt2:hover{box-shadow:0 7px 0 #7e4fbd}.bigbtn.alt2:active{box-shadow:0 2px 0 #7e4fbd}
.bigbtn.alt3{background:var(--green);color:#fff;box-shadow:0 5px 0 #3DB877}
.bigbtn.alt3:hover{box-shadow:0 7px 0 #3DB877}.bigbtn.alt3:active{box-shadow:0 2px 0 #3DB877}
.bigbtn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:0 4px 0 var(--line)}
.bigbtn.ghost:hover{box-shadow:0 6px 0 var(--line)}.bigbtn.ghost:active{box-shadow:0 1px 0 var(--line)}

/* ---------- contact form ---------- */
.cform{display:flex;flex-direction:column;gap:14px;max-width:520px;margin:18px 0 22px}
.cform label{display:flex;flex-direction:column;gap:6px;font-weight:800}
.cform input,.cform textarea{font:inherit;color:var(--ink);background:#fff;border:2px solid var(--line);border-radius:var(--r-sm);padding:10px 12px}
.cform textarea{resize:vertical}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--pop)}
.cform .cform-send{align-self:flex-start}
.cform .cform-send:disabled{opacity:.6;transform:none;cursor:default}
.cform-err{color:#c0392b;font-weight:800;margin:0}
.cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:24px 0}

/* ---------- chips ---------- */
.chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:7px 14px;font-weight:800;font-size:.84rem;box-shadow:var(--sh-sm)}
.chip b{color:var(--purple)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}

/* ---------- pet/animal page redesign: title bar, snapshot, sections, next-steps ---------- */
.titlebar{display:flex;align-items:flex-start;gap:14px;margin:6px 0 4px}
.titlebar .ticon{width:60px;height:60px;border-radius:18px;background:#fff;border:1px solid var(--line);
  box-shadow:var(--sh-sm);display:grid;place-items:center;flex:none;font-size:2rem}
.titlebar .ticon .picon{width:34px;height:34px}
.titlebar .tmeta{flex:1;min-width:0}
.titlebar h1{margin:0}
.titlebar .printbtn{flex:none;background:#fff;border:1px solid var(--line-2);border-radius:999px;
  width:40px;height:40px;padding:0;font-size:1rem;cursor:pointer;box-shadow:var(--sh-sm);
  line-height:1;display:grid;place-items:center;text-align:center}
.expbadge{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-family:"Fredoka",sans-serif;
  font-weight:500;font-size:.84rem;border-radius:999px;padding:4px 12px;border:1px solid var(--line)}
.expbadge.e0{background:#EAFBEF;border-color:#b6e8c9;color:#2f8f59}
.expbadge.e1{background:#FFF6E0;border-color:#f0dba6;color:#8a6d1f}
.expbadge.e2{background:#FFF0EC;border-color:#f6c9bd;color:var(--pop-d)}
/* snapshot "at a glance" card */
.snap{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:12px 0}
.snapcell{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:11px 12px;box-shadow:var(--sh-sm)}
.snapcell .si{font-size:1.35rem;flex:none;line-height:1}
.snapcell .st{min-width:0}
.snapcell .sk{font-size:.66rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;line-height:1.1}
.snapcell .sv{font-family:"Fredoka",sans-serif;font-weight:500;font-size:.92rem;line-height:1.2;margin-top:1px}
.snapcell .stars{color:var(--pop2);letter-spacing:1px;font-family:"Nunito",sans-serif}
@media(max-width:760px){.snap{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.snap{grid-template-columns:repeat(2,1fr)}}
/* quiet section divider heading (replaces a wall of equally-loud emoji H2s) */
.secrow{display:flex;align-items:center;gap:12px;margin:26px 0 10px}
.secrow h2{margin:0;font-size:1.22rem}
.secrow .ln{flex:1;height:1px;background:var(--line)}
/* compact cost callout (folded in from the old standalone cost section) */
.callout{background:#F3FAFF;border:1px solid #c9e9f4;border-radius:var(--r);padding:11px 15px;margin:12px 0}
/* consolidated "what's next?" zone */
.nextzone{background:linear-gradient(180deg,#fff,#FFF3EC);border:1px solid #f6d6c8;border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);padding:22px 20px;margin:24px 0;text-align:center}
.nextzone h2{margin:0 0 4px;font-size:1.35rem}
.nextzone .sub{color:var(--muted);font-weight:700;font-size:.92rem;margin-bottom:16px}
.nextzone .nextgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:470px;margin:0 auto}
.nextzone .nextgrid .bigbtn{width:100%}
.nextzone .nextcompare{margin-top:16px;font-size:.86rem;font-weight:700;color:var(--muted)}
.nextzone .nextcompare a{font-weight:800;color:var(--purple);text-decoration:none;white-space:nowrap}
@media(max-width:480px){.nextzone .nextgrid{grid-template-columns:1fr}}

/* ---------- notes ---------- */
.note{background:#EAF7FF;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:var(--r);padding:13px 16px;margin:12px 0}
.note.warn{background:#FFF0EC;border-left-color:var(--pop)}
.note.fun{background:#FFF6E0;border-left-color:var(--pop2)}

/* ---------- fun-fact carousel ---------- */
.factcard{background:#FFF6E0;border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;margin:14px 0}
.factcard h2{font-size:1.15rem;margin:0 0 8px}
.factrow{display:flex;align-items:center;gap:12px}
.facttext{flex:1;min-height:3.2em;display:flex;align-items:center;justify-content:center;text-align:center;font-size:1.05rem;margin:0;font-weight:700}
.factnav{flex:none;cursor:pointer;border:none;background:var(--pop2);color:var(--ink);border-radius:50%;width:38px;height:38px;
  font-size:1rem;font-weight:bold;box-shadow:var(--sh-sm);font-family:inherit}
.factnav:hover{transform:translateY(-2px)}.factnav:active{transform:translateY(2px)}
.factdots{display:flex;gap:7px;justify-content:center;margin-top:10px}
.factdots .fd{width:9px;height:9px;border-radius:50%;background:var(--line-2);cursor:pointer;border:none}
.factdots .fd.on{background:var(--pop)}

/* ---------- pros / cons ---------- */
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:14px 0}
@media(max-width:640px){.two{grid-template-columns:1fr}}
.box{border:1px solid var(--line);border-radius:var(--r-lg);padding:16px;box-shadow:var(--sh-sm)}
.box.good{background:#EAFBEF}.box.bad{background:#FFF0EC}
.box ul{margin-left:18px}.box li{margin:5px 0}

/* ---------- care guide ---------- */
.careblock{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:8px 18px;box-shadow:var(--sh-sm)}
.careblock .crow{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--line)}
.careblock .crow:last-child{border-bottom:none}
.careblock .cic{width:40px;height:40px;border-radius:12px;background:var(--bg);display:grid;place-items:center;font-size:1.3rem;flex-shrink:0}
.careblock b{display:block;font-family:"Fredoka",sans-serif;font-weight:500}
/* prominent "Full habitat setup guide →" callout under the Home/care block */
.habitatcta{display:flex;align-items:center;gap:14px;margin:14px 0 4px;padding:14px 18px;
  background:linear-gradient(180deg,#F6EEFF,#EFE2FF);border:1.5px solid var(--purple);
  border-radius:var(--r-lg);box-shadow:var(--sh-sm);text-decoration:none;color:var(--ink);
  transition:transform .15s ease,box-shadow .15s ease}
.habitatcta:hover{transform:translateY(-3px);box-shadow:var(--sh)}
.habitatcta .hcic{width:46px;height:46px;border-radius:14px;background:#fff;display:grid;place-items:center;font-size:1.5rem;flex:none;box-shadow:var(--sh-sm)}
.habitatcta .hctx{display:flex;flex-direction:column;gap:2px;min-width:0}
.habitatcta .hctx b{font-family:"Fredoka",sans-serif;font-weight:600;font-size:1.02rem;color:#5b3a8a}
.habitatcta .hcsub{font-size:.84rem;color:var(--muted);font-weight:700}
.habitatcta .hcgo{margin-left:auto;flex:none;font-family:"Fredoka",sans-serif;font-weight:600;font-size:.9rem;
  color:#fff;background:var(--purple);border-radius:999px;padding:8px 14px;box-shadow:0 3px 0 #7b50b3;white-space:nowrap}
@media(max-width:540px){.habitatcta .hcgo{display:none}}

/* ---------- getting started ---------- */
.startblock{margin-top:18px}
.startlead{font-size:1.04rem;margin:0 0 6px}
.startsub{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.06rem;margin:20px 0 12px}
.startgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.startcard{display:flex;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;box-shadow:var(--sh-sm)}
.startcard .sic{width:40px;height:40px;border-radius:12px;background:var(--bg);display:grid;place-items:center;font-size:1.3rem;flex-shrink:0}
.startcard b{display:block;font-family:"Fredoka",sans-serif;font-weight:500;margin-bottom:2px}
.routinegrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.routinecol{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:6px 16px 14px;box-shadow:var(--sh-sm)}
.rhead{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1rem;margin:0 -16px 8px;padding:11px 16px;border-radius:var(--r) var(--r) 0 0}
.rh-day{background:rgba(255,194,61,.22)}
.rh-week{background:rgba(82,196,223,.20)}
.rh-month{background:rgba(156,107,214,.18)}
.routinecol ul{margin:0;padding-left:20px}
.routinecol li{margin:5px 0;font-weight:600}
@media(max-width:640px){.startgrid,.routinegrid{grid-template-columns:1fr}}

/* ---------- video ---------- */
.vid{margin:22px 0}
.vidframe{position:relative;width:100%;padding-top:56.25%;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);background:#000}
.vidframe iframe{position:absolute;inset:0;width:100%;height:100%}

/* ---------- supplies ---------- */
.supplygrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:8px}
.supplycard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px 10px;text-align:center;box-shadow:var(--sh-sm);display:flex;flex-direction:column}
.supplycard .se{font-size:1.8rem}.supplycard .sl{font-family:"Fredoka",sans-serif;font-weight:500;margin:4px 0 8px}
/* $/$$/$$$ budget badge + product emoji (our rough estimate, not a live price) */
.ptier{display:inline-block;font-weight:800;font-size:.82rem;color:#2e7d52;background:#eafbf1;border:1px solid #cdeed9;border-radius:8px;padding:1px 7px;letter-spacing:1px;line-height:1.5}
/* push the price badge + Amazon button to the card bottom so buttons line up
   across a row regardless of how many lines the title/description take */
.supplycard .ptier{margin:auto 0 8px;align-self:center}
.prodcard .pe{font-size:1.15rem}
.prodcard .pn .ptier{vertical-align:middle;margin-left:4px}
.sbtns{display:flex;gap:6px;justify-content:center}
.shopb{flex:1;text-decoration:none;border:none;border-radius:10px;padding:8px 6px;font-weight:800;font-size:.82rem;box-shadow:var(--sh-sm);transition:transform .08s}
.shopb.chewy{background:#1c6ecf;color:#fff}.shopb.amazon{background:var(--pop2);color:var(--ink)}
.shopb:hover{transform:translateY(-2px)}
.shopb:active{transform:translateY(2px)}

/* ---------- breeds ---------- */
.breedgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:8px}
.breedcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px;box-shadow:var(--sh-sm)}
.breedcard .bn{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.05rem}
.breedcard .bd{font-size:.85rem;margin-top:6px;color:#5a545f}
.bchips{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.bchips span{background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:2px 8px;font-size:.72rem;font-weight:800}
.tag{display:inline-block;background:var(--blue);color:#fff;border-radius:9px;padding:1px 7px;font-size:.68rem;font-weight:800}

/* ---------- pet grids / related ---------- */
.petgrid,.petrow{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-top:10px}
.pet{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px;text-align:center;
  text-decoration:none;color:inherit;box-shadow:var(--sh);cursor:pointer;
  transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,border-color .18s}
.pet:hover{transform:translateY(-6px) rotate(-1.5deg);box-shadow:var(--sh-lg);border-color:var(--pop)}
.pet:nth-child(even):hover{transform:translateY(-6px) rotate(1.5deg)}
.pet:active{transform:translateY(1px) rotate(0)}
.pet .em{font-size:2.2rem}
.pet .nm{font-family:"Fredoka",sans-serif;font-weight:500;margin-top:4px}
.pet .tg{font-size:.76rem;color:var(--muted);font-weight:700}

/* ---------- article ---------- */
.article{max-width:720px;margin:0 auto}
.article .byline{color:var(--muted);margin:6px 0 14px}
.article p{margin:14px 0;font-size:1.06rem}
.article a{color:var(--purple);font-weight:800;text-decoration:underline}
.article a.bigbtn{color:#fff;text-decoration:none}
.ghead{margin:30px 0 2px;font-size:1.35rem;display:flex;align-items:center;gap:8px}
.ghead:first-of-type{margin-top:18px}
.gintro{margin:0 0 12px;color:var(--muted);font-weight:700;font-size:.9rem}
.gcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.gcard{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:14px;text-decoration:none;color:inherit;box-shadow:var(--sh-sm);
  transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,border-color .18s}
.gcard:hover{transform:translateY(-4px) rotate(-.6deg);box-shadow:var(--sh);border-color:var(--purple)}
.gcard:nth-child(even):hover{transform:translateY(-4px) rotate(.6deg)}
.gcard .gem{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;font-size:1.3rem;background:var(--bg);flex:none}
.gcard .gem .gicon{display:block;width:30px;height:30px}
.gcard .gt{font-family:"Fredoka",sans-serif;font-weight:500;font-size:.98rem}
.gcard .gb{font-size:.82rem;color:var(--muted);font-weight:700}

/* ---------- footer ---------- */
footer.bigfooter{margin-top:34px;background:#fff;border-top:1px solid var(--line);padding:28px}
.footcols{max-width:960px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:22px}
.footcol h4{font-size:1rem;margin-bottom:10px;color:var(--ink)}
.footcol a{display:block;text-decoration:none;font-size:.88rem;padding:3px 0;font-weight:700;color:#6a6470;cursor:pointer}
.footcol a:hover{color:var(--purple)}
.footbrand{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.05rem;display:flex;align-items:center;gap:8px}
.footcol p{font-size:.85rem;margin:8px 0;color:var(--muted);font-weight:600}
.footadopt{display:inline-flex;align-items:center;justify-content:center;gap:6px;text-align:center;max-width:230px;margin-top:8px;
  background:var(--pop);color:#fff;border:none;border-radius:var(--r-sm);padding:10px 18px;font-weight:800;box-shadow:0 4px 0 var(--pop-d);text-decoration:none;transition:transform .08s;cursor:pointer}
.footadopt:hover{transform:translateY(-2px)}
.footadopt.footwb{background:var(--pop2);color:var(--ink) !important;box-shadow:0 4px 0 #e0a51f}
.footnote{max-width:960px;margin:20px auto 0;padding-top:16px;border-top:1px solid var(--line);font-size:.8rem;color:var(--muted);text-align:center;font-weight:600}

/* ---------- homepage ---------- */
.homehero{text-align:center;padding:34px 10px 12px}
.homehero h1{font-size:2.9rem}
.homehero .hl{color:var(--pop);white-space:nowrap}
@media(max-width:480px){.homehero h1{font-size:clamp(1.6rem,9.5vw,2.4rem)}}
.homehero .hl .wv{display:inline-block}
@media (prefers-reduced-motion: no-preference){
  .homehero .hl .wv{animation:hlwave 1.9s ease-in-out infinite;animation-delay:calc(var(--i,0)*.08s)}
  @keyframes hlwave{0%,100%{transform:translateY(0)}25%{transform:translateY(-7px) rotate(-3deg)}50%{transform:translateY(0)}}
}
.homehero .lead{max-width:620px;margin:12px auto 8px}
.trustbadge{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:6px 15px;font-size:.82rem;font-weight:800;color:#6a6470;box-shadow:var(--sh-sm)}
.subnote{color:var(--muted);font-size:.9rem;font-weight:700;margin-top:12px}
.quizcount{display:inline-block;margin:12px auto 0;padding:7px 16px;border-radius:999px;background:#fff3d6;color:#7a5b12;font-weight:800;font-size:1rem;box-shadow:0 2px 0 rgba(0,0,0,.05)}
.quizcount b{font-variant-numeric:tabular-nums}
.quizcount-top{display:block;width:fit-content;margin:6px auto 2px;text-align:center}
.floaty{font-size:3rem;display:inline-block}
.m-blob{width:96px;height:96px;border-radius:30px 30px 34px 34px;margin:6px auto 0;display:grid;place-items:center;font-size:3rem;
  background:radial-gradient(circle at 35% 30%,#fff 0,#ffe7d6 60%,#ffd0b3 100%);box-shadow:0 12px 0 var(--line)}
.hero-blobs{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-blobs .m-blob{margin:6px 0 0}
.m-blob.blob-sky{background:radial-gradient(circle at 35% 30%,#fff 0,#e0f4fb 60%,#bfe7f4 100%)}   /* sky */
.m-blob.blob-grape{background:radial-gradient(circle at 35% 30%,#fff 0,#efe6fa 60%,#dcc8f2 100%)} /* grape */
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media (prefers-reduced-motion: no-preference){
  .floaty{animation:bob 2.6s ease-in-out infinite}
}

/* ---------- section head row ---------- */
.sechead{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:30px 0 12px}
.sechead h2{margin:0}
.sechead a{color:var(--muted);text-decoration:none;font-weight:800;font-size:.9rem}
.sechead a:hover{color:var(--pop)}

/* ---------- category grid (tinted icon tiles) ---------- */
.catgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:8px}
.catcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;text-align:center;
  text-decoration:none;color:inherit;box-shadow:var(--sh);overflow:hidden;cursor:pointer;
  transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,border-color .18s}
.catcard:hover{transform:translateY(-6px) rotate(-1deg);box-shadow:var(--sh-lg);border-color:var(--pop)}
.catcard:nth-child(even):hover{transform:translateY(-6px) rotate(1deg)}
.catcard:active{transform:translateY(1px) rotate(0)}
.catcard-em{width:58px;height:58px;border-radius:18px;margin:0 auto 10px;display:grid;place-items:center;font-size:1.9rem;background:var(--bg)}
.catcard-nm{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.12rem}
.catcard-ct{font-size:.82rem;color:var(--muted);font-weight:700}
.catcard-samp{display:flex;gap:6px;justify-content:center;margin-top:8px;font-size:1.1rem;opacity:.85}
/* tints — apply with a second class on .catcard-em (or quiz answer tiles) */
.t-coral{background:#FFE7DE}.t-sun{background:#FFF1CC}.t-sky{background:#DAF3FA}
.t-mint{background:#DCF5E6}.t-grape{background:#EEE3FA}.t-rose{background:#FCE3EC}.t-amber{background:#FCEBD2}

/* ---------- fun tile hovers (wiggles & bounces) ---------- */
@media (prefers-reduced-motion: no-preference){
  .pet:hover .em,.catcard:hover .catcard-em,.gcard:hover .gem{animation:tilepop .5s ease both}
  .catcard:hover .catcard-samp .picon{animation:sampbounce .55s ease both}
  .catcard:hover .catcard-samp .picon:nth-child(2){animation-delay:.07s}
  .catcard:hover .catcard-samp .picon:nth-child(3){animation-delay:.14s}
  .catcard:hover .catcard-samp .picon:nth-child(4){animation-delay:.21s}
  .vslinks a:hover .picon{animation:tilepop .5s ease both}
  @keyframes tilepop{0%{transform:rotate(0) scale(1)}30%{transform:rotate(-12deg) scale(1.25)}65%{transform:rotate(9deg) scale(1.1)}100%{transform:rotate(0) scale(1.08)}}
  @keyframes sampbounce{0%,100%{transform:translateY(0)}40%{transform:translateY(-6px) scale(1.15)}}
}
@media (prefers-reduced-motion: reduce){
  .pet:hover,.catcard:hover,.gcard:hover,.vslinks a:hover{transform:none}
}
.catsection{margin-top:18px}
.cathead{font-size:1.3rem}
.intro{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh);margin:24px 0}
.intro a{color:var(--purple);font-weight:800}
.adoptcta{background:linear-gradient(135deg,#EAFBF1,#E0F6FB);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:24px;box-shadow:var(--sh);margin:26px 0;text-align:center}
.adoptcta a{color:var(--purple);font-weight:800}

/* ---------- pet-of-the-day ---------- */
#potd .sechead h2{display:flex;align-items:center;gap:8px}
.potdcard{display:flex;gap:16px;align-items:center;flex-wrap:wrap;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--sh)}
.potd-em{width:72px;height:72px;border-radius:22px;display:grid;place-items:center;font-size:2.2rem;
  background:radial-gradient(circle at 35% 30%,#fff,#ffe7d6 70%,#ffd0b3);box-shadow:0 6px 0 var(--line);flex:none}
.potd-em .picon{height:44px;width:44px}
.potd-n{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.3rem}
.potd-t{color:#5a545f;margin:2px 0 12px;font-weight:600}
.potd-when{color:var(--muted);font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em}

/* ---------- collectible "pets I've met" strip ---------- */
.collect{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--sh);
  margin:24px 0;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.collect-h{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.1rem}
.collect-h b{color:var(--pop)}
.collect-bar{flex:1;min-width:160px;height:12px;background:var(--bg);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.collect-bar>div{height:100%;background:linear-gradient(90deg,var(--green),var(--blue));border-radius:999px;transition:width .5s}

/* ---------- real-photo hero + pet page bits ---------- */
.pethero{margin:0 0 16px;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh)}
.pethero img{display:block;width:100%;height:auto;max-height:340px;object-fit:cover}
.pethero figcaption{font-size:.75rem;color:var(--muted);background:#fff;padding:6px 12px;text-align:right}
.dhero{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-top:6px}
.dhero .demoji{font-size:4rem}

/* ---------- 404 page ---------- */
.nf{text-align:center;padding:24px 10px 10px}
.nf-emoji{font-size:5rem;display:inline-block;cursor:pointer;user-select:none}
@media (prefers-reduced-motion: no-preference){.nf-emoji{animation:bob 2s ease-in-out infinite}}
.nf h1{font-size:5rem;text-shadow:4px 4px 0 var(--pop2);margin:0}
.nf-joke{font-size:1.2rem;font-weight:800;margin:6px auto 20px;max-width:560px}
.poster{position:relative;max-width:420px;margin:0 auto 20px;background:#fffdf5;border:1px dashed var(--line-2);
  border-radius:10px;padding:22px 20px;transform:rotate(-2deg);box-shadow:0 6px 0 rgba(58,51,64,.12);text-align:center}
.poster-h{font-family:"Fredoka",sans-serif;font-weight:600;font-size:1.35rem;letter-spacing:1px;margin-bottom:8px}
.poster p{font-size:.95rem;line-height:1.7}
.poster-tape{position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(3deg);
  width:90px;height:22px;background:rgba(255,194,61,.75);border:1px solid rgba(58,51,64,.2)}
.nf .muted a{color:var(--purple);font-weight:800}

/* ===== FAQ accordions (pet pages) ===== */
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 14px;margin:8px 0;box-shadow:var(--sh-sm)}
.faq summary{font-weight:800;cursor:pointer}
.faq p{margin:8px 0 2px}

/* ===== comparison pages (X vs Y) ===== */
.vswrap{border:1px solid var(--line);border-radius:var(--r);overflow-x:auto;background:#fff;margin:14px 0;box-shadow:var(--sh-sm)}
.vstable{width:100%;border-collapse:collapse;min-width:480px}
.vstable th,.vstable td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;font-weight:700}
.vstable thead th{background:var(--ink);color:#fff;font-family:"Fredoka",sans-serif;font-weight:500;font-size:1rem}
.vstable tbody tr:nth-child(odd) td{background:#FFFBF4}
.vstable tr:last-child td{border-bottom:none}
.vstable td:first-child{font-weight:800;white-space:nowrap;color:var(--muted)}
.vslinks{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.vslinks a{background:#fff;border:1px solid var(--line);border-radius:12px;padding:7px 13px;font-weight:800;font-size:.82rem;text-decoration:none;color:var(--ink);box-shadow:var(--sh-sm);
  transition:transform .18s cubic-bezier(.34,1.56,.64,1),border-color .18s}
.vslinks a:hover{transform:translateY(-3px) rotate(-1deg);border-color:var(--pop)}
.vslinks a:nth-child(even):hover{transform:translateY(-3px) rotate(1deg)}

/* ===== shortlist (favorites) ===== */
.favbtn{cursor:pointer;border:1px solid var(--line);background:#fff;border-radius:var(--r-sm);padding:9px 15px;font-weight:800;
  font-size:.9rem;box-shadow:var(--sh-sm);font-family:inherit}
.favbtn.on{background:var(--pop2)}
.shortliststrip{max-width:960px;margin:20px auto 0;padding:12px 16px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center;font-size:.92rem;box-shadow:var(--sh-sm)}
.shortliststrip a{color:var(--ink);font-weight:800}
.shortliststrip .sx{cursor:pointer;border:none;background:none;font-weight:bold;font-family:inherit}
.cmpcols select{font-family:inherit;font-weight:800;border:1px solid var(--line);border-radius:11px;padding:9px 12px;font-size:1rem;background:#fff}

/* ===== printable care sheets ===== */
@media print{
  header.bar,footer.bigfooter,.crumbs,.cta,.vid,.supplygrid,.breedgrid,.petrow,
  .factnav,.factdots,.printbtn,.favbtn,.shortliststrip,.collect,.noprint,.faq summary::marker{display:none!important}
  .faq details{border:1px solid #999;box-shadow:none}
  .faq details[open] summary~*{display:block}
  body{background:#fff}
  .pethero,.factcard,.careblock,.box,.catcard,.pet{box-shadow:none}
  a{text-decoration:none;color:#000}
}

/* ===== compare tool: each pet column is its own card ===== */
.cmpwrap{overflow-x:auto;margin:14px 0;padding-bottom:8px}
.cmptable{border-collapse:separate;border-spacing:10px 0;min-width:480px;width:100%;table-layout:fixed}
.cmptable th,.cmptable td{padding:10px 14px;text-align:left;vertical-align:top;font-weight:700;overflow-wrap:break-word}
.cmptable td:first-child,.cmptable th:first-child{font-weight:800;white-space:nowrap;background:transparent;padding-left:0;color:var(--muted);width:150px}
.cmptable .pc{background:#fff;border-left:1px solid var(--line);border-right:1px solid var(--line)}
.cmptable thead .pc{background:var(--ink);color:#fff;font-family:"Fredoka",sans-serif;font-weight:500;border-radius:var(--r) var(--r) 0 0;text-align:center;font-size:1rem}
.cmptable thead .pc .sx{color:#fff;opacity:.8}
.cmptable tbody tr:nth-child(odd) .pc{background:#FFFBF4}
.cmptable tbody tr:last-child .pc{border-bottom:1px solid var(--line);border-radius:0 0 var(--r) var(--r);box-shadow:var(--sh-sm)}
.cmptable .win{color:#1f9d6b;font-weight:900}

/* ===== clay pet icons (replace emojis; sized via parent font-size) ===== */
.picon{height:1em;width:1em;object-fit:contain;display:inline-block;vertical-align:-0.12em}

/* compare tool: bigger pet icons in the column headers */
.cmptable .picon{height:1.9em;width:1.9em;vertical-align:-0.55em}

/* pet pages: bigger icons in the "Compare before you choose" pills */
.vslinks .picon{height:2em;width:2em;vertical-align:-0.65em}

/* 15% bigger icons: pet-page "more to explore" rows + homepage category samples */
.petrow .picon{height:1.15em;width:1.15em}
.catcard-samp .picon{height:1.44em;width:1.44em;vertical-align:-0.3em}

/* compare tool: icon picker menu */
.cmpmenu{position:absolute;z-index:60;top:110%;left:0;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:0 18px 40px -16px rgba(58,51,64,.35);max-height:330px;overflow-y:auto;padding:6px;display:grid;grid-template-columns:repeat(2,minmax(170px,1fr));gap:2px;min-width:360px;max-width:92vw}
.cmpopt{display:flex;align-items:center;gap:8px;border:none;background:none;font-family:inherit;font-weight:800;font-size:.92rem;padding:7px 10px;border-radius:10px;cursor:pointer;text-align:left;color:var(--ink)}
.cmpopt:hover{background:var(--bg)}
.cmpmenu .picon{height:22px;width:22px}

/* ============================================================
   DARK THEME — Firefox on mobile ONLY.
   Firefox for Android force-darkens pages no matter what we
   declare, so instead of letting it invent unreadable colors we
   hand it this designed dark theme. Everyone else (all desktop
   browsers, Chrome/Safari mobile) keeps the locked light theme.
   Targeting: (pointer:coarse) = touch device, and
   @supports (-moz-appearance:none) = Gecko/Firefox engine only.
   ============================================================ */
@media (prefers-color-scheme:dark) and (pointer:coarse){
@supports (-moz-appearance:none){
  :root{
    color-scheme:dark;
    --bg:#1e1e30; --card:#2a2a42; --ink:#ece7f6; --muted:#a9a5c0;
    --pop:#ff7a59; --pop-d:#c94e30; --pop2:#ffc23d;
    --blue:#52c4df; --green:#5fcf8e; --purple:#b48ae0;
    --line:rgba(236,231,246,.18); --line-2:rgba(236,231,246,.3);
    --sh:0 5px 0 rgba(0,0,0,.4); --sh-sm:0 3px 0 rgba(0,0,0,.35); --sh-lg:0 8px 0 rgba(0,0,0,.4);
    --onpop:#26263c; /* dark "ink" for text on colorful buttons/chips */
  }
  body{background:radial-gradient(circle at 10% 10%,#2c2342 0,transparent 40%),
                  radial-gradient(circle at 90% 18%,#1f2e3e 0,transparent 40%),var(--bg)}
  .lead,.potd-t,.breedcard .bd{color:var(--muted)}
  header.bar{background:rgba(42,42,66,.92)}
  /* nav pills: dark bodies, keep the candy borders; hover fills with the accent */
  header nav a.nl,header nav .navdrop-btn.nl,header nav .navdrop{--nb:#363052}
  header nav a.nl:hover,header nav .navdrop:hover .navdrop-btn.nl,header nav .navdrop.open .navdrop-btn.nl{color:var(--onpop)}
  .navdrop-menu{box-shadow:0 10px 24px rgba(0,0,0,.5),0 3px 0 var(--nc,var(--line-2))}
  header nav .navdrop-menu a{color:var(--ink)}
  header nav .navdrop-menu a:hover{background:var(--nc,var(--line-2));color:var(--onpop)}
  header nav a.navcta{background:var(--pop2);border-color:var(--pop2);color:var(--onpop);box-shadow:0 3px 0 rgba(0,0,0,.4)}
  header nav a.navcta:hover{background:var(--pop2);color:var(--onpop);box-shadow:0 6px 0 rgba(0,0,0,.4)}
  /* white surfaces -> card navy */
  .chip,.catcard,.pet,.gcard,.intro,.potdcard,.collect,.careblock,.supplycard,.breedcard,
  .factdots .fd,.favbtn,.shortliststrip,.faq details,.vswrap,.vslinks a,.cmpmenu,
  .snapcell,.titlebar .ticon,.titlebar .printbtn,
  .pethero figcaption,.bigbtn.ghost,.cmpcols select{background:var(--card);color:var(--ink)}
  .callout{background:#22364a}
  .nextzone{background:#3b3324}
  .factdots .fd.on{background:var(--pop)}
  .cmptable .pc,.cmptable tbody tr:nth-child(odd) .pc{background:var(--card)}
  .vstable tbody tr:nth-child(odd) td{background:#32304b}
  .vstable thead th,.cmptable thead .pc{background:#11111d}
  .careblock .cic,.gcard .gem,.catcard-em,.bchips span,.collect-bar,.cmpopt:hover{background:#363052}
  .t-coral,.t-sun,.t-sky,.t-mint,.t-grape,.t-rose,.t-amber{background:#363052}
  /* text on yellow / orange / blue stays dark */
  .shopb.amazon{color:var(--onpop)}
  .factnav{color:var(--onpop)}
  .favbtn.on{background:var(--pop2);color:var(--onpop)}
  .footadopt.footwb{color:var(--onpop) !important;box-shadow:0 4px 0 rgba(0,0,0,.4)}
  .tag{color:#fff}
  /* tinted panels get deep-color versions */
  .note{background:#22364a}
  .note.warn{background:#41282c}
  .note.fun,.factcard{background:#3b3324}
  .box.good{background:#23382c}.box.bad{background:#41282c}
  .adoptcta{background:#23382c}
  footer.bigfooter{background:var(--card)}
  .footcol a{color:var(--muted)}
  .m-blob,.potd-em{background:radial-gradient(circle at 35% 30%,#4a4066,#363052 70%,#2a2a42)}
  /* 404 "missing" poster */
  .poster{background:#2e2c40;box-shadow:0 6px 0 rgba(0,0,0,.35)}
  .poster-tape{background:rgba(255,194,61,.4);border-color:rgba(236,231,246,.25)}
  .nf h1{text-shadow:4px 4px 0 rgba(255,194,61,.35)}
  .tshadow{text-shadow:3px 3px 0 rgba(255,194,61,.35)}
}
}

/* ---- feedback popup ("Are you enjoying this site?") ---- */
#fbcard{position:fixed;right:16px;bottom:16px;z-index:9999;width:min(320px,calc(100vw - 32px));
  background:var(--card);border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--sh-lg);
  padding:16px 18px;font-family:inherit;
  opacity:0;transform:translateY(14px);transition:opacity .3s ease,transform .3s ease}
#fbcard.show{opacity:1;transform:none}
#fbcard .fbx{position:absolute;top:8px;right:10px;cursor:pointer;border:none;background:none;
  font-size:15px;font-weight:800;color:var(--muted);padding:4px;line-height:1}
#fbcard .fbx:hover{color:var(--ink)}
#fbcard .fbq{font-family:Fredoka,Nunito,sans-serif;font-weight:600;font-size:17px;color:var(--ink);
  padding-right:18px;display:flex;align-items:center;gap:8px}
#fbcard .fbemoji{font-size:22px}
#fbcard .fbstars{display:flex;gap:4px;justify-content:center;margin-top:10px}
#fbcard .fbstar{cursor:pointer;border:none;background:none;font-size:30px;line-height:1;padding:2px;
  color:var(--line-2);transition:transform .12s ease,color .12s ease}
#fbcard .fbstar:hover{transform:scale(1.18)}
#fbcard .fbstar.on{color:var(--pop2)}
#fbcard .fbmore{margin-top:10px}
#fbcard .fbtext{width:100%;resize:none;border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:8px 10px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff}
#fbcard .fbtext:focus{outline:2px solid var(--blue)}
#fbcard .fbsend{margin-top:8px;width:100%;cursor:pointer;border:none;border-radius:var(--r-sm);
  background:var(--pop);color:#fff;font-family:inherit;font-weight:800;font-size:15px;padding:9px 0;
  box-shadow:0 3px 0 var(--pop-d)}
#fbcard .fbsend:active{transform:translateY(2px);box-shadow:none}
/* honeypot: visually & physically hidden from real users, still in the DOM
   so form-filling bots trip it (don't use display:none — some bots skip those) */
#fbcard .fbhp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;opacity:0}
@media print{#fbcard{display:none!important}}

/* inline "rate the site" block at the end of the quiz (find.html #rRating).
   Reuses the same feedback pipeline as #fbcard, styled to sit in the result panel. */
.qrate{position:relative;margin:24px auto 4px;max-width:440px;text-align:center;
  background:var(--card2,#fff);border:1px solid var(--line-2);border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);padding:16px 18px}
.qrate-q{font-family:Fredoka,Nunito,sans-serif;font-weight:600;font-size:18px;color:var(--ink);
  display:flex;align-items:center;justify-content:center;gap:8px}
.qrate-emoji{font-size:22px}
.qrate-stars{display:flex;gap:6px;justify-content:center;margin-top:10px}
.qrate-star{cursor:pointer;border:none;background:none;font-size:34px;line-height:1;padding:2px;
  color:var(--line-2);transition:transform .12s ease,color .12s ease}
.qrate-star:hover{transform:scale(1.18)}
.qrate-star.on{color:var(--pop2)}
.qrate-more{margin-top:12px}
.qrate-text{width:100%;resize:none;border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:8px 10px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff}
.qrate-text:focus{outline:2px solid var(--blue)}
.qrate-send{margin-top:8px;cursor:pointer;border:none;border-radius:var(--r-sm);
  background:var(--pop);color:#fff;font-family:inherit;font-weight:800;font-size:15px;padding:9px 22px;
  box-shadow:0 3px 0 var(--pop-d)}
.qrate-send:active{transform:translateY(2px);box-shadow:none}
.qrate-hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;opacity:0}
@media print{.qrate{display:none!important}}

/* ---- 🐾 secret paw hunt ---- */
.hpaw{cursor:pointer;border:none;background:none;font-size:20px;line-height:1;padding:4px;
  opacity:.32;filter:grayscale(.4);transform:rotate(-18deg);display:inline-block;
  transition:opacity .2s ease,transform .2s ease;vertical-align:middle}
.hpaw:hover,.hpaw:focus-visible{opacity:.9;filter:none;transform:rotate(8deg) scale(1.25)}
.hpaw.found{opacity:.85;filter:none}
.hpaw.found::after{content:'✓';font-size:11px;font-weight:900;color:var(--green);
  position:relative;top:-9px;left:-3px}
.hpaw.pop{animation:pawpop .5s ease}
@keyframes pawpop{0%{transform:scale(1)}45%{transform:scale(1.8) rotate(20deg)}100%{transform:scale(1) rotate(8deg)}}
.dhero .hpaw{align-self:flex-end}

.pawtoast{position:fixed;left:50%;bottom:18px;transform:translate(-50%,16px);z-index:10000;
  width:min(360px,calc(100vw - 32px));background:var(--card);border:1px solid var(--line-2);
  border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:13px 16px;text-align:center;
  font-weight:700;opacity:0;transition:opacity .3s ease,transform .3s ease}
.pawtoast.show{opacity:1;transform:translate(-50%,0)}
.pawtoast .pawhint{color:var(--muted);font-size:.9rem;font-weight:700}

.pawmodal{position:fixed;inset:0;z-index:10001;background:rgba(58,51,64,.45);
  display:flex;align-items:center;justify-content:center;padding:18px}
.pawmodal-card{position:relative;background:var(--card);border:2px solid var(--ink);
  border-radius:var(--r-xl);box-shadow:var(--sh-lg);padding:26px 24px;max-width:380px;text-align:center}
.pawmodal-card h3{font-size:1.5rem;margin:8px 0 6px}
.pawmodal-card p{margin-bottom:14px}
.pawmodal-big{font-size:1.6rem;letter-spacing:4px}
.pawmodal-big .pawghost{opacity:.22;filter:grayscale(1)}
.pawmodal-card .pawhint{color:var(--muted);font-size:.9rem;font-weight:700}
.pawmodal .fbx{position:absolute;top:8px;right:10px;cursor:pointer;border:none;background:none;
  font-size:15px;font-weight:800;color:var(--muted);padding:4px;line-height:1}

.pawconfetti{position:fixed;top:-40px;z-index:10002;pointer-events:none;
  animation:pawfall 2.8s linear forwards}
@keyframes pawfall{
  0%{transform:translateY(0) rotate(0)}
  100%{transform:translateY(105vh) rotate(340deg)}}

/* ---- secret Samantha page ---- */
.secretbanner{display:inline-block;background:var(--ink);color:#fff;font-family:Fredoka,Nunito,sans-serif;
  font-weight:600;border-radius:999px;padding:8px 18px;margin:10px 0 4px;letter-spacing:.04em;
  box-shadow:0 4px 0 var(--pop-d)}
.snifferbadge{display:inline-block;background:#FFF6E0;border:2px solid var(--pop2);border-radius:var(--r);
  padding:10px 16px;margin:10px 0;font-weight:800;box-shadow:var(--sh-sm)}
.snifferbadge.teaser{background:#EAF7FF;border-color:var(--blue)}
@media print{.pawtoast,.pawmodal,.pawconfetti,.hpaw{display:none!important}}

/* ============================================================
   Test Your Knowledge — quiz pages, hub, cards & cross-links
   ============================================================ */
/* ---- quiz hub (index) ---- */
.quizindex-hero{text-align:center;margin:6px 0 18px}
.quizindex-hero h1{margin:0 0 6px}
.quizprogress{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;margin:0 0 24px;box-shadow:var(--sh-sm)}
.quizprogress-h{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.12rem;margin-bottom:10px}
.quizprogress-h b{font-variant-numeric:tabular-nums}
.quizprogress-bar{height:14px;background:var(--bg);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.quizprogress-bar>div{height:100%;background:linear-gradient(90deg,var(--pop2),var(--pop));border-radius:999px;transition:width .6s}
.quizprogress .muted{margin:8px 0 0;font-size:.86rem}

/* ---- quiz card grid (hub, category, compare, cross-links) ---- */
.quizgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin:8px 0 16px}
.quizcard{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 12px;text-decoration:none;color:var(--ink);
  box-shadow:var(--sh-sm);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.quizcard:hover{transform:translateY(-5px) rotate(-1deg);box-shadow:var(--sh-lg);border-color:var(--purple)}
.quizcard:nth-child(even):hover{transform:translateY(-5px) rotate(1deg)}
.quizcard .picon{width:40px;height:40px;margin-bottom:2px}
.quizcard-nm{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1rem;line-height:1.2}
.quizcard-ct{font-size:.76rem;color:var(--muted);font-weight:700}
.quizcard.done{border-color:var(--green)}
.quizcard-badge{position:absolute;top:-10px;right:-8px;font-size:1.35rem;line-height:1;filter:drop-shadow(0 2px 1px rgba(0,0,0,.18))}
.quizcard-badge:empty{display:none}

/* ---- quiz page hero ---- */
.quizpage{position:relative}
.quizhero{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:6px 0 18px}
.quizhero-em{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;background:var(--bg);border:1px solid var(--line);position:relative;flex:none}
.quizhero-em .picon{width:40px;height:40px}
.quizhero-em span{position:absolute;bottom:-6px;right:-6px;font-size:1.3rem}
.quizhero-tx{flex:1;min-width:220px}
.quizhero-tx h1{margin:0 0 2px}
.quizbest{margin-top:8px;min-height:26px}
.quizbest-badge{display:inline-block;font-weight:800;font-size:.9rem;padding:5px 12px;border-radius:999px;background:var(--bg);border:1px solid var(--line)}
.quizbest-badge.gold{background:#FFF3D6;border-color:#f0c419;color:#7a5b12}
.quizbest-badge.silver{background:#eef1f5;border-color:#c4ccd6;color:#5a6472}
.quizbest-badge.bronze{background:#f7ece0;border-color:#d8a878;color:#7a5325}
.quizbest-badge.sprout,.quizbest-badge.none{background:#EAF7FF;border-color:var(--blue);color:#2d6f86}

/* ---- quiz stage (live questions) ---- */
.quizstage{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:22px;box-shadow:var(--sh);min-height:120px}
.quizbar{height:10px;background:var(--bg);border:1px solid var(--line);border-radius:999px;overflow:hidden;margin-bottom:14px}
.quizbar-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--green));border-radius:999px;transition:width .4s}
.quizmeta{font-size:.85rem;color:var(--muted);font-weight:700;margin-bottom:6px}
.quizmeta b{color:var(--ink);font-variant-numeric:tabular-nums}
.quizq{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.3rem;line-height:1.3;margin:0 0 16px}
.quizopts{display:grid;gap:10px}
.quizopt{display:flex;align-items:center;gap:12px;text-align:left;width:100%;cursor:pointer;
  background:#fff;border:2px solid var(--line-2);border-radius:var(--r);padding:13px 14px;font:inherit;color:var(--ink);
  box-shadow:0 3px 0 var(--line);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease}
.quizopt:hover:not(.locked){transform:translateY(-2px);border-color:var(--purple);box-shadow:0 5px 0 var(--line)}
.quizopt:active:not(.locked){transform:translateY(1px);box-shadow:0 1px 0 var(--line)}
.quizopt-key{flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-weight:800;background:var(--bg);color:var(--muted)}
.quizopt-txt{flex:1;font-weight:600}
.quizopt.locked{cursor:default}
.quizopt.right{border-color:var(--green);background:#EAFBF1}
.quizopt.right .quizopt-key{background:var(--green);color:#fff}
.quizopt.chosen-right{border-color:var(--green);background:#EAFBF1}
.quizopt.chosen-wrong{border-color:var(--pop);background:#FFF0EC}
.quizopt.chosen-wrong .quizopt-key{background:var(--pop);color:#fff}
.quizopt.locked:not(.right):not(.chosen-wrong){opacity:.6}
.quizfb{margin-top:16px;border-radius:var(--r);padding:14px 16px;border:1px solid var(--line);animation:quizfbin .25s ease both}
.quizfb.ok{background:#EAFBF1;border-left:4px solid var(--green)}
.quizfb.no{background:#FFF0EC;border-left:4px solid var(--pop)}
.quizfb-head{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.1rem;margin-bottom:2px}
.quizfb p{margin:2px 0 0}
.quizfact{margin-top:10px;background:#FFF6E0;border-radius:var(--r-sm);padding:9px 12px;font-size:.92rem}
@keyframes quizfbin{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.quiznav{margin-top:16px;display:flex;justify-content:flex-end}
.quiznext-btn{padding:11px 20px}

/* ---- quiz results ---- */
.quizresults{margin-top:8px}
.quizscorecard{text-align:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:26px 22px;box-shadow:var(--sh);margin:8px 0 24px}
.quizscore-badge{font-size:3.4rem;line-height:1;animation:scorepop .5s cubic-bezier(.2,1.4,.5,1) both}
@keyframes scorepop{from{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}
.quizscore-num{font-family:"Fredoka",sans-serif;font-weight:500;font-size:2.2rem;margin-top:6px}
.quizscore-pct{font-weight:800;color:var(--muted)}
.quizscore-label{font-family:"Fredoka",sans-serif;font-weight:500;font-size:1.25rem;margin-top:6px}
.quizscore-msg{max-width:34ch;margin:8px auto 16px}
.quizrecap-list{list-style:none;padding:0;margin:8px 0 24px;display:grid;gap:10px}
.quizrecap-list li{background:#fff;border:1px solid var(--line);border-left:4px solid var(--green);border-radius:var(--r);padding:12px 15px;display:grid;gap:3px}
.recap-q{font-weight:700}
.recap-a{color:#2d8a55;font-weight:800;font-size:.95rem}
.recap-w{color:var(--muted);font-size:.92rem}
.quizall{text-align:center;margin-top:12px}
.quizall a{color:var(--purple);font-weight:800;text-decoration:none}
.quizall a:hover{color:var(--pop)}

/* ---- promo block on care-guide pages ---- */
.quizpromo{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center;text-align:center;
  background:linear-gradient(135deg,#FFF6E0,#EAF7FF);border:1px solid var(--line);border-radius:var(--r-xl);padding:20px 22px;margin:22px 0}
.quizpromo-ic{position:relative;flex:none}
.quizpromo-ic .picon{width:52px;height:52px}
.quizpromo-ic span{position:absolute;bottom:-4px;right:-8px;font-size:1.4rem}
.quizpromo-tx{flex:1;min-width:240px;text-align:left}
.quizpromo-tx h2{margin:0 0 4px}
.quizpromo-tx p{margin:0;color:var(--ink)}

/* ---- homepage feature band ---- */
.quizhome{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;
  background:linear-gradient(135deg,#F3ECFF,#EAF7FF);border:1px solid var(--line);border-radius:var(--r-xl);padding:24px 26px;margin:30px 0}
.quizhome-tx{flex:1;min-width:260px}
.quizhome-tx h2{margin:0 0 6px}
.quizhome-tx p{margin:0 0 14px;max-width:52ch}
.quizhome-em{display:flex;gap:8px;flex:none}
.quizhome-em .picon{width:42px;height:42px;animation:floaty 3s ease-in-out infinite}
.quizhome-em .picon:nth-child(2){animation-delay:.3s}
.quizhome-em .picon:nth-child(3){animation-delay:.6s}
.quizhome-em .picon:nth-child(4){animation-delay:.9s}
.quizhome-em .picon:nth-child(5){animation-delay:1.2s}
.quizhome-em .picon:nth-child(6){animation-delay:1.5s}

/* ---- confetti on a perfect score ---- */
.quizconfetti{position:fixed;inset:0;pointer-events:none;z-index:9999;overflow:hidden}
.quizconfetti i{position:absolute;top:-12px;width:9px;height:14px;border-radius:2px;animation:quizfall 2.4s linear forwards}
@keyframes quizfall{to{transform:translateY(105vh) rotate(540deg);opacity:.9}}

@media (max-width:560px){
  .quizgrid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .quizq{font-size:1.15rem}
  .quizstage{padding:16px}
  .quizpromo-tx,.quizhome-tx{text-align:center}
}
@media (prefers-reduced-motion:reduce){
  .quizscore-badge,.quizhome-em .picon,.quizconfetti i,.quizfb{animation:none}
}

/* ---- Daily Challenge banner (hub) + daily hero icon ---- */
.dailybanner{display:flex;align-items:center;gap:16px;flex-wrap:wrap;text-decoration:none;color:var(--ink);
  background:linear-gradient(135deg,#FFE8C7,#FFD0C2);border:1px solid var(--line);border-radius:var(--r-xl);
  padding:18px 22px;margin:0 0 22px;box-shadow:var(--sh);transition:transform .18s ease,box-shadow .18s ease}
.dailybanner:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.dailybanner-ic{position:relative;font-size:2.4rem;flex:none;line-height:1}
.dailybanner-ic span{position:absolute;bottom:-6px;right:-10px;font-size:1.3rem}
.dailybanner-tx{flex:1;min-width:220px}
.dailybanner-tx h2{margin:0 0 3px}
.dailybanner-tx p{margin:0;color:var(--ink);font-size:.95rem}
.dailybanner-go{font-family:"Fredoka",sans-serif;font-weight:500;color:var(--pop-d);white-space:nowrap}
.quizhero-daily{font-size:1.9rem}

/* ---- "about" chip on mixed/daily questions ---- */
.quizq-about{display:inline-block;font-size:.8rem;font-weight:800;color:var(--purple);
  background:#F3ECFF;border-radius:999px;padding:3px 11px;margin-bottom:10px}
.recap-pet{display:inline-block;font-size:.72rem;font-weight:800;color:var(--purple);background:#F3ECFF;border-radius:999px;padding:1px 8px;margin-right:6px;vertical-align:1px}

/* ---- share bar + result buttons ---- */
.quizshare{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;margin:4px 0 4px}
.quizshare-label{font-weight:800;color:var(--muted);font-size:.9rem;width:100%;margin-bottom:2px}
.quizshare .bigbtn{padding:9px 16px;font-size:.95rem}
.quizscore-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:16px}

/* ---- emoji icons for wild-animal quizzes (no clay SVG) ---- */
.quizcard-emoji{font-size:34px;line-height:1;height:40px;display:grid;place-items:center;margin-bottom:2px}
.quizhero-em{font-size:2.2rem}
.quizpromo-emoji{font-size:48px;line-height:1}
