/* ============ Petshub marketing site — shared styles ============ */
:root{
  --forest:#10342b;
  --forest-deep:#0a221c;
  --cream:#f6f1e7;
  --cream-soft:#efe7d6;
  --coral:#ff6b47;
  --coral-soft:#ff8a6b;
  --sage:#5b7d65;
  --sage-soft:#e7efe9;
  --amber:#d9962a;
  --ink:#16241f;
  --ink-soft:#5c6b62;
  --line:#e7e2d6;
  --white:#fff;
  --radius:22px;
  --radius-sm:14px;
  --shadow:0 18px 44px -22px rgba(16,52,43,.4);
  --shadow-sm:0 10px 26px -16px rgba(16,52,43,.32);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Hanken Grotesk',sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Fraunces',serif;font-weight:500;line-height:1.07;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.accent{color:var(--coral)}
.serif-it{font-style:italic}

/* ---- nav ---- */
nav{position:sticky;top:0;z-index:100;background:rgba(246,241,231,.82);backdrop-filter:blur(14px);border-bottom:1px solid rgba(16,52,43,.07)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-size:23px;font-weight:600;color:var(--forest)}
.logo .mark{width:34px;height:34px;border-radius:11px;background:var(--forest);display:flex;align-items:center;justify-content:center;font-size:18px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-weight:600;font-size:15px;color:var(--forest);opacity:.78;transition:.2s}
.nav-links a:hover,.nav-links a.active{opacity:1}
.nav-cta{background:var(--forest);color:var(--cream)!important;padding:10px 20px;border-radius:100px;opacity:1!important;transition:.25s}
.nav-cta:hover{background:var(--coral)}
.menu-btn{display:none;background:none;border:none;font-size:24px;color:var(--forest);cursor:pointer}
@media(max-width:820px){.nav-links{display:none}}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Hanken Grotesk',sans-serif;font-weight:700;font-size:15px;padding:14px 26px;border-radius:100px;cursor:pointer;border:none;transition:.25s}
.btn-primary{background:var(--forest);color:var(--cream)}
.btn-primary:hover{background:var(--coral);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--forest);border:1.5px solid rgba(16,52,43,.22)}
.btn-ghost:hover{border-color:var(--forest);background:var(--forest);color:var(--cream)}

/* ---- store badges ---- */
.stores{display:flex;gap:12px;flex-wrap:wrap}
.store{display:inline-flex;align-items:center;gap:11px;background:var(--forest);color:var(--cream);padding:11px 20px;border-radius:14px;transition:.25s}
.store:hover{background:var(--coral);transform:translateY(-2px)}
.store .ico{font-size:24px}
.store small{display:block;font-size:10px;opacity:.8;letter-spacing:.04em;text-transform:uppercase}
.store b{font-size:16px;font-weight:700;font-family:'Fraunces',serif}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(26px);transition:.8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---- hero ---- */
.hero{position:relative;padding:90px 0 80px;overflow:hidden}
.hero::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,var(--coral-soft),transparent 66%);opacity:.5;top:-180px;right:-120px}
.hero::after{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,var(--sage),transparent 70%);opacity:.32;bottom:-160px;left:-130px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--sage);background:var(--sage-soft);padding:8px 16px;border-radius:100px;margin-bottom:22px}
.hero h1{font-size:clamp(42px,6vw,72px);color:var(--forest)}
.hero .lead{font-size:19px;color:var(--ink-soft);max-width:480px;margin:24px 0 32px}
.hero-cta{display:flex;flex-direction:column;gap:18px}
.hero-meta{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--ink-soft)}
.stars{color:var(--amber);letter-spacing:2px}
.avatars{display:flex}
.avatars span{width:36px;height:36px;border-radius:50%;border:2.5px solid var(--cream);margin-left:-10px;display:flex;align-items:center;justify-content:center;font-size:17px;background:var(--sage-soft)}
.avatars span:first-child{margin-left:0}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr}.hero-visual{order:-1}}

/* ---- phone mock ---- */
.phone-mock{width:280px;height:580px;margin:0 auto;background:#0c0a1a;border-radius:44px;padding:10px;box-shadow:var(--shadow);position:relative}
.phone-mock .scr{width:100%;height:100%;border-radius:35px;overflow:hidden;background:var(--cream);display:flex;flex-direction:column}
.pm-island{position:absolute;top:13px;left:50%;transform:translateX(-50%);width:84px;height:24px;background:#0c0a1a;border-radius:14px;z-index:5}
.pm-top{padding:34px 18px 12px}
.pm-greet{font-size:11px;color:var(--sage);font-weight:600}
.pm-name{font-family:'Fraunces',serif;font-size:22px;font-weight:600;color:var(--forest)}
.pm-pets{display:flex;gap:10px;padding:4px 18px 14px}
.pm-pet{width:48px;height:48px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:24px;background:#fff;box-shadow:var(--shadow-sm)}
.pm-pet.on{border:2.5px solid var(--coral)}
.pm-card{margin:0 18px 12px;border-radius:16px;padding:14px;box-shadow:var(--shadow-sm)}
.pm-rem{background:var(--forest);color:var(--cream);position:relative;overflow:hidden}
.pm-rem::after{content:"";position:absolute;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--coral),transparent 70%);opacity:.4;top:-44px;right:-28px}
.pm-rem .lab{font-size:9px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--coral-soft)}
.pm-rem .row{display:flex;align-items:center;gap:10px;margin-top:8px;position:relative}
.pm-ico{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-size:19px}
.pm-card.white{background:#fff}
.pm-feed{background:#fff;padding:0;overflow:hidden}
.pm-feed .img{height:96px;background:linear-gradient(135deg,#ffd4a3,#ff9d6e);display:flex;align-items:center;justify-content:center;font-size:38px}

/* ---- sections ---- */
section{padding:84px 0}
.sec-head{max-width:640px;margin-bottom:54px}
.sec-head .eyebrow{margin-bottom:16px}
.sec-head h2{font-size:clamp(32px,4.4vw,50px);color:var(--forest)}
.sec-head p{font-size:18px;color:var(--ink-soft);margin-top:16px}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* ---- feature bento ---- */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.feat{border-radius:var(--radius);padding:32px;min-height:240px;display:flex;flex-direction:column;justify-content:space-between;transition:.35s}
.feat:hover{transform:translateY(-6px)}
.feat .fico{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:27px}
.feat h3{font-size:24px;margin:22px 0 8px}
.feat p{font-size:15px}
.feat.dark{background:var(--forest);color:var(--cream)}.feat.dark .fico{background:rgba(255,255,255,.1)}.feat.dark p{color:rgba(246,241,231,.74)}
.feat.coral{background:var(--coral);color:#fff}.feat.coral .fico{background:rgba(255,255,255,.2)}.feat.coral p{color:rgba(255,255,255,.85)}
.feat.cream{background:var(--white);color:var(--forest)}.feat.cream .fico{background:var(--sage-soft)}.feat.cream p{color:var(--ink-soft)}
.feat.sage{background:var(--sage);color:var(--cream)}.feat.sage .fico{background:rgba(255,255,255,.16)}.feat.sage p{color:rgba(246,241,231,.8)}
.col-7{grid-column:span 7}.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-4{grid-column:span 4}
@media(max-width:820px){.feat{grid-column:span 12!important}}

/* ---- pillars ---- */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pillar{background:var(--white);border:1px solid var(--line);border-radius:18px;padding:26px;transition:.25s}
.pillar:hover{box-shadow:var(--shadow);border-color:transparent}
.pillar .pn{font-family:'Fraunces',serif;font-style:italic;color:var(--coral);font-size:16px;margin-bottom:9px}
.pillar h4{font-size:19px;color:var(--forest);margin-bottom:6px}
.pillar p{font-size:14px;color:var(--ink-soft)}
@media(max-width:820px){.pillars{grid-template-columns:1fr 1fr}}

/* ---- cta band ---- */
.cta{background:var(--forest);border-radius:36px;padding:74px 36px;text-align:center;position:relative;overflow:hidden;margin:0 28px}
.cta::before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,var(--coral),transparent 70%);opacity:.34;top:-150px;right:-90px}
.cta h2{font-size:clamp(32px,5vw,54px);color:var(--cream);position:relative;max-width:660px;margin:0 auto}
.cta p{color:rgba(246,241,231,.76);font-size:18px;margin:20px auto 30px;max-width:440px;position:relative}
.cta .stores{justify-content:center;position:relative}
.cta .store{background:var(--cream);color:var(--forest)}
.cta .store:hover{background:var(--coral);color:#fff}

/* ---- doc pages (privacy/terms) ---- */
.doc{padding:64px 0 40px}
.doc-head{max-width:760px;margin:0 auto 40px}
.doc-head .eyebrow{margin-bottom:16px}
.doc-head h1{font-size:clamp(34px,5vw,52px);color:var(--forest)}
.doc-head .updated{color:var(--ink-soft);margin-top:12px;font-size:15px}
.doc-body{max-width:760px;margin:0 auto}
.doc-body h2{font-size:25px;color:var(--forest);margin:36px 0 12px}
.doc-body h3{font-size:18px;color:var(--forest);margin:24px 0 8px;font-family:'Hanken Grotesk',sans-serif;font-weight:700}
.doc-body p,.doc-body li{font-size:16px;color:var(--ink-soft);margin-bottom:12px}
.doc-body ul{padding-left:22px}
.doc-body li{margin-bottom:8px}
.doc-body a{color:var(--coral);font-weight:600}
.callout{background:var(--sage-soft);border-radius:16px;padding:20px 22px;margin:24px 0;font-size:15px;color:var(--ink-soft)}

/* ---- footer ---- */
footer{padding:56px 0 40px;border-top:1px solid var(--line);background:var(--cream-soft)}
.foot-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:36px}
.foot-brand{max-width:280px}
.foot-brand p{color:var(--ink-soft);font-size:15px;margin-top:14px}
.foot-col h5{font-size:12px;text-transform:uppercase;letter-spacing:.09em;color:var(--sage);margin-bottom:15px;font-weight:700}
.foot-col a{display:block;color:var(--ink-soft);font-size:15px;margin-bottom:10px;transition:.2s}
.foot-col a:hover{color:var(--coral)}
.foot-bottom{margin-top:46px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:14px;color:var(--ink-soft)}
