/*
Theme Name: Flick Media
Theme URI: https://flickmedia.co.nz
Author: Flick Media
Description: Custom theme for Flick Media — a NZ rural and agri marketing studio. Editorial, earthy, and built for storytelling.
Version: 1.4.7
Requires at least: 6.0
Requires PHP: 7.4
License: GPL v2 or later
Text Domain: flickmedia
*/

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,600;9..144,800&family=Inter+Tight:wght@400;500;600&display=swap');

:root{
  /* Core palette */
  --cream:#f4efe6;
  --bone:#ebe3d3;
  --ink:#1c1a17;
  --ink-soft:#2a2723;
  --moss:#3b5d3a;
  --moss-deep:#27411f;
  --moss-ink:#0e1a0a;
  --rust:#b9532b;
  --rust-deep:#8f3a18;
  --gold:#c89a3c;
  --gold-soft:#e4c26b;

  /* Semantic tones */
  --text:#1c1a17;
  --text-muted:#5a534a;
  --text-soft:#8e867a;
  --text-on-dark:#d8d0bd;
  --text-on-dark-soft:#a8a094;
  --rule:rgba(28,26,23,.18);
  --rule-strong:rgba(28,26,23,.32);
  --rule-dark:rgba(244,239,230,.14);

  /* Type */
  --serif:"Fraunces", Georgia, serif;
  --sans:"Inter Tight", system-ui, sans-serif;

  /* Motion */
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-snap:cubic-bezier(.5,1.4,.5,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
  --dur-fast:.25s;
  --dur:.45s;
  --dur-slow:.7s;

  /* Elevation */
  --shadow-sm:0 2px 8px rgba(28,26,23,.06);
  --shadow:0 14px 40px rgba(28,26,23,.12);
  --shadow-lg:0 30px 80px rgba(0,0,0,.28);

  /* Update old aliases so nothing breaks */
  --muted:var(--text-muted);
}

/* Subtle paper-grain overlay on cream sections */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.1  0 0 0 0 0.09  0 0 0 0 0.08  0 0 0 .08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
@media(prefers-reduced-motion:reduce){body::before{display:none}}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.55;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:300;letter-spacing:-.025em;margin:0}

/* Polished focus ring for accessibility */
:focus{outline:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:3px}
.btn:focus-visible,.nav-cta:focus-visible{outline-offset:4px}

/* Selection colour */
::selection{background:var(--gold);color:var(--ink)}

.wrap{max-width:1240px;margin:0 auto;padding:0 28px}

/* ───────── NAV ───────── */
.site-nav{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;border-bottom:1px solid var(--rule);position:sticky;top:0;background:rgba(244,239,230,.92);backdrop-filter:blur(10px);z-index:60}
.site-logo{font-family:var(--serif);font-weight:800;font-size:22px;letter-spacing:-.02em}
.site-logo span{color:var(--rust);font-style:italic;font-weight:400}
.site-logo img{max-height:38px;width:auto}
.primary-menu{display:flex;gap:34px;list-style:none;margin:0;padding:0;font-size:14px;font-weight:500}
.primary-menu li{position:relative}
.primary-menu a{padding:4px 0;transition:.2s}
.primary-menu a:hover{color:var(--rust)}
.primary-menu .sub-menu{display:none;position:absolute;top:100%;left:-12px;background:var(--cream);border:1px solid var(--rule);padding:14px 18px;list-style:none;min-width:240px;margin-top:8px;border-radius:4px;box-shadow:0 8px 24px rgba(0,0,0,.08)}
.primary-menu li:hover>.sub-menu{display:block}
.primary-menu .sub-menu li{margin:6px 0}
.nav-cta{background:var(--ink);color:var(--cream);padding:11px 22px;border-radius:999px;font-size:14px;font-weight:500;transition:.2s}
.nav-cta:hover{background:var(--moss-deep)}
.menu-toggle{display:none;background:none;border:1px solid var(--ink);padding:8px 14px;border-radius:999px;font-family:var(--sans);font-size:13px;cursor:pointer;z-index:70;position:relative}
.nav-cta{white-space:nowrap}
@media(max-width:1080px){
  .site-nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--cream)}
  .primary-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;flex-direction:column;background:var(--cream);padding:120px 32px 40px;gap:0;z-index:55;overflow-y:auto;box-shadow:0 -1px 0 var(--rule);align-items:flex-start;justify-content:flex-start}
  .primary-menu.is-open{display:flex}
  .primary-menu li{width:100%;border-bottom:1px solid var(--rule)}
  .primary-menu a{display:block;padding:22px 0;font-family:var(--serif);font-size:24px;font-weight:400;letter-spacing:-.01em}
  .primary-menu .sub-menu{display:block;position:static;background:transparent;border:none;padding:0 0 12px 16px;box-shadow:none}
  .primary-menu .sub-menu a{font-size:18px;padding:10px 0}
  .menu-toggle{display:inline-block}
  .nav-cta{display:none}
  body.menu-open{overflow:hidden}
  .menu-open .site-nav{background:var(--cream)}
}

/* ───────── BUTTONS ───────── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 30px;border-radius:999px;font-weight:500;font-size:15px;transition:.25s;border:none;cursor:pointer;font-family:var(--sans)}
.btn-primary{background:var(--moss-deep);color:var(--cream)}
.btn-primary:hover{background:var(--rust);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--ink);background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-light{background:var(--cream);color:var(--ink)}
.btn-light:hover{background:var(--gold)}

/* ───────── COMMON ───────── */
.kicker{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--rust);margin-bottom:14px;display:inline-block}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--moss);margin-bottom:28px;display:flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:38px;height:1px;background:var(--moss)}
.h1{font-size:clamp(48px,8vw,118px);line-height:1.02;letter-spacing:-.035em;margin:0 0 36px;font-weight:300}
.h1 em{font-style:italic;color:var(--rust);font-weight:400}
.h1 .grow{display:block;font-weight:800;margin-top:.18em;font-size:.5em;line-height:1.05}
.h2{font-size:clamp(38px,5vw,68px);line-height:1;margin:0;max-width:14ch}
.h2 em{font-style:italic;color:var(--moss)}
.section{padding:110px 0}
.hero + .section,.marquee + .section,.hero .marquee + .section{padding-top:50px}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px;gap:40px;flex-wrap:wrap}
.section-head p{max-width:36ch;color:var(--muted);font-size:16px;margin:0}
.lede{font-size:19px;max-width:52ch;color:#3a3631}

/* ───────── HOME — HERO ───────── */
.hero{padding:90px 0 0;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:end}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
.hero-meta{border-left:1px solid var(--rule);padding:8px 0 8px 28px;font-size:14px;color:var(--muted)}
.hero-meta strong{font-family:var(--serif);font-size:42px;font-weight:600;color:var(--ink);display:block;line-height:1;margin-bottom:6px}
.hero-meta + .hero-meta{margin-top:24px}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;gap:40px}}

/* ───────── MARQUEE ───────── */
.marquee{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:26px 0;background:var(--bone);overflow:hidden;margin-top:60px}
.marquee-track{display:flex;gap:70px;white-space:nowrap;animation:scroll 18s linear infinite;font-family:var(--serif);font-size:22px;font-style:italic;color:var(--muted)}
.marquee-track span{display:inline-flex;align-items:center;gap:70px}
.marquee-track span::after{content:"✦";color:var(--rust);font-style:normal}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ───────── DISCIPLINES GRID ───────── */
.disciplines{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.disc{background:var(--cream);padding:42px 36px 50px;transition:.35s;position:relative;min-height:300px;display:flex;flex-direction:column}
.disc:hover{background:var(--moss-deep);color:var(--cream)}
.disc:hover .disc-num,.disc:hover .disc-arrow{color:var(--gold)}
.disc-num{font-family:var(--serif);font-size:14px;color:var(--rust);margin-bottom:auto;font-style:italic;transition:.3s}
.disc h3{font-family:var(--serif);font-size:32px;font-weight:400;margin:60px 0 14px;line-height:1.05}
.disc p{font-size:15px;margin:0 0 28px;opacity:.85}
.disc-arrow{font-size:22px;color:var(--ink);transition:.3s;margin-top:auto}
.disc:hover .disc-arrow{transform:translateX(6px)}
.disc.featured{background:var(--rust);color:var(--cream)}
.disc.featured .disc-num,.disc.featured .disc-arrow{color:var(--gold)}
@media(max-width:880px){.disciplines{grid-template-columns:1fr}}

/* ───────── DARK WORK STRIP ───────── */
.work{background:var(--ink);color:var(--cream);padding:110px 0}
.work .h2{color:var(--cream)}
.work .kicker{color:var(--gold)}
.work-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:50px}
.work-item{aspect-ratio:1;border-radius:4px;display:flex;align-items:flex-end;padding:22px;font-family:var(--serif);font-style:italic;font-size:18px;position:relative;overflow:hidden;transition:.4s;border:1px solid #34302a;color:var(--cream)}
.work-item.video-trigger{cursor:pointer;background-color:#000;background-size:cover;background-position:center;font:inherit;font-family:var(--serif);font-style:italic;font-size:18px;text-align:left;width:100%}
.work-item.video-trigger::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.1) 50%,rgba(0,0,0,.2) 100%);transition:.3s}
.work-item.video-trigger:hover::before{background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,.4) 100%)}
.work-item .play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:68px;height:68px;border-radius:50%;background:rgba(244,239,230,.95);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:22px;padding-left:6px;transition:.3s;z-index:1}
.work-item.video-trigger:hover .play-icon{background:var(--rust);color:var(--cream);transform:translate(-50%,-50%) scale(1.08)}
.work-item .work-title{position:relative;z-index:1}
.work-item:nth-child(4n+1){background:linear-gradient(160deg,#3b5d3a,#1c2a18)}
.work-item:nth-child(4n+2){background:linear-gradient(160deg,#b9532b,#5a2810)}
.work-item:nth-child(4n+3){background:linear-gradient(160deg,#c89a3c,#5e4615)}
.work-item:nth-child(4n+4){background:linear-gradient(160deg,#27411f,#0e1a0a)}
.work-item:hover{transform:translateY(-6px)}
@media(max-width:880px){.work-grid{grid-template-columns:repeat(2,1fr)}}

/* ───────── VIDEO LIGHTBOX ───────── */
.video-lightbox{position:fixed;inset:0;background:rgba(12,11,9,.94);backdrop-filter:blur(8px);z-index:1000;display:none;align-items:center;justify-content:center;padding:40px}
.video-lightbox.is-open{display:flex}
.video-frame{width:100%;height:100%;max-width:1400px;max-height:85vh;position:relative;display:flex;align-items:center;justify-content:center}
.video-frame #video-embed{width:100%;height:100%}
.video-frame iframe{width:100%;height:100%;border:none;border-radius:6px;box-shadow:0 30px 80px rgba(0,0,0,.5);background:#000}
.video-close{position:fixed;top:24px;right:30px;background:transparent;border:1px solid rgba(244,239,230,.4);color:var(--cream);width:48px;height:48px;border-radius:50%;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;line-height:1;padding:0;z-index:1001}
.video-close:hover{background:var(--rust);border-color:var(--rust)}
body.lightbox-open{overflow:hidden}
@media(max-width:720px){.video-lightbox{padding:20px}.video-close{top:14px;right:14px}}

/* ───────── TESTIMONIAL ───────── */
.quote-section{padding:130px 0;background:var(--bone)}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.quote-img{aspect-ratio:4/3;background:linear-gradient(160deg,#3b5d3a,#1c2a18);border-radius:6px;position:relative;overflow:hidden}
.quote-img img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.quote-text{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3vw,38px);line-height:1.25;letter-spacing:-.015em;margin:0}
.quote-text em{color:var(--rust);font-style:italic}
.quote-cite{margin-top:34px;padding-top:24px;border-top:1px solid var(--rule);font-size:14px;color:var(--muted)}
.quote-cite strong{color:var(--ink);display:block;font-size:16px;margin-bottom:4px}
@media(max-width:820px){.quote-grid{grid-template-columns:1fr}}

/* ───────── CTA STRIP ───────── */
.cta-strip{padding:120px 0 140px;background:var(--moss-deep);color:var(--cream);text-align:center}
.cta-strip .h2{margin:0 auto 30px;max-width:18ch;color:var(--cream)}
.cta-strip .h2 em,.contact-section .h2 em{color:var(--gold)}
.cta-strip p{max-width:48ch;margin:0 auto 40px;color:#d8d0bd}

/* ───────── PAGE HEADER (subpages) ───────── */
.page-header{padding:120px 0 80px;border-bottom:1px solid var(--rule)}
.page-header .h1{font-size:clamp(44px,6vw,82px);max-width:18ch}
.page-header .lede{margin-top:30px}
.breadcrumb{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--moss);margin-bottom:24px}
.breadcrumb a:hover{color:var(--rust)}

/* ───────── SERVICE PAGE BLOCKS ───────── */
.svc-intro{padding-top:90px;padding-bottom:90px;display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start}
.svc-intro aside{position:sticky;top:120px}
.svc-intro h2{font-size:clamp(32px,4vw,48px);margin-bottom:20px}
.svc-intro p{font-size:17px;color:#3a3631;margin:0 0 18px;max-width:60ch}
@media(max-width:880px){.svc-intro{grid-template-columns:1fr;gap:30px;padding-top:70px;padding-bottom:70px}.svc-intro aside{position:static}}

.feature-list{list-style:none;padding:0;margin:36px 0;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);border:1px solid var(--rule)}
.feature-list li{background:var(--cream);padding:28px;font-family:var(--serif);font-size:20px;font-weight:400;line-height:1.3;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);cursor:default}
.feature-list li::before{content:"→";color:var(--rust);display:block;font-size:14px;margin-bottom:10px;font-style:italic;transition:color var(--dur) var(--ease)}
.feature-list li:hover{background:var(--moss-deep);color:var(--cream)}
.feature-list li:hover::before{color:var(--gold)}
@media(max-width:680px){.feature-list{grid-template-columns:1fr}}

.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:60px 0}
.media-grid .item{aspect-ratio:4/3;border-radius:4px;background:linear-gradient(160deg,#3b5d3a,#1c2a18)}
.media-grid .item:nth-child(2){background:linear-gradient(160deg,#b9532b,#5a2810)}
.media-grid .item:nth-child(3){background:linear-gradient(160deg,#c89a3c,#5e4615)}
.media-grid .item:nth-child(4){background:linear-gradient(160deg,#27411f,#0e1a0a)}
.media-grid .item:nth-child(5){background:linear-gradient(160deg,#3b5d3a,#27411f)}
.media-grid .item:nth-child(6){background:linear-gradient(160deg,#b9532b,#c89a3c)}
@media(max-width:680px){.media-grid{grid-template-columns:1fr 1fr}}

/* ───────── WEBSITE SHOWCASE GRID ───────── */
.showcase{padding:90px 0}
.showcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px}
.showcase-card{display:flex;flex-direction:column;gap:14px}
.showcase-img{aspect-ratio:4/3;background:linear-gradient(160deg,#3b5d3a,#1c2a18);border-radius:6px;overflow:hidden;display:block;transition:.35s}
.showcase-img img{width:100%;height:100%;object-fit:cover;display:block}
.showcase-card a:hover .showcase-img{transform:translateY(-4px);box-shadow:0 14px 40px rgba(0,0,0,.12)}
.showcase-meta{font-family:var(--serif);font-size:18px;font-style:italic;color:var(--ink)}
.showcase-meta small{display:block;font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--rust);font-style:normal;margin-bottom:4px}
@media(max-width:880px){.showcase-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.showcase-grid{grid-template-columns:1fr}}

/* ───────── PHOTO SLIDER (horizontal scroll-snap) ───────── */
.slider{padding:90px 0;background:var(--bone)}
.slider-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;gap:20px}
.slider-controls{display:flex;gap:10px}
.slider-arrow{width:48px;height:48px;border-radius:50%;border:1px solid var(--ink);background:transparent;color:var(--ink);font-size:20px;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;padding:0}
.slider-arrow:hover{background:var(--ink);color:var(--cream)}
.slider-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:0 28px 30px;margin:0 -28px;scrollbar-width:none}
.slider-track::-webkit-scrollbar{display:none}
.slider-slide{flex:0 0 auto;width:min(70vw,560px);aspect-ratio:3/2;border-radius:6px;background:linear-gradient(160deg,#3b5d3a,#1c2a18);scroll-snap-align:start;overflow:hidden}
.slider-slide img{width:100%;height:100%;object-fit:cover;display:block}

/* ───────── CONTENT VIDEO GRID (lightbox) ───────── */
.video-grid-section{padding:100px 0}
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.video-grid .work-item{aspect-ratio:16/9}
@media(max-width:880px){.video-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.video-grid{grid-template-columns:1fr}}

/* ───────── EXPLAINER (heading + body + image) ───────── */
.explainer{padding:110px 0;background:var(--bone)}
.explainer-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.explainer h2{font-size:clamp(32px,4vw,52px);margin-bottom:24px}
.explainer h2 em{font-style:italic;color:var(--moss)}
.explainer p{font-size:17px;color:#3a3631;margin:0 0 18px;max-width:52ch}
.explainer-media{aspect-ratio:5/4;border-radius:6px;overflow:hidden;background:linear-gradient(160deg,#3b5d3a,#1c2a18)}
.explainer-media img{width:100%;height:100%;object-fit:cover;display:block}
.explainer.reverse .explainer-media{order:-1}
@media(max-width:880px){.explainer-grid{grid-template-columns:1fr;gap:40px}.explainer.reverse .explainer-media{order:0}}

/* ───────── HIGHLIGHT CARD (rust/moss coloured callout) ───────── */
.highlight{padding:100px 0}
.highlight-card{background:var(--rust);color:var(--cream);border-radius:8px;padding:60px 70px;display:grid;grid-template-columns:1.1fr 1.4fr;gap:60px;align-items:start}
.highlight-card.moss{background:var(--moss-deep)}
.highlight-card h2{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:400;line-height:1.05;margin:0 0 18px;color:var(--cream);letter-spacing:-.02em}
.highlight-card h2 em{font-style:italic;color:var(--gold)}
.highlight-card .lead{font-size:16px;color:#f4e8de;margin:0;max-width:34ch}
.highlight-card.moss .lead{color:#d8d0bd}
.highlight-card ul{list-style:none;padding:0;margin:0;display:grid;gap:18px}
.highlight-card li{font-family:var(--serif);font-size:19px;line-height:1.4;padding-left:32px;position:relative}
.highlight-card li::before{content:"→";position:absolute;left:0;top:0;color:var(--gold);font-style:italic}
@media(max-width:880px){.highlight-card{grid-template-columns:1fr;padding:44px 36px;gap:36px}}

/* ───────── FAQ ACCORDION ───────── */
.faq-section{padding:110px 0;background:var(--bone)}
.faq-head{margin-bottom:50px;max-width:20ch}
.faq-list{max-width:900px;margin:0 auto}
.faq-item{border-top:1px solid var(--rule)}
.faq-item:last-child{border-bottom:1px solid var(--rule)}
.faq-q{width:100%;background:transparent;border:none;padding:28px 40px 28px 0;font-family:var(--serif);font-size:clamp(20px,2.5vw,26px);font-weight:400;color:var(--ink);text-align:left;cursor:pointer;position:relative;letter-spacing:-.01em;line-height:1.3;display:block}
.faq-q::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);font-family:var(--sans);font-size:28px;color:var(--rust);font-weight:300;transition:.3s}
.faq-item.is-open .faq-q::after{content:"−"}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;font-size:16px;color:#3a3631;line-height:1.6}
.faq-item.is-open .faq-a{max-height:600px;padding:0 0 28px}
.faq-a p{margin:0 0 12px;max-width:70ch}
.faq-a p:last-child{margin-bottom:0}

/* ───────── HIGHLIGHTED-TEXT TESTIMONIAL ───────── */
.hl-quote-section{padding:130px 0}
.hl-quote-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:70px;align-items:center}
.hl-quote-grid.reverse{grid-template-columns:1fr 1.4fr}
.hl-quote-grid.reverse .hl-quote-img{order:-1}
.hl-quote-text{font-family:var(--serif);font-weight:300;font-size:clamp(32px,5vw,64px);line-height:1.05;letter-spacing:-.025em;margin:0}
.hl-quote-text mark{background:linear-gradient(180deg,transparent 55%,rgba(200,154,60,.5) 55%,rgba(200,154,60,.5) 92%,transparent 92%);color:inherit;padding:0 .08em;font-style:italic}
.hl-quote-cite{margin-top:34px;padding-top:24px;border-top:1px solid var(--rule);font-size:14px;color:var(--muted)}
.hl-quote-cite strong{color:var(--ink);display:block;font-size:16px;margin-bottom:4px;font-weight:600}
.hl-quote-img{aspect-ratio:4/5;border-radius:6px;overflow:hidden;background:linear-gradient(160deg,#3b5d3a,#1c2a18)}
.hl-quote-img img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
@media(max-width:880px){.hl-quote-grid,.hl-quote-grid.reverse{grid-template-columns:1fr;gap:50px}.hl-quote-grid.reverse .hl-quote-img{order:0}}

/* ───────── INLINE LEAD FORM ───────── */
.lead-form-section{padding:100px 0;background:var(--ink);color:var(--cream)}
.lead-form-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:70px;align-items:center}
.lead-form-section h2{color:var(--cream);font-size:clamp(32px,4vw,52px)}
.lead-form-section h2 em{color:var(--gold)}
.lead-form-section .kicker{color:var(--gold)}
.lead-form-section p{color:#a8a094;max-width:40ch;margin-top:20px}
.lead-form-wrap{background:var(--cream);color:var(--ink);padding:44px;border-radius:6px}
@media(max-width:880px){.lead-form-grid{grid-template-columns:1fr;gap:40px}.lead-form-wrap{padding:32px}}


.process{padding:100px 0;background:var(--bone)}
.process-list{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-top:60px;counter-reset:step}
.process-step{counter-increment:step;border-top:1px solid var(--ink);padding-top:24px}
.process-step::before{content:"0" counter(step);font-family:var(--serif);font-style:italic;color:var(--rust);font-size:14px;display:block;margin-bottom:14px}
.process-step h4{font-size:24px;margin-bottom:10px}
.process-step p{font-size:15px;color:var(--muted);margin:0}
@media(max-width:880px){.process-list{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.process-list{grid-template-columns:1fr}}

/* ───────── TEAM ───────── */
.mission{padding:100px 0;text-align:center}
.mission p{font-family:var(--serif);font-size:clamp(26px,3.5vw,42px);font-weight:300;line-height:1.25;max-width:38ch;margin:30px auto 0}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:60px;padding:80px 0 120px}
.team-member{display:grid;grid-template-columns:.8fr 1.2fr;gap:30px;align-items:start}
.team-photo{aspect-ratio:4/5;background:linear-gradient(160deg,#3b5d3a,#1c2a18);border-radius:6px}
.team-member:nth-child(2) .team-photo{background:linear-gradient(160deg,#b9532b,#5a2810)}
.team-member:nth-child(3) .team-photo{background:linear-gradient(160deg,#c89a3c,#5e4615)}
.team-member:nth-child(4) .team-photo{background:linear-gradient(160deg,#27411f,#0e1a0a)}
.team-member h3{font-size:30px;margin-bottom:4px}
.team-role{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--rust);margin-bottom:18px}
.team-quote{font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.5;color:#3a3631;margin:0}
@media(max-width:880px){.team-grid{grid-template-columns:1fr}}

/* ───────── CONTACT ───────── */
.contact-section{padding:120px 0;background:var(--moss-deep);color:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px}
.contact-section .h2{color:var(--cream)}
.contact-section .kicker{color:var(--gold)}
.contact-section p{max-width:38ch;color:#d8d0bd;margin:24px 0 40px}
.contact-detail{font-family:var(--serif);font-size:22px;font-style:italic;margin-top:20px}
.contact-detail a{border-bottom:1px solid rgba(244,239,230,.3)}
.fm-form{background:var(--cream);color:var(--ink);padding:48px;border-radius:6px}
.fm-form label{display:block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--moss);margin-bottom:8px;font-weight:500}
.field{margin-bottom:24px}
.fm-form input[type="text"],.fm-form input[type="email"],.fm-form input[type="tel"],.fm-form textarea{width:100%;border:none;border-bottom:1px solid var(--rule);background:transparent;padding:8px 0 12px;font-family:var(--sans);font-size:16px;color:var(--ink);outline:none;transition:.2s}
.fm-form input:focus,.fm-form textarea:focus{border-color:var(--rust)}
.fm-form textarea{resize:vertical;min-height:90px}
.radio-row{display:flex;gap:24px;font-size:15px}
.radio-row label{display:inline-flex;align-items:center;gap:8px;text-transform:none;letter-spacing:0;color:var(--ink);font-weight:400;font-size:15px;cursor:pointer}
.fm-form button{background:var(--ink);color:var(--cream);border:none;padding:18px 38px;border-radius:999px;font-family:var(--sans);font-size:15px;font-weight:500;cursor:pointer;margin-top:14px;transition:.2s}
.fm-form button:hover{background:var(--rust)}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:50px}.fm-form{padding:32px}}

/* ───────── BLOG / AGRI-NEWS ───────── */
.blog-header{padding:120px 0 60px}
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 32px;padding:40px 0 120px}
.post-card{display:flex;flex-direction:column}
.post-thumb{aspect-ratio:4/3;background:linear-gradient(160deg,#3b5d3a,#1c2a18);border-radius:4px;margin-bottom:22px;overflow:hidden}
.post-thumb img{width:100%;height:100%;object-fit:cover}
.post-meta{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--rust);margin-bottom:10px}
.post-card h2{font-family:var(--serif);font-size:24px;font-weight:400;line-height:1.2;margin-bottom:12px}
.post-card h2 a:hover{color:var(--rust)}
.post-card .excerpt{font-size:15px;color:var(--muted);margin:0 0 16px}
.post-card .read{font-size:13px;font-weight:500;color:var(--moss)}
@media(max-width:880px){.posts{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.posts{grid-template-columns:1fr}}

/*.single-post{max-width:760px;margin:0 auto;padding:80px 28px 120px}*/
.single-post h1{font-size:clamp(32px,4.2vw,52px);line-height:1.05;margin-bottom:24px;letter-spacing:-.02em}
.single-post .post-meta{margin-bottom:20px}
.single-post .entry-content{font-size:18px;line-height:1.7}
.single-post .entry-content p{margin:0 0 24px}
.single-post .entry-content h2{font-size:32px;margin:40px 0 16px}
.single-post .entry-content h3{font-size:24px;margin:32px 0 12px}
.single-post .entry-content a{color:var(--rust);border-bottom:1px solid var(--rust)}

.pagination{display:flex;justify-content:center;gap:14px;margin:40px 0 80px}
.pagination .page-numbers{padding:10px 16px;border:1px solid var(--rule);border-radius:999px;font-size:14px}
.pagination .current{background:var(--ink);color:var(--cream);border-color:var(--ink)} 

/* ───────── FOOTER ───────── */
.site-footer{background:var(--ink);color:#8e867a;padding:80px 0 40px;font-size:14px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
.site-footer h4{font-family:var(--sans);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:18px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:8px 0}
.site-footer a:hover{color:var(--gold)}
.site-footer .site-logo{color:var(--cream)}
.footer-tagline{font-family:var(--serif);font-style:italic;font-size:18px;color:#a8a094;margin-top:18px;max-width:30ch;line-height:1.4}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:30px;border-top:1px solid #2a2723;flex-wrap:wrap;gap:16px}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ═════════════════════════════════════════════
 * VISUAL ENHANCEMENTS LAYER
 * ═════════════════════════════════════════════ */

/* ── Ensure content sits above the grain overlay ── */
.site-nav,.hero,.section,.work,.quote-section,.cta-strip,.page-header,.svc-intro,.media-grid,.process,.mission,.team-grid,.contact-section,.showcase,.slider,.video-grid-section,.explainer,.highlight,.faq-section,.hl-quote-section,.lead-form-section,.site-footer,.posts,.blog-header,.marquee{position:relative;z-index:2}

/* ── Focus states: soft gold outline, brand-consistent ── */
*:focus{outline:none}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,.faq-q:focus-visible,.work-item:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ── Buttons: enhanced hover with arrow slide ── */
.btn{position:relative;overflow:hidden;transition:transform var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}
.btn::after{content:"";position:absolute;inset:0;background:currentColor;opacity:0;transition:opacity var(--dur-fast) var(--ease);pointer-events:none;border-radius:inherit}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--rust)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-light:hover{background:var(--gold);transform:translateY(-2px) scale(1.02)}

/* ── Nav CTA pulse on hover ── */
.nav-cta{transition:background var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease)}
.nav-cta:hover{transform:translateY(-1px)}

/* ── Marquee: edge fade masking ── */
.marquee{mask-image:linear-gradient(to right,transparent 0,#000 8%,#000 92%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,#000 8%,#000 92%,transparent 100%)}

/* ── Discipline cards: internal shift + subtle scale on hover ── */
.disc{transition:background var(--dur) var(--ease),color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.disc h3{transition:transform var(--dur) var(--ease)}
.disc:hover h3{transform:translateX(6px)}
.disc::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--x,50%) var(--y,50%),rgba(200,154,60,.12),transparent 60%);opacity:0;transition:opacity var(--dur) var(--ease);pointer-events:none}
.disc:hover::after{opacity:1}

/* ── Work items: zoom image on hover ── */
.work-item{transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);background-size:cover !important}
.work-item.video-trigger::before{transition:background var(--dur) var(--ease),backdrop-filter var(--dur) var(--ease)}
.work-item.video-trigger:hover{transform:translateY(-6px) scale(1.015);box-shadow:var(--shadow-lg)}
.work-item.video-trigger:hover .play-icon{box-shadow:0 0 0 8px rgba(185,83,43,.25),var(--shadow)}
.play-icon{box-shadow:0 0 0 0 rgba(185,83,43,0),var(--shadow-sm);transition:box-shadow var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease),transform var(--dur) var(--ease)}

/* ── Showcase cards: image lift + overlay gleam ── */
.showcase-img{transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);position:relative}
.showcase-img img{transition:transform var(--dur-slow) var(--ease)}
.showcase-card a:hover .showcase-img img{transform:scale(1.04)}

/* ── Team photos: subtle grayscale lift ── */
.team-photo{transition:transform var(--dur) var(--ease),filter var(--dur) var(--ease);filter:saturate(.92)}
.team-member:hover .team-photo{transform:translateY(-4px);filter:saturate(1.05)}

/* ── Post cards: thumbnail zoom ── */
.post-thumb{transition:transform var(--dur) var(--ease);overflow:hidden}
.post-thumb img{transition:transform var(--dur-slow) var(--ease)}
.post-card:hover .post-thumb img{transform:scale(1.05)}
.post-card h2 a{transition:color var(--dur-fast) var(--ease)}

/* ── FAQ: smoother open animation ── */
.faq-a{transition:max-height .55s var(--ease),padding .4s var(--ease),opacity .4s var(--ease);opacity:.3}
.faq-item.is-open .faq-a{opacity:1}
.faq-q{transition:color var(--dur-fast) var(--ease)}
.faq-q:hover{color:var(--rust)}
.faq-q::after{transition:transform .4s var(--ease-snap),color var(--dur-fast) var(--ease)}
.faq-item.is-open .faq-q::after{transform:translateY(-50%) rotate(180deg)}

/* ── Slider arrows: more refined hover ── */
.slider-arrow{transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease)}
.slider-arrow:hover{transform:scale(1.08)}

/* ── Links inside body content get an animated underline ── */
.entry-content a{position:relative;background-image:linear-gradient(var(--rust),var(--rust));background-size:100% 1px;background-position:0 100%;background-repeat:no-repeat;transition:background-size var(--dur) var(--ease)}
.entry-content a:hover{background-size:100% 2px}

/* ── Primary menu underline on hover ── */
.primary-menu a{position:relative}
.primary-menu a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--rust);transition:right var(--dur) var(--ease)}
.primary-menu a:hover::after{right:0}

/* ─────────────────────────────────────────────
 * ENTRANCE ANIMATIONS
 * ───────────────────────────────────────────── */

@keyframes fmRise{
  from{opacity:0;transform:translateY(32px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fmRiseSoft{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fmFade{
  from{opacity:0}
  to{opacity:1}
}
@keyframes fmScaleIn{
  from{opacity:0;transform:scale(.96)}
  to{opacity:1;transform:scale(1)}
}
@keyframes fmSlideRight{
  from{opacity:0;transform:translateX(-24px)}
  to{opacity:1;transform:translateX(0)}
}

/* Hero: orchestrated stagger on load */
.hero .eyebrow,.hero .h1,.hero .lede,.hero .hero-cta,.hero .hero-meta{opacity:0;animation:fmRise .9s var(--ease) forwards}
.hero .eyebrow{animation-delay:.1s}
.hero .h1{animation-delay:.25s;animation-duration:1.1s}
.hero .lede{animation-delay:.5s}
.hero .hero-cta{animation-delay:.65s}
.hero .hero-meta:nth-of-type(1){animation-delay:.75s}
.hero .hero-meta:nth-of-type(2){animation-delay:.85s}
.hero .hero-meta:nth-of-type(3){animation-delay:.95s}
.hero .marquee{opacity:0;animation:fmFade 1s var(--ease) forwards;animation-delay:1.1s}

/* Page header: simpler entrance */
.page-header .breadcrumb,.page-header .h1,.page-header .lede{opacity:0;animation:fmRiseSoft .8s var(--ease) forwards}
.page-header .breadcrumb{animation-delay:.05s}
.page-header .h1{animation-delay:.15s}
.page-header .lede{animation-delay:.3s}

/* ───────── PRIVACY POLICY ───────── */
.privacy{padding:80px 0 140px}
.privacy-wrap{max-width:780px;margin:0 auto}
.privacy-intro{font-family:var(--serif);font-size:22px;font-weight:300;line-height:1.5;color:var(--ink);margin:0 0 60px;padding-bottom:40px;border-bottom:1px solid var(--rule)}
.privacy-section{margin-bottom:52px}
.privacy-section:last-of-type{margin-bottom:40px}
.privacy-section h2{font-family:var(--serif);font-size:clamp(24px,3vw,32px);font-weight:400;letter-spacing:-.015em;margin:0 0 18px;color:var(--ink);position:relative;padding-left:22px}
.privacy-section h2::before{content:"";position:absolute;left:0;top:14px;width:10px;height:10px;background:var(--rust);border-radius:50%}
.privacy-section p{font-size:17px;line-height:1.75;color:#3a3631;margin:0 0 16px;max-width:66ch}
.privacy-section p:last-child{margin-bottom:0}
.privacy-section strong{color:var(--ink);font-weight:600}
.privacy-section ul{list-style:none;padding:0;margin:0 0 18px}
.privacy-section li{font-size:17px;line-height:1.65;color:#3a3631;padding:8px 0 8px 28px;position:relative;border-bottom:1px solid var(--rule)}
.privacy-section li:last-child{border-bottom:none}
.privacy-section li::before{content:"→";position:absolute;left:0;top:8px;color:var(--rust);font-family:var(--serif);font-style:italic;font-size:15px}
.privacy-section a{color:var(--rust);border-bottom:1px solid var(--rust);transition:color var(--dur-fast) var(--ease)}
.privacy-section a:hover{color:var(--rust-deep)}
.privacy-legal{margin-top:60px;padding-top:30px;border-top:1px solid var(--rule);font-size:13px;color:var(--text-muted);line-height:1.6}

   Only apply initial hidden state when JS has loaded — prevents invisible
   content if JS fails or is blocked. */
.js .reveal{opacity:0;transform:translateY(36px);transition:opacity .8s var(--ease),transform .8s var(--ease);will-change:opacity,transform}
.js .reveal.is-visible{opacity:1;transform:translateY(0)}
.js .reveal-soft{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal-soft.is-visible{opacity:1;transform:translateY(0)}
.js .reveal-scale{opacity:0;transform:scale(.94);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .reveal-scale.is-visible{opacity:1;transform:scale(1)}

/* Stagger children: .stagger > * uses incrementing --i */
.js .stagger > *{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:calc(var(--i,0) * 80ms)}
.js .stagger.is-visible > *{opacity:1;transform:translateY(0)}

/* Nav shrink on scroll */
.site-nav{transition:padding var(--dur) var(--ease),background var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.site-nav.is-scrolled{padding-top:14px;padding-bottom:14px;background:rgba(244,239,230,.96);box-shadow:0 1px 0 var(--rule),0 6px 24px rgba(28,26,23,.05)}
.site-nav.is-scrolled .site-logo{font-size:19px;transition:font-size var(--dur) var(--ease)}
.site-logo{transition:font-size var(--dur) var(--ease)}

/* Page transitions: fade in body on load */
@keyframes fmPageIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
main,.site-nav + section,.site-nav + header{animation:fmPageIn .55s var(--ease) both}

/* Respect reduced-motion preference */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-delay:0 !important;transition-duration:.01ms !important}
  .reveal,.reveal-soft,.reveal-scale,.stagger > *{opacity:1 !important;transform:none !important}
}
