/* ===========================================================
   PawPick — "Warm Editorial" theme (v2, upgraded)
   Fraunces display + Plus Jakarta Sans, layered hero, elevated
   cards, paw-print texture, refined badges & motion.
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root{
  --ink:#231f2b; --ink-soft:#4b4555;
  --teal:#0d9488; --teal-dark:#0f6f66; --teal-tint:#e6f5f2;
  --coral:#ff6b5e; --coral-dark:#ec5346;
  --gold:#f4b740;
  --cream:#fffaf4; --sand:#fdeee2; --card:#ffffff;
  --muted:#7c7488; --line:#efe6dc; --good:#1f9d6b;
  --shadow-sm:0 2px 10px rgba(35,31,43,.06);
  --shadow:0 14px 34px -12px rgba(35,31,43,.18);
  --shadow-lg:0 28px 60px -18px rgba(13,148,136,.30);
  --radius:20px; --maxw:1160px;
  --display:"Fraunces",Georgia,serif; --body:"Plus Jakarta Sans",system-ui,sans-serif;
  --paw:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Cg fill='%23ffffff'%3E%3Cellipse cx='32' cy='40' rx='10' ry='8'/%3E%3Ccircle cx='18' cy='27' r='3.6'/%3E%3Ccircle cx='27' cy='20' r='3.6'/%3E%3Ccircle cx='37' cy='20' r='3.6'/%3E%3Ccircle cx='46' cy='27' r='3.6'/%3E%3C/g%3E%3C/svg%3E");
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--teal-dark)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

.topbar{background:var(--ink);color:#e8def3;font-size:13px;text-align:center;padding:9px 14px;letter-spacing:.2px}
.topbar a{color:var(--gold);text-decoration:underline}

.site-header{position:sticky;top:0;z-index:50;background:rgba(255,250,244,.85);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink);font-family:var(--display);font-weight:700;font-size:24px;letter-spacing:-.4px}
.brand .logo{width:42px;height:42px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--coral),var(--coral-dark));display:grid;place-items:center;color:#fff;font-size:21px;box-shadow:0 6px 16px -4px rgba(236,83,70,.6)}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-links a{text-decoration:none;color:var(--ink-soft);font-weight:600;font-size:15px;padding:9px 15px;border-radius:999px;transition:.18s}
.nav-links a:hover{background:var(--teal-tint);color:var(--teal-dark)}
.nav-toggle{display:none;background:none;border:0;font-size:27px;color:var(--ink);cursor:pointer}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;text-align:center;padding:100px 22px 96px;
  background:
    radial-gradient(1100px 500px at 50% -10%, var(--teal-tint), transparent 60%),
    radial-gradient(700px 420px at 85% 110%, var(--sand), transparent 55%),
    linear-gradient(180deg,#fffdf9,var(--cream));}
.hero::before{content:"";position:absolute;inset:0;background-image:var(--paw);background-size:120px 120px;opacity:.05;filter:invert(1);pointer-events:none}
.hero::after{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,94,.18),transparent 70%);top:-90px;right:-60px;pointer-events:none}
.hero>.wrap{position:relative}
.hero h1{font-family:var(--display);font-weight:600;font-size:clamp(36px,6vw,64px);line-height:1.02;margin:0 0 18px;letter-spacing:-1.2px}
.hero h1 em{font-style:italic;color:var(--coral-dark)}
.hero p{font-size:clamp(17px,2.2vw,21px);max-width:600px;margin:0 auto 30px;color:var(--ink-soft)}
.hero .btn{font-size:17px}
.hero-trust{margin-top:22px;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.hero-trust span{background:#fff;border:1px solid var(--line);color:var(--ink-soft);font-size:13px;font-weight:600;padding:6px 14px;border-radius:999px;box-shadow:var(--shadow-sm)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;background:linear-gradient(135deg,var(--coral),var(--coral-dark));color:#fff;text-decoration:none;font-family:var(--body);font-weight:700;padding:14px 28px;border-radius:999px;box-shadow:0 12px 24px -8px rgba(236,83,70,.6);transition:transform .15s,box-shadow .15s,filter .15s;border:0;cursor:pointer}
.btn::after{content:"→";transition:transform .15s}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 32px -8px rgba(236,83,70,.7);filter:saturate(1.08)}
.btn:hover::after{transform:translateX(3px)}
.btn-block{width:100%;justify-content:center}
.btn-ghost{background:#fff;color:var(--teal-dark);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.btn-ghost::after{content:""}
.btn-ghost:hover{background:var(--teal-tint)}

/* ---------- Sections ---------- */
section{padding:72px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 44px}
.section-head h2{font-family:var(--display);font-weight:600;font-size:clamp(28px,4vw,42px);margin:0 0 12px;letter-spacing:-.7px;line-height:1.1}
.section-head p{color:var(--muted);margin:0;font-size:17px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:700;text-transform:uppercase;letter-spacing:1.6px;font-size:12px;color:var(--teal-dark);background:var(--teal-tint);padding:6px 14px;border-radius:999px;margin:0 0 16px}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral)}

/* ---------- Category grid ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:32px 22px;text-align:center;text-decoration:none;color:var(--ink);box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s,border-color .18s}
.cat-card .ic{display:inline-grid;place-items:center;width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--teal-tint),var(--sand));font-size:34px;margin-bottom:14px;transition:.18s}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.cat-card:hover .ic{background:linear-gradient(135deg,var(--coral),var(--coral-dark));transform:scale(1.06)}
.cat-card h3{font-family:var(--display);font-weight:600;margin:0 0 4px;font-size:19px}
.cat-card span{color:var(--muted);font-size:14px}

/* ---------- Product cards ---------- */
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.product{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .2s;position:relative}
.product:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.product .ribbon{position:absolute;top:16px;left:16px;background:linear-gradient(135deg,var(--coral),var(--coral-dark));color:#fff;font-weight:700;font-size:11.5px;letter-spacing:.4px;text-transform:uppercase;padding:7px 13px;border-radius:999px;z-index:2;box-shadow:0 8px 18px -6px rgba(236,83,70,.7)}
.product .thumb{height:170px;position:relative;background:radial-gradient(circle at 30% 25%,#fff,transparent 60%),linear-gradient(135deg,var(--teal-tint),var(--sand));display:grid;place-items:center;font-size:64px;border-bottom:1px solid var(--line)}
.product .thumb::after{content:"";position:absolute;inset:0;background-image:var(--paw);background-size:80px 80px;opacity:.04}
.product .body{padding:22px;display:flex;flex-direction:column;flex:1}
.product .cat-tag{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--teal)}
.product h3{font-family:var(--display);font-weight:600;margin:7px 0 9px;font-size:21px;line-height:1.2}
.stars{color:var(--gold);font-size:15px;letter-spacing:2px;margin-bottom:10px}
.stars span{color:var(--muted);font-size:13px;letter-spacing:0;margin-left:6px;font-family:var(--body)}
.product p.why{font-size:15px;color:var(--ink-soft);margin:0 0 16px;flex:1}
.product .meta{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}
.tag{background:var(--teal-tint);color:var(--teal-dark);font-weight:600;font-size:12px;padding:5px 12px;border-radius:999px}
.price{font-family:var(--display);font-weight:600;color:var(--ink);font-size:18px;margin-bottom:14px}
.price small{color:var(--muted);font-weight:500;font-family:var(--body)}

/* ---------- Comparison table ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff}
table.compare{width:100%;border-collapse:collapse;min-width:640px}
table.compare th,table.compare td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:15px}
table.compare thead th{background:var(--teal);color:#fff;font-family:var(--body);font-weight:700;font-size:13.5px;letter-spacing:.3px}
table.compare tbody tr:nth-child(even){background:var(--cream)}
table.compare td.name{font-family:var(--display);font-weight:600;color:var(--ink)}

/* ---------- Article body ---------- */
.article-head{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--teal-dark),var(--teal));color:#fff;padding:74px 0 64px}
.article-head::before{content:"";position:absolute;inset:0;background-image:var(--paw);background-size:120px 120px;opacity:.07}
.article-head::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,94,.30),transparent 70%);top:-120px;right:-80px}
.article-head>.wrap{position:relative}
.article-head .eyebrow{background:rgba(255,255,255,.16);color:#fff}
.article-head .eyebrow::before{background:var(--gold)}
.article-head h1{font-family:var(--display);font-weight:600;font-size:clamp(30px,4.8vw,48px);margin:0 0 14px;max-width:840px;letter-spacing:-.8px;line-height:1.08}
.article-head p{color:#dff3ef;max-width:720px;font-size:18.5px;margin:0}
.article-head .byline{margin-top:20px;font-size:14px;color:#a9ddd5}
.prose{max-width:820px;margin:0 auto}
.prose h2{font-family:var(--display);font-weight:600;font-size:30px;margin:46px 0 16px;letter-spacing:-.5px}
.prose h3{font-family:var(--display);font-weight:600;color:var(--teal-dark);font-size:22px;margin:30px 0 8px}
.prose p{margin:0 0 16px}
.prose ul{margin:0 0 18px;padding-left:22px}
.prose li{margin-bottom:7px}
.prose a{color:var(--teal-dark);font-weight:700;text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:3px}
.toc{background:#fff;border:1px solid var(--line);border-left:5px solid var(--coral);border-radius:14px;padding:22px 26px;box-shadow:var(--shadow-sm);margin:8px 0 32px}
.toc strong{font-family:var(--display);font-weight:600;display:block;margin-bottom:10px;font-size:17px}
.toc a{color:var(--teal-dark);text-decoration:none;font-weight:600}
.toc a:hover{text-decoration:underline}

/* ---------- Detailed pick ---------- */
.pick{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:30px;margin:26px 0;display:grid;grid-template-columns:140px 1fr;gap:26px;align-items:start;transition:box-shadow .2s,transform .2s}
.pick:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.pick .pick-ic{font-size:68px;text-align:center;background:linear-gradient(135deg,var(--teal-tint),var(--sand));border-radius:16px;padding:24px 0}
.pick .award{display:inline-block;background:linear-gradient(135deg,var(--coral),var(--coral-dark));color:#fff;font-weight:700;font-size:12px;padding:6px 15px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.pick h3{font-family:var(--display);font-weight:600;margin:0 0 6px;font-size:24px}
.pick .pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:16px 0}
.pick .pros-cons h4{font-family:var(--body);margin:0 0 6px;font-size:13px;text-transform:uppercase;letter-spacing:.5px}
.pick .pros h4{color:var(--good)}
.pick .cons h4{color:var(--coral-dark)}
.pick .pros-cons ul{margin:0;padding-left:18px;font-size:14px}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--ink),#352f42);color:#fff;text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;background-image:var(--paw);background-size:110px 110px;opacity:.06}
.cta-band::after{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(13,148,136,.45),transparent 70%);bottom:-160px;left:-80px}
.cta-band>.wrap{position:relative}
.cta-band h2{font-family:var(--display);font-weight:600;color:#fff;letter-spacing:-.5px}
.cta-band .section-head p{color:#cfc7da}
.signup{display:flex;gap:12px;max-width:480px;margin:0 auto}
.signup input{flex:1;padding:15px 20px;border:0;border-radius:999px;font-size:16px;font-family:var(--body)}
.signup .btn{white-space:nowrap;background:linear-gradient(135deg,var(--teal),var(--teal-dark));box-shadow:0 12px 24px -8px rgba(13,148,136,.7)}
.signup-note{font-size:13px;color:#cfc7da;margin-top:14px}

/* ---------- Trust ---------- */
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.trust{text-align:center;padding:30px 22px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s}
.trust:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.trust .ic{display:inline-grid;place-items:center;width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,var(--teal-tint),var(--sand));font-size:30px;margin-bottom:12px}
.trust h3{font-family:var(--display);font-weight:600;margin:0 0 6px;font-size:19px}
.trust p{color:var(--muted);font-size:15px;margin:0}

/* ---------- Footer ---------- */
.site-footer{position:relative;overflow:hidden;background:var(--ink);color:#b9b2c6;padding:58px 0 32px;font-size:15px}
.site-footer::before{content:"";position:absolute;inset:0;background-image:var(--paw);background-size:130px 130px;opacity:.04}
.site-footer>.wrap{position:relative}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;gap:32px;margin-bottom:30px}
.site-footer h4{font-family:var(--display);font-weight:600;color:#fff;margin:0 0 14px;font-size:17px}
.site-footer a{color:#b9b2c6;text-decoration:none;display:block;margin-bottom:9px;transition:.15s}
.site-footer a:hover{color:var(--coral);transform:translateX(2px)}
.footer-disclaimer{border-top:1px solid #3a3447;padding-top:22px;font-size:13px;color:#8a8399;line-height:1.6}

@media(max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}.products{grid-template-columns:repeat(2,1fr)}.trust-grid{grid-template-columns:1fr;gap:14px}.footer-grid{grid-template-columns:1fr 1fr;gap:24px}}
@media(max-width:680px){.nav-links{display:none;position:absolute;top:74px;left:0;right:0;background:var(--cream);flex-direction:column;gap:0;padding:8px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}.nav-links.open{display:flex}.nav-links a{padding:13px}.nav-toggle{display:block}.products{grid-template-columns:1fr}.cat-grid{grid-template-columns:1fr 1fr}.pick{grid-template-columns:1fr}.pick .pick-ic{max-width:140px}.pick .pros-cons{grid-template-columns:1fr}.signup{flex-direction:column}.footer-grid{grid-template-columns:1fr}}
