/* =========================================================
   GREENGOLD AGRIFIN — Glass Field System
   Inspired: full-bleed crop photography, floating frosted-glass bento panels,
             oversized display typography, soft organic curves.
   Type:  Archivo (display) · Inter (body) · Instrument Serif (italic accents)
   Color: Lush greens, cream glass, warm gold accent.
   ========================================================= */

:root{
  /* GREEN PALETTE */
  --green-deep:#0E2818;
  --green-rich:#1A3A28;
  --green-mid:#27553A;
  --green-bright:#3F8C56;
  --green-leaf:#5BB373;
  --green-soft:#B8D4BC;
  --green-mist:#D8E8DC;

  /* surfaces */
  --cream:#F4F1E8;
  --paper:#FAF8F1;
  --bone:#EFEAD9;

  /* glass */
  --glass-light:rgba(255,255,255,0.78);
  --glass-light-2:rgba(255,255,255,0.62);
  --glass-dark:rgba(14,40,24,0.62);
  --glass-dark-2:rgba(14,40,24,0.38);
  --glass-cream:rgba(244,241,232,0.85);

  /* accents */
  --gold:#D4A937;
  --gold-soft:#E8C46A;
  --lime:#C7E45F;
  --terra:#C97A3C;

  /* ink */
  --ink:#0A1A12;
  --ink-2:#1A2B1F;
  --mute:#3A4A3F;            /* solid for reliable contrast */
  --mute-2:#4F5C53;
  --mute-light:rgba(255,255,255,.88);

  /* lines */
  --line:rgba(14,40,24,.10);
  --line-light:rgba(255,255,255,.18);

  /* radii */
  --r-sm:14px;
  --r:24px;
  --r-lg:36px;
  --r-xl:48px;
  --r-pill:999px;

  /* layout */
  --max:1340px;
  --gutter:24px;

  /* timing */
  --ease:cubic-bezier(.2,.8,.2,1);

  /* shadows */
  --shadow-sm:0 4px 12px rgba(14,40,24,.08);
  --shadow:0 12px 40px rgba(14,40,24,.14);
  --shadow-lg:0 24px 80px rgba(14,40,24,.22);
  --shadow-glass:0 8px 32px rgba(14,40,24,.12), inset 0 1px 0 rgba(255,255,255,.4);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--green-deep)}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

/* =========================================================
   Type
   ========================================================= */
.display,h1,h2,h3{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  letter-spacing:-0.025em;
  line-height:.92;
  color:var(--ink);
}
.italic,.serif-it{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  letter-spacing:-0.01em;
}
.label,.kicker{
  font-family:'Inter',sans-serif;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:700;
}
.kicker{color:var(--green-mid)}

h1{font-size:clamp(3rem,9vw,9rem);font-weight:900}
h2{font-size:clamp(2rem,5vw,4.5rem);font-weight:800}
h3{font-size:clamp(1.4rem,2.6vw,2rem);font-weight:700;line-height:1.05}
p{font-size:1.02rem;line-height:1.6;color:var(--ink-2)}
.lead{font-size:clamp(1.05rem,1.4vw,1.25rem);line-height:1.5;color:var(--ink);max-width:50ch}

/* =========================================================
   Layout
   ========================================================= */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
section{padding:80px 0;position:relative}
@media (max-width:780px){section{padding:56px 0}}

.section-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  flex-wrap:wrap;gap:24px;margin-bottom:48px;
}
.section-head h2{max-width:18ch}
.section-head p{max-width:42ch}

/* =========================================================
   PILL NAV (floating, frosted)
   ========================================================= */
.nav-shell{
  position:fixed;top:18px;left:0;right:0;z-index:100;
  padding:0 var(--gutter);
  display:flex;justify-content:center;
  pointer-events:none;
}
.nav{
  pointer-events:auto;
  width:100%;max-width:var(--max);
  background:var(--glass-light);
  backdrop-filter:saturate(160%) blur(20px);
  -webkit-backdrop-filter:saturate(160%) blur(20px);
  border:1px solid rgba(255,255,255,.6);
  border-radius:var(--r-pill);
  padding:10px 12px 10px 22px;
  display:flex;align-items:center;gap:24px;
  box-shadow:var(--shadow-glass);
  transition:padding .35s var(--ease),background .35s var(--ease);
}
.nav.scrolled{
  background:rgba(255,255,255,.92);
  padding:8px 10px 8px 18px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:'Archivo',sans-serif;font-weight:700;font-size:.95rem;color:var(--green-deep);
  flex-shrink:0;
}
.brand img{
  width:32px;height:32px;border-radius:50%;object-fit:cover;
  border:2px solid var(--green-deep);background:var(--cream);
}
.brand b{font-weight:800;letter-spacing:-.01em}

.nav-links{
  display:flex;align-items:center;gap:4px;list-style:none;flex:1;justify-content:center;
}
.nav-links a{
  padding:9px 18px;border-radius:var(--r-pill);
  font-size:.88rem;font-weight:600;color:var(--green-deep);
  transition:all .25s var(--ease);
}
.nav-links a:hover{background:rgba(14,40,24,.06)}
.nav-links a.active{background:var(--green-deep);color:var(--cream)}

.nav-end{display:flex;align-items:center;gap:10px;flex-shrink:0}
.search-pill{
  display:flex;align-items:center;gap:8px;
  background:rgba(14,40,24,.08);border-radius:var(--r-pill);
  padding:9px 16px;color:var(--green-deep);font-size:.85rem;font-weight:500;
}
.search-pill::before{content:"⌕";font-size:1rem;color:var(--green-deep)}
.icon-btn{
  width:38px;height:38px;border-radius:50%;
  background:rgba(14,40,24,.06);
  display:flex;align-items:center;justify-content:center;color:var(--green-deep);
  transition:all .25s var(--ease);font-size:1.05rem;
}
.icon-btn:hover{background:var(--green-deep);color:var(--cream)}

.menu-toggle{
  display:none;width:42px;height:42px;border-radius:50%;
  background:rgba(14,40,24,.08);
  align-items:center;justify-content:center;flex-direction:column;gap:4px;
}
.menu-toggle span{display:block;width:16px;height:2px;background:var(--green-deep);border-radius:2px;transition:.3s var(--ease)}
.menu-toggle.open span:nth-child(1){transform:translateY(3px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){transform:translateY(-3px) rotate(-45deg)}

@media (max-width:980px){
  .nav-links,.search-pill{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;align-items:stretch;gap:4px;
    position:absolute;top:calc(100% + 12px);left:0;right:0;
    background:rgba(255,255,255,.96);backdrop-filter:blur(20px);
    border-radius:var(--r-lg);padding:14px;
    box-shadow:var(--shadow);
  }
  .nav-links.open a{padding:14px 18px;text-align:center;border-radius:var(--r-pill)}
  .menu-toggle{display:flex}
}

/* =========================================================
   HERO — full-bleed image + giant display word + floating bento
   ========================================================= */
.hero{
  position:relative;
  min-height:100vh;
  padding:120px var(--gutter) 40px;
  display:flex;flex-direction:column;justify-content:flex-start;
  overflow:hidden;
  background:var(--green-deep);
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  filter:saturate(1.1) brightness(.78);
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(14,40,24,.55) 0%,
    rgba(14,40,24,.30) 35%,
    rgba(14,40,24,.40) 70%,
    rgba(14,40,24,.70) 100%);
}
.hero-inner{
  position:relative;z-index:2;
  max-width:var(--max);width:100%;margin:0 auto;
  display:flex;flex-direction:column;gap:40px;flex:1;
}
.hero-meta{
  display:flex;justify-content:space-between;align-items:center;
  color:#fff;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  margin-top:80px;
  padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.28);
  text-shadow:0 1px 12px rgba(14,40,24,.55);
}
.hero-meta .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--lime);margin-right:8px;box-shadow:0 0 0 4px rgba(199,228,95,.2)}

.hero-display{
  font-family:'Archivo',sans-serif;
  font-weight:900;
  font-size:clamp(2.6rem,13.2vw,13.5rem);
  line-height:.88;letter-spacing:-0.045em;
  color:#fff;
  text-shadow:0 6px 50px rgba(14,40,24,.6), 0 2px 12px rgba(14,40,24,.4);
  text-align:center;
  margin:0;
  white-space:nowrap;
}
.hero-display em{
  font-family:'Instrument Serif',serif;
  font-style:italic;font-weight:400;
  color:var(--lime);
  letter-spacing:-0.03em;
}

/* HERO BENTO — floating glass cards */
.hero-bento{
  display:grid;
  grid-template-columns:1.2fr 1.4fr 1.2fr;
  gap:18px;
  align-items:stretch;
  margin-top:auto;
}
@media (max-width:980px){.hero-bento{grid-template-columns:1fr;gap:14px}}

.gcard{
  background:rgba(255,255,255,0.92);
  backdrop-filter:saturate(160%) blur(24px);
  -webkit-backdrop-filter:saturate(160%) blur(24px);
  border:1px solid rgba(255,255,255,.7);
  border-radius:var(--r-lg);
  padding:28px;
  box-shadow:var(--shadow-glass);
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:240px;
  position:relative;overflow:hidden;
  color:var(--ink);
}
.gcard.dark{
  background:rgba(14,40,24,0.82);color:#fff;
  border-color:rgba(255,255,255,.22);
  backdrop-filter:saturate(140%) blur(30px);
  -webkit-backdrop-filter:saturate(140%) blur(30px);
}
.gcard.cream{background:rgba(250,248,241,0.94)}
.gcard.green{background:rgba(39,85,58,.92);color:#fff;border-color:rgba(255,255,255,.28)}

.gcard .label{
  font-size:.7rem;letter-spacing:.2em;font-weight:700;
  color:var(--green-mid);margin-bottom:14px;
}
.gcard.dark .label{color:var(--lime)}
.gcard.green .label{color:var(--lime)}

.gcard h3{
  font-family:'Archivo',sans-serif;font-weight:800;
  font-size:clamp(1.4rem,2vw,2rem);line-height:1.0;color:var(--ink);
  margin-bottom:14px;
}
.gcard.dark h3,.gcard.green h3{color:#fff}

.gcard h3 .it{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--green-mid)}
.gcard.dark h3 .it,
.gcard.center-q h3 .it,
.gcard.green h3 .it{color:var(--lime)}

.pill-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 24px;
  background:var(--gold);color:var(--green-deep);
  border-radius:var(--r-pill);font-weight:600;font-size:.92rem;
  transition:all .25s var(--ease);
}
.pill-btn:hover{background:var(--lime);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.pill-btn::after{content:"→";transition:transform .25s var(--ease)}
.pill-btn:hover::after{transform:translateX(3px)}
.pill-btn.dark{background:var(--green-deep);color:var(--cream)}
.pill-btn.dark:hover{background:var(--green-mid)}
.pill-btn.outline{background:transparent;color:var(--cream);border:1px solid rgba(255,255,255,.5)}
.pill-btn.outline:hover{background:#fff;color:var(--green-deep);border-color:#fff}

.gcard .small{font-size:.88rem;color:var(--ink-2);line-height:1.5}
.gcard.dark .small,.gcard.green .small{color:rgba(255,255,255,.92)}

/* hero center card with image fragment */
.gcard .farmer-img{
  width:54px;height:54px;border-radius:50%;
  object-fit:cover;border:3px solid rgba(255,255,255,.7);
  box-shadow:var(--shadow-sm);
}
.gcard.center-q{
  background:rgba(14,40,24,0.88);color:#fff;
  border-color:rgba(255,255,255,.22);
}
.gcard.center-q h3{color:#fff}
.center-q .top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:24px}
.center-q .farm-name{font-family:'Archivo',sans-serif;font-weight:700;font-size:1rem;color:#fff}
.center-q .farm-tag{font-size:.8rem;color:var(--lime);margin-top:4px;font-weight:500}

/* stats card */
.stat-row{display:flex;align-items:flex-end;gap:8px;margin-bottom:6px}
.stat-row .num{
  font-family:'Archivo',sans-serif;font-weight:800;
  font-size:clamp(2rem,3vw,2.6rem);line-height:1;color:var(--green-deep);
}
.stat-row .unit{font-size:.85rem;color:var(--mute);padding-bottom:6px}

.feat-list{display:flex;gap:14px;margin-top:auto}
.feat-item{
  flex:1;padding:14px;background:rgba(14,40,24,.07);border-radius:var(--r-sm);
  display:flex;flex-direction:column;gap:6px;
}
.feat-item .n{font-family:'Archivo',sans-serif;font-weight:800;font-size:1.4rem;color:var(--green-deep)}
.feat-item .t{font-size:.78rem;color:var(--ink-2);line-height:1.35;font-weight:500}

/* =========================================================
   FULL-BLEED SECTION (image background + floating panels)
   ========================================================= */
.bleed-section{
  position:relative;padding:120px var(--gutter);
  background:var(--green-deep);overflow:hidden;
  min-height:80vh;display:flex;align-items:center;
}
.bleed-section .bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  filter:saturate(1.05) brightness(.78);
}
.bleed-section .inner > div p{text-shadow:0 1px 12px rgba(14,40,24,.5)}
.bleed-section .inner h2{text-shadow:0 4px 30px rgba(14,40,24,.5)}
.bleed-section .bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(14,40,24,.78),rgba(14,40,24,.45) 60%,rgba(14,40,24,.7));
}
.bleed-section .inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;width:100%}

/* =========================================================
   STANDARD CARD GRID (sections)
   ========================================================= */
.card-grid{
  display:grid;gap:18px;
}
.card-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.card-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.card-grid.cols-2{grid-template-columns:1fr 1fr}
@media (max-width:980px){
  .card-grid.cols-3,.card-grid.cols-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:580px){
  .card-grid.cols-3,.card-grid.cols-4,.card-grid.cols-2{grid-template-columns:1fr}
}

.surface-card{
  background:#fff;border-radius:var(--r-lg);padding:32px;
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:16px;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  position:relative;overflow:hidden;
}
.surface-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.surface-card .num{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:.85rem;color:var(--green-mid);
  letter-spacing:.08em;
}
.surface-card.dark{background:var(--green-deep);color:#fff;border-color:transparent}
.surface-card.dark .num{color:var(--lime)}
.surface-card.dark p{color:rgba(244,241,232,.88)}
.surface-card.dark h3{color:#fff}
.surface-card.green-soft{background:var(--green-mist)}
.surface-card.green-soft .num{color:var(--green-deep)}
.surface-card.green-soft p{color:var(--ink-2)}
.surface-card.gold{background:var(--gold);color:var(--green-deep)}
.surface-card.gold .num{color:var(--green-deep)}
.surface-card.gold p{color:var(--green-deep)}
.surface-card.gold h3{color:var(--green-deep)}
.surface-card p{color:var(--ink-2);font-size:.96rem}

/* image card */
.img-card{
  border-radius:var(--r-lg);overflow:hidden;position:relative;
  min-height:320px;background:var(--green-deep);
}
.img-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.img-card .overlay{
  position:absolute;inset:0;z-index:2;padding:28px;
  display:flex;flex-direction:column;justify-content:flex-end;
  background:linear-gradient(180deg,transparent 40%,rgba(14,40,24,.85));
  color:#fff;
}
.img-card .overlay .label{color:var(--lime);margin-bottom:10px}
.img-card .overlay h3{color:#fff;font-size:1.5rem}

/* =========================================================
   SPLIT (text + image)
   ========================================================= */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
}
@media (max-width:880px){.split{grid-template-columns:1fr;gap:32px}}
.split.flip > .split-img{order:-1}
@media (max-width:880px){.split.flip > .split-img{order:0}}
.split-img{
  border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:5/6;background:var(--green-deep);position:relative;
}
.split-img img{width:100%;height:100%;object-fit:cover}
.split-img .badge{
  position:absolute;top:20px;left:20px;
  background:var(--glass-light);backdrop-filter:blur(20px);
  padding:10px 16px;border-radius:var(--r-pill);
  font-size:.75rem;font-weight:600;color:var(--green-deep);letter-spacing:.06em;
}

.split-text h2{margin-bottom:20px}
.split-text h2 .it{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--green-mid)}
.split-text p{margin-bottom:14px;font-size:1.02rem}
.split-text .check{
  display:flex;align-items:flex-start;gap:14px;
  padding:18px 0;border-top:1px solid var(--line);
}
.split-text .check:last-child{border-bottom:1px solid var(--line)}
.split-text .check .ic{
  flex-shrink:0;width:32px;height:32px;border-radius:50%;
  background:var(--green-mist);color:var(--green-mid);
  display:flex;align-items:center;justify-content:center;font-weight:700;
}
.split-text .check b{display:block;font-family:'Archivo',sans-serif;font-weight:700;color:var(--ink);margin-bottom:4px}
.split-text .check span{color:var(--ink-2);font-size:.94rem}

/* =========================================================
   PAGE HERO (inner pages)
   ========================================================= */
.page-hero{
  position:relative;min-height:70vh;
  padding:140px var(--gutter) 60px;
  display:flex;flex-direction:column;justify-content:flex-end;
  background:var(--green-deep);overflow:hidden;
}
.page-hero .bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  filter:saturate(1.05) brightness(.7);
}
.page-hero .bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,40,24,.55) 0%,rgba(14,40,24,.45) 50%,rgba(14,40,24,.78) 100%);
}
.page-hero .inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;width:100%;color:#fff}
.page-hero .breadcrumbs{
  font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.92);margin-bottom:32px;font-weight:600;
}
.page-hero .breadcrumbs a{color:var(--lime)}
.page-hero .breadcrumbs span{margin:0 10px;opacity:.6}
.page-hero h1{
  font-size:clamp(3rem,12vw,11rem);color:#fff;
  text-shadow:0 6px 50px rgba(14,40,24,.55), 0 2px 12px rgba(14,40,24,.35);font-weight:900;
  line-height:.88;
}
.page-hero h1 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--lime);letter-spacing:-0.02em}
.page-hero .lede{
  display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:flex-end;
  margin-top:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,.28);
}
@media (max-width:880px){.page-hero .lede{grid-template-columns:1fr;gap:18px}}
.page-hero .lede .label{color:var(--lime)}
.page-hero .lede p{font-size:1.12rem;color:#fff;max-width:50ch;text-shadow:0 1px 10px rgba(14,40,24,.4)}

/* =========================================================
   STATS BAR
   ========================================================= */
.stats-bar{
  background:var(--green-deep);color:var(--cream);
  border-radius:var(--r-xl);padding:48px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  position:relative;overflow:hidden;
}
@media (max-width:780px){.stats-bar{grid-template-columns:repeat(2,1fr);padding:32px;gap:18px}}
.stats-bar .stat{padding:0 20px;border-left:1px solid rgba(255,255,255,.15)}
.stats-bar .stat:first-child{border-left:0;padding-left:0}
.stats-bar .num{
  font-family:'Archivo',sans-serif;font-weight:900;
  font-size:clamp(2.5rem,5vw,4rem);line-height:.9;color:var(--lime);letter-spacing:-.02em;
}
.stats-bar .lab{font-size:.78rem;color:rgba(244,241,232,.7);margin-top:8px;letter-spacing:.06em;text-transform:uppercase;font-weight:500}

/* =========================================================
   CTA SECTION (full-bleed-ish with curved card)
   ========================================================= */
.cta-shell{
  padding:80px var(--gutter);
  background:var(--cream);
}
.cta-card{
  position:relative;max-width:var(--max);margin:0 auto;
  background:var(--green-deep);color:var(--cream);
  border-radius:var(--r-xl);padding:80px 60px;overflow:hidden;
  display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center;
}
.cta-card::before{
  content:"";position:absolute;inset:0;
  background:url('../../Images/farm-field-irrigation-photo.jpg') center/cover;
  opacity:.18;
}
.cta-card > *{position:relative;z-index:2}
@media (max-width:880px){.cta-card{grid-template-columns:1fr;padding:48px 32px;text-align:center}}
.cta-card h2{color:#fff;font-weight:900}
.cta-card h2 .it{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--lime)}
.cta-card p{color:rgba(244,241,232,.85);max-width:42ch;margin:14px 0 0}
@media (max-width:880px){.cta-card p{margin:14px auto 0}}
.cta-card .actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end}
@media (max-width:880px){.cta-card .actions{justify-content:center}}

/* =========================================================
   CHAPTER (services)
   ========================================================= */
.chapter{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  padding:60px 0;border-top:1px solid var(--line);
}
.chapter:first-of-type{border-top:0;padding-top:0}
.chapter.flip > .chap-visual{order:-1}
@media (max-width:880px){
  .chapter,.chapter.flip{grid-template-columns:1fr;gap:32px}
  .chapter.flip > .chap-visual{order:0}
}
.chap-meta{
  display:flex;align-items:center;gap:14px;margin-bottom:24px;
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green-mid);font-weight:600;
}
.chap-meta .num{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:1.1rem;color:var(--green-mid);letter-spacing:0;
  background:var(--green-mist);padding:6px 14px;border-radius:var(--r-pill);
}
.chap-visual{
  border-radius:var(--r-lg);overflow:hidden;aspect-ratio:5/6;
  background:var(--green-deep);position:relative;
}
.chap-visual img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.chap-visual:hover img{transform:scale(1.04)}
.chap-visual .tag{
  position:absolute;left:16px;bottom:16px;
  background:var(--glass-light);backdrop-filter:blur(20px);
  padding:8px 14px;border-radius:var(--r-pill);
  font-size:.72rem;font-weight:600;color:var(--green-deep);letter-spacing:.06em;
}
.chap h2{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:18px}
.chap h2 .it{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--green-mid)}
.chap p{font-size:1.02rem;margin-bottom:14px}
.chap-list{list-style:none;padding:0;margin:24px 0 0}
.chap-list li{
  padding:14px 0;border-top:1px solid var(--line);
  display:grid;grid-template-columns:32px 1fr;gap:14px;align-items:flex-start;
  font-size:.96rem;
}
.chap-list li:last-child{border-bottom:1px solid var(--line)}
.chap-list li::before{
  content:"✓";color:var(--green-mid);font-weight:700;
  width:24px;height:24px;background:var(--green-mist);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:.85rem;
}

/* =========================================================
   CONTACT
   ========================================================= */
.contact-grid{
  display:grid;grid-template-columns:1fr 1.1fr;gap:32px;align-items:flex-start;
}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr}}

.contact-info{
  background:var(--green-deep);color:var(--cream);
  border-radius:var(--r-xl);padding:48px;
  position:relative;overflow:hidden;
}
.contact-info::before{
  content:"";position:absolute;top:-100px;right:-100px;width:280px;height:280px;
  background:radial-gradient(circle,rgba(199,228,95,.2),transparent 70%);border-radius:50%;
}
.contact-info > *{position:relative;z-index:2}
.contact-info h2{color:#fff;font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:14px}
.contact-info h2 .it{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--lime)}
.contact-info p{color:rgba(244,241,232,.85);margin-bottom:32px}
.contact-info ul{list-style:none}
.contact-info li{
  padding:18px 0;border-top:1px solid rgba(255,255,255,.12);
  display:grid;grid-template-columns:42px 1fr;gap:18px;
}
.contact-info li:first-child{border-top:0}
.contact-info .ic{
  width:42px;height:42px;border-radius:50%;
  background:rgba(199,228,95,.15);color:var(--lime);
  display:flex;align-items:center;justify-content:center;font-size:1.05rem;
}
.contact-info .lab{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--lime);margin-bottom:4px;font-weight:700}
.contact-info .val{font-size:1rem;color:#fff;line-height:1.5}
.contact-info .val a{color:#fff;border-bottom:1px solid rgba(199,228,95,.5)}
.contact-info .val a:hover{border-bottom-color:var(--lime)}

.contact-form{
  background:#fff;border-radius:var(--r-xl);padding:48px;
  border:1px solid var(--line);
}
.field{margin-bottom:18px}
.field label{
  display:block;font-size:.7rem;font-weight:600;color:var(--green-mid);
  margin-bottom:8px;letter-spacing:.14em;text-transform:uppercase;
}
.field input,.field textarea,.field select{
  width:100%;padding:14px 18px;border:1px solid var(--line);
  border-radius:var(--r-pill);font-size:.95rem;font-family:inherit;
  color:var(--ink);background:var(--paper);
  transition:all .25s var(--ease);
}
.field textarea{border-radius:var(--r);min-height:120px;resize:vertical}
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'><path fill='none' stroke='%230E2818' stroke-width='1.5' d='M3 5l4 4 4-4'/></svg>");
  background-repeat:no-repeat;background-position:right 18px center;padding-right:40px;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--green-mid);background:#fff;
  box-shadow:0 0 0 4px rgba(63,140,86,.12);
}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:520px){.row-2{grid-template-columns:1fr}}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  background:var(--green-deep);color:var(--cream);
  padding:80px var(--gutter) 30px;
  position:relative;overflow:hidden;
}
.footer-top{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:48px;
  padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.12);
}
@media (max-width:980px){.footer-top{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:560px){.footer-top{grid-template-columns:1fr}}
.footer .brand{color:var(--cream)}
.footer .brand img{border-color:var(--lime)}
.footer-about p{color:rgba(244,241,232,.7);max-width:38ch;margin-top:16px;font-size:.95rem}
.footer h4{
  font-family:'Inter',sans-serif;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--lime);font-weight:600;margin-bottom:18px;
}
.footer ul{list-style:none}
.footer li{margin-bottom:10px;font-size:.94rem}
.footer a{color:rgba(244,241,232,.78)}
.footer a:hover{color:var(--lime)}

.wordmark{
  font-family:'Archivo',sans-serif;font-weight:900;
  font-size:clamp(5rem,28vw,22rem);line-height:.85;letter-spacing:-0.05em;
  color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,.12);
  display:block;text-align:center;
  padding:60px 0 30px;
  user-select:none;pointer-events:none;
  white-space:nowrap;overflow:hidden;
}

.footer-bottom{
  max-width:var(--max);margin:0 auto;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  padding-top:24px;font-size:.78rem;color:rgba(244,241,232,.7);
  letter-spacing:.06em;
}
.footer-bottom b{color:rgba(244,241,232,.85);font-weight:600}

/* =========================================================
   Reveal
   ========================================================= */
.r{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.r.in{opacity:1;transform:none}
.r-2{transition-delay:.08s}
.r-3{transition-delay:.16s}
.r-4{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .r,.r-2,.r-3,.r-4{opacity:1;transform:none;transition:none}
}
