/* ═══════════════════════════════════════════════════════════════════════
   PaddockMateIQ — Marketing CSS
   Shared styles for landing pages and blog (homepage uses its own inline CSS).
   Visual language deliberately mirrors index.html so the brand stays cohesive.
   ─────────────────────────────────────────────────────────────────────── */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Phase 9A-2: palette swapped to match new homepage (ink-2 / gum / ochre / sand).
     Old token names preserved as aliases so existing selectors don't break. */
  --ink:#102417;
  --ink-2:#173b2b;
  --green:#173b2b;
  --green-mid:#274b3b;
  --gum:#789b83;
  --gum-soft:#e8f0e7;
  --ochre:#c86f2b;
  --ochre-dark:#a95d30;
  --ochre-2:#e1963e;
  --ochre-light:#f0c989;
  --clay:#a95d30;
  --sand:#fbf4e8;
  --sand-2:#f0dfc4;
  --paper:#fffaf1;
  --cream:#fbf4e8;
  --linen:#f0dfc4;
  --stone:#d6ccbe;
  --text:#102417;
  --muted:#586653;
  --line:rgba(23,59,43,.12);
  --r:16px;
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;background:var(--cream);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* ── Reveal animation ─────────────────────────────────────────────── */
/* Default state is VISIBLE so content renders even if JS fails or the
   inline IntersectionObserver script is truncated. The .visible class
   added by JS is now a no-op — animations are sacrificed for safety. */
.reveal{opacity:1;transform:none;transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.12s}
.reveal-d2{transition-delay:.24s}
.reveal-d3{transition-delay:.36s}

/* ── Floating pill nav (matches homepage) ────────────────────────── */
.site-header{position:fixed;z-index:200;top:24px;left:clamp(16px,4vw,48px);right:clamp(16px,4vw,48px);height:66px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:0 18px;border:1px solid var(--line);border-radius:20px;background:rgba(255,250,241,.86);box-shadow:0 12px 40px rgba(46,38,24,.08);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}
.brand{display:flex;align-items:center;gap:12px;min-width:max-content;text-decoration:none}
.brand-mark{width:40px;height:40px;display:grid;place-items:center;border-radius:11px;background:linear-gradient(135deg,var(--ink-2),#0b2617);color:#f0c989;font-weight:900;font-size:.78rem;flex-shrink:0}
.brand strong{display:block;font-family:'Fraunces',Georgia,serif;font-size:1.35rem;line-height:1;letter-spacing:-.02em;color:var(--ink-2)}
.brand small{display:block;margin-top:2px;color:var(--clay);font-size:.64rem;font-weight:900;letter-spacing:.15em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:20px}
.nav-links a{color:var(--muted);font-weight:700;font-size:.9rem;transition:color .2s;text-decoration:none;white-space:nowrap}
.nav-links a:hover{color:var(--ink)}
.nav-cta{padding:10px 16px!important;border-radius:12px!important;background:var(--ink-2)!important;color:#fff!important;box-shadow:0 10px 28px rgba(23,59,43,.18)!important;font-weight:800!important}
.nav-cta:hover{background:var(--ochre)!important}
.menu-button{display:none;background:none;border:0;width:40px;height:40px;padding:0;cursor:pointer}
.menu-button span{display:block;width:24px;height:2px;margin:5px auto;background:var(--ink);border-radius:2px;transition:all .3s}
/* dropdown items */
.nav-item{position:relative}
.nav-btn{background:none;border:0;cursor:pointer;color:var(--muted);font-weight:700;font-size:.9rem;padding:0;display:inline-flex;align-items:center;gap:5px;transition:color .2s;font-family:inherit;white-space:nowrap}
.nav-btn:hover{color:var(--ink)}
.nav-caret{font-size:.68rem;transition:transform .22s ease;display:inline-block;margin-top:1px}
.nav-item:hover .nav-caret,.nav-item.open .nav-caret{transform:rotate(180deg)}
.nav-simple{color:var(--muted);font-weight:700;font-size:.9rem;transition:color .2s;white-space:nowrap;text-decoration:none}
.nav-simple:hover{color:var(--ink)}
.nav-dropdown{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-6px);min-width:210px;padding:8px;border:1px solid var(--line);border-radius:16px;background:rgba(255,250,241,.97);box-shadow:0 18px 56px rgba(46,38,24,.15);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease}
.nav-item:hover .nav-dropdown,.nav-item.open .nav-dropdown{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-dropdown a{display:block;padding:9px 13px;border-radius:10px;color:var(--ink);font-size:.87rem;font-weight:650;transition:background .12s,color .12s;white-space:nowrap}
.nav-dropdown a:hover{background:var(--gum-soft);color:var(--ink-2)}
/* Mobile slide-in panel */
.mob-overlay{display:none;position:fixed;inset:0;z-index:300;background:rgba(10,28,18,.55);backdrop-filter:blur(4px)}
.mob-overlay.open{display:block}
.mob-panel{position:fixed;top:0;right:0;bottom:0;width:min(340px,94vw);background:var(--paper);padding:0;overflow-y:auto;transform:translateX(102%);transition:transform .32s cubic-bezier(.22,1,.36,1);box-shadow:-24px 0 80px rgba(0,0,0,.2)}
.mob-overlay.open .mob-panel{transform:none}
.mob-panel-head{display:flex;align-items:center;justify-content:space-between;padding:22px 22px 14px;border-bottom:1px solid var(--line)}
.mob-panel-head .brand{gap:10px}
.mob-close{background:rgba(23,59,43,.08);border:0;width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:1.15rem;display:grid;place-items:center}
.mob-nav{padding:16px 14px 32px}
.mob-group{margin-bottom:6px;border-radius:12px;overflow:hidden}
.mob-group-head{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;cursor:pointer;color:var(--ink);font-weight:700;font-size:.97rem;transition:background .12s;background:none;border:0;width:100%;font-family:inherit;text-align:left}
.mob-group-head:hover{background:rgba(23,59,43,.05)}
.mob-group-caret{font-size:.7rem;transition:transform .2s;display:inline-block}
.mob-group.open .mob-group-caret{transform:rotate(180deg)}
.mob-sub{display:none;padding:0 6px 8px 8px}
.mob-group.open .mob-sub{display:block}
.mob-sub a{display:block;padding:9px 12px;border-radius:9px;color:var(--muted);font-size:.9rem;font-weight:600;transition:background .12s,color .12s;text-decoration:none}
.mob-sub a:hover{background:var(--gum-soft);color:var(--ink-2)}
.mob-divider{height:1px;background:var(--line);margin:10px 14px}
.mob-solo{display:block;padding:11px 14px;color:var(--ink);font-weight:700;font-size:.97rem;border-radius:10px;transition:background .12s;text-decoration:none}
.mob-solo:hover{background:rgba(23,59,43,.05)}
.mob-cta{display:block;margin:18px 14px 0;padding:14px;border-radius:12px;background:var(--ink-2);color:#fff;text-align:center;font-weight:900;font-size:1rem;text-decoration:none}
.mob-signin{display:block;margin:10px 14px 0;padding:13px;border-radius:12px;background:rgba(23,59,43,.07);color:var(--ink-2);text-align:center;font-weight:800;font-size:.97rem;text-decoration:none}
@media(max-width:760px){
  .site-header{top:12px;left:12px;right:12px}
  .nav-links{display:none}
  .menu-button{display:block}
}

/* ── Page hero (text-only, no slideshow) ─────────────────────────── */

.lp-hero{position:relative;min-height:62vh;padding:140px 7% 80px;background:linear-gradient(135deg,var(--green) 0%,#0E2010 50%,#1C2E0E 100%);color:#fff;overflow:hidden}
.lp-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 25% 20%,rgba(200,118,42,.18) 0%,transparent 50%),radial-gradient(circle at 75% 80%,rgba(200,118,42,.10) 0%,transparent 50%);pointer-events:none}
.lp-hero-inner{position:relative;max-width:920px}
.lp-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(200,118,42,.18);border:1px solid rgba(200,118,42,.45);color:var(--ochre-light);font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:6px 16px;border-radius:40px;margin-bottom:24px}
.lp-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--ochre)}
.lp-hero h1{font-family:'Fraunces',serif;font-size:clamp(2.4rem,5.6vw,4.4rem);line-height:1.05;font-weight:900;letter-spacing:-.025em;margin-bottom:22px}
.lp-hero h1 em{font-style:italic;color:var(--ochre-light)}
.lp-hero-sub{font-size:clamp(1rem,1.6vw,1.18rem);color:rgba(255,255,255,.78);max-width:640px;line-height:1.7;margin-bottom:32px;font-weight:300}
.lp-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}

/* ── Buttons ─────────────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:9px;background:var(--ochre);color:#fff;font-size:1rem;font-weight:700;padding:15px 28px;border-radius:11px;transition:all .2s;box-shadow:0 6px 28px rgba(200,118,42,.30);white-space:nowrap;border:none;cursor:pointer;font-family:'Inter',sans-serif}
.btn-primary:hover{background:var(--ochre-dark);transform:translateY(-2px);box-shadow:0 10px 36px rgba(200,118,42,.42)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.85);font-size:.95rem;font-weight:600;padding:13px 22px;border-radius:11px;border:1.5px solid rgba(255,255,255,.28);transition:all .2s;white-space:nowrap;background:transparent;cursor:pointer;font-family:'Inter',sans-serif}
.btn-secondary:hover{border-color:rgba(255,255,255,.6);color:#fff;background:rgba(255,255,255,.06)}
.btn-light{display:inline-flex;align-items:center;gap:8px;color:var(--green);font-size:.95rem;font-weight:600;padding:13px 22px;border-radius:11px;border:1.5px solid var(--stone);transition:all .2s;background:#fff}
.btn-light:hover{border-color:var(--ochre);color:var(--ochre)}

/* ── Sections ────────────────────────────────────────────────────── */
.section{padding:88px 7%}
.section-light{background:var(--cream);color:var(--text)}
.section-linen{background:var(--linen);color:var(--text)}
.section-dark{background:var(--ink);color:#fff}
.section-narrow{max-width:1080px;margin:0 auto}
.label{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ochre);margin-bottom:12px}
.section-dark .label{color:var(--ochre-light)}
h2.display{font-family:'Fraunces',serif;font-size:clamp(1.9rem,4.2vw,3.2rem);line-height:1.1;letter-spacing:-.02em;margin-bottom:18px}
.section-light h2.display,.section-linen h2.display{color:var(--green)}
.section-dark h2.display{color:#fff}
.body-lg{font-size:1rem;line-height:1.78;color:var(--muted);max-width:660px}
.section-dark .body-lg{color:rgba(255,255,255,.65)}

/* ── Two-column content blocks ───────────────────────────────────── */
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;max-width:1080px;margin:0 auto}
.split-grid.flip{direction:rtl}
.split-grid.flip > *{direction:ltr}
@media(max-width:860px){.split-grid{grid-template-columns:1fr;gap:36px}.split-grid.flip{direction:ltr}}

/* ── Feature cards ───────────────────────────────────────────────── */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.feat{background:#fff;border-radius:18px;padding:28px;border:1.5px solid var(--stone);transition:all .25s}
.feat:hover{border-color:var(--ochre);box-shadow:0 8px 28px rgba(0,0,0,.06);transform:translateY(-3px)}
.feat-icon{width:46px;height:46px;border-radius:12px;background:var(--linen);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:14px}
.feat h3{font-size:1.05rem;font-weight:700;color:var(--green);margin-bottom:7px;letter-spacing:-.005em}
.feat p{font-size:.88rem;color:var(--muted);line-height:1.65}
@media(max-width:860px){.feat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.feat-grid{grid-template-columns:1fr}}

/* ── Bullet list (rich content) ──────────────────────────────────── */
.rich p{font-size:1rem;line-height:1.78;color:var(--muted);margin-bottom:16px;max-width:680px}
.rich h3{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--green);margin:30px 0 12px;font-weight:700}
.rich ul{list-style:none;margin:18px 0}
.rich ul li{position:relative;padding-left:28px;margin-bottom:10px;font-size:.97rem;color:var(--text);line-height:1.65}
.rich ul li::before{content:'✓';position:absolute;left:0;top:1px;width:18px;height:18px;border-radius:50%;background:var(--ochre);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}

/* ── Species chips ───────────────────────────────────────────────── */
.species-chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px}
.species-chips .chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--stone);border-radius:50px;padding:8px 16px;font-size:.85rem;font-weight:600;color:var(--green);transition:all .2s}
.species-chips .chip:hover{border-color:var(--ochre);background:var(--cream)}

/* ── FAQ ─────────────────────────────────────────────────────────── */
.faq{max-width:820px;margin:48px auto 0}
.faq details{background:#fff;border:1.5px solid var(--stone);border-radius:14px;padding:18px 22px;margin-bottom:12px;transition:border-color .2s}
.faq details[open]{border-color:var(--ochre)}
.faq summary{font-weight:700;color:var(--green);font-size:1rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::after{content:'+';font-size:1.4rem;color:var(--ochre);font-weight:700;line-height:1;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details > p{margin-top:12px;color:var(--muted);line-height:1.7;font-size:.95rem}

/* ── CTA banner ──────────────────────────────────────────────────── */
.cta-banner{background:var(--green);color:#fff;border-radius:24px;padding:52px 44px;text-align:center;max-width:1000px;margin:0 auto;background-image:radial-gradient(circle at 20% 30%,rgba(200,118,42,.20) 0%,transparent 55%),radial-gradient(circle at 80% 70%,rgba(200,118,42,.10) 0%,transparent 55%)}
.cta-banner h2{font-family:'Fraunces',serif;font-size:clamp(1.7rem,3.6vw,2.6rem);margin-bottom:14px;letter-spacing:-.01em}
.cta-banner p{color:rgba(255,255,255,.72);max-width:560px;margin:0 auto 28px;font-size:1rem;line-height:1.7}
.cta-banner .btn-primary{background:var(--ochre)}

/* ── Breadcrumbs ─────────────────────────────────────────────────── */
.crumbs{font-size:.78rem;color:rgba(255,255,255,.55);margin-bottom:20px;letter-spacing:.04em}
.crumbs a{color:rgba(255,255,255,.75);text-decoration:none}
.crumbs a:hover{color:var(--ochre-light)}
.crumbs span{margin:0 8px;color:rgba(255,255,255,.35)}

/* ── Cross-links (related pages) ─────────────────────────────────── */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.related-card{display:block;background:#fff;border:1.5px solid var(--stone);border-radius:14px;padding:22px;transition:all .2s;text-decoration:none}
.related-card:hover{border-color:var(--ochre);transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,0,0,.06)}
.related-card .label{font-size:.65rem;color:var(--ochre);margin-bottom:6px}
.related-card h4{font-size:1rem;color:var(--green);font-weight:700;margin-bottom:5px}
.related-card p{font-size:.84rem;color:var(--muted);line-height:1.55}
@media(max-width:860px){.related{grid-template-columns:1fr}}

/* ── Footer ──────────────────────────────────────────────────────── */
footer{background:var(--ink);border-top:1px solid rgba(200,118,42,.18);padding:56px 7% 32px;color:#fff}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:36px;margin-bottom:44px}
.footer-brand-name{font-family:'Fraunces',serif;font-size:1.5rem;color:#fff;margin-bottom:5px}
.footer-tagline{font-size:.8rem;color:rgba(255,255,255,.38)}
.footer-links{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.footer-links a{font-size:.83rem;color:rgba(255,255,255,.48);transition:color .2s}
.footer-links a:hover{color:var(--ochre-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.76rem;color:rgba(255,255,255,.28)}
.memorial-line{color:rgba(240,200,138,.38);font-style:italic}
@media(max-width:600px){.footer-top{flex-direction:column;gap:24px}}

/* ── Article (blog post) ─────────────────────────────────────────── */
.article-hero{padding:140px 7% 60px;background:linear-gradient(135deg,var(--green) 0%,#0E2010 100%);color:#fff}
.article-hero-inner{max-width:780px;margin:0 auto}
.article-cat{display:inline-block;background:rgba(200,118,42,.18);border:1px solid rgba(200,118,42,.45);color:var(--ochre-light);font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:5px 14px;border-radius:40px;margin-bottom:18px}
.article-hero h1{font-family:'Fraunces',serif;font-size:clamp(2rem,4.6vw,3.4rem);line-height:1.12;letter-spacing:-.02em;margin-bottom:18px}
.article-meta{font-size:.85rem;color:rgba(255,255,255,.55);display:flex;gap:18px;flex-wrap:wrap}
.article-body{padding:64px 7%;background:var(--cream)}
.article-body-inner{max-width:780px;margin:0 auto}
.article-body p{font-size:1.06rem;line-height:1.85;color:var(--text);margin-bottom:18px}
.article-body h2{font-family:'Fraunces',serif;font-size:clamp(1.5rem,2.8vw,2rem);color:var(--green);margin:40px 0 14px;letter-spacing:-.01em}
.article-body h3{font-size:1.25rem;color:var(--green);font-weight:700;margin:30px 0 10px}
.article-body ul,.article-body ol{margin:18px 0 18px 28px}
.article-body li{margin-bottom:8px;line-height:1.75}
.article-body blockquote{border-left:3px solid var(--ochre);padding:6px 22px;margin:24px 0;font-family:'Fraunces',serif;font-size:1.15rem;font-style:italic;color:var(--green);line-height:1.6}
.article-body a{color:var(--ochre);text-decoration:underline;text-decoration-color:rgba(200,118,42,.35);text-underline-offset:3px}
.article-body a:hover{text-decoration-color:var(--ochre)}

/* Blog index list */
.posts-list{display:grid;grid-template-columns:1fr;gap:20px;max-width:820px;margin:48px auto 0}
.post-card{display:block;background:#fff;border:1.5px solid var(--stone);border-radius:18px;padding:30px;transition:all .25s}
.post-card:hover{border-color:var(--ochre);box-shadow:0 8px 32px rgba(0,0,0,.06);transform:translateY(-3px)}
.post-card .article-cat{background:var(--linen);border-color:var(--stone);color:va