/*
Theme Name: Andy Parrish
Theme URI: https://andyparrish.org
Author: Andy Parrish
Description: Custom theme for andyparrish.org — independent accountability media. Daily briefing list-building, podcast monetization, and the Flock Safety citizen toolkit (with the interactive Flock Footprint map). Off-white palette, Elementor-friendly.
Version: 2.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: andyparrish
*/

/*
 * Palette note: variables named --cream are kept for historical reasons,
 * but the values are TRUE off-white (cool, neutral) — not cream / ivory / parchment.
 *   --cream   #F1EFE9  off-white background
 *   --cream-2 #F8F7F2  lighter off-white band
 */
:root{
  --navy:#081224; --navy-2:#0d1d36; --cream:#F1EFE9; --cream-2:#F8F7F2;
  --gold:#D9AB6F; --gold-deep:#b8853f; --barn:#9c2b25; --barn-bright:#c0392f;
  --ink:#0b1322; --muted:#5b6577; --line:rgba(8,18,36,.14);
  --display:"Fraunces",Georgia,serif; --body:"Public Sans",system-ui,sans-serif; --mono:"IBM Plex Mono",monospace;
  --wrap:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--display);font-weight:800;line-height:1.06;letter-spacing:-.01em;margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
p{margin:0 0 1rem}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;display:inline-block}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:var(--gold);color:var(--navy);padding:8px 14px;z-index:999}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--body);font-weight:700;font-size:.95rem;padding:.85rem 1.4rem;border-radius:2px;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{box-shadow:0 8px 22px rgba(217,171,111,.4)}
.btn-barn{background:var(--barn);color:var(--cream)}
.btn-barn:hover{box-shadow:0 8px 22px rgba(156,43,37,.4)}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid rgba(243,236,220,.4)}
.btn-ghost.dark{color:var(--navy);border-color:var(--line)}

/* header / nav */
.site-header{position:sticky;top:0;z-index:50;background:rgba(8,18,36,.96);backdrop-filter:blur(8px);border-bottom:1px solid rgba(217,171,111,.25)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--display);font-weight:800;font-size:1.34rem;color:var(--cream);letter-spacing:.01em}
.brand .tag{font-family:var(--mono);font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-top:5px}
.brand img.custom-logo{max-height:46px;width:auto}
.primary-nav{display:flex;align-items:center;gap:4px}
.primary-nav ul{list-style:none;display:flex;align-items:center;gap:2px;margin:0;padding:0}
.primary-nav a{font-weight:600;font-size:.9rem;color:rgba(243,236,220,.78);padding:.5rem .85rem;border-radius:2px;transition:color .15s}
.primary-nav a:hover,.primary-nav .current-menu-item>a{color:var(--cream);box-shadow:inset 0 -2px 0 var(--gold)}
.nav-cta{margin-left:10px}
.menu-toggle{display:none;background:none;border:1px solid rgba(243,236,220,.4);color:var(--cream);border-radius:2px;padding:.5rem .7rem;cursor:pointer;font-size:1.1rem}

/* hero */
.hero{position:relative;background:var(--navy);color:var(--cream);overflow:hidden}
.hero .topo{position:absolute;inset:0;opacity:.5;pointer-events:none}
.hero-inner{position:relative;padding:84px 0 92px}
.hero.compact .hero-inner{padding:62px 0}
.hero h1{font-size:clamp(2.4rem,6vw,4.5rem);max-width:15ch}
.hero h1 em{font-style:italic;color:var(--gold);font-weight:500}
.hero .lede{font-size:1.18rem;max-width:48ch;color:rgba(243,236,220,.84);margin:1.4rem 0 2rem}
.pill-tag{display:inline-flex;gap:14px;font-family:var(--mono);font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.pill-tag span{padding-right:14px;border-right:1px solid rgba(217,171,111,.4)}
.pill-tag span:last-child{border:none;padding-right:0}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* page load stagger */
.stagger{opacity:0;animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.s1{transform:translateY(18px);animation-delay:.05s}
.s2{transform:translateY(18px);animation-delay:.18s}
.s3{transform:translateY(18px);animation-delay:.31s}
.s4{transform:translateY(18px);animation-delay:.44s}

/* sections */
.section{padding:74px 0}
.band-navy{background:var(--navy);color:var(--cream)}
.band-cream2{background:var(--cream-2)}
.sec-head{max-width:64ch;margin-bottom:38px}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);margin:.5rem 0}
.sec-head p{color:var(--muted);font-size:1.05rem;margin:0}
.band-navy .sec-head p{color:rgba(243,236,220,.72)}

/* grids + cards */
.grid{display:grid;gap:24px}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:4px;padding:26px;transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(8,18,36,.1)}
.card .kicker{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.card h3{font-size:1.36rem;margin:.5rem 0 .6rem;color:var(--navy)}
.card p{color:var(--muted);margin:0 0 1rem;font-size:.97rem;flex:1}
.card .more{font-weight:700;color:var(--barn);font-size:.92rem;align-self:flex-start}
.card .thumb{margin:-26px -26px 18px;border-bottom:1px solid var(--line)}
.card .thumb img{width:100%;height:180px;object-fit:cover}

/* who-decides */
.who{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.who blockquote{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.3rem);font-weight:600;line-height:1.2;margin:0;color:var(--navy)}
.who blockquote em{color:var(--gold-deep);font-style:italic}
.who .sig{font-family:var(--mono);font-size:.8rem;letter-spacing:.08em;color:var(--muted);margin-top:18px}
.who-list{list-style:none;padding:0;margin:0;display:grid;gap:18px}
.who-list li{padding-left:34px;position:relative;font-size:1rem}
.who-list li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;background:var(--gold);transform:rotate(45deg)}
.who-list b{display:block;font-family:var(--display);font-size:1.15rem;font-weight:700;margin-bottom:2px}

/* email capture */
.capture{background:var(--navy);color:var(--cream);border-radius:6px;padding:46px;position:relative;overflow:hidden}
.capture .topo{position:absolute;inset:0;opacity:.32}
.capture-inner{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.capture h3{font-size:1.9rem;color:var(--cream)}
.capture p{color:rgba(243,236,220,.8);margin:.6rem 0 0}
.signup{display:flex;gap:10px;flex-wrap:wrap}
.signup input{flex:1;min-width:200px;padding:.95rem 1rem;border:1px solid rgba(243,236,220,.3);background:rgba(243,236,220,.06);color:var(--cream);border-radius:2px;font-family:var(--body);font-size:1rem}
.signup input::placeholder{color:rgba(243,236,220,.5)}
.micro{font-size:.78rem;color:rgba(243,236,220,.55);margin-top:12px}
.signup.light input{background:#fff;color:var(--ink);border-color:var(--line)}
.ap-subscribe-wrap{width:100%}
.ap-subscribe-status{margin-top:12px;font-weight:600;font-size:.98rem;color:var(--gold);font-family:var(--body)}

/* podcast */
.sub-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.sub-row a{display:inline-flex;align-items:center;gap:8px;padding:.65rem 1.05rem;border:1px solid rgba(243,236,220,.3);background:rgba(243,236,220,.06);color:var(--cream);border-radius:2px;font-weight:600;font-size:.85rem}
.sub-row a:hover{border-color:var(--gold)}
.ep{display:grid;grid-template-columns:88px 1fr auto;gap:22px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:4px;padding:20px 24px;margin-bottom:14px}
.ep .num{font-family:var(--display);font-size:2rem;font-weight:800;color:var(--gold);text-align:center}
.ep h3{font-size:1.2rem;margin:0 0 4px;color:var(--navy)}
.ep .meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.ep .play{white-space:nowrap}

/* sponsor */
.sponsor{background:linear-gradient(135deg,var(--barn),#7a201b);color:var(--cream);border-radius:6px;padding:48px;display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center}
.sponsor h3{color:var(--cream);font-size:2rem}
.sponsor p{color:rgba(243,236,220,.85)}
.sponsor .stats{display:flex;gap:30px;margin-top:8px}
.sponsor .stats b{font-family:var(--display);font-size:1.8rem;display:block}
.sponsor .stats span{font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;opacity:.8}

/* membership tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tier{background:#fff;border:1px solid var(--line);border-radius:6px;padding:30px;display:flex;flex-direction:column}
.tier.feat{background:var(--navy);color:var(--cream);border-color:var(--gold);transform:scale(1.03)}
.tier.feat h3,.tier.feat .price{color:var(--cream)}
.tier .badge{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.tier.feat .badge{color:var(--gold)}
.tier h3{font-size:1.5rem;margin:.4rem 0}
.tier .price{font-family:var(--display);font-size:2.4rem;font-weight:800;color:var(--navy)}
.tier .price span{font-size:.9rem;font-family:var(--body);color:var(--muted);font-weight:500}
.tier.feat .price span{color:rgba(243,236,220,.6)}
.tier ul{list-style:none;padding:0;margin:18px 0;display:grid;gap:10px;flex:1}
.tier li{font-size:.92rem;padding-left:24px;position:relative}
.tier li::before{content:"\2713";position:absolute;left:0;color:var(--gold-deep);font-weight:700}
.tier.feat li::before{color:var(--gold)}

/* article / single content */
.entry{max-width:760px;margin:0 auto;padding:64px 24px}
.entry .entry-head{margin-bottom:30px}
.entry h1{font-size:clamp(2rem,4vw,3rem);color:var(--navy);margin-bottom:.6rem}
.entry .entry-meta{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.entry-content{font-size:1.12rem;color:#1c2738}
.entry-content h2{font-size:1.7rem;color:var(--navy);margin:2rem 0 .8rem}
.entry-content h3{font-size:1.3rem;color:var(--navy);margin:1.6rem 0 .6rem}
.entry-content a{color:var(--barn);text-decoration:underline}
.entry-content blockquote{border-left:4px solid var(--gold);padding-left:20px;margin:1.5rem 0;font-family:var(--display);font-size:1.3rem;color:var(--navy)}
.entry-content img{border-radius:4px;margin:1.5rem 0}
.alignfull{width:100vw;margin-left:calc(50% - 50vw)}
.alignwide{width:min(1000px,100%);margin-left:calc(50% - min(500px,50%))}

/* flock toolkit */
.tk-nav{position:sticky;top:76px;z-index:30;background:var(--cream-2);border-bottom:1px solid var(--line)}
.tk-nav .wrap{display:flex;gap:6px;overflow-x:auto;padding-top:12px;padding-bottom:12px}
.tk-nav a{white-space:nowrap;font-weight:600;font-size:.84rem;padding:.45rem .85rem;border-radius:2px;color:var(--muted)}
.tk-nav a:hover{background:#fff;color:var(--navy)}
.glossary{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.term{background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:0 4px 4px 0;padding:20px 22px}
.term dt{font-family:var(--display);font-size:1.18rem;font-weight:700;color:var(--navy)}
.term .ab{font-family:var(--mono);font-size:.72rem;color:var(--gold-deep);margin-left:8px}
.term dd{margin:.5rem 0 0;color:var(--muted);font-size:.94rem}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;text-align:left;background:none;border:none;padding:22px 0;cursor:pointer;display:flex;justify-content:space-between;gap:20px;align-items:center;font-family:var(--display);font-size:1.2rem;font-weight:700;color:var(--navy)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .3s ease}
.qa .ans p{color:var(--muted);margin:0 0 18px;font-size:.98rem}
.qa .icon{flex-shrink:0;width:26px;height:26px;border:1px solid var(--gold-deep);border-radius:50%;display:grid;place-items:center;color:var(--gold-deep);transition:transform .3s;font-size:1.1rem}
.qa.open .icon{transform:rotate(45deg);background:var(--gold);color:var(--navy);border-color:var(--gold)}
.gen{display:grid;grid-template-columns:.85fr 1.15fr;border:1px solid var(--line);border-radius:6px;overflow:hidden;background:#fff}
.gen-form{padding:34px;background:var(--cream-2);border-right:1px solid var(--line)}
.gen-form label{display:block;font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:18px 0 6px}
.gen-form label:first-child{margin-top:0}
.gen-form input,.gen-form select{width:100%;padding:.7rem .8rem;border:1px solid var(--line);border-radius:2px;font-family:var(--body);font-size:.92rem;background:#fff}
.gen-out{padding:34px;display:flex;flex-direction:column}
.gen-out .bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.gen-out .bar b{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep)}
.gen-out .acts button{font-size:.78rem;padding:.5rem .8rem;border:1px solid var(--line);background:#fff;border-radius:2px;cursor:pointer;font-weight:600;font-family:var(--body);margin-left:6px}
.gen-out .acts button:hover{border-color:var(--gold-deep);color:var(--barn)}
.letter{flex:1;background:var(--cream-2);border:1px solid var(--line);border-radius:3px;padding:24px;font-family:var(--mono);font-size:.8rem;line-height:1.7;white-space:pre-wrap;overflow:auto;max-height:520px}
.tpl{background:#fff;border:1px solid var(--line);border-radius:4px;padding:22px;margin-bottom:14px}
.tpl summary{cursor:pointer;font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--navy)}
.tpl pre{font-family:var(--mono);font-size:.78rem;line-height:1.65;white-space:pre-wrap;background:var(--cream-2);padding:18px;border-radius:3px;margin:12px 0 0}
.tpl .copy{margin-top:10px;font-size:.78rem;padding:.45rem .8rem;border:1px solid var(--line);background:#fff;border-radius:2px;cursor:pointer;font-weight:600;font-family:var(--body)}
.rights{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.right{background:#fff;border:1px solid var(--line);border-radius:4px;padding:24px}
.right .stat{font-family:var(--display);font-size:1.7rem;font-weight:800;color:var(--barn)}
.right h4{font-size:1.08rem;margin:.4rem 0 .5rem;color:var(--navy)}
.right p{color:var(--muted);font-size:.9rem;margin:0}
.right .cite{font-family:var(--mono);font-size:.7rem;color:var(--gold-deep);margin-top:10px}
.disclaimer{background:rgba(156,43,37,.06);border:1px solid rgba(156,43,37,.25);border-radius:4px;padding:22px 26px;font-size:.88rem;color:var(--muted);margin-top:22px}
.disclaimer b{color:var(--barn)}

/* footer */
.site-footer{background:var(--navy);color:rgba(243,236,220,.7);padding:58px 0 30px;border-top:3px solid var(--gold)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:36px}
.site-footer .name{font-family:var(--display);font-size:1.5rem;font-weight:800;color:var(--cream)}
.site-footer h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:0 0 14px}
.site-footer a{display:block;color:rgba(243,236,220,.7);font-size:.9rem;margin-bottom:8px}
.site-footer a:hover{color:var(--cream)}
.site-footer ul{list-style:none;margin:0;padding:0}
.foot-bottom{border-top:1px solid rgba(243,236,220,.15);padding-top:22px;font-size:.78rem;color:rgba(243,236,220,.45);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* toast */
.ap-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--navy);color:var(--cream);padding:12px 22px;border-radius:3px;z-index:9999;font-size:.9rem;box-shadow:0 8px 24px rgba(0,0,0,.3)}

@media(max-width:860px){
  .primary-nav{display:none;position:absolute;top:76px;left:0;right:0;background:var(--navy);flex-direction:column;padding:14px 24px;border-bottom:1px solid rgba(217,171,111,.25)}
  .primary-nav.open{display:flex}
  .primary-nav ul{flex-direction:column;align-items:stretch;width:100%;gap:2px}
  .menu-toggle{display:block}
  .who,.capture-inner,.sponsor,.gen{grid-template-columns:1fr}
  .g3,.g2,.glossary,.rights,.tiers{grid-template-columns:1fr}
  .tier.feat{transform:none}
  .gen-form{border-right:none;border-bottom:1px solid var(--line)}
  .foot-grid{grid-template-columns:1fr}
  .ep{grid-template-columns:54px 1fr;gap:14px}
  .ep .play{grid-column:1/-1}
}

/* ---- social icons (header / footer / contact) ---- */
.social-icons{display:inline-flex;align-items:center;gap:6px}
.header-social{margin-left:14px}
.header-social a{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;color:rgba(243,236,220,.7);transition:color .15s,background .15s,transform .15s}
.header-social a:hover{color:var(--navy);background:var(--gold);transform:translateY(-2px)}
.footer-social{margin-top:16px;gap:8px}
.footer-social a{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;color:rgba(243,236,220,.75);border:1px solid rgba(243,236,220,.2);transition:all .15s}
.footer-social a:hover{color:var(--navy);background:var(--gold);border-color:var(--gold)}
.social-icons.dark a{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;color:var(--navy);border:1px solid var(--line);transition:all .15s}
.social-icons.dark a:hover{color:#fff;background:var(--navy);border-color:var(--navy)}

/* ---- contact page ---- */
.contact-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:48px;align-items:start}
.contact-form label{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 6px}
.contact-form input,.contact-form textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:2px;font-family:var(--body);font-size:1rem;background:#fff;margin-bottom:18px}
.contact-form .hp{position:absolute;left:-9999px;height:0;overflow:hidden}
.contact-side h3{font-size:1.3rem;color:var(--navy);margin-bottom:10px}
.contact-side .contact-email{font-weight:700;color:var(--barn);font-size:1.05rem}
.contact-side .contact-loc{color:var(--muted);font-size:.92rem;margin-top:6px}
.support-callout{margin-top:32px;background:var(--cream-2);border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:0 4px 4px 0;padding:22px}
.support-callout p{color:var(--muted);font-size:.94rem;margin:.5rem 0 1rem}
.form-flash{padding:14px 18px;border-radius:4px;margin-bottom:22px;font-weight:600}
.form-flash.ok{background:rgba(217,171,111,.15);border:1px solid var(--gold);color:var(--navy)}
.form-flash.err{background:rgba(156,43,37,.08);border:1px solid var(--barn);color:var(--barn)}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:32px}}

/* ---- announcement ribbon (Flock WI highlight) ---- */
.ap-ribbon{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;background:linear-gradient(90deg,var(--barn),#7a201b);color:var(--cream);padding:9px 18px;font-size:.86rem;font-weight:600;text-decoration:none;border-bottom:1px solid rgba(217,171,111,.4)}
.ap-ribbon:hover{filter:brightness(1.08)}
.ap-ribbon-badge{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;background:var(--gold);color:var(--navy);padding:3px 8px;border-radius:2px;font-weight:700}
.ap-ribbon-go{font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;color:var(--gold)}

/* ---- brand lockup in header ---- */
.brand-lockup{display:flex;align-items:center;gap:12px}
.brand-mark{width:44px;height:44px;border-radius:50%}
.brand-words{display:flex;flex-direction:column;line-height:1}

/* ---- split hero with portrait ---- */
.hero-split .hero-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:end}
.hero-split .hero-copy{padding-bottom:18px}
.hero-portrait{align-self:end;display:flex;justify-content:center}
.hero-portrait img{max-height:480px;width:auto;filter:drop-shadow(0 18px 40px rgba(0,0,0,.45))}
.hero h1 em{font-style:italic;color:var(--gold);font-weight:500}
@media(max-width:860px){.hero-split .hero-inner{grid-template-columns:1fr}.hero-portrait{display:none}}

/* ---- signatures ---- */
.inline-sig{height:64px;width:auto;margin-top:14px;opacity:.95}
.footer-sig{height:54px;width:auto;margin:14px 0 4px;opacity:.9}

/* ---- feature toggles (CSS-level) ---- */
.ap-no-anim .stagger{animation:none!important;opacity:1!important;transform:none!important}
.ap-no-capture .capture{display:none!important}

/* ---- share buttons ---- */
.ap-share{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:34px 0 0;padding-top:22px;border-top:1px solid var(--line)}
.ap-share-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
.ap-share a,.ap-copylink{font-size:.84rem;font-weight:600;padding:.45rem .85rem;border:1px solid var(--line);border-radius:2px;background:#fff;color:var(--navy);cursor:pointer;font-family:var(--body);text-decoration:none}
.ap-share a:hover,.ap-copylink:hover{border-color:var(--gold-deep);color:var(--barn)}

/* ---- inline subscribe CTA inside articles ---- */
.ap-inline-cta{background:var(--cream-2);border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:0 4px 4px 0;padding:22px 24px;margin:30px 0}
.ap-inline-cta>div{margin-bottom:12px;font-size:1.02rem;color:var(--navy)}
.ap-inline-cta .signup input{background:#fff}

/* ---- ad slots ---- */
.ap-ad{margin:28px 0;text-align:center;min-height:90px}
.ap-ad-tag{display:block;font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}

/* ---- sticky subscribe bar ---- */
.ap-sticky-bar[hidden]{display:none!important}
.ap-sticky-bar{position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--navy);color:var(--cream);display:flex;align-items:center;gap:18px;justify-content:center;flex-wrap:wrap;padding:12px 20px;box-shadow:0 -8px 24px rgba(0,0,0,.25)}
.ap-sticky-bar span{font-weight:600}
.ap-sticky-bar .signup{max-width:380px}
.ap-sticky-bar .signup input{background:rgba(243,236,220,.08);color:var(--cream);border-color:rgba(243,236,220,.3)}
.ap-sticky-close{background:none;border:none;color:rgba(243,236,220,.7);font-size:1.5rem;cursor:pointer;line-height:1}
@media(max-width:680px){.ap-sticky-bar span{display:none}}

/* ---- nav search (mobile menu; hidden on desktop) ---- */
.nav-search{display:none}
@media(max-width:860px){
  .nav-search{display:block;width:100%;margin:6px 0}
  .nav-search input{width:100%;padding:.7rem .9rem;border:1px solid rgba(243,236,220,.3);background:rgba(243,236,220,.06);color:var(--cream);border-radius:2px;font-family:var(--body)}
  .nav-search input::placeholder{color:rgba(243,236,220,.5)}
  .header-social{margin:8px 0 4px}
}

/* ---- back to top ---- */
.ap-top{position:fixed;right:18px;bottom:18px;z-index:55;width:42px;height:42px;border-radius:50%;border:none;background:var(--gold);color:var(--navy);font-size:1.2rem;font-weight:800;cursor:pointer;box-shadow:0 8px 20px rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:opacity .2s}
.ap-top.show{opacity:1;pointer-events:auto}

/* ---- Flock Footprint feature card (sits on /flock-toolkit/ page) ---- */
.fp-feature{position:relative;background:var(--navy);color:var(--cream);border-radius:8px;padding:42px 46px;overflow:hidden;display:grid;grid-template-columns:1.25fr .85fr;gap:36px;align-items:center;border:1px solid rgba(217,171,111,.35)}
.fp-feature .topo{position:absolute;inset:0;opacity:.32}
.fp-feature>*{position:relative;z-index:2}
.fp-feature .fp-eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700;display:inline-block;margin-bottom:14px}
.fp-feature h2{font-size:clamp(1.7rem,3.2vw,2.4rem);color:var(--cream);line-height:1.1;margin:0 0 14px}
.fp-feature h2 em{font-style:italic;color:var(--gold);font-weight:600}
.fp-feature .fp-lede{color:rgba(243,236,220,.84);font-size:1.02rem;margin:0 0 20px;max-width:48ch}
.fp-feature .fp-num{font-family:var(--display);font-weight:800;font-size:3.4rem;color:var(--gold);line-height:1;letter-spacing:-.02em}
.fp-feature .fp-num-sub{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(243,236,220,.65);margin-top:6px}
.fp-feature .fp-card{background:rgba(243,236,220,.06);border:1px solid rgba(243,236,220,.18);border-radius:6px;padding:26px;text-align:center}
.fp-feature .btn{margin-top:14px;width:100%;justify-content:center;font-size:1rem;padding:1rem 1.4rem}
@media(max-width:860px){.fp-feature{grid-template-columns:1fr;padding:32px 24px}}

/* ---- in-tool subscribe panel (used inside the standalone footprint tool too) ---- */
.fp-subscribe{background:var(--cream-2);border:1.5px solid var(--line);border-left:4px solid var(--gold);border-radius:0 6px 6px 0;padding:18px 20px;margin-top:14px}
.fp-subscribe .fp-sub-head{font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--navy);line-height:1.25;margin-bottom:4px}
.fp-subscribe .fp-sub-sub{font-size:.82rem;color:var(--muted);margin-bottom:10px}
.fp-subscribe form{display:flex;gap:6px;flex-wrap:wrap}
.fp-subscribe input[type=email]{flex:1;min-width:160px;padding:.7rem .85rem;border:1px solid var(--line);border-radius:3px;font-family:var(--body);font-size:.92rem;background:#fff}
.fp-subscribe button{padding:.7rem 1.1rem;background:var(--barn);color:#fff;border:none;border-radius:3px;font-weight:700;font-size:.86rem;cursor:pointer;font-family:var(--body)}
.fp-subscribe button:hover{background:var(--barn-bright)}
.fp-subscribe .fp-sub-ok{color:var(--gold-deep);font-weight:600;font-size:.92rem}
