/*
Theme Name: Cafetal Coffee Import
Theme URI: https://cafetalcoffeeimport.com
Author: Cafetal Coffee Import
Description: Brand theme for Cafetal Coffee Import — Danish green coffee importer. A faithful WordPress port of the Cafetal site: deep teal / warm orange palette, Fraunces + Inter type, direct-relationship positioning. Classic theme, no page builder required.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: cafetal
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --bg:#f5f4f1;
  --fg:#2d2e2e;
  --sand:#f2f2f0;
  --sand-fg:#262727;
  --teal:#0f464c;
  --teal-fg:#f7faf9;
  --teal-glow:#16585f;
  --teal-light:#e2edee;
  --ink:#2d2e2e;
  --ink-fg:#f7faf9;
  --orange:#ef733a;
  --orange-fg:#ffffff;
  --cobalt:#346cd5;
  --cobalt-fg:#ffffff;
  --butter:#f9f58b;
  --butter-fg:#2d2e2e;
  --card:#ffffff;
  --muted:#ededea;
  --muted-fg:#6b6f6d;
  --border:#e4e2dc;
  --radius:0.5rem;
  --maxw:80rem;
  --shadow-card:0 1px 2px rgba(0,0,0,.04), 0 12px 32px -8px rgba(15,70,76,.18);
  --shadow-soft:0 1px 2px rgba(0,0,0,.04), 0 8px 24px rgba(0,0,0,.06);
  --ease:cubic-bezier(.22,1,.36,1);
  --font-display:"Fraunces","Inter",ui-serif,Georgia,serif;
  --font-body:"Inter",ui-sans-serif,system-ui,sans-serif;
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font-family:var(--font-body);font-size:16px;line-height:1.5;
  font-feature-settings:"ss01","cv11";
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;
  background:
    linear-gradient(180deg,rgba(255,255,255,.36),transparent 18%),
    radial-gradient(circle at top left,rgba(249,245,139,.16),transparent 28%);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.1;margin:0}
p{margin:0}
.font-display{font-family:var(--font-display)}
em{font-style:italic}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.container{max-width:var(--maxw);margin:0 auto;padding-left:1.5rem;padding-right:1.5rem}
@media(min-width:1024px){.container{padding-left:2.5rem;padding-right:2.5rem}}
.eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.22em;color:var(--teal);margin-bottom:1.25rem}
.section{padding-block:5rem}
@media(min-width:768px){.section{padding-block:7rem}}
.bg-sand{background:var(--sand)}
.bg-ink{background:var(--ink);color:var(--ink-fg)}
.bg-teal{background:var(--teal);color:var(--teal-fg)}
.lead{font-size:1.125rem;color:var(--muted-fg);max-width:42rem}

/* Headings scale */
.h-xl{font-size:clamp(2.6rem,6vw,5rem);line-height:1.02}
.h-lg{font-size:clamp(2.1rem,4.5vw,3rem);line-height:1.1}
.h-md{font-size:clamp(1.6rem,3vw,2rem)}

/* ============================================================
   BUTTONS / BADGES
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:.5rem;border-radius:999px;padding:1rem 1.75rem;font-size:1rem;font-weight:500;transition:.2s ease;cursor:pointer;border:0}
.btn-orange{background:var(--orange);color:var(--orange-fg)}
.btn-orange:hover{opacity:.9}
.btn-teal{background:var(--teal);color:var(--teal-fg)}
.btn-teal:hover{background:var(--teal-glow)}
.btn-outline{border:1px solid rgba(255,255,255,.4);color:#fff;background:transparent}
.btn-outline:hover{background:rgba(255,255,255,.1)}
.badge{display:inline-block;font-size:.625rem;text-transform:uppercase;letter-spacing:.16em;padding:.25rem .625rem;border-radius:999px}
.badge-direct{background:var(--teal);color:var(--teal-fg)}
.badge-cooperative,.badge-cobalt{background:var(--cobalt);color:var(--cobalt-fg)}
.badge-sourced,.badge-muted{background:var(--muted);color:var(--fg)}
.badge-butter{background:var(--butter);color:var(--butter-fg)}
.arrow-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--teal);transition:.2s ease}
.arrow-link:hover{gap:.75rem}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:40;transition:all .5s ease}
.site-header.transparent{background:transparent;color:#fff}
.site-header.solid{background:rgba(245,244,241,.9);backdrop-filter:blur(12px);color:var(--fg);border-bottom:1px solid rgba(228,226,220,.7)}
.header-inner{max-width:var(--maxw);margin:0 auto;height:5rem;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between}
@media(min-width:1024px){.header-inner{padding:0 2.5rem}}
.brand{display:flex;align-items:center;gap:.75rem}
.brand img{height:2.5rem;width:auto;max-width:168px;transition:.2s}
.site-header.transparent .brand img{filter:brightness(0) invert(1)}
.brand-tag{font-size:.6875rem;text-transform:uppercase;letter-spacing:.18em;display:none}
@media(min-width:1024px){.brand-tag{display:inline}}
.site-header.transparent .brand-tag{color:rgba(255,255,255,.7)}
.site-header.solid .brand-tag{color:var(--muted-fg)}
.nav{display:none;align-items:center;gap:2rem;font-size:.875rem}
@media(min-width:768px){.nav{display:flex}}
.nav a{opacity:.8;transition:opacity .2s}
.nav a:hover,.nav a.current{opacity:1}
.site-header.transparent .nav a{color:rgba(255,255,255,.85)}
.site-header.solid .nav a{color:rgba(45,46,46,.72)}
.nav .btn{padding:.5rem 1rem;font-size:.875rem;margin-left:.5rem;opacity:1}
.menu-toggle{display:inline-flex;height:2.5rem;width:2.5rem;align-items:center;justify-content:center;border-radius:.375rem;border:1px solid currentColor;background:transparent;color:inherit;cursor:pointer}
@media(min-width:768px){.menu-toggle{display:none}}
.menu-toggle svg{width:1.5rem;height:1.5rem}
/* Mobile overlay */
.mobile-menu{position:fixed;inset:0;z-index:50;background:var(--ink);color:var(--ink-fg);display:none;flex-direction:column}
.mobile-menu.open{display:flex}
.mobile-menu-bar{height:5rem;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1)}
.mobile-menu-bar img{height:2.5rem;filter:brightness(0) invert(1)}
.mobile-menu nav{flex:1;display:flex;flex-direction:column;justify-content:center;gap:2rem;padding:0 2rem}
.mobile-menu nav a{font-family:var(--font-display);font-size:2.25rem}
.mobile-menu .btn{width:fit-content;margin-top:1rem}
.close-btn{height:2.5rem;width:2.5rem;background:transparent;border:0;color:#fff;cursor:pointer}
.close-btn svg{width:1.5rem;height:1.5rem}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero>img{position:absolute;inset:0;height:100%;width:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(45,46,46,.72))}
.hero-inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:10rem 1.5rem 6rem;width:100%}
@media(min-width:1024px){.hero-inner{padding:10rem 2.5rem 6rem}}
.hero-eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.24em;color:rgba(255,255,255,.7);margin-bottom:2rem}
.hero h1{font-size:clamp(3rem,8vw,6.5rem);line-height:.98;max-width:64rem}
.hero h1 em{font-style:normal;color:rgba(255,255,255,.8)}
.hero p{margin-top:2rem;max-width:36rem;font-size:1.2rem;color:rgba(255,255,255,.85)}
.hero-actions{margin-top:2.5rem;display:flex;flex-wrap:wrap;gap:1rem}

/* Trust bar */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#fff}
.trust-inner{max-width:var(--maxw);margin:0 auto;padding:1.25rem 1.5rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem 2rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted-fg)}
.trust-inner .dot{color:var(--border)}

/* ============================================================
   GENERIC SECTION PIECES
   ============================================================ */
.split{display:grid;gap:4rem;align-items:center}
@media(min-width:1024px){.split{grid-template-columns:1fr 1fr;gap:6rem}}
.prose p+p{margin-top:1.25rem}
.prose{color:rgba(45,46,46,.8);line-height:1.7}
.media-frame{position:relative}
.media-frame img{width:100%;object-fit:cover;border-radius:var(--radius);aspect-ratio:4/5}
.media-badge{position:absolute;bottom:-1.5rem;left:-1.5rem;background:var(--teal);color:var(--teal-fg);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--shadow-card)}
.media-badge .big{font-family:var(--font-display);font-size:1.5rem}
.media-badge .small{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.7);margin-top:.25rem}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem 0;text-align:center}
@media(min-width:768px){.stats{grid-template-columns:repeat(4,1fr)}}
.stats .value{font-family:var(--font-display);font-size:clamp(2.2rem,4vw,3rem);color:var(--teal)}
.stats .label{margin-top:.5rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--muted-fg)}

/* Steps */
.steps{margin-top:4rem;display:grid;gap:2rem}
@media(min-width:768px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{border-top:1px solid var(--border);padding-top:2rem}
.step .num{font-family:var(--font-display);font-size:3rem;color:rgba(15,70,76,.3)}
.step .t{margin-top:1rem;font-family:var(--font-display);font-size:1.5rem}
.step p{margin-top:.75rem;font-size:.875rem;color:rgba(45,46,46,.75);line-height:1.6}

/* Founder quote */
.founder-quote blockquote{font-family:var(--font-display);font-style:italic;font-size:clamp(1.6rem,3.4vw,3rem);line-height:1.15;margin:0}
.founder-quote .who{margin-top:2.5rem;font-size:.875rem;color:rgba(255,255,255,.6)}

/* Section heading row */
.section-head{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}
@media(min-width:768px){.section-head{flex-direction:row;align-items:flex-end;justify-content:space-between}}

/* ============================================================
   COFFEE CARDS / GRID
   ============================================================ */
.coffee-grid{display:grid;gap:1.75rem;grid-template-columns:1fr}
@media(min-width:640px){.coffee-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.coffee-grid.four{grid-template-columns:repeat(4,1fr)}.coffee-grid.three{grid-template-columns:repeat(3,1fr)}}
.coffee-grid.two{grid-template-columns:1fr}
@media(min-width:768px){.coffee-grid.two{grid-template-columns:repeat(2,1fr)}}
.coffee-card{display:flex;flex-direction:column;border:1px solid var(--border);background:var(--card);border-radius:var(--radius);overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.coffee-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
.coffee-photo{position:relative;aspect-ratio:5/3}
.coffee-photo>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.coffee-photo .tags{position:absolute;top:1rem;left:1rem;display:flex;gap:.5rem;z-index:2}
.coffee-photo .tier{position:absolute;bottom:1rem;left:1rem;z-index:2;font-size:.625rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(15,70,76,.85);background:rgba(245,244,241,.85);backdrop-filter:blur(4px);padding:.25rem .5rem;border-radius:.25rem}
.coffee-body{padding:1.75rem;display:flex;flex-direction:column;flex:1}
.coffee-body h3{font-size:1.5rem}
.coffee-body .origin{font-size:.875rem;color:var(--muted-fg);margin-top:.25rem}
.spec{margin-top:1.25rem;display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1rem;border-top:1px solid var(--border);padding-top:1.25rem;font-size:.75rem}
.spec dt{text-transform:uppercase;letter-spacing:.14em;color:rgba(107,111,109,.85);font-size:.625rem}
.spec dd{margin:.125rem 0 0;color:var(--fg)}
.coffee-desc{margin-top:1.25rem;font-size:.875rem;color:rgba(45,46,46,.8);line-height:1.6}
.coffee-cta{margin-top:1.5rem;padding-top:.5rem}

/* Image placeholder (fallback when no photo set) */
.img-placeholder{background:linear-gradient(135deg,var(--teal-light),var(--sand));position:relative;overflow:hidden}
.img-placeholder::after{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-style:italic;font-size:.875rem;color:var(--teal);opacity:.55}

/* Filter bar */
.filter-bar{position:sticky;top:5rem;z-index:20;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.filter-bar-inner{max-width:var(--maxw);margin:0 auto;padding:1rem 1.5rem;display:flex;flex-wrap:wrap;gap:.5rem}
@media(min-width:1024px){.filter-bar-inner{padding:1rem 2.5rem}}
.filter-btn{padding:.5rem 1rem;border-radius:999px;font-size:.875rem;border:1px solid var(--border);color:rgba(45,46,46,.7);background:transparent;cursor:pointer;transition:.2s}
.filter-btn:hover{border-color:rgba(15,70,76,.4);color:var(--teal)}
.filter-btn.active{background:var(--teal);color:var(--teal-fg);border-color:var(--teal)}
.tier-count{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted-fg)}

/* ============================================================
   CARDS / GENERIC TILES (origins, transparency)
   ============================================================ */
.tile-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:768px){.tile-grid.three{grid-template-columns:repeat(3,1fr)}.tile-grid.two{grid-template-columns:repeat(2,1fr)}}
.tile{border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:1.75rem}
.tile h3{margin-top:1.25rem;font-size:1.5rem;line-height:1.25}
.tile p{margin-top:1rem;font-size:.875rem;color:rgba(45,46,46,.75);line-height:1.6}
.future-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.future-tile{border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:1.5rem}
.future-tile .k{font-size:.625rem;text-transform:uppercase;letter-spacing:.18em;color:var(--teal)}
.future-tile .v{margin-top:.5rem;font-family:var(--font-display);font-size:1.5rem}

/* Farm article */
.farm{border:1px solid var(--border);background:var(--card);border-radius:1rem;overflow:hidden}
.farm .photo{aspect-ratio:16/10}
.farm .photo img{width:100%;height:100%;object-fit:cover}
.farm .body{padding:1.75rem}
.farm .row{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.farm dl{margin:1.25rem 0 0;display:grid;grid-template-columns:1fr 1fr;gap:1rem;font-size:.875rem}
.farm dt{font-size:.625rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted-fg)}
.farm dd{margin:.25rem 0 0}
.farm p{margin-top:1.25rem;font-size:.875rem;color:rgba(45,46,46,.75);line-height:1.6}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;gap:3rem;grid-template-columns:1fr}
@media(min-width:1024px){.about-grid{grid-template-columns:5fr 7fr;gap:4rem}}
.about-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:1rem;box-shadow:var(--shadow-card)}
@media(min-width:1024px){.about-photo{position:sticky;top:7rem}}
.about-meta{margin-top:1.25rem;font-size:.875rem;color:var(--muted-fg)}
.about-meta .name{font-family:var(--font-display);font-size:1.25rem;color:var(--fg)}
.pull-quote{margin-top:3rem;border-left:2px solid var(--teal);padding-left:1.5rem;font-family:var(--font-display);font-style:italic;font-size:clamp(1.4rem,2.4vw,1.875rem);line-height:1.3}
.detail-dl{border-top:1px solid var(--border);margin-top:1.5rem}
.detail-dl .r{display:grid;grid-template-columns:1fr 2fr;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border);font-size:.875rem}
.detail-dl dt{text-transform:uppercase;letter-spacing:.14em;color:var(--muted-fg);font-size:.6875rem}
.detail-dl dd{margin:0}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;gap:3.5rem;grid-template-columns:1fr}
@media(min-width:1024px){.contact-grid{grid-template-columns:7fr 5fr}}
.field{margin-bottom:0}
.field label{font-size:.625rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted-fg)}
.field input,.field textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--border);padding:.75rem 0;margin-top:.25rem;font-family:inherit;font-size:1rem;color:var(--fg);outline:none;transition:border-color .2s}
.field input:focus,.field textarea:focus{border-color:var(--teal)}
.field textarea{resize:none}
.grid-2{display:grid;gap:1.5rem 2rem;grid-template-columns:1fr}
@media(min-width:640px){.grid-2{grid-template-columns:1fr 1fr}}
.form-stack>*+*{margin-top:2rem}
.contact-card{border:1px solid rgba(228,226,220,.7);background:var(--sand);border-radius:var(--radius);padding:2rem}
.contact-card.alt{background:var(--card);border-color:var(--border);margin-top:2rem}
.contact-card dl>*+*{margin-top:1.25rem}
.contact-card dt{font-size:.625rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted-fg)}
.contact-card dd{margin:.25rem 0 0}
.contact-card a:hover{color:var(--teal)}
.notice{border-radius:1rem;background:var(--teal-light);border:1px solid rgba(15,70,76,.2);padding:2.5rem}
.notice h2{color:var(--teal)}
.checklist{list-style:none;margin:0;padding:0;font-size:.875rem;color:rgba(45,46,46,.8)}
.checklist li{display:flex;gap:.75rem;margin-top:.75rem}
.checklist li::before{content:"·";color:var(--teal)}
.form-error{color:#b3261e;font-size:.75rem;margin-top:.25rem}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero{background:var(--sand);padding:9rem 0 5rem;border-bottom:1px solid rgba(228,226,220,.7)}
@media(min-width:768px){.page-hero{padding:11rem 0 7rem}}
.page-hero h1{font-size:clamp(2.6rem,6vw,4.5rem);line-height:1.02;max-width:56rem}
.page-hero .lead{margin-top:2rem;font-size:1.125rem}

/* ============================================================
   CTA
   ============================================================ */
.cta{background:var(--teal);color:var(--teal-fg)}
.cta-inner{max-width:var(--maxw);margin:0 auto;padding:6rem 1.5rem;display:flex;flex-direction:column;align-items:flex-start;gap:2.5rem}
@media(min-width:768px){.cta-inner{flex-direction:row;align-items:center;justify-content:space-between;padding:8rem 2.5rem}}
.cta h2{max-width:36rem}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:var(--ink-fg)}
.footer-grid{max-width:var(--maxw);margin:0 auto;padding:5rem 1.5rem;display:grid;gap:3rem}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(3,1fr);padding:5rem 2.5rem}}
.site-footer img{height:2.75rem;width:auto;filter:brightness(0) invert(1)}
.site-footer .blurb{margin-top:.75rem;font-size:.875rem;color:rgba(255,255,255,.6);max-width:20rem}
.footer-h{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.5);margin-bottom:1rem}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer ul li{margin-top:.625rem;font-size:.875rem;color:rgba(255,255,255,.8)}
.site-footer ul li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom-inner{max-width:var(--maxw);margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;font-size:.72rem;color:rgba(255,255,255,.5)}
@media(min-width:768px){.footer-bottom-inner{flex-direction:row;align-items:center;justify-content:space-between;padding:1.5rem 2.5rem}}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

.mt-link{margin-top:2.5rem}
.space-y>*+*{margin-top:1.25rem}
