/*
Theme Name: PureLiving Guide
Theme URI: https://purelivingguide.com
Author: PureLiving
Author URI: https://purelivingguide.com
Description: A curated directory of Zero Plastic, PFAS-Free, and BPA-Free products. Clean, modern single-page theme.
Version: 1.0.0
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
Tags: one-column, custom-menu, featured-images, full-width-template
*/

/* ── 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;
  --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,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.site-nav .container{display:flex;align-items:center;justify-content:space-between;height:60px}
.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 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}
.site-nav ul li a:hover,.site-nav ul li.current-menu-item a{color:var(--accent)}
.menu-btn{display:none;background:0;border:0;cursor:pointer}
.menu-btn svg{width:26px;height:26px;stroke:var(--text)}

/* ── HERO ─────────────────────────────────────── */
.hero{position:relative;min-height:min(92vh,900px);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}
.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}

/* ── 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}
.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)}

/* ── 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}

/* ── CATEGORY GRID ────────────────────────────── */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr));gap:20px}

/* ── BRAND CARD ───────────────────────────────── */
.brand-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rad);padding:clamp(20px,3vw,28px);transition:all .3s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.brand-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}
.brand-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:var(--accent3)}
.brand-card:hover::before{opacity:1}
.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.brand-card h3{font-family:var(--f-display);font-size:clamp(1.05rem,1.6vw,1.25rem);font-weight:700;line-height:1.3}
.ic{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.ic-g{background:#E8F5E9}.ic-w{background:#FFF3E0}.ic-b{background:#E3F2FD}.ic-p{background:#F3E5F5}
.tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.t{font-size:.65rem;font-weight:600;letter-spacing:.04em;padding:3px 9px;border-radius:999px;text-transform:uppercase}
.t-g{background:#E8F5E9;color:#2D6A4F}.t-w{background:#FFF3E0;color:#A0522D}
.t-b{background:#E3F2FD;color:#457B9D}.t-p{background:#F3E5F5;color:#7B1FA2}
.t-r{background:#FFEBEE;color:#BC4749}
.brand-card p{font-size:.88rem;color:var(--muted);margin-bottom:14px;line-height:1.6;flex:1}
.card-link{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:.86rem;color:var(--accent);margin-top:auto}
.card-link::after{content:'\2192';transition:transform .2s}
.brand-card:hover .card-link::after{transform:translateX(4px)}

/* ── 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}

/* ── 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}

/* ── 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)}}
/* Fade-in: all content always visible. .v just adds a subtle entrance. */
.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:60px;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}
}
@media(max-width:640px){
  .cat-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}
}
@media(min-width:1440px){:root{--max:1360px}.cat-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1920px){:root{--max:1520px}html{font-size:17px}}

/* ── WP OVERRIDES ─────────────────────────────── */
.wp-admin-bar .site-nav{top:32px}
@media(max-width:782px){.wp-admin-bar .site-nav{top:46px}}
