/*
Theme Name:  Hive & Veil
Theme URI:   https://hiveandveil.com
Author:      The Hive & Veil team
Author URI:  https://hiveandveil.com/about/
Description: Backyard beekeeping content theme - field-guide design, full CSS in one file.
Version:     1.0
License:     GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hiveandveil
Tags:        custom-background, custom-logo, featured-images, full-width-template
*/

/* ==========================================================================
   RESET + ROOT TOKENS
   ========================================================================== */
*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:clip}
html{scroll-behavior:smooth}

:root{
  --bg:#f2f3e9;
  --ink:#23271a;
  --ink2:#5f6650;
  --sage:#7e8c63;
  --sage-d:#566237;
  --sage-dd:#3e4a2b;
  --honey:#d99a22;
  --deep:#9a6610;
  --amber:#eebd57;
  --cream:#fcfcf4;
  --line:#dde0cd;
  --serif:"Petrona",Georgia,serif;
  --sans:"Mulish",system-ui,sans-serif;
}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

.wrap{max-width:1180px;margin:0 auto;padding:0 30px}
.narrow{max-width:840px;margin:0 auto;padding:0 30px}
.col{max-width:720px;margin:0 auto;padding:0 30px}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}

::selection{background:var(--amber)}
:focus-visible{outline:2.5px solid var(--deep);outline-offset:3px;border-radius:4px}

/* ==========================================================================
   SCROLL REVEAL
   ========================================================================== */
html.js .rev{opacity:0;transform:translateY(18px)}
.rev.in{opacity:1;transform:none;transition:.75s cubic-bezier(.2,.8,.2,1)}

/* noscript fallback */
.rev{opacity:1!important;transform:none!important}
html.js .rev{opacity:0;transform:translateY(18px)}

/* ==========================================================================
   SKIP LINK
   ========================================================================== */
.skip{
  position:absolute;left:-999px;top:0;z-index:50;
  background:var(--ink);color:#fff;
  padding:11px 18px;border-radius:0 0 10px 0;
  font-weight:700;font-size:14px;
}
.skip:focus{left:0}

/* ==========================================================================
   HEADER
   ========================================================================== */
body>header{
  position:sticky;top:0;z-index:30;
  background:rgba(242,243,233,.9);
  backdrop-filter:blur(9px);
  border-bottom:1px solid var(--line);
}
header .wrap{display:flex;align-items:center;gap:30px;height:70px}

.brand{
  display:flex;align-items:center;gap:11px;
  font-family:var(--serif);font-size:23px;font-weight:600;flex:none;
}
.logo{flex:none;display:block}

nav{
  display:flex;align-items:center;gap:23px;
  font-size:14.5px;font-weight:600;
  color:var(--ink2);margin-left:auto;
}
nav>a{position:relative;padding:4px 0}
nav>a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;
  height:2px;background:var(--honey);transition:right .25s;
}
nav>a[aria-current]{color:var(--sage-dd)}
nav>a:hover{color:var(--ink)}
nav>a:hover::after,nav>a[aria-current]::after{right:0}

/* dropdown groups */
.grp{position:relative}
.grp-t{
  font-family:inherit;font-size:14.5px;font-weight:600;
  color:var(--ink2);background:none;border:0;cursor:pointer;
  display:inline-flex;align-items:center;gap:5px;padding:4px 0;
}
.grp-t svg{transition:transform .2s;opacity:.7}
.grp:hover .grp-t,.grp-t[aria-expanded="true"]{color:var(--ink)}
.grp:hover .grp-t svg,.grp-t[aria-expanded="true"] svg{transform:rotate(180deg)}
.grp-p{
  position:absolute;top:calc(100% + 16px);right:0;width:238px;
  background:var(--cream);border:1px solid var(--line);
  border-radius:14px;
  box-shadow:0 28px 56px -26px rgba(86,98,55,.5);
  padding:9px;opacity:0;visibility:hidden;
  transform:translateY(-8px);transition:.2s;z-index:40;
}
.grp:hover .grp-p,.grp-p.open{opacity:1;visibility:visible;transform:none}
.grp-p a{
  display:block;padding:9px 13px;border-radius:9px;
  font-size:14px;color:var(--ink);font-weight:600;
}
.grp-p a:hover{background:#eef0e2;color:var(--sage-dd)}

/* hamburger - FIX 4: 44x44 tap target, icon centered */
.menu-btn{
  display:none;margin-left:auto;background:none;border:0;
  cursor:pointer;color:var(--ink);
  width:44px;height:44px;align-items:center;justify-content:center;
}
@media(max-width:920px){nav{display:none}.menu-btn{display:flex}}

/* mobile nav panel */
.mnav{
  display:none;position:fixed;top:70px;left:0;right:0;z-index:29;
  background:rgba(242,243,233,.98);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
  padding:8px 0 14px;
  box-shadow:0 24px 44px -26px rgba(0,0,0,.35);
}
.mnav.open{display:block}
.mnav a{
  display:block;padding:14px 30px;
  font-size:16px;font-weight:600;
  color:var(--ink);border-bottom:1px solid var(--line);
}
.mnav a:last-child{border-bottom:0}

/* range input theming */
input[type=range]::-moz-range-thumb{
  width:20px;height:20px;border:none;border-radius:50%;
  background:#fff;box-shadow:0 0 0 3px var(--sage-d);cursor:pointer;
}
input[type=range]::-moz-range-track{
  height:6px;border-radius:99px;
  background:linear-gradient(90deg,var(--honey),#e7e2c2);
}

/* ==========================================================================
   HERO (front-page)
   ========================================================================== */
.hero{
  position:relative;width:100vw;left:50%;margin-left:-50vw;
  min-height:90vh;display:flex;align-items:center;overflow:hidden;
}
.hero .bg{
  position:absolute;inset:0;
  background:url('img/hv-hero-bee-clover.jpeg') center right/cover no-repeat;
}
.hero .veil{
  position:absolute;inset:0;
  background:linear-gradient(95deg,rgba(34,38,24,.82) 0%,rgba(40,46,28,.66) 30%,rgba(50,58,34,.28) 52%,rgba(50,58,34,0) 66%);
}
.hero .inner{
  position:relative;z-index:2;width:100%;
  max-width:1180px;margin:0 auto;padding:0 30px;
}
.hero .copy{max-width:540px;color:#f3f4e4}
.hero .o{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--serif);font-style:italic;font-size:19px;color:var(--amber);
}
.hero .o::before{content:"";width:30px;height:1.5px;background:var(--amber)}
.hero h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(40px,6vw,76px);line-height:1.01;
  letter-spacing:-.01em;margin:14px 0 16px;color:#fff;
}
.hero p{font-size:18px;color:#e6ead6;max-width:38ch}
.hero .row{display:flex;gap:13px;margin-top:30px;flex-wrap:wrap}

.btn{
  font-weight:700;font-size:15px;padding:14px 26px;
  border-radius:999px;transition:.2s;
  display:inline-flex;gap:9px;align-items:center;
}
.btn.solid{background:var(--honey);color:#23271a}
.btn.solid:hover{background:var(--amber);transform:translateY(-2px)}
.btn.ghost{border:1.5px solid rgba(255,255,255,.5);color:#fff}
.btn.ghost:hover{background:rgba(255,255,255,.12)}

@media(max-width:700px){
  .hero{display:block;position:relative;width:100%;left:auto;margin-left:0;min-height:0;overflow:visible}
  .hero .bg{position:relative;height:52vh;min-height:330px;max-height:440px;background-position:72% 46%}
  .hero .veil{display:none}
  .hero .inner{position:static;max-width:none;padding:28px 26px 40px}
  .hero .copy{max-width:none;color:var(--ink)}
  .hero .o{color:var(--deep);font-size:16px}
  .hero .o::before{background:var(--honey)}
  .hero h1{color:var(--ink);font-size:clamp(34px,9.5vw,50px);margin:10px 0 12px}
  .hero p{color:var(--ink2);font-size:16.5px;max-width:none}
  .hero .row{margin-top:24px}
  .hero .btn.ghost{border-color:var(--line);color:var(--ink)}
  /* FIX 1: preserve side gutter on col/wrap at mobile so crumb, .ahead, .body never run flush */
  .col,.wrap,.narrow{padding-left:24px;padding-right:24px}
}

/* ==========================================================================
   INTRO
   ========================================================================== */
.intro{text-align:center;padding:60px 0 6px}
.intro p{
  font-family:var(--serif);font-size:clamp(22px,3vw,31px);
  line-height:1.42;max-width:26ch;margin:0 auto;
}
.intro em{font-style:italic;color:var(--sage-d)}

/* ==========================================================================
   SECTION HEADING
   ========================================================================== */
.sec-h{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:16px;margin-bottom:26px;flex-wrap:wrap;
}
.sec-h .k{
  font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sage-d);font-weight:700;
}
.sec-h h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(28px,3.6vw,40px);line-height:1.05;margin-top:6px;
}
.sec-h p{color:var(--ink2);font-size:15px;max-width:34ch}

/* ==========================================================================
   PILLARS GRID
   ========================================================================== */
.pillars{padding:46px 0 30px}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

.pc{
  background:var(--cream);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;transition:.2s;display:block;
}
.pc:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 48px -28px rgba(86,98,55,.55);
  border-color:var(--amber);
}
.pc .thumb{position:relative;aspect-ratio:16/10;overflow:hidden}
.pc .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pc:hover .thumb img{transform:scale(1.05)}
.pc .thumb::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(36,40,26,0) 55%,rgba(36,40,26,.5));
}
.pc .ct{
  position:absolute;z-index:2;top:11px;right:11px;
  font-size:11.5px;font-weight:700;color:#fff;
  background:rgba(36,40,26,.55);backdrop-filter:blur(3px);
  border-radius:999px;padding:4px 10px;
}
.pc .body{padding:17px 20px 21px}
.pc h3{font-family:var(--serif);font-weight:500;font-size:21px;margin-bottom:4px}
.pc p{font-size:13.5px;color:var(--ink2)}

.pc.all{
  background:radial-gradient(circle at 1px 1px,rgba(255,255,255,.07) 1.4px,transparent 0) 0 0/22px 19px,
             linear-gradient(160deg,#5b6840,#3a4628);
  border-color:#3e4a2b;color:#eef0dd;
  display:flex;align-items:center;justify-content:center;
  text-align:center;min-height:120px;
}
.pc.all:hover{border-color:var(--amber)}
.pc.all .body{padding:30px 24px}
.pc.all h3{color:#fff}
.pc.all p{color:#cfd3b6}
.pc.all .ar{font-size:22px;color:var(--amber);margin-bottom:6px}

@media(max-width:860px){.pgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pgrid{grid-template-columns:1fr}}

/* ==========================================================================
   FEATURED ARTICLES
   ========================================================================== */
.feat{padding:46px 0 30px}
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

.fa{
  background:var(--cream);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;transition:.18s;
  display:flex;flex-direction:column;
}
.fa:hover{
  border-color:var(--sage);transform:translateY(-4px);
  box-shadow:0 22px 44px -28px rgba(86,98,55,.5);
}
.fa .thumb{aspect-ratio:16/9;overflow:hidden}
.fa .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.fa:hover .thumb img{transform:scale(1.05)}
.fa .body{padding:18px 22px 22px;display:flex;flex-direction:column;gap:7px;flex:1}
.fa .cat{font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--deep)}
.fa h3{font-family:var(--serif);font-weight:500;font-size:20px;line-height:1.2}
.fa p{font-size:13.5px;color:var(--ink2)}
.fa .go{
  margin-top:auto;padding-top:8px;font-size:13px;font-weight:700;
  color:var(--sage-d);display:inline-flex;gap:6px;align-items:center;
}
.fa:hover .go svg{transform:translateX(4px)}
.fa .go svg{transition:.2s}

@media(max-width:860px){.fgrid{grid-template-columns:1fr}}

/* ==========================================================================
   LATEST FROM THE HIVE
   ========================================================================== */
.latest{padding:46px 0 30px}
.latest .sec-h a{
  font-size:14px;font-weight:700;color:var(--deep);
  display:inline-flex;gap:6px;align-items:center;white-space:nowrap;
}
.latest .sec-h a:hover{color:var(--sage-dd)}
.lgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

.lc{
  background:var(--cream);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;transition:.18s;
  display:flex;flex-direction:column;position:relative;
}
.lc:hover{
  border-color:var(--sage);transform:translateY(-4px);
  box-shadow:0 20px 40px -28px rgba(86,98,55,.5);
}
.lc .thumb{aspect-ratio:16/10;overflow:hidden}
.lc .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.lc:hover .thumb img{transform:scale(1.05)}
.lc .new{
  position:absolute;top:10px;left:10px;z-index:2;
  font-size:11px;font-weight:800;letter-spacing:.04em;
  text-transform:uppercase;color:#fff;background:var(--deep);
  border-radius:999px;padding:4px 10px;
}
.lc .body{padding:15px 17px 18px}
.lc .meta{
  font-size:12px;color:var(--ink2);
  display:flex;gap:8px;align-items:center;margin-bottom:5px;
}
.lc .meta .cat{font-family:var(--serif);font-style:italic;color:var(--deep)}
.lc .meta .dot{opacity:.5}
.lc h3{font-family:var(--serif);font-weight:500;font-size:17px;line-height:1.22}

@media(max-width:860px){.lgrid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.lgrid{grid-template-columns:1fr}}

/* ==========================================================================
   CALCULATOR
   ========================================================================== */
.calc{padding:40px 0 30px}
.calc .panel{
  border-radius:24px;overflow:hidden;border:1px solid var(--line);
  background:var(--cream);display:grid;grid-template-columns:1.1fr .9fr;
  box-shadow:0 30px 60px -40px rgba(86,98,55,.5);
}
.calc .ctrl{padding:36px 38px}
.calc .ck{
  font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sage-d);font-weight:700;
}
.calc h2{font-family:var(--serif);font-weight:500;font-size:30px;margin:6px 0 4px}
.calc h3{font-family:var(--serif);font-weight:500;font-size:23px;margin:5px 0 16px;color:var(--ink)}
.calc .lede{color:var(--ink2);font-size:14.5px;margin-bottom:24px}

.field{margin-bottom:22px}
.field .fl{
  display:flex;justify-content:space-between;align-items:baseline;
  font-weight:700;font-size:14.5px;margin-bottom:9px;
}
.field .fl .fv{color:var(--deep)}

.seg{display:flex;gap:7px;flex-wrap:wrap}
.seg button{
  font-family:var(--sans);font-weight:700;font-size:13px;
  color:var(--ink2);background:#fff;border:1.5px solid var(--line);
  padding:9px 13px;border-radius:9px;cursor:pointer;transition:.15s;
}
.seg button:hover{border-color:var(--sage)}
.seg button[data-on="1"]{background:var(--sage-dd);color:#fff;border-color:var(--sage-dd)}

input[type=range]{
  width:100%;-webkit-appearance:none;height:6px;border-radius:99px;
  background:linear-gradient(90deg,var(--honey),#e7e2c2);outline:none;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:22px;height:22px;border-radius:50%;
  background:#fff;border:3px solid var(--sage-d);cursor:pointer;
  box-shadow:0 2px 6px rgba(0,0,0,.18);
}

.toggle{display:flex;align-items:center;gap:12px;font-size:14.5px;font-weight:600}
.sw{
  width:46px;height:26px;border-radius:99px;background:var(--line);
  position:relative;cursor:pointer;transition:.2s;flex:none;
}
.sw::after{
  content:"";position:absolute;top:3px;left:3px;
  width:20px;height:20px;border-radius:50%;background:#fff;
  transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.sw[data-on="1"]{background:var(--honey)}
.sw[data-on="1"]::after{left:23px}

.calc .out{
  background:linear-gradient(165deg,#566237,#3a4528);
  color:#eef0dd;padding:36px 34px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.out .ok{
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:#c7d0a3;font-weight:700;
}
.out .total{
  font-family:var(--serif);font-size:58px;line-height:1;
  color:#fff;margin:6px 0 2px;
}
.out .range{color:#c7d0a3;font-size:13.5px}
.lines{margin:22px 0;display:flex;flex-direction:column;gap:10px}
.lines .li{
  display:flex;justify-content:space-between;font-size:14px;
  border-bottom:1px dashed rgba(199,208,163,.3);padding-bottom:9px;
}
.lines .li span:last-child{font-weight:700;color:#fff}
.out .foot{font-size:12.5px;color:#bcc69a;line-height:1.5}

/* pillar label above calc */
.calc .label{display:flex;align-items:center;gap:11px;margin-bottom:16px}
.calc .label .pill{
  font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;
  font-weight:800;color:#fff;background:var(--deep);
  border-radius:999px;padding:5px 11px;
}
.calc .label span{font-size:14px;color:var(--ink2)}

/* article inline calc variant */
.calc.art .panel{grid-template-columns:1fr .82fr}
.calc.art .ctrl{padding:28px 30px}
.calc.art .out{padding:28px}
.calc.art .out .total{font-size:50px}
.calc.art .lines{margin:18px 0 0;gap:8px}
.calc.art .lines .li{font-size:13px;padding-bottom:7px}

@media(max-width:800px){.calc .panel{grid-template-columns:1fr}.out .total{font-size:48px}}
@media(max-width:680px){.calc.art .panel{grid-template-columns:1fr}.calc.art .out .total{font-size:44px}}

/* ==========================================================================
   HONEST DARK CARD
   ========================================================================== */
.honest{padding:40px 0 56px}
.honest .card{
  background:linear-gradient(160deg,#566237,#3a4528);
  color:#eef0dd;border-radius:24px;padding:48px 44px;
  display:grid;grid-template-columns:1.1fr 1fr;gap:32px;
  align-items:center;position:relative;overflow:hidden;
}
.honest .bee{
  position:absolute;right:-4px;bottom:-10px;width:132px;
  opacity:.32;transform:rotate(10deg);pointer-events:none;
}
.honest h2{
  font-family:var(--serif);font-weight:500;font-style:italic;
  font-size:clamp(24px,3vw,33px);color:#fff;line-height:1.2;
  position:relative;z-index:2;
}
.honest .nums{display:grid;grid-template-columns:1fr 1fr;gap:18px;position:relative;z-index:2}
.honest .n{font-family:var(--serif);font-size:36px;font-weight:600;color:var(--amber);line-height:1}
.honest .t{font-size:12.5px;color:#cfd3b6;margin-top:3px}

@media(max-width:760px){.honest .card{grid-template-columns:1fr;padding:34px 26px}}

/* ==========================================================================
   FOOTER
   ========================================================================== */
footer{background:var(--sage-dd);color:#d6dcc4;padding:46px 0 30px}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
footer .fb{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:21px;color:#fff}
footer .tag{margin-top:12px;font-style:italic;font-family:var(--serif);color:#b9c49c;font-size:15px;max-width:32ch}
footer h4{
  font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;
  color:#9fae7c;font-weight:700;margin-bottom:12px;
}
footer ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:14px}
footer ul a:hover{color:#fff}
footer .legal{
  border-top:1px solid rgba(214,220,196,.18);margin-top:34px;padding-top:18px;
  font-size:12.5px;color:#9fae7c;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
}

@media(max-width:760px){footer .grid{grid-template-columns:1fr 1fr}footer .fbcol{grid-column:1/3}}

/* ==========================================================================
   BREADCRUMB
   ========================================================================== */
.crumb{
  padding-top:20px;padding-bottom:4px;font-size:13px;color:var(--ink2);
  display:flex;gap:9px;align-items:center;flex-wrap:wrap;
}
.crumb a:hover{color:var(--deep)}
.crumb .sep{opacity:.5}
.crumb .cur{color:var(--ink)}

/* ==========================================================================
   PILLAR / CATEGORY HERO
   ========================================================================== */
.phero{padding:18px 0 40px}
.phero .grid{display:grid;grid-template-columns:1.08fr .92fr;gap:48px;align-items:center}
.phero .eye{
  font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sage-d);font-weight:700;
}
.phero h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(38px,5.2vw,64px);line-height:1.02;
  letter-spacing:-.015em;margin:10px 0 16px;
}
.phero .lede{font-size:18px;color:var(--ink2);max-width:46ch}
.phero .chips{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}

.chip{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:11px 15px}
.chip b{font-family:var(--serif);font-size:21px;color:var(--deep);display:block;line-height:1}
.chip span{font-size:12px;color:var(--ink2)}

.phero .ph{
  position:relative;border-radius:20px;overflow:hidden;
  border:1px solid var(--line);aspect-ratio:4/3;
  box-shadow:0 30px 60px -38px rgba(86,98,55,.5);
}
.phero .ph img{width:100%;height:100%;object-fit:cover}
.phero .ph .tag{
  position:absolute;left:16px;bottom:16px;
  background:rgba(252,252,244,.92);backdrop-filter:blur(4px);
  border-radius:11px;padding:9px 14px;
  font-size:12.5px;font-weight:700;color:var(--sage-dd);
}

@media(max-width:820px){.phero .grid{grid-template-columns:1fr;gap:28px}.phero .ph{aspect-ratio:16/10}}

/* ==========================================================================
   CLUSTER GUIDES (category page)
   ========================================================================== */
.cluster{padding:26px 0 20px}
.sub{margin:34px 0 18px}
.sub h2{font-family:var(--serif);font-weight:500;font-size:clamp(24px,3vw,32px)}
.sub p{color:var(--ink2);font-size:15px;margin-top:3px}

.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gc{
  background:var(--cream);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;transition:.2s;display:block;
}
.gc:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 48px -28px rgba(86,98,55,.55);
  border-color:var(--amber);
}
.gc .thumb{aspect-ratio:16/10;overflow:hidden}
.gc .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gc:hover .thumb img{transform:scale(1.05)}
.gc .body{padding:16px 19px 19px}
.gc h3{font-family:var(--serif);font-weight:500;font-size:19px;line-height:1.18;margin-bottom:4px}
.gc p{font-size:13px;color:var(--ink2)}

@media(max-width:860px){.cgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cgrid{grid-template-columns:1fr}}

/* ==========================================================================
   NEXT PILLARS DARK CARDS
   ========================================================================== */
.next-pillars{padding:34px 0 56px}
.next-pillars h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(24px,3vw,32px);margin-bottom:18px;
}
.ngrid-dark{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.nc-dark{
  background:linear-gradient(160deg,#5b6840,#3e4a2b);
  color:#eef0dd;border-radius:16px;padding:24px;transition:.2s;
  display:flex;flex-direction:column;gap:5px;
  min-height:130px;justify-content:center;
}
.nc-dark:hover{transform:translateY(-4px);box-shadow:0 22px 44px -26px rgba(0,0,0,.4)}
.nc-dark .k{
  font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--amber);font-weight:700;
}
.nc-dark h3{font-family:var(--serif);font-weight:500;font-size:22px;color:#fff}
.nc-dark p{font-size:13px;color:#cfd3b6}
.nc-dark .ar{margin-top:6px;color:var(--amber);font-weight:700;font-size:14px}

@media(max-width:760px){.ngrid-dark{grid-template-columns:1fr}}

/* ==========================================================================
   READING PROGRESS BAR
   ========================================================================== */
.progress{
  position:fixed;top:0;left:0;height:3px;
  background:var(--honey);width:0;z-index:40;transition:width .1s linear;
}

/* ==========================================================================
   ARTICLE HEAD
   ========================================================================== */
.ahead{padding-top:26px;padding-bottom:6px}
.ahead .eye{font-family:var(--serif);font-style:italic;font-size:17px;color:var(--deep)}
.ahead h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(34px,5vw,58px);line-height:1.04;
  letter-spacing:-.015em;margin:8px 0 14px;
}
.ahead .dek{font-size:19px;color:var(--ink2);max-width:60ch}
.byline{
  display:flex;align-items:center;gap:14px;
  margin-top:22px;flex-wrap:wrap;font-size:14px;color:var(--ink2);
}
.byline .av{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(150deg,var(--amber),var(--honey));
  display:grid;place-items:center;flex:none;
}
.byline b{color:var(--ink);font-weight:700}
.byline .dot{opacity:.5}

.hero-img{margin:30px 0 8px}
.hero-img figure{border-radius:20px;overflow:hidden;border:1px solid var(--line)}
.hero-img img{width:100%;aspect-ratio:16/9;object-fit:cover}
.hero-img figcaption{
  font-size:13px;color:var(--ink2);font-style:italic;
  padding:10px 4px 0;font-family:var(--serif);
}

/* ==========================================================================
   ARTICLE BODY / PROSE
   ========================================================================== */
.body{padding:18px 0 10px;font-family:var(--serif);font-size:19px;line-height:1.78;color:#2b2f22}
.body p{margin-bottom:22px}
.body p.lead{font-size:21px}
.body .lead:first-of-type::first-letter{
  font-size:64px;line-height:.8;float:left;font-weight:600;
  color:var(--deep);padding:8px 12px 0 0;
}
.body h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(26px,3.4vw,34px);line-height:1.1;
  margin:42px 0 8px;letter-spacing:-.01em;
}
.body h3{
  font-family:var(--sans);font-weight:700;
  font-size:18px;color:var(--sage-dd);margin:28px 0 6px;
}
.body .rule{width:54px;height:2px;background:var(--honey);margin:6px 0 22px}
.body em{font-style:italic;color:var(--sage-d)}
.body a.inline{
  color:var(--deep);text-decoration:underline;
  text-decoration-color:var(--amber);text-underline-offset:3px;
}
.body a.inline:hover{background:#fbf1d8}
.body ul{list-style:none;margin:0 0 22px}
.body li{position:relative;padding-left:26px;margin-bottom:11px}
.body li::before{
  content:"";position:absolute;left:4px;top:12px;
  width:7px;height:7px;background:var(--honey);
  border-radius:2px;transform:rotate(45deg);
}

/* callout box */
.callout{
  font-family:var(--sans);
  background:linear-gradient(160deg,#fbf1d6,#f6e8c6);
  border:1px solid var(--line);border-radius:16px;
  padding:24px 26px;margin:30px 0;
  font-size:15.5px;line-height:1.6;color:var(--ink);
}
.callout .k{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--deep);font-weight:800;margin-bottom:7px;
}
.callout b{color:var(--sage-dd)}

/* ==========================================================================
   COST TABLE (article)
   ========================================================================== */
.tablewrap{
  font-family:var(--sans);margin:30px 0;border:1px solid var(--line);
  border-radius:16px;overflow:hidden;background:var(--cream);
}
.tablewrap .th{
  display:grid;grid-template-columns:1.6fr 1fr;
  background:var(--sage-dd);color:#eef0dd;
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  font-weight:700;padding:13px 22px;
}
.tablewrap .tr{
  display:grid;grid-template-columns:1.6fr 1fr;
  padding:13px 22px;border-bottom:1px solid var(--line);font-size:15px;
}
.tablewrap .tr:last-of-type{border-bottom:0}
.tablewrap .tr span:last-child{font-weight:700;color:var(--ink);text-align:right}
.tablewrap .tr.total{background:#eef0e2;font-family:var(--serif)}
.tablewrap .tr.total span{font-size:19px;color:var(--sage-dd)}
.tablewrap .tr.total span:last-child{color:var(--deep)}

/* ==========================================================================
   INLINE FIG (article)
   ========================================================================== */
.fig{margin:30px 0}
.fig img{width:100%;border-radius:16px;border:1px solid var(--line);aspect-ratio:16/10;object-fit:cover}
.fig.tall img{aspect-ratio:4/3}
.fig figcaption{
  font-size:13px;color:var(--ink2);font-style:italic;
  padding:9px 4px 0;font-family:var(--serif);
}

/* FIX 3: in-body importer figures (.fig-4x3) */
.fig-4x3{margin:30px 0}
.fig-4x3 .frame{border-radius:16px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3}
.fig-4x3 .frame img{width:100%;height:100%;object-fit:cover;display:block}
.fig-4x3 figcaption{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink2);padding-top:8px}

/* ==========================================================================
   PULL STAT (article)
   ========================================================================== */
.pull{margin:34px 0;text-align:center}
.pull .n{
  font-family:var(--serif);font-size:clamp(44px,8vw,72px);
  font-weight:600;color:var(--deep);line-height:1;
}
.pull .t{
  font-family:var(--sans);font-size:15px;color:var(--ink2);
  max-width:34ch;margin:6px auto 0;
}

/* ==========================================================================
   SOURCES / REFS BLOCK (article)
   ========================================================================== */
.refs{
  font-family:var(--sans);margin:40px 0 10px;
  background:var(--cream);border:1px solid var(--line);
  border-radius:16px;padding:26px 28px;
}
.refs-lbl{
  display:flex;align-items:center;gap:9px;
  font-size:12.5px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--sage-d);margin-bottom:14px;
}
.refs-lbl svg{width:18px;height:18px}
.refs ol{list-style:none;counter-reset:s;display:flex;flex-direction:column;gap:13px}
.refs li{
  counter-increment:s;position:relative;padding-left:32px;
  font-size:14px;color:var(--ink2);line-height:1.55;
}
.refs li::before{
  content:counter(s);position:absolute;left:0;top:0;
  width:22px;height:22px;border-radius:50%;
  background:var(--sage-dd);color:#eef0dd;
  font-size:12px;font-weight:700;display:grid;place-items:center;
}
.refs li b{color:var(--ink)}
.refs li .desc{display:block;font-style:italic;color:var(--sage-d);font-size:13px;margin-top:2px}

/* ==========================================================================
   AUTHOR CARD (article)
   ========================================================================== */
.author{
  font-family:var(--sans);margin:30px 0;
  display:flex;gap:18px;align-items:flex-start;
  background:var(--cream);border:1px solid var(--line);
  border-radius:16px;padding:24px 26px;
}
.author .av{
  width:54px;height:54px;border-radius:50%;flex:none;
  background:linear-gradient(150deg,var(--amber),var(--honey));
  display:grid;place-items:center;
}
.author h3{font-family:var(--serif);font-weight:500;font-size:20px}
.author p{font-size:14px;color:var(--ink2);margin-top:4px}

/* ==========================================================================
   READ NEXT (article)
   ========================================================================== */
.next{padding:30px 0 56px}
.next h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(24px,3vw,32px);margin-bottom:18px;
}
.ngrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.nc{
  background:var(--cream);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;transition:.2s;
  display:flex;flex-direction:column;
}
.nc:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 44px -28px rgba(86,98,55,.5);
  border-color:var(--amber);
}
.nc .thumb{aspect-ratio:16/10;overflow:hidden}
.nc .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.nc:hover .thumb img{transform:scale(1.05)}
.nc .body{padding:16px 19px 19px}
.nc .cat{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--deep)}
.nc h3{font-family:var(--serif);font-weight:500;font-size:18px;line-height:1.2;margin-top:2px}

@media(max-width:760px){.ngrid{grid-template-columns:1fr}}

/* ==========================================================================
   FAQ ACCORDION (article)
   ========================================================================== */
.faq-section{padding:34px 0}
.faq-list{max-width:720px;margin:20px auto 0;display:flex;flex-direction:column;gap:8px}
.faq-item{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--cream)}
.faq-item summary{
  padding:16px 20px;font-family:var(--sans);font-weight:700;
  font-size:16px;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  list-style:none;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item[open] summary{color:var(--deep)}
.chev svg{transition:transform .2s}
.faq-item[open] .chev svg{transform:rotate(180deg)}
.faq-body{padding:0 20px 18px;font-size:15px;color:var(--ink2);line-height:1.6}

/* ==========================================================================
   TABLE OF CONTENTS
   ========================================================================== */
.toc-lbl{
  display:flex;align-items:center;gap:9px;
  font-size:12px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--sage-d);margin-bottom:10px;
}
.toc-lbl svg{width:16px;height:16px}
nav[aria-label="Table of contents"]{
  background:var(--cream);border:1px solid var(--line);
  border-radius:14px;padding:18px 22px;margin:0 0 32px;
}
nav[aria-label="Table of contents"] ol{list-style:none;display:flex;flex-direction:column;gap:6px}
nav[aria-label="Table of contents"] a{font-size:14.5px;color:var(--sage-dd);font-weight:600;text-decoration:none}
nav[aria-label="Table of contents"] a:hover{color:var(--deep)}
nav[aria-label="Table of contents"] a.active{color:var(--deep)}

/* ==========================================================================
   TABLE WRAP (WP content tables - mobile scroll)
   ========================================================================== */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-wrap table{min-width:600px;border-collapse:collapse;width:100%;font-size:14px}
@media(max-width:600px){
  .table-wrap{display:block}
  .table-wrap table{min-width:0}
}

/* ==========================================================================
   WP CORE COMPATIBILITY
   ========================================================================== */
img{max-width:100%;height:auto}
.aligncenter{display:block;margin:0 auto}
.alignleft{float:left;margin:0 1em 1em 0}
.alignright{float:right;margin:0 0 1em 1em}
.wp-caption{max-width:100%;text-align:center}
.wp-caption-text{font-size:13px;color:var(--ink2);font-style:italic;padding-top:6px}
.screen-reader-text{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ==========================================================================
   PAGINATION
   ========================================================================== */
.pagination{
  text-align:center;padding:30px 0;font-size:14px;
  display:flex;gap:8px;justify-content:center;flex-wrap:wrap;
}
.pagination .page-numbers{
  padding:8px 14px;border:1px solid var(--line);
  border-radius:9px;color:var(--ink2);font-weight:600;
}
.pagination .page-numbers.current{
  background:var(--sage-dd);color:#fff;border-color:var(--sage-dd);
}
.pagination .page-numbers:hover{border-color:var(--sage);color:var(--ink)}

/* ==========================================================================
   404 PAGE
   ========================================================================== */
.page-404{
  min-height:60vh;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:60px 30px;
}
.page-404 .inner{max-width:480px}
.page-404 .code{
  font-family:var(--serif);font-size:clamp(80px,18vw,140px);
  font-weight:600;color:var(--honey);line-height:1;
}
.page-404 h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(26px,4vw,38px);margin:8px 0 14px;
}
.page-404 p{font-size:17px;color:var(--ink2);margin-bottom:28px}
