/* =========================================================
   Pet Gobbles — premium cozy bakery design system
   Shared across all pages
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  /* warm palette */
  --espresso:#321E12;
  --cocoa:#4A2C1A;
  --primary:#8A4520;        /* warm chocolate-caramel */
  --primary-deep:#6B3214;
  --caramel:#B45309;
  --honey:#E6A552;
  --honey-soft:#F4D9A8;
  --rose:#E0A03F;       /* (accent slot) warm honey-amber */
  --rose-deep:#A6601A;  /* deep caramel — AA on cream */
  --rose-soft:#F5E4C5;  /* pale honey */
  --cream:#FBF3E3;          /* page bg */
  --cream-2:#F5E8CF;
  --sand:#EFDFBF;
  --card:#FFFCF6;
  --ink:#43301F;
  --ink-soft:#8C7159;
  --line:#EBD9B6;

  /* type */
  --display:"Baloo 2",system-ui,sans-serif;
  --body:"Nunito Sans",system-ui,-apple-system,sans-serif;

  /* shape */
  --r-sm:14px; --r:20px; --r-lg:30px; --r-xl:42px;
  --maxw:1200px;
  --gutter:clamp(20px,5vw,40px);

  /* shadow (layered, warm-tinted) */
  --sh-1:0 1px 2px rgba(80,40,15,.05), 0 4px 10px rgba(80,40,15,.05);
  --sh-2:0 6px 16px rgba(90,45,20,.08), 0 18px 40px rgba(90,45,20,.10);
  --sh-3:0 20px 60px rgba(80,40,15,.16);
  --sh-rose:0 14px 30px rgba(166,96,26,.30);
  --sh-primary:0 14px 30px rgba(138,69,32,.30);

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  /* subtle warm grain + glow */
  background-image:
    radial-gradient(1200px 600px at 85% -5%, rgba(230,165,82,.16), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(217,138,134,.12), transparent 55%);
  background-attachment:fixed;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--rose);color:#fff}

h1,h2,h3,h4,.display{font-family:var(--display);font-weight:700;line-height:1.14;letter-spacing:0;color:var(--primary-deep)}
h1{font-optical-sizing:auto}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.narrow{max-width:820px}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:var(--cream-2)}
::-webkit-scrollbar-thumb{background:var(--honey);border-radius:99px;border:3px solid var(--cream-2)}
::-webkit-scrollbar-thumb:hover{background:var(--caramel)}

/* ---------- Preloader ---------- */
.preloader{position:fixed;inset:0;z-index:1000;background:var(--cream);display:grid;place-items:center;transition:opacity .6s var(--ease),visibility .6s}
.preloader.done{opacity:0;visibility:hidden}
.preloader .pl-paw{width:64px;height:64px;color:var(--primary);animation:plbob 1s var(--ease) infinite alternate}
.preloader .pl-text{position:absolute;bottom:34%;font-family:var(--display);color:var(--primary);letter-spacing:.04em;font-size:1.1rem;opacity:.7}
@keyframes plbob{from{transform:translateY(0) scale(1);opacity:.6}to{transform:translateY(-14px) scale(1.05);opacity:1}}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--primary);--fg:#fff;
  position:relative;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--display);font-weight:600;font-size:1rem;
  padding:14px 28px;border-radius:99px;border:none;cursor:pointer;
  background:var(--bg);color:var(--fg);min-height:50px;
  box-shadow:var(--sh-primary);overflow:hidden;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),background .3s;
}
.btn::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35),transparent 70%);transform:translateX(-120%);transition:transform .7s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(138,69,32,.36)}
.btn:hover::after{transform:translateX(120%)}
.btn:active{transform:translateY(-1px)}
.btn:focus-visible{outline:3px solid var(--rose-deep);outline-offset:3px}
.btn .ic{width:20px;height:20px}
.btn-rose{--bg:var(--rose);--fg:#4A2C1A;box-shadow:var(--sh-rose)}
.btn-rose:hover{box-shadow:0 18px 40px rgba(166,96,26,.4)}
.btn-ghost{--bg:transparent;--fg:var(--primary-deep);box-shadow:none;border:2px solid var(--line)}
.btn-ghost::after{display:none}
.btn-ghost:hover{border-color:var(--honey);background:#fff;box-shadow:var(--sh-2)}
.btn-cream{--bg:var(--cream);--fg:var(--primary-deep);box-shadow:var(--sh-2)}
.btn-lg{padding:17px 34px;font-size:1.08rem}

.link-arrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;color:var(--rose-deep);transition:gap .3s var(--ease)}
.link-arrow svg{width:18px;height:18px;transition:transform .3s var(--ease)}
.link-arrow:hover{gap:12px}
.link-arrow:hover svg{transform:translateX(3px)}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;transition:transform .4s var(--ease),background .4s,box-shadow .4s,padding .4s}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;height:84px;transition:height .4s var(--ease)}
.site-header.scrolled{background:rgba(251,243,227,.82);backdrop-filter:blur(14px) saturate(1.2);box-shadow:0 1px 0 rgba(235,217,182,.9),0 10px 30px rgba(90,45,20,.06)}
.site-header.scrolled .bar{height:68px}
.site-header.hide{transform:translateY(-100%)}

.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:600;font-size:1.4rem;color:var(--primary-deep)}
.brand .logo{width:48px;height:48px;background:url(img/logo.png) center/contain no-repeat;display:grid;place-items:center;transition:transform .4s var(--ease)}
.brand:hover .logo{transform:scale(1.06)}
.brand .logo svg{display:none}
.brand small{display:block;font-family:var(--body);font-weight:700;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose-deep);margin-top:-2px}

.nav{display:flex;align-items:center;gap:6px}
.nav a{position:relative;font-weight:700;font-size:.98rem;color:var(--ink);padding:9px 15px;border-radius:99px;transition:color .25s}
.nav a::after{content:"";position:absolute;left:15px;right:15px;bottom:5px;height:2px;background:var(--rose);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav a:hover{color:var(--primary-deep)}
.nav a:hover::after{transform:scaleX(1)}
.nav a.active{color:var(--primary-deep)}
.nav a.active::after{transform:scaleX(1);background:var(--honey)}

.header-cta{display:flex;align-items:center;gap:12px}
.menu-btn{display:none;width:50px;height:50px;border-radius:14px;background:#fff;border:2px solid var(--line);cursor:pointer;align-items:center;justify-content:center;color:var(--primary-deep)}
.menu-btn svg{width:24px;height:24px}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:95;pointer-events:none}
.drawer .scrim{position:absolute;inset:0;background:rgba(50,30,18,.45);opacity:0;transition:opacity .4s}
.drawer .panel{position:absolute;top:0;right:0;height:100%;width:min(84vw,360px);background:var(--cream);box-shadow:var(--sh-3);transform:translateX(100%);transition:transform .45s var(--ease-out);padding:26px 24px;display:flex;flex-direction:column;gap:6px}
.drawer.open{pointer-events:auto}
.drawer.open .scrim{opacity:1}
.drawer.open .panel{transform:none}
.drawer .panel .d-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.drawer .panel a.d-link{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--primary-deep);padding:13px 8px;border-bottom:1px solid var(--line)}
.drawer .panel a.d-link.active{color:var(--rose-deep)}
.drawer .panel .d-foot{margin-top:auto;display:flex;flex-direction:column;gap:12px}
.drawer .x{width:46px;height:46px;border-radius:12px;border:2px solid var(--line);background:#fff;cursor:pointer;display:grid;place-items:center;color:var(--primary-deep)}
.drawer .x svg{width:22px;height:22px}

/* ---------- Section scaffolding ---------- */
.section{padding:clamp(64px,9vw,120px) 0;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;color:var(--rose-deep);font-size:1rem;letter-spacing:.01em;margin-bottom:14px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--rose);border-radius:2px}
.eyebrow.center::before{display:none}
.sec-head{max-width:680px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(2.1rem,4.6vw,3.4rem)}
.sec-head p{margin-top:16px;color:var(--ink-soft);font-size:1.12rem}
.h-display{font-size:clamp(2.05rem,5.6vw,4.3rem);overflow-wrap:break-word}

/* pill badge */
.tagpill{display:inline-flex;align-items:center;gap:9px;background:var(--rose-soft);color:var(--rose-deep);font-weight:800;font-size:.82rem;letter-spacing:.02em;padding:9px 17px;border-radius:99px}
.tagpill svg{width:16px;height:16px}

/* page hero offset (fixed header) */
.page-top{padding-top:120px}

/* page enter / leave transition */
main{animation:pageIn .6s var(--ease-out) both}
@keyframes pageIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
html.page-leaving main{opacity:0;transform:translateY(-10px);transition:opacity .28s var(--ease),transform .28s var(--ease)}
html.shot main{animation:none}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-2);overflow:hidden}

/* treat card */
.treat{min-width:0;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-1);transition:transform .4s var(--ease-out),box-shadow .4s var(--ease-out)}
.treat .body h3{min-width:0;flex-wrap:wrap}
.treat:hover{transform:translateY(-8px);box-shadow:var(--sh-2)}
.treat .pic{position:relative;aspect-ratio:4/3;overflow:hidden}
.treat .pic img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.treat:hover .pic img{transform:scale(1.035)}
.treat .pic .chip{position:absolute;top:14px;left:14px;background:rgba(255,252,246,.94);backdrop-filter:blur(6px);color:var(--primary-deep);font-family:var(--display);font-weight:600;font-size:.76rem;padding:6px 13px;border-radius:99px;box-shadow:var(--sh-1)}
.treat .pic .chip.rose{background:var(--rose-deep);color:#fff}
.treat .body{padding:24px;display:flex;flex-direction:column;flex:1}
.treat .body h3{font-size:1.45rem;display:flex;justify-content:space-between;gap:12px;align-items:baseline}
.treat .body .price{font-family:var(--body);font-weight:800;font-size:1.02rem;color:var(--rose-deep);white-space:nowrap}
.treat .body .diet{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0 0}
.treat .body .diet span{font-size:.72rem;font-weight:700;color:var(--ink-soft);background:var(--cream-2);padding:4px 10px;border-radius:99px}
.treat .body p{color:var(--ink-soft);font-size:.97rem;margin:12px 0 18px;flex:1}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.r-left{transform:translateX(-44px)}
.reveal.r-right{transform:translateX(44px)}
.reveal.r-scale{transform:scale(.92)}
.reveal.in{opacity:1;transform:none}
[data-stagger] > *{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-stagger].in > *{opacity:1;transform:none}
[data-stagger].in > *{transition-delay:calc(var(--d,80ms) * var(--i,0))}

/* count up */
.count{font-variant-numeric:tabular-nums}

/* floating decorative blobs */
.blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5;z-index:0;pointer-events:none}
.float{animation:floaty 7s var(--ease) infinite alternate}
@keyframes floaty{from{transform:translateY(0) rotate(0)}to{transform:translateY(-22px) rotate(6deg)}}
.spin-slow{animation:spin 26s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* paw trail decoration */
.paw-deco{position:absolute;color:var(--honey);opacity:.35;width:30px;pointer-events:none;z-index:0}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(90deg,var(--cream-2),var(--cream),var(--cream-2));padding:20px 0}
.marquee .track{display:flex;gap:54px;width:max-content;animation:marq 32s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee .item{display:inline-flex;align-items:center;gap:14px;font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--primary);white-space:nowrap}
.marquee .item svg{width:22px;height:22px;color:var(--rose)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- Stat ---------- */
.stat strong{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4vw,2.8rem);color:var(--primary);display:block;line-height:1}
.stat span{font-size:.92rem;color:var(--ink-soft);font-weight:600}

/* ---------- Footer ---------- */
.site-footer{background:var(--espresso);color:rgba(255,247,235,.78);padding:74px 0 30px;position:relative;overflow:hidden}
.site-footer .f-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(230,165,82,.18),transparent 70%);top:-280px;right:-120px;pointer-events:none}
.f-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;position:relative}
.site-footer .brand{color:#fff}
.site-footer .brand .logo{background:url(img/logo.png) center/contain no-repeat}
.site-footer .f-about{margin:16px 0 20px;font-size:.96rem;color:rgba(255,247,235,.6);max-width:300px}
.f-col h4{font-family:var(--display);color:#fff;font-size:1.1rem;margin-bottom:16px}
.f-col a,.f-col p{display:block;color:rgba(255,247,235,.66);padding:5px 0;font-size:.96rem;transition:color .25s}
.f-col a:hover{color:var(--honey)}
.f-social{display:flex;gap:12px;margin-top:8px}
.f-social a{width:46px;height:46px;border-radius:13px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;transition:.3s var(--ease)}
.f-social a:hover{background:var(--honey);color:var(--espresso);transform:translateY(-3px)}
.f-social svg{width:22px;height:22px}
.f-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:50px;padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.86rem;color:rgba(255,247,235,.5)}
.f-bottom .paw{color:var(--rose)}

/* ---------- Forms ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-weight:800;font-size:.88rem;margin-bottom:7px;color:var(--ink)}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border:2px solid var(--line);border-radius:var(--r-sm);
  font-family:inherit;font-size:1rem;background:#fff;color:var(--ink);transition:border-color .25s,box-shadow .25s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(138,69,32,.12)}
.field textarea{resize:vertical;min-height:110px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-ok{display:none;background:#E9F4E4;border:1px solid #B6DCA9;color:#33691E;border-radius:var(--r-sm);padding:15px;font-weight:700;margin-bottom:16px;text-align:center}

/* ---------- Utility ---------- */
.text-center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:26px}.mt-l{margin-top:44px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.divider-wave{display:block;width:100%;height:54px}
.bg-dark{background:var(--espresso);color:#fff}
.bg-primary{background:radial-gradient(120% 130% at 50% -10%, #C07C38 0%, #9A5A24 38%, #6E3C18 100%);color:#fff}
.bg-sand{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.bg-rose{background:linear-gradient(160deg,#E2B257,var(--rose-deep));color:#fff}
.on-dark h1,.on-dark h2,.on-dark h3{color:#fff}
.on-dark .sec-head p{color:rgba(255,255,255,.8)}
.on-dark .eyebrow{color:#FCEBCB}
.on-dark .eyebrow::before{background:var(--honey)}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .f-grid{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:860px){
  .nav{display:none}
  .menu-btn{display:flex}
  .header-cta .btn-ghost{display:none}
}
@media(max-width:620px){
  .grid-2{grid-template-columns:1fr}
  .f-grid{grid-template-columns:1fr;gap:28px}
  .f-bottom{justify-content:center;text-align:center}
  .header-cta>.btn{display:none}
  .site-header .bar{position:relative}
  .header-cta{position:absolute;right:var(--gutter);top:50%;transform:translateY(-50%)}
  .brand{max-width:calc(100vw - 88px);padding-right:48px}
  .site-header .menu-btn{display:flex!important;visibility:visible!important;opacity:1!important;position:fixed!important;top:11px;right:var(--gutter);z-index:500}
}

/* ============ Premium polish & motion v2 ============ */

/* film grain — subtle tactile depth */
body::after{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}

/* scroll progress bar */
.scroll-prog{position:fixed;top:0;left:0;right:0;height:3px;z-index:300;transform:scaleX(0);transform-origin:left;
  background:linear-gradient(90deg,var(--honey),var(--rose-deep) 55%,var(--primary));box-shadow:0 0 12px rgba(224,160,63,.55)}

/* magnetic buttons */
.btn-lg{will-change:transform}

/* cinematic clip-wipe heading reveal (added to .h-display by JS) */
.h-rev{clip-path:inset(0 0 100% 0);transform:translateY(16px);opacity:.001}
.h-rev.in{clip-path:inset(0 0 0 0);transform:none;opacity:1;
  transition:clip-path 1.05s var(--ease-out),transform 1.05s var(--ease-out),opacity .55s ease}

/* treat cards: light, smooth pop-up on hover (no shine) */
.treat:hover{box-shadow:0 18px 38px rgba(120,53,15,.13)}

/* gallery: very subtle light sweep */
.shot-card::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(105deg,transparent 42%,rgba(255,255,255,.2) 50%,transparent 60%);transform:translateX(-135%)}
.shot-card:hover::after{transition:transform 1s var(--ease);transform:translateX(135%)}

/* more organic, slower-drifting blobs */
@keyframes floaty{0%{transform:translate(0,0) rotate(0) scale(1)}
  50%{transform:translate(14px,-20px) rotate(5deg) scale(1.05)}
  100%{transform:translate(-10px,-32px) rotate(-4deg) scale(1.02)}}
.float{animation-duration:9s}
.blob{filter:blur(10px)}

/* ---- animated feature cards (why-grid: home promise + about philosophy) ---- */
.why-grid .card{position:relative;overflow:hidden;transition:transform .5s var(--ease-out),box-shadow .5s var(--ease-out)}
.why-grid .card:hover{transform:translateY(-12px);box-shadow:var(--sh-3),0 0 0 1px rgba(224,160,63,.3)}
.why-grid .card h3{transition:color .35s}
.why-grid .card:hover h3{color:var(--rose-deep)}
.why-grid .card > span:first-child{position:relative;transition:transform .55s var(--ease),box-shadow .45s var(--ease)}
.why-grid .card:hover > span:first-child{transform:translateY(-5px) rotate(-9deg) scale(1.12);box-shadow:0 12px 24px rgba(166,96,26,.3)}
/* gentle idle pulse ring on each icon */
.why-grid .card > span:first-child::before{content:"";position:absolute;inset:-5px;border-radius:inherit;border:2px solid rgba(224,160,63,.5);opacity:0;animation:iconpulse 3s ease-out infinite}
.why-grid .card:nth-child(2) > span:first-child::before{animation-delay:.55s}
.why-grid .card:nth-child(3) > span:first-child::before{animation-delay:1.1s}
.why-grid .card:nth-child(4) > span:first-child::before{animation-delay:1.65s}
@keyframes iconpulse{0%{transform:scale(.9);opacity:.55}70%{opacity:0}100%{transform:scale(1.4);opacity:0}}
/* very subtle light sweep across card on hover */
.why-grid .card::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.18) 50%,transparent 60%);transform:translateX(-140%)}
.why-grid .card:hover::after{transition:transform 1.1s var(--ease);transform:translateX(140%)}

/* ============ Home hero (focused, conversion-first) ============ */
.hero-sec{position:relative;overflow:hidden;min-height:clamp(640px,90vh,900px);display:flex;align-items:center;padding:140px 0 72px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:clamp(36px,5vw,76px);align-items:center;width:100%;position:relative;z-index:2}
.hero-copy{max-width:600px}
.hero-h1{font-size:clamp(2.4rem,5.1vw,4.1rem);line-height:1.05;letter-spacing:-.012em;margin:18px 0 0;max-width:15ch}
.hero-h1 em{font-style:normal;font-weight:800;color:var(--rose-deep);position:relative;white-space:nowrap}
.hero-h1 em::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.34em;background:var(--honey-soft);border-radius:99px;z-index:-1;transform:scaleX(1);transform-origin:left;opacity:.9}
html.hero-go .hero-h1 em::after{transform:scaleX(0);animation:heroUnderline .7s var(--ease-out) .9s forwards}
@keyframes heroUnderline{to{transform:scaleX(1)}}
.hero-lead{font-size:1.16rem;line-height:1.6;color:var(--ink-soft);max-width:500px;margin-top:18px}
.hero-rate{display:flex;align-items:center;gap:11px;margin:20px 0 0;color:var(--ink-soft);font-weight:700;font-size:.95rem}
.hero-rate .rstars{display:inline-flex;gap:1px;color:var(--honey)}
.hero-rate .rstars svg{width:18px;height:18px}
.hero-rate b{color:var(--primary-deep)}
.feat-pills{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px}
.feat-pill{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line);border-radius:99px;padding:9px 15px;font-weight:800;font-size:.82rem;color:var(--cocoa);box-shadow:var(--sh-1)}
.feat-pill svg{width:16px;height:16px;color:var(--rose-deep);flex:none}
.hero-copy .cta-row{margin-top:30px}
.hero-trust{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:8px 20px;margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.hero-trust li{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.86rem;color:var(--ink-soft)}
.hero-trust li svg{width:17px;height:17px;color:var(--rose-deep);flex:none}
/* hero-stats + ORDER NOW are the client-preferred PHONE layout — desktop hides them */
.hero-stats,.stat-cta{display:none}

.hero-media{position:relative}
.hero-photo{border-radius:var(--r-xl);overflow:hidden;border:9px solid #fff;box-shadow:var(--sh-3);aspect-ratio:4/4.6;transform:rotate(2deg)}
.hero-photo img{width:100%;height:100%;object-fit:cover}

/* ---- cinematic on-load entrance (gated behind .hero-go) ---- */
html.hero-go .hero-copy > *{opacity:0;animation:heroRise .72s var(--ease-out) both}
html.hero-go .hero-copy > :nth-child(1){animation-delay:.06s}
html.hero-go .hero-copy > :nth-child(2){animation-delay:.14s}
html.hero-go .hero-copy > :nth-child(3){animation-delay:.22s}
html.hero-go .hero-copy > :nth-child(4){animation-delay:.30s}
html.hero-go .hero-copy > :nth-child(5){animation-delay:.38s}
html.hero-go .hero-copy > :nth-child(6){animation-delay:.46s}
html.hero-go .hero-copy > :nth-child(7){animation-delay:.54s}
html.hero-go .hero-copy > :nth-child(8){animation-delay:.22s} /* mobile stats — sits right after the headline */
/* the photo pops in; floating badges & spinning seal ride along inside it,
   so their perpetual float/spin animations stay intact */
html.hero-go .hero-media{animation:heroPop 1s var(--ease-out) .28s both}
@keyframes heroRise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes heroPop{from{opacity:0;transform:translateY(28px) rotate(2deg) scale(.95)}to{opacity:1;transform:none}}
.seal{position:absolute;left:-36px;bottom:34px;width:120px;height:120px;z-index:5;filter:drop-shadow(0 10px 20px rgba(80,40,15,.3))}
.seal circle{fill:var(--primary)}
.seal text{fill:#fff;font-family:var(--display);font-weight:700;font-size:8px;letter-spacing:1.2px}
.seal .seal-paw{fill:var(--honey)}

.scroll-cue{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--ink-soft);font-weight:800;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;opacity:.7}
.scroll-cue .m{width:24px;height:38px;border:2px solid var(--ink-soft);border-radius:13px;position:relative}
.scroll-cue .m::after{content:"";position:absolute;top:7px;left:50%;width:4px;height:7px;background:var(--ink-soft);border-radius:3px;transform:translateX(-50%);animation:cuemove 1.7s var(--ease) infinite}
@keyframes cuemove{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,13px)}}

@media(max-width:880px){
  .hero-sec{min-height:auto;padding:118px 0 48px}
  .hero-media{max-width:440px;margin:6px auto 0}
  .scroll-cue{display:none}
  .seal{width:98px;height:98px;left:-14px;bottom:22px}
}

/* ---------- Responsive overrides for inline-styled grids ----------
   (inline grid-template-columns needs !important to be overridden) */
@media(max-width:880px){
  .hero-grid,.story-grid{grid-template-columns:minmax(0,1fr)!important;gap:32px!important}
  .hero-grid > div:last-child{max-width:460px;margin:0 auto}
  .hero-media{order:-1}                            /* show the dog photo first on mobile */
  .hero-media .card.float{display:none!important}  /* hide the floating badges (inline display:flex) */
  .hero-sec .seal{display:none!important}
}
@media(max-width:820px){
  .why-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .treat-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
}
@media(max-width:560px){
  .why-grid,.treat-grid{grid-template-columns:minmax(0,1fr)!important}
  #customcard{grid-template-columns:minmax(0,1fr)!important}
  h1.h-display{font-size:clamp(2rem,7.6vw,2.9rem)!important}
  .sec-head h2{font-size:clamp(1.7rem,6.4vw,2.3rem)}
}

/* ---------- Mobile refinement pass ---------- */
@media(max-width:760px){
  :root{--gutter:clamp(16px,4.8vw,22px)}
  html,body{max-width:100vw;overflow-x:hidden}
  body{background-attachment:scroll}
  body::after{opacity:.025}

  .site-header,.site-header .wrap,main,section,.site-footer{max-width:100vw}
  .wrap{width:100vw;max-width:100vw;min-width:0}
  .section{padding:clamp(48px,14vw,72px) 0}
  .page-top{padding-top:96px!important}
  section.page-top[style]{padding-top:96px!important}
  .page-top .wrap{overflow:hidden}
  .h-display,.hero-h1,.sec-head h2{white-space:normal!important;overflow-wrap:anywhere;text-wrap:balance}
  .page-top p{max-width:100%!important}
  .sec-head p{font-size:1rem}
  .tagpill{font-size:.76rem;padding:8px 13px}

  .site-header{background:rgba(251,243,227,.9);backdrop-filter:blur(12px) saturate(1.15);box-shadow:0 1px 0 rgba(235,217,182,.85)}
  .site-header .bar,.site-header.scrolled .bar{height:66px}
  .site-header.hide{transform:none}
  .site-header .bar{position:relative;min-width:0}
  .brand{gap:9px;font-size:1.08rem;line-height:1.05;min-width:0;max-width:calc(100vw - 92px);padding-right:0}
  .brand .logo{width:40px;height:40px;flex:none}
  .brand>span:last-child{min-width:0}
  .brand small{font-size:.5rem;letter-spacing:.14em}
  .header-cta{position:static;transform:none;margin-left:auto;gap:8px;flex:0 0 auto}
  .header-cta>.btn{display:none}
  .menu-btn{width:44px;height:44px;border-radius:12px}
  .site-header .menu-btn{display:flex!important;visibility:visible!important;opacity:1!important;position:static!important;z-index:500}

  .drawer .panel{width:min(92vw,360px);padding:18px;overflow-y:auto}
  .drawer .panel .d-top{margin-bottom:10px}
  .drawer .panel a.d-link{font-size:1.12rem;padding:11px 4px}
  .drawer .x{width:42px;height:42px}

  .btn{min-height:46px;padding:12px 20px;font-size:.96rem}
  .btn-lg{padding:13px 22px;font-size:1rem}
  .cta-row{width:100%;gap:10px}
  .cta-row .btn{flex:1 1 180px;justify-content:center}

  .card{border-radius:22px}
  .treat{border-radius:22px}
  .treat:hover{transform:none}
  .treat .body{padding:18px}
  .treat .body h3{display:block;font-size:1.26rem;line-height:1.14}
  .treat .body .price{display:block;margin-top:4px;font-size:.95rem;white-space:normal}
  .treat .body p{font-size:.94rem;margin:10px 0 16px}
  .treat .pic .chip{top:10px;left:10px;font-size:.7rem;padding:5px 10px}

  .hero-sec{padding:96px 0 38px;min-height:auto}
  .hero-h1{font-size:clamp(2.05rem,10vw,2.8rem);line-height:1.06}
  .hero-lead{font-size:1rem;margin-top:14px}
  .hero-rate{align-items:flex-start;gap:8px;font-size:.9rem}
  .hero-rate .rstars{margin-top:2px}
  .feat-pills{gap:8px;margin-top:18px}
  .feat-pill{font-size:.76rem;padding:8px 11px}
  .hero-trust{gap:6px 16px;margin-top:20px;padding-top:18px}
  .hero-trust li{font-size:.8rem}
  .hero-media{display:flex;flex-direction:column}
  .hero-photo{border-width:6px;border-radius:24px;transform:none;aspect-ratio:4/4.2}
  .hero-media .card.float{position:static!important;margin:12px 0 0;padding:12px 14px!important;animation:none;box-shadow:var(--sh-1)!important}
  .story-grid .card.float{position:static!important;margin-top:14px;animation:none;box-shadow:var(--sh-1)!important}
  .seal{width:82px;height:82px;left:10px;bottom:132px}
  .marquee{padding:14px 0}
  .marquee .track{gap:30px}
  .marquee .item{font-size:1.08rem}

  .site-footer{padding:52px 0 24px}
  .f-social a{width:42px;height:42px}
}

/* ---------- Photo-forward mobile hero (client-preferred) ----------
   On phones: tagpill → headline → 2×2 stats grid + ORDER NOW → dog photo
   with the rotating "made fresh" seal + Vet-friendly badge. The desktop
   focused layout (subhead, pills, two CTAs, trust strip) is hidden here. */
@media(max-width:760px){
  .hero-sec .hero-rate,
  .hero-sec .hero-lead,
  .hero-sec .feat-pills,
  .hero-sec .cta-row,
  .hero-sec .hero-trust{display:none!important}

  .hero-sec{padding:84px 0 34px}
  .hero-sec .tagpill{margin-bottom:14px}
  .hero-copy{max-width:none}
  /* !important needed to beat the ≤560 `h1.h-display{font-size…!important}` rule.
     Cap width to the viewport so the headline always wraps on-screen. */
  .hero-sec .hero-h1{font-size:clamp(1.4rem,5.6vw,1.85rem)!important;line-height:1.12;margin:0 0 22px;
    white-space:normal!important;overflow-wrap:break-word;max-width:calc(100vw - 2*var(--gutter))}
  .hero-grid > div:first-child{min-width:0;max-width:100%}
  .hero-grid > div:last-child{max-width:none;margin:0}
  .hero-sec .hero-media{order:0;max-width:none;margin:0}   /* stats first, photo second */

  /* 2×2 stats grid with ORDER NOW as the 4th cell */
  .hero-stats{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px 18px;margin:0 0 22px}
  .hero-stats > *{min-width:0}
  .hero-stats .stat{margin:0}
  .hero-stats .stat strong{font-size:clamp(1.7rem,7.6vw,2.25rem)}
  .stat-cta{display:flex;align-items:center;justify-content:center;align-self:center;justify-self:start;
    width:fit-content;max-width:100%;white-space:nowrap;overflow:hidden;
    font-family:var(--display);font-weight:800;line-height:1;text-decoration:none;letter-spacing:.01em;
    font-size:clamp(.98rem,4vw,1.18rem);color:var(--primary-deep);
    background:linear-gradient(135deg,var(--honey),var(--rose));
    padding:13px 18px;border-radius:14px;box-shadow:0 8px 18px rgba(166,96,26,.28)}
  .stat-cta:active{transform:scale(.97);box-shadow:0 4px 10px rgba(166,96,26,.26)}

  /* restore the seal + show only the Vet-friendly badge (as a static card) */
  .hero-sec .seal{display:block!important;left:4px;bottom:150px;width:86px;height:86px}
  .hero-media .card.float{display:flex!important}
  .hero-media .card.float.hide-sm{display:none!important}
}

@media(max-width:420px){
  .brand{font-size:1rem}
  .brand .logo{width:36px;height:36px}
  .menu-btn{width:42px;height:42px}
  .cta-row .btn{flex-basis:100%;width:100%}
  .hero-stats{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px 16px}
}

/* ---------- Motion / shot preferences ---------- */
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;animation:none!important}
  .reveal,[data-stagger] > *{opacity:1!important;transform:none!important;transition:none!important}
  .h-rev{clip-path:none!important;transform:none!important;opacity:1!important}
  .btn:hover,.treat:hover{transform:none}
  .scroll-prog{display:none}
  .treat .pic::after,.shot-card::after,body::after{display:none}
}
/* ?shot resting-state preview for screenshots */
html.shot *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
html.shot .reveal,html.shot [data-stagger] > *{opacity:1!important;transform:none!important}
html.shot .preloader{display:none!important}
html.shot .marquee .track{transform:none!important}
html.shot .h-rev{clip-path:none!important;opacity:1!important;transform:none!important}
html.shot .scroll-prog{display:none!important}
.no-js .reveal,.no-js [data-stagger] > *{opacity:1;transform:none}

/* ===== Floating WhatsApp chat button (site-wide; sits above the cart when present) ===== */
.wa-fab{position:fixed;right:22px;bottom:22px;z-index:379;width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:var(--sh-3);transition:transform .25s var(--ease),background .25s var(--ease)}
.wa-fab:hover{transform:translateY(-3px) scale(1.05);background:#1ebe5d}
.wa-fab svg{width:33px;height:33px}
.wa-fab.stacked{bottom:96px}
.wa-fab .wa-tip{position:absolute;right:72px;top:50%;background:#fff;color:var(--ink);font-family:var(--body);font-weight:800;font-size:.85rem;padding:8px 13px;border-radius:11px;box-shadow:var(--sh-2);white-space:nowrap;opacity:0;visibility:hidden;transform:translateY(-50%) translateX(8px);transition:.22s var(--ease);pointer-events:none}
.wa-fab .wa-tip::after{content:"";position:absolute;right:-5px;top:50%;width:10px;height:10px;background:#fff;transform:translateY(-50%) rotate(45deg)}
.wa-fab:hover .wa-tip{opacity:1;visibility:visible;transform:translateY(-50%) translateX(0)}
.wa-fab::before{content:"";position:absolute;inset:0;border-radius:50%;background:#25D366;z-index:-1;animation:waPulse 2.4s var(--ease) infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:.5}70%,100%{transform:scale(1.7);opacity:0}}
@media(max-width:760px){
  .wa-fab{right:16px;bottom:16px;width:54px;height:54px}
  .wa-fab.stacked{bottom:82px}
  .wa-fab svg{width:30px;height:30px}
  .wa-fab .wa-tip{display:none}
}
@media(prefers-reduced-motion:reduce){.wa-fab,.wa-fab::before{animation:none!important;transition:none!important}}
