/*
Theme Name: Modern Natural Living
Theme URI: https://modernlivingnatural.com
Author: Modern Natural Living
Version: 3.0.0
Description: Affiliate-first editorial commerce theme. Zero Plastic, PFAS-Free, BPA-Free product guides.
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pureliving
*/

/* ── RESET & BASE ─────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#FDFAF5;--surface:#FFF;--text:#1A1A1A;--muted:#6B6B6B;
  --accent:#2D6A4F;--accent2:#40916C;--accent3:#95D5B2;
  --warm:#D4A373;--warm2:#FAEDCD;--blue:#457B9D;--border:#E8E0D4;
  --danger:#BC4749;--danger-bg:#FFEBEE;
  --rad:16px;--rad-sm:10px;
  --sh:0 4px 24px rgba(0,0,0,.06);--sh-lg:0 12px 48px rgba(0,0,0,.10);
  --f-display:'Playfair Display',Georgia,serif;
  --f-body:'Inter',system-ui,sans-serif;
  --f-mono:'JetBrains Mono',monospace;
  --max:1280px;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--f-body);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent2)}

/* ── UTILITY ──────────────────────────────────── */
.container{max-width:var(--max);margin:0 auto;padding:0 clamp(16px,4vw,24px)}

/* ── NAV ──────────────────────────────────────── */
.site-nav{position:sticky;top:0;z-index:100;background:rgba(253,250,245,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.site-nav .container{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{font-family:var(--f-display);font-weight:800;font-size:clamp(1rem,2.5vw,1.25rem);color:var(--accent);letter-spacing:-.02em}
.logo span{color:var(--warm)}
.site-nav ul{list-style:none;display:flex;gap:clamp(12px,2vw,28px);margin:0;padding:0}
.site-nav ul li{position:relative}
.site-nav ul li a{font-size:clamp(.7rem,1.2vw,.85rem);font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;transition:color .2s;white-space:nowrap;padding:8px 0;display:block}
.site-nav ul li a:hover,.site-nav ul li.current-menu-item a,.site-nav ul li.current_page_item a{color:var(--accent)}
.menu-btn{display:none;background:0;border:0;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;position:relative;z-index:101;padding:8px}
.menu-btn svg{width:26px;height:26px;stroke:var(--text);pointer-events:none}

/* ── BREADCRUMBS ─────────────────────────────── */
.breadcrumbs{padding:14px 0;font-size:.82rem;color:var(--muted)}
.breadcrumbs a{color:var(--muted);font-weight:500}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs span{margin:0 6px;opacity:.5}

/* ── HERO ─────────────────────────────────────── */
.hero{position:relative;min-height:min(88vh,860px);display:flex;align-items:center;justify-content:center;text-align:center;background:linear-gradient(165deg,#F5F0E8 0%,#E8F5E9 50%,#FFF8E1 100%);overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(45,106,79,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(212,163,115,.12) 0%,transparent 50%)}
.hero-content{position:relative;z-index:2;max-width:820px;padding:clamp(32px,8vw,60px) 24px}
.hero .shape{position:absolute;border-radius:50%;opacity:.12;animation:float 8s ease-in-out infinite}
.shape-1{width:clamp(160px,25vw,320px);height:clamp(160px,25vw,320px);background:var(--accent3);top:-60px;left:-80px}
.shape-2{width:clamp(110px,18vw,220px);height:clamp(110px,18vw,220px);background:var(--warm);bottom:-40px;right:-60px;animation-delay:-3s}
.shape-3{width:clamp(70px,10vw,140px);height:clamp(70px,10vw,140px);background:var(--blue);top:30%;right:8%;animation-delay:-5s}
.badge{display:inline-block;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:rgba(45,106,79,.08);border:1px solid rgba(45,106,79,.18);padding:6px 16px;border-radius:999px;margin-bottom:24px;animation:fadeUp .8s ease-out both}
.hero h1{font-family:var(--f-display);font-size:clamp(2rem,5vw,3.8rem);font-weight:800;line-height:1.12;letter-spacing:-.03em;margin-bottom:18px;animation:fadeUp .8s .15s ease-out both}
.hero h1 em{font-style:normal;background:linear-gradient(120deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{font-size:clamp(.95rem,1.8vw,1.15rem);color:var(--muted);max-width:600px;margin:0 auto 32px;animation:fadeUp .8s .3s ease-out both}
.hero-cta{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center;animation:fadeUp .8s .45s ease-out both}
.hero-sm{min-height:min(50vh,400px)}
.hero-sm h1{font-size:clamp(1.6rem,4vw,2.8rem)}

/* ── BUTTONS ──────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:999px;font-weight:600;font-size:clamp(.85rem,1.4vw,.95rem);transition:all .25s;cursor:pointer;border:none;text-decoration:none}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 16px rgba(45,106,79,.25)}
.btn-primary:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 6px 24px rgba(45,106,79,.3);color:#fff}
.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}
.btn-outline:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}
.btn-amazon{background:#FF9900;color:#111;font-weight:700;box-shadow:0 4px 16px rgba(255,153,0,.3)}
.btn-amazon:hover{background:#e68a00;transform:translateY(-2px);color:#111}
.btn-sm{padding:9px 20px;font-size:.82rem}
.btn-lg{padding:16px 36px;font-size:1.05rem}
.btn-block{width:100%;justify-content:center}

/* ── CRITERIA BAR ─────────────────────────────── */
.criteria-bar{background:var(--accent);color:#fff;padding:20px 24px;text-align:center}
.criteria-bar .pills{display:flex;justify-content:center;gap:clamp(8px,2vw,16px);flex-wrap:wrap;margin-bottom:8px}
.criteria-bar .pill{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:6px 16px;font-size:.82rem;font-weight:600;letter-spacing:.02em}
.criteria-bar p{font-size:.85rem;opacity:.88;max-width:680px;margin:0 auto}

/* ── SECTIONS ─────────────────────────────────── */
section{padding:clamp(48px,8vw,80px) 0}
.section-label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.section-title{font-family:var(--f-display);font-size:clamp(1.6rem,3.5vw,2.5rem);font-weight:700;line-height:1.18;letter-spacing:-.02em;margin-bottom:10px}
.section-desc{font-size:clamp(.9rem,1.5vw,1.05rem);color:var(--muted);max-width:640px;margin-bottom:40px}
.bg-alt{background:#F5F0E8}

/* ── DISCLOSURE BAR ──────────────────────────── */
.disclosure-bar{background:var(--warm2);border-bottom:1px solid var(--border);padding:10px 24px;font-size:.78rem;color:var(--muted);text-align:center;line-height:1.5}
.disclosure-bar a{color:var(--accent);font-weight:600;text-decoration:underline}

/* ── CATEGORY HUB CARDS ──────────────────────── */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr));gap:24px}
.hub-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rad);padding:clamp(24px,4vw,36px);transition:all .3s;position:relative;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:var(--text)}
.hub-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent3));opacity:0;transition:opacity .3s}
.hub-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);border-color:var(--accent3);color:var(--text)}
.hub-card:hover::before{opacity:1}
.hub-card .hub-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:16px}
.hub-card h3{font-family:var(--f-display);font-size:clamp(1.15rem,2vw,1.35rem);font-weight:700;margin-bottom:8px}
.hub-card .hub-meta{font-size:.82rem;color:var(--muted);margin-bottom:14px;flex:1}
.hub-card .hub-cta{font-weight:600;font-size:.88rem;color:var(--accent);display:inline-flex;align-items:center;gap:6px}
.hub-card .hub-cta::after{content:'\2192';transition:transform .2s}
.hub-card:hover .hub-cta::after{transform:translateX(4px)}
.hub-card .hub-count{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:rgba(45,106,79,.08);border-radius:999px;padding:3px 10px;display:inline-block;margin-bottom:12px}

/* ── PRODUCT CARD FULL (buyer guide) ─────────── */
.product-card-full{background:var(--surface);border:1px solid var(--border);border-radius:var(--rad);padding:clamp(24px,4vw,36px);margin-bottom:24px;position:relative}
.product-card-full.editors-pick{border-color:var(--accent);border-width:2px}
.product-card-full.editors-pick::after{content:"Editor's Pick";position:absolute;top:14px;right:14px;background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;border-radius:999px}
.pcf-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.pcf-rank{font-family:var(--f-display);font-size:2rem;font-weight:800;color:var(--accent);line-height:1;min-width:40px}
.pcf-title{flex:1}
.pcf-title h3{font-family:var(--f-display);font-size:clamp(1.2rem,2vw,1.5rem);font-weight:700;margin-bottom:4px}
.pcf-title .pcf-subtitle{font-size:.85rem;color:var(--muted)}
.pcf-body{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px}
.pcf-details p{font-size:.9rem;color:var(--muted);line-height:1.7;margin-bottom:12px}
.pcf-pros-cons h4{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.pcf-pros-cons ul{list-style:none;margin:0 0 14px;padding:0}
.pcf-pros-cons li{font-size:.85rem;padding:4px 0 4px 22px;position:relative;color:var(--muted)}
.pcf-pros li::before{content:'\2713';position:absolute;left:0;color:var(--accent);font-weight:700}
.pcf-cons li::before{content:'\2717';position:absolute;left:0;color:var(--danger);font-weight:700}
.pcf-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:16px;border-top:1px solid var(--border)}
.pcf-meta{display:flex;gap:16px;flex-wrap:wrap}
.pcf-meta-item{font-size:.78rem;color:var(--muted)}
.pcf-meta-item strong{color:var(--text);display:block;font-size:.85rem}

/* ── PRICE TIER ──────────────────────────────── */
.price-tier{font-family:var(--f-mono);font-weight:700;letter-spacing:.04em}
.price-tier .active{color:var(--accent)}
.price-tier .dim{color:var(--border)}

/* ── COMPARISON TABLE ────────────────────────── */
.comparison-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:var(--rad);overflow:hidden;margin:32px 0;font-size:.88rem}
.comparison-table thead{background:var(--accent);color:#fff}
.comparison-table th{padding:14px 16px;text-align:left;font-weight:600;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.comparison-table td{padding:14px 16px;border-top:1px solid var(--border);vertical-align:middle}
.comparison-table tbody tr{background:var(--surface);transition:background .2s}
.comparison-table tbody tr:hover{background:rgba(45,106,79,.03)}
.comparison-table tbody tr:first-child td{border-top:none}
.comparison-table .ct-product{font-weight:600;color:var(--text)}
.comparison-table .ct-pick{background:rgba(45,106,79,.06)}
.ct-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:32px 0}
.ct-wrap::-webkit-scrollbar{height:6px}
.ct-wrap::-webkit-scrollbar-track{background:var(--border);border-radius:3px}
.ct-wrap::-webkit-scrollbar-thumb{background:var(--accent3);border-radius:3px}

/* ── FILTER / SORT CONTROLS ──────────────────── */
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px;align-items:center}
.filter-bar label{font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.filter-select{padding:8px 14px;border:1px solid var(--border);border-radius:var(--rad-sm);font-size:.85rem;font-family:var(--f-body);background:var(--surface);color:var(--text);cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%236B6B6B' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
.filter-select:focus{outline:none;border-color:var(--accent)}

/* ── STICKY CTA (mobile) ────────────────────── */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:12px 16px;display:none;align-items:center;justify-content:space-between;gap:12px;z-index:90;box-shadow:0 -4px 16px rgba(0,0,0,.08)}
.sticky-cta .sticky-label{font-size:.82rem;font-weight:600;color:var(--text);line-height:1.3}
.sticky-cta .sticky-label small{display:block;font-weight:400;color:var(--muted);font-size:.75rem}
.sticky-cta .btn{flex-shrink:0}

/* ── METHODOLOGY BLOCK ───────────────────────── */
.methodology-block{background:rgba(45,106,79,.04);border:1px solid rgba(45,106,79,.12);border-radius:var(--rad);padding:clamp(20px,3vw,28px);margin:32px 0}
.methodology-block h4{font-family:var(--f-display);font-size:1.05rem;font-weight:700;margin-bottom:10px;color:var(--accent)}
.methodology-block ul{list-style:none;margin:0;padding:0}
.methodology-block li{font-size:.85rem;color:var(--muted);padding:5px 0 5px 20px;position:relative}
.methodology-block li::before{content:'\2713';position:absolute;left:0;color:var(--accent);font-weight:700}
.methodology-block .meth-link{display:inline-flex;align-items:center;gap:4px;font-size:.82rem;font-weight:600;margin-top:12px}

/* ── LEAD MAGNET ─────────────────────────────── */
.lead-magnet{background:linear-gradient(135deg,#2D6A4F 0%,#1B4332 100%);color:#fff;border-radius:var(--rad);padding:clamp(28px,5vw,48px);text-align:center;margin:40px 0}
.lead-magnet h3{font-family:var(--f-display);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:700;margin-bottom:8px}
.lead-magnet p{font-size:.95rem;opacity:.88;max-width:480px;margin:0 auto 20px}
.lead-magnet .nl-form{max-width:440px;margin:0 auto}
.lead-magnet .lm-tiny{font-size:.75rem;opacity:.6;margin-top:10px}

/* ── INFO BANNER ─────────────────────────────── */
.info-banner{background:linear-gradient(135deg,#2D6A4F,#40916C);color:#fff;border-radius:var(--rad);padding:clamp(28px,5vw,48px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,40px);align-items:center;margin:0 0 48px}
.info-banner h2{font-family:var(--f-display);font-size:clamp(1.4rem,3vw,2rem);font-weight:700;margin-bottom:14px}
.info-banner p{opacity:.9;font-size:.93rem;line-height:1.7}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat-box{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:var(--rad-sm);padding:clamp(14px,2.5vw,24px);text-align:center}
.stat-box .num{font-family:var(--f-display);font-size:clamp(1.4rem,3vw,2rem);font-weight:800;display:block}
.stat-box .label{font-size:.78rem;opacity:.8;margin-top:4px}

/* ── RESOURCE CARDS ──────────────────────────── */
.resource-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,260px),1fr));gap:18px}
.resource-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rad);padding:22px;text-align:center;transition:all .3s}
.resource-card:hover{transform:translateY(-3px);box-shadow:var(--sh)}
.resource-card .emoji{font-size:1.8rem;margin-bottom:10px}
.resource-card h4{font-family:var(--f-display);font-size:1.05rem;margin-bottom:6px}
.resource-card p{font-size:.83rem;color:var(--muted);margin-bottom:12px}

/* ── TRUST PAGE CONTENT ──────────────────────── */
.trust-page{max-width:800px;margin:0 auto}
.trust-page h1{font-family:var(--f-display);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;margin-bottom:16px;line-height:1.2}
.trust-page h2{font-family:var(--f-display);font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:700;margin:32px 0 12px;color:var(--accent)}
.trust-page h3{font-size:1.05rem;font-weight:700;margin:24px 0 8px}
.trust-page p{font-size:.95rem;color:var(--muted);line-height:1.75;margin-bottom:16px}
.trust-page ul,.trust-page ol{margin:0 0 16px 24px;color:var(--muted);font-size:.95rem;line-height:1.75}
.trust-page li{margin-bottom:6px}

/* ── CERT GLOSSARY CARDS ─────────────────────── */
.cert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:20px;margin:28px 0}
.cert-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rad);padding:24px}
.cert-card h3{font-family:var(--f-display);font-size:1.1rem;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.cert-card p{font-size:.88rem;color:var(--muted);line-height:1.6;margin-bottom:10px}
.cert-card .cert-link{font-size:.82rem;font-weight:600}

/* ── INTERNAL LINK CARDS ─────────────────────── */
.related-guides{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:16px;margin:32px 0}
.related-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--rad-sm);padding:16px;text-decoration:none;color:var(--text);transition:all .2s}
.related-card:hover{border-color:var(--accent3);box-shadow:var(--sh);color:var(--text)}
.related-card .rc-icon{font-size:1.4rem;flex-shrink:0}
.related-card .rc-text{font-size:.88rem;font-weight:600}
.related-card .rc-text small{display:block;font-weight:400;color:var(--muted);font-size:.78rem;margin-top:2px}

/* ── NEWSLETTER ──────────────────────────────── */
.newsletter{background:linear-gradient(135deg,#2D6A4F 0%,#1B4332 100%);color:#fff;padding:clamp(48px,8vw,80px) 0;text-align:center}
.newsletter h2{font-family:var(--f-display);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;margin-bottom:12px}
.newsletter p{font-size:clamp(.9rem,1.5vw,1.05rem);opacity:.88;max-width:520px;margin:0 auto 28px}
.nl-form{display:flex;gap:10px;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.nl-form input[type="email"]{flex:1;min-width:200px;padding:14px 20px;border:2px solid rgba(255,255,255,.25);border-radius:999px;background:rgba(255,255,255,.1);color:#fff;font-size:.95rem;font-family:var(--f-body);outline:none;transition:border-color .2s}
.nl-form input[type="email"]::placeholder{color:rgba(255,255,255,.6)}
.nl-form input[type="email"]:focus{border-color:rgba(255,255,255,.6)}
.nl-form button{padding:14px 28px;border-radius:999px;background:#fff;color:var(--accent);font-weight:700;font-size:.95rem;border:none;cursor:pointer;transition:all .25s}
.nl-form button:hover{background:var(--warm2);transform:translateY(-2px)}
.nl-tiny{font-size:.78rem;opacity:.65;margin-top:14px}

/* ── FOOTER ──────────────────────────────────── */
.site-footer{background:#1A1A1A;color:#ccc;padding:clamp(40px,6vw,64px) 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(20px,3vw,40px);margin-bottom:40px}
.footer-brand{font-family:var(--f-display);font-size:1.2rem;font-weight:800;color:#fff;margin-bottom:10px}
.footer-brand span{color:var(--warm)}
.site-footer p{font-size:.85rem;line-height:1.7}
.site-footer h5{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#999;margin-bottom:14px}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer ul li{margin-bottom:8px}
.site-footer ul li a{color:#bbb;font-size:.85rem}
.site-footer ul li a:hover{color:var(--accent3)}
.footer-bottom{border-top:1px solid #333;padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:#777;flex-wrap:wrap;gap:8px}
.footer-disclosure{font-size:.75rem;color:#666;max-width:700px;line-height:1.6;margin-top:12px}

/* ── BACK TO TOP ─────────────────────────────── */
.back-to-top{position:fixed;bottom:28px;right:28px;width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.15);opacity:0;visibility:hidden;transform:translateY(12px);transition:all .3s;z-index:89}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--accent2);transform:translateY(-2px)}
.back-to-top svg{width:20px;height:20px;fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* ── ANIMATIONS ──────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(3deg)}}
.fi{opacity:1;transform:none}

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:960px){
  .site-nav ul{display:none}
  .menu-btn{display:block}
  .site-nav.open ul{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:var(--bg);padding:20px;border-bottom:1px solid var(--border);gap:14px;z-index:99}
  .info-banner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .pcf-body{grid-template-columns:1fr}
}
@media(max-width:768px){
  .sticky-cta{display:flex}
}
@media(max-width:640px){
  .cat-grid,.hub-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{min-height:min(80vh,700px)}
  .stat-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .comparison-table{font-size:.8rem}
  .comparison-table th,.comparison-table td{padding:10px 12px}
}
@media(min-width:1440px){:root{--max:1360px}.cat-grid,.hub-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1920px){:root{--max:1520px}html{font-size:17px}}

/* ── WP OVERRIDES ────────────────────────────── */
.admin-bar .site-nav{top:32px}
@media(max-width:782px){.admin-bar .site-nav{top:46px}}
