/* ==========================================================================
   EL-AMENA OLEA — Institutional B2B olive-oil sourcing & export
   Design language: deep olive green + warm gold/cream, red brand accent,
   generous whitespace. Acesur/Migasa restraint. No framework.
   ========================================================================== */

:root{
  --green-900:#1f2a14;
  --green-800:#2b3a1c;
  --green-700:#3a4a23;
  --green-600:#4a5d2e;
  --green-100:#e9eede;
  --gold-700:#a8801f;
  --gold-600:#c8a24a;
  --gold-500:#d4af37;
  --gold-300:#e7cf8f;
  --cream:#f7f3ea;
  --cream-2:#fbf8f1;
  --paper:#ffffff;
  --red-700:#a01f24;
  --red-600:#c0252b;
  --ink:#23291c;
  --ink-soft:#54603f;
  --muted:#6c7458;
  --line:#e4e0d2;
  --line-soft:#eee9dc;
  --ok:#2f7a3e;

  --maxw:1180px;
  --gap:clamp(1rem,3vw,2rem);
  --radius:14px;
  --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(31,42,20,.06),0 2px 8px rgba(31,42,20,.05);
  --shadow:0 8px 30px rgba(31,42,20,.10);
  --shadow-lg:0 24px 60px rgba(31,42,20,.16);
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Inter","Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  --t:.25s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-700);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--gold-700)}
h1,h2,h3,h4{font-family:var(--serif);color:var(--green-800);line-height:1.12;
  font-weight:600;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.4vw,3.15rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}
h3{font-size:clamp(1.25rem,2vw,1.5rem)}
p{margin:0 0 1rem}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.18em;
  font-size:.78rem;font-weight:700;color:var(--gold-700);margin:0 0 1rem;display:block}
.lede{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--ink-soft);line-height:1.6}

/* ---------- layout ---------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.section{padding-block:clamp(3.5rem,7vw,6rem)}
.section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.section--cream{background:var(--cream)}
.section--paper2{background:var(--cream-2)}
.section--green{background:var(--green-800);color:#e9eede}
.section--green h2,.section--green h3{color:#fff}
.section--green .lede{color:#cfd6bf}
.center{text-align:center}
.measure{max-width:62ch}
.measure-narrow{max-width:48ch}
.center .measure,.center .measure-narrow{margin-inline:auto}
.grid{display:grid;gap:var(--gap)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.stack-sm>*+*{margin-top:.4rem}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);
  font-weight:600;font-size:.98rem;line-height:1;padding:.95em 1.6em;border-radius:999px;
  border:1.5px solid transparent;cursor:pointer;transition:var(--t);text-align:center;
  white-space:nowrap;position:relative;overflow:hidden;isolation:isolate}
.btn::before{content:"";position:absolute;inset:-40% auto -40% -70%;width:55%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.42),transparent);
  transform:skewX(-18deg);transition:left .65s ease;z-index:-1}
.btn:hover::before{left:120%}
.btn svg{width:1.05em;height:1.05em;flex:0 0 auto}
.btn--primary{background:var(--gold-600);color:var(--green-900);border-color:var(--gold-600);
  box-shadow:0 6px 18px rgba(168,128,31,.28)}
.btn--primary:hover{background:var(--gold-500);color:var(--green-900);transform:translateY(-2px);
  box-shadow:0 10px 26px rgba(168,128,31,.36)}
.btn--ghost{background:transparent;color:var(--green-800);border-color:var(--green-600)}
.btn--ghost:hover{background:var(--green-800);color:#fff;border-color:var(--green-800)}
/* ghost buttons sitting on dark backgrounds become light-outlined */
.hero .btn--ghost,.offer .btn--ghost,.section--green .btn--ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.hero .btn--ghost:hover,.offer .btn--ghost:hover,.section--green .btn--ghost:hover{background:#fff;color:var(--green-900);border-color:#fff}
.btn--light{background:#fff;color:var(--green-800);border-color:#fff}
.btn--light:hover{background:var(--cream);color:var(--green-900)}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--outline-light:hover{background:#fff;color:var(--green-900);border-color:#fff}
.btn--wa{background:#25d366;color:#0a2e16;border-color:#25d366}
.btn--wa:hover{background:#1fb959;color:#06230f;transform:translateY(-2px)}
.btn--block{display:flex;width:100%;justify-content:center}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem}
.center .btn-row{justify-content:center}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line);
  transition:box-shadow var(--t),background var(--t);animation:headerDrop .65s cubic-bezier(.16,1,.3,1) both}
.site-header.is-scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;gap:1.2rem;min-height:74px}
.brand{display:flex;align-items:center;gap:.65rem;flex:0 0 auto}
.brand img{height:46px;width:auto}
.brand-name{font-family:var(--serif);font-weight:700;font-size:1.32rem;color:var(--green-800);
  line-height:1;letter-spacing:.01em}
.brand-name small{display:block;font-family:var(--sans);font-weight:600;font-size:.58rem;
  letter-spacing:.26em;color:var(--gold-700);text-transform:uppercase;margin-top:.28em}
.primary-nav{margin-inline-start:auto;display:flex;align-items:center;gap:.3rem}
.primary-nav a.navlink{font-family:var(--sans);font-weight:500;font-size:.93rem;color:var(--ink);
  padding:.55em .7em;border-radius:8px;position:relative;white-space:nowrap}
.primary-nav a.navlink:hover{color:var(--green-700);background:var(--cream)}
.primary-nav a.navlink.is-active{color:var(--green-800);font-weight:600}
.primary-nav a.navlink.is-active::after{content:"";position:absolute;left:.7em;right:.7em;bottom:.32em;
  height:2px;background:var(--gold-500);border-radius:2px}
.header-actions{display:flex;align-items:center;gap:.6rem;flex:0 0 auto}

/* language switcher */
.lang{position:relative}
.lang__btn{display:inline-flex;align-items:center;gap:.35em;background:transparent;border:1px solid var(--line);
  border-radius:999px;padding:.5em .8em;font-family:var(--sans);font-weight:600;font-size:.85rem;
  color:var(--green-800);cursor:pointer}
.lang__btn:hover{border-color:var(--green-600)}
.lang__menu{position:absolute;inset-inline-end:0;top:calc(100% + .4rem);background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);padding:.4rem;min-width:172px;display:none;z-index:70}
.lang__menu.open{display:block}
.lang__menu a{display:flex;align-items:center;gap:.6rem;padding:.5em .7em;border-radius:8px;
  font-size:.9rem;color:var(--ink);font-weight:500}
.lang__menu a:hover{background:var(--cream);color:var(--green-800)}
.lang__menu a.is-current{color:var(--green-800);font-weight:700}
.lang__menu .flag{font-size:1.05rem;line-height:1}

.nav-toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:10px;
  width:44px;height:44px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:20px;
  height:2px;background:var(--green-800);border-radius:2px;position:relative;transition:var(--t)}
.nav-toggle span::before{position:absolute;top:-6px}.nav-toggle span::after{position:absolute;top:6px}
.nav-open .nav-toggle span{background:transparent}
.nav-open .nav-toggle span::before{top:0;transform:rotate(45deg)}
.nav-open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;color:#eef1e4;
  background:
    radial-gradient(120% 100% at 85% -10%,rgba(200,162,74,.22),transparent 55%),
    radial-gradient(90% 80% at 12% 110%,rgba(160,31,36,.16),transparent 60%),
    linear-gradient(160deg,var(--green-900) 0%,var(--green-800) 45%,#33421f 100%)}
.hero-video-bg{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;object-position:center 100%;
  opacity:.88;transform:translate3d(0,var(--hero-y,0px),0) scale(1.01);transform-origin:center bottom;transition:transform .18s linear}
.hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,rgba(22,38,15,.78) 0%,rgba(22,38,15,.56) 42%,rgba(22,38,15,.24) 100%)}
.hero::after{content:"";position:absolute;inset:0;opacity:.32;pointer-events:none;
  z-index:1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 59h60' stroke='%23ffffff' stroke-opacity='.03' /%3E%3Cpath d='M59 0v60' stroke='%23ffffff' stroke-opacity='.03'/%3E%3C/svg%3E")}
.hero .container{position:relative;z-index:2}
.hero--home .container{max-width:none;margin-inline:0;padding-inline-start:clamp(1.4rem,6vw,5.5rem);padding-inline-end:clamp(1.1rem,4vw,2rem)}
.hero--home{min-height:calc(100vh - 74px);padding-block:clamp(4.5rem,8vw,7rem);display:flex;align-items:center}
.hero--page{padding-block:clamp(3rem,6vw,5rem)}
.hero h1{color:#fff;max-width:16ch}
.hero--page h1{max-width:20ch}
.hero .eyebrow{color:var(--gold-300)}
.hero .lede{color:#d8dec8;max-width:50ch}
.hero .btn-row{margin-top:2rem}
.hero-copy{max-width:620px}
.hero--home .hero-copy{padding-inline-start:0;margin-inline-end:auto}
.hero-copy h1{margin-bottom:.72em}
.hero-copy .lede{font-weight:500}
.hero-copy .eyebrow{margin-bottom:1.25rem}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero-figure{position:relative;display:grid;place-items:center;min-height:280px}
.hero-figure .drop-card{background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.03));
  border:1px solid rgba(231,207,143,.28);border-radius:24px;padding:2.4rem;backdrop-filter:blur(4px);
  box-shadow:var(--shadow-lg);text-align:center;width:min(100%,360px)}
.hero-figure .drop-card img{height:150px;width:auto;margin:0 auto .9rem;filter:drop-shadow(0 12px 24px rgba(0,0,0,.35))}
.hero-figure .drop-card .k{font-family:var(--serif);font-size:1.6rem;color:#fff;line-height:1.1}
.hero-figure .drop-card .s{font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-300);
  font-weight:700;margin-top:.3rem}
.hero-stats{display:flex;gap:2rem;margin-top:2.2rem;flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column}
.hero-stat .n{display:block;font-family:var(--serif);font-size:1.9rem;color:var(--gold-300);font-weight:700;line-height:1.05}
.hero-stat .l{display:block;font-size:.8rem;color:#c4ccb1;letter-spacing:.04em;margin-top:.3rem}

/* trust bar */
.trustbar{background:var(--cream);color:var(--green-800);
  border-top:0;border-bottom:1px solid var(--line)}
.trustbar__grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.75rem;padding-block:1rem}
.trustbar__item{display:flex;align-items:center;gap:.7rem;min-height:58px;padding:.7rem .8rem;
  border:1px solid var(--line);border-radius:8px;background:#fff;
  box-shadow:var(--shadow-sm);transition:transform var(--t),border-color var(--t),background var(--t)}
.trustbar__item:hover{transform:translateY(-2px);border-color:var(--gold-300);background:var(--cream-2)}
.trustbar__label{font-size:.82rem;font-weight:700;line-height:1.25;color:var(--green-800)}
.trustbar>.container:not(.trustbar__grid){display:flex;align-items:center;justify-content:center;gap:.85rem 1.35rem;flex-wrap:wrap;padding-block:1rem}
.trustbar .ti{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:700;line-height:1.25;color:var(--green-800);white-space:nowrap}
.trustbar .ti svg{width:18px;height:18px;color:var(--gold-500)}
.trustbar .sep{width:1px;height:18px;background:var(--line)}
.trustbar .ti,.trustbar__item{animation:elFadeUp .7s cubic-bezier(.16,1,.3,1) both}
.trustbar .ti:nth-of-type(2),.trustbar__item:nth-child(2){animation-delay:.08s}
.trustbar .ti:nth-of-type(3),.trustbar__item:nth-child(3){animation-delay:.16s}
.trustbar .ti:nth-of-type(4),.trustbar__item:nth-child(4){animation-delay:.24s}
.trustbar .ti:nth-of-type(5),.trustbar__item:nth-child(5){animation-delay:.32s}
.trustbar .ti:nth-of-type(6),.trustbar__item:nth-child(6){animation-delay:.40s}
.trust-mark{display:inline-grid;place-items:center;flex:0 0 auto;min-width:42px;height:32px;padding:0 .55rem;
  border:1px solid rgba(212,171,76,.55);border-radius:7px;background:linear-gradient(180deg,rgba(231,207,143,.16),rgba(231,207,143,.07));
  color:var(--gold-300);font-size:.68rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;
  box-shadow:0 8px 18px rgba(0,0,0,.14),inset 0 0 0 1px rgba(255,255,255,.035)}
.trust-logo{width:40px;height:40px;object-fit:contain;border-radius:7px;background:#fff;padding:4px;
  box-shadow:0 8px 18px rgba(0,0,0,.18)}

/* ---------- cards ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;
  box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t),border-color var(--t);height:100%}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold-300)}
.card .ico{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;margin-bottom:1.1rem;
  background:linear-gradient(160deg,var(--green-100),#fff);border:1px solid var(--line);color:var(--green-700)}
.card .ico svg{width:26px;height:26px}
.card h3{margin-bottom:.45rem;font-size:1.28rem}
.card p{color:var(--ink-soft);margin-bottom:0;font-size:.98rem}
.card .num{font-family:var(--serif);font-size:2.4rem;color:var(--gold-500);font-weight:700;
  line-height:1;display:block;margin-bottom:.4rem}
.card--feature .num{color:var(--gold-600)}
.card--soft{background:var(--cream-2)}

/* grade tiles */
.grade-tile{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);height:100%;transition:var(--t)}
.grade-tile:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.grade-tile__top{padding:1.3rem 1.4rem;color:#fff;position:relative}
.grade-tile__top .g{font-family:var(--serif);font-size:1.45rem;font-weight:700}
.grade-tile__top .tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;opacity:.9;font-weight:700}
.gt-evoo{background:linear-gradient(135deg,#3a4a23,#566f31)}
.gt-virgin{background:linear-gradient(135deg,#4a5d2e,#6f8a3e)}
.gt-lampante{background:linear-gradient(135deg,#7a6a2a,#a8801f)}
.gt-refined{background:linear-gradient(135deg,#8a6d3a,#c8a24a)}
.gt-pomace{background:linear-gradient(135deg,#6b5b3a,#9a8455)}
.grade-tile__body{padding:1.2rem 1.4rem;flex:1}
.grade-tile__body ul{list-style:none;margin:0;padding:0;font-size:.92rem}
.grade-tile__body li{display:flex;justify-content:space-between;gap:1rem;padding:.4em 0;border-bottom:1px dashed var(--line)}
.grade-tile__body li:last-child{border-bottom:0}
.grade-tile__body li .k{color:var(--muted)}
.grade-tile__body li .v{font-weight:600;color:var(--green-800)}

/* steps */
.steps{counter-reset:step;display:grid;gap:1.2rem}
.steps.cols-4{grid-template-columns:repeat(4,1fr)}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem 1.4rem 1.4rem;box-shadow:var(--shadow-sm)}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-18px;inset-inline-start:1.4rem;
  width:40px;height:40px;border-radius:50%;background:var(--gold-600);color:var(--green-900);
  font-family:var(--serif);font-weight:700;font-size:1.25rem;display:grid;place-items:center;
  box-shadow:0 6px 14px rgba(168,128,31,.3)}
.step h3{margin:.7rem 0 .35rem;font-size:1.2rem}
.step p{color:var(--ink-soft);font-size:.95rem;margin:0}

/* tables */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
table.spec{width:100%;border-collapse:collapse;font-size:.95rem;min-width:560px;background:#fff}
table.spec th,table.spec td{padding:.95em 1.1em;text-align:start;border-bottom:1px solid var(--line)}
table.spec thead th{background:var(--green-800);color:#fff;font-family:var(--sans);font-weight:600;
  font-size:.82rem;letter-spacing:.05em;text-transform:uppercase}
table.spec tbody tr:nth-child(even){background:var(--cream-2)}
table.spec tbody tr:hover{background:var(--green-100)}
table.spec td .k{font-weight:600;color:var(--green-800)}

/* badges / pills */
.pill{display:inline-flex;align-items:center;gap:.4em;background:var(--green-100);color:var(--green-800);
  border-radius:999px;padding:.35em .85em;font-size:.8rem;font-weight:600;letter-spacing:.02em}
.pill--gold{background:#f6ecd2;color:var(--gold-700)}
.pill-row{display:flex;flex-wrap:wrap;gap:.55rem}

/* checklist */
.checks{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.checks li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink-soft)}
.checks li svg{width:22px;height:22px;flex:0 0 auto;color:var(--ok);margin-top:.12em}
.checks.two{grid-template-columns:1fr 1fr}

/* ---------- certifications grid ---------- */
.cert-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.cert{display:flex;flex-direction:column;gap:.6rem;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:1.3rem;text-align:center;align-items:center;box-shadow:var(--shadow-sm);
  transition:var(--t);height:100%}
.cert:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--gold-300)}
.cert__badge{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(160deg,var(--green-100),#fff);border:1px solid var(--line);color:var(--green-700)}
.cert__badge svg{width:32px;height:32px}
.cert h3{font-size:1.05rem;margin:0}
.cert p{font-size:.82rem;color:var(--muted);margin:0}
.cert .verify{margin-top:auto;font-size:.8rem;font-weight:700;color:var(--gold-700);
  display:inline-flex;align-items:center;gap:.3em}
.cert .verify svg{width:14px;height:14px}

/* awards strip */
.awards-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:1.35rem;align-items:stretch}
.award{display:flex;min-height:225px;flex-direction:column;align-items:center;justify-content:flex-start;
  text-align:center;padding:1.05rem .8rem .9rem;border:1px solid rgba(31,42,20,.08);border-radius:10px;
  background:linear-gradient(180deg,#fffdf7 0%,#f8f4ea 100%);box-shadow:0 12px 28px rgba(31,42,20,.07);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.award img{width:150px;height:150px;object-fit:contain;margin:0 auto .9rem;padding:0;border:0;border-radius:0;
  background:transparent;box-shadow:none;filter:contrast(1.08) saturate(1.08) drop-shadow(0 10px 16px rgba(31,42,20,.16));
  transition:transform var(--t),filter var(--t)}
.award:hover{transform:translateY(-4px);border-color:rgba(200,162,74,.28);box-shadow:0 18px 38px rgba(31,42,20,.12)}
.award:hover img{transform:scale(1.035);filter:contrast(1.12) saturate(1.12) drop-shadow(0 12px 18px rgba(31,42,20,.18))}
.award .t{max-width:19ch;margin:auto auto 0;font-size:.8rem;color:var(--muted);font-weight:700;line-height:1.28}

/* logo / cert verify strip (home) */
.verify-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:1.4rem 2.2rem;align-items:center}
.verify-strip a{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--green-800);
  font-size:.92rem;padding:.6em 1em;border:1px solid var(--line);border-radius:999px;background:#fff}
.verify-strip a:hover{border-color:var(--gold-400);color:var(--gold-700);box-shadow:var(--shadow-sm)}
.verify-strip a svg{width:18px;height:18px;color:var(--gold-600)}

/* split media */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split--rev .split__media{order:2}
.media-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.media-fill{aspect-ratio:4/3;border-radius:var(--radius);position:relative;overflow:hidden;
  box-shadow:var(--shadow);display:grid;place-items:center;color:#eef1e4;text-align:center;padding:2rem}
.media-fill.olive{background:radial-gradient(100% 100% at 30% 0%,rgba(212,175,55,.25),transparent 55%),
  linear-gradient(150deg,var(--green-800),#33421f)}
.media-fill:has(.media-asset){padding:0;background:var(--green-900)}
.media-asset{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.04) contrast(1.02)}
.media-fill:has(.media-asset)::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(31,42,20,0) 48%,rgba(31,42,20,.22) 100%);
  pointer-events:none}
.media-fill .ml{font-family:var(--serif);font-size:1.5rem;color:#fff}
.media-fill .ico-lg{width:84px;height:84px;color:var(--gold-300);margin-bottom:1rem}
.media-note{font-size:.78rem;color:var(--muted);margin-top:.6rem;text-align:center}

/* traceability chain */
.chain{display:grid;grid-template-columns:repeat(4,1fr);gap:0;counter-reset:c}
.chain__node{position:relative;text-align:center;padding:1.4rem 1rem}
.chain__node .dot{width:54px;height:54px;border-radius:50%;background:var(--green-800);color:#fff;
  display:grid;place-items:center;margin:0 auto .8rem;box-shadow:var(--shadow-sm)}
.chain__node .dot svg{width:26px;height:26px}
.chain__node:not(:last-child)::after{content:"";position:absolute;top:calc(1.4rem + 27px);inset-inline-start:50%;
  width:100%;height:2px;background:linear-gradient(90deg,var(--gold-500),var(--gold-300));z-index:0}
.chain__node h4{font-family:var(--serif);font-size:1.05rem;margin:0 0 .25rem}
.chain__node p{font-size:.85rem;color:var(--muted);margin:0}

/* FAQ */
.faq{display:grid;gap:.8rem;max-width:820px;margin-inline:auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm)}
.faq summary{list-style:none;cursor:pointer;padding:1.15em 1.4em;display:flex;justify-content:space-between;
  align-items:center;gap:1rem;font-weight:600;color:var(--green-800);font-family:var(--sans);font-size:1.02rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:0 0 auto;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--gold-500);
  position:relative;transition:var(--t)}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--gold-700);
  inset-inline-start:50%;top:50%;transform:translate(-50%,-50%)}
.faq summary .pm::before{width:11px;height:2px}.faq summary .pm::after{width:2px;height:11px;transition:var(--t)}
.faq details[open] summary .pm::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq details[open] summary .pm{background:var(--gold-500)}
.faq details[open] summary .pm::before{background:var(--green-900)}
.faq .ans{padding:0 1.4em 1.25em;color:var(--ink-soft);font-size:.97rem}

/* ---------- forms ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.4rem);
  box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field.full{grid-column:1/-1}
.field label{font-size:.83rem;font-weight:600;color:var(--green-800);letter-spacing:.02em}
.field label .req{color:var(--red-600)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:.97rem;color:var(--ink);
  background:var(--cream-2);border:1.5px solid var(--line);border-radius:10px;padding:.78em .9em;transition:var(--t);width:100%}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold-500);
  background:#fff;box-shadow:0 0 0 3px rgba(212,175,55,.18)}
.form-note{font-size:.82rem;color:var(--muted);margin-top:.4rem}
.form-success{display:none;background:var(--green-100);border:1px solid var(--green-600);border-radius:var(--radius);
  padding:1.2rem 1.4rem;color:var(--green-800);font-weight:600}
.form-success.show{display:block}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.83rem;color:var(--muted)}
.consent input{width:18px;height:18px;margin-top:.15em;accent-color:var(--green-700)}

/* info list contact */
.contact-detail{display:grid;gap:1.1rem}
.contact-detail .row{display:flex;gap:.9rem;align-items:flex-start}
.contact-detail .row .ic{width:42px;height:42px;border-radius:11px;background:var(--green-100);color:var(--green-700);
  display:grid;place-items:center;flex:0 0 auto}
.contact-detail .row .ic svg{width:20px;height:20px}
.contact-detail .row .k{font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700}
.contact-detail .row .v{color:var(--green-800);font-weight:600}
.contact-detail .row a.v:hover{color:var(--gold-700)}

/* callout / offer */
.offer{background:linear-gradient(150deg,var(--green-800),#33421f);color:#eef1e4;border-radius:20px;
  padding:clamp(2rem,5vw,3.4rem);position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.offer::after{content:"";position:absolute;inset-inline-end:-60px;top:-60px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,55,.3),transparent 70%)}
.offer h2,.offer h3{color:#fff}
.offer .lede{color:#d8dec8}
.offer .container,.offer>*{position:relative;z-index:2}

/* breadcrumb */
.crumb{font-size:.82rem;color:#c4ccb1;display:flex;gap:.5em;align-items:center;margin-bottom:1rem}
.crumb a{color:var(--gold-300)}.crumb a:hover{color:#fff}

/* ---------- footer ---------- */
.site-footer{background:var(--green-900);color:#b9c2a4;font-size:.92rem}
.footer-top{padding-block:clamp(3rem,5vw,4rem);border-bottom:1px solid rgba(255,255,255,.08)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem}
.footer-brand img{height:54px;margin-bottom:1rem}
.footer-brand p{color:#9aa585;font-size:.9rem;max-width:34ch}
.site-footer h4{color:#fff;font-family:var(--sans);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  margin:0 0 1rem;font-weight:700}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.site-footer ul a{color:#b9c2a4}.site-footer ul a:hover{color:var(--gold-300)}
.site-footer .cert-strip{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.site-footer .cert-strip .pill{background:rgba(255,255,255,.06);color:#cdd5ba;font-size:.72rem}
.footer-contact-row{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.7rem;color:#b9c2a4}
.footer-contact-row svg{width:17px;height:17px;color:var(--gold-500);flex:0 0 auto;margin-top:.2em}
.footer-bottom{padding-block:1.4rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.82rem;color:#8a957a}
.footer-bottom a{color:#8a957a}.footer-bottom a:hover{color:var(--gold-300)}

/* floating whatsapp */
.wa-float{position:fixed;inset-block-end:22px;inset-inline-end:22px;z-index:80;width:58px;height:58px;border-radius:50%;
  background:#25d366;display:grid;place-items:center;box-shadow:0 10px 26px rgba(37,211,102,.45);
  transition:var(--t);animation:waPulse 2.8s ease-in-out infinite}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;color:#fff}

/* scaffold (AR/CN) */
.scaffold{min-height:62vh;display:grid;place-items:center;text-align:center;padding:4rem 1rem}
.scaffold .inner{max-width:560px}
.scaffold img{height:84px;margin:0 auto 1.5rem}

/* misc utilities */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.divider{height:1px;background:var(--line);border:0;margin-block:0}
.text-gold{color:var(--gold-700)}
hr.rule{border:0;height:3px;width:60px;background:var(--gold-500);border-radius:3px;margin:0 0 1.4rem}
.center hr.rule{margin-inline:auto}
.reveal{opacity:0;transform:translateY(34px) scale(.985);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.hero-copy.reveal{opacity:1;transform:none}
.hero-copy .eyebrow,.hero-copy h1,.hero-copy .lede,.hero-copy .btn-row{opacity:0;animation:elFadeUp .9s cubic-bezier(.16,1,.3,1) both}
.hero-copy .eyebrow{animation-delay:.12s}
.hero-copy h1{animation-delay:.24s}
.hero-copy .lede{animation-delay:.38s}
.hero-copy .btn-row{animation-delay:.52s}
.reveal.in .card,.reveal.in .grade-tile,.reveal.in .step,.reveal.in .award,
.reveal.in .verify-strip a,.reveal.in .faq details,.reveal.in .checks li{
  animation:elFadeUp .75s cubic-bezier(.16,1,.3,1) both}
.reveal.in .grid>*:nth-child(2),.reveal.in .steps>*:nth-child(2),.reveal.in .awards-grid>*:nth-child(2),
.reveal.in .verify-strip>*:nth-child(2),.reveal.in .faq>*:nth-child(2),.reveal.in .checks>*:nth-child(2){animation-delay:.07s}
.reveal.in .grid>*:nth-child(3),.reveal.in .steps>*:nth-child(3),.reveal.in .awards-grid>*:nth-child(3),
.reveal.in .verify-strip>*:nth-child(3),.reveal.in .faq>*:nth-child(3),.reveal.in .checks>*:nth-child(3){animation-delay:.14s}
.reveal.in .grid>*:nth-child(4),.reveal.in .steps>*:nth-child(4),.reveal.in .awards-grid>*:nth-child(4),
.reveal.in .verify-strip>*:nth-child(4),.reveal.in .faq>*:nth-child(4),.reveal.in .checks>*:nth-child(4){animation-delay:.21s}
.reveal.in .grid>*:nth-child(5),.reveal.in .awards-grid>*:nth-child(5),.reveal.in .verify-strip>*:nth-child(5),
.reveal.in .faq>*:nth-child(5),.reveal.in .checks>*:nth-child(5){animation-delay:.28s}
.reveal.in .grid>*:nth-child(6),.reveal.in .awards-grid>*:nth-child(6),.reveal.in .verify-strip>*:nth-child(6),
.reveal.in .faq>*:nth-child(6),.reveal.in .checks>*:nth-child(6){animation-delay:.35s}

@keyframes elFadeUp{
  from{opacity:0;transform:translate3d(0,24px,0) scale(.985)}
  to{opacity:1;transform:none}
}
@keyframes headerDrop{
  from{opacity:0;transform:translateY(-18px)}
  to{opacity:1;transform:none}
}
@keyframes waPulse{
  0%,100%{box-shadow:0 10px 26px rgba(37,211,102,.45)}
  50%{box-shadow:0 10px 30px rgba(37,211,102,.32),0 0 0 12px rgba(37,211,102,.12)}
}

/* ---------- RTL ---------- */
[dir="rtl"]{direction:rtl}
[dir="rtl"] .primary-nav{margin-inline-start:auto}
[dir="rtl"] .hero h1{margin-inline-end:0}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-figure{order:-1;min-height:auto}
  .hero-figure .drop-card{width:min(100%,320px)}
  .trustbar__grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .cols-4,.cert-grid,.awards-grid{grid-template-columns:repeat(3,1fr)}
  .steps.cols-4{grid-template-columns:repeat(2,1fr)}
  .chain{grid-template-columns:repeat(2,1fr);gap:1rem}
  .chain__node:not(:last-child)::after{display:none}
  .split,.hero-grid{gap:2rem}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .primary-nav{position:fixed;inset:74px 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;
    gap:0;padding:.8rem 1.1rem 1.4rem;border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:var(--t);margin:0;max-height:calc(100vh - 74px);overflow:auto}
  .nav-open .primary-nav{transform:none;opacity:1;pointer-events:auto}
  .primary-nav a.navlink{padding:.85em .4em;border-bottom:1px solid var(--line-soft);border-radius:0}
  .primary-nav a.navlink.is-active::after{display:none}
  .nav-toggle{display:flex}
  .cols-2,.cols-3,.split,.hero-grid,.form-grid,.checks.two{grid-template-columns:1fr}
  .trustbar__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}
  .trustbar__item{min-height:54px;padding:.65rem .7rem}
  .split--rev .split__media{order:0}
  .cols-4,.cert-grid{grid-template-columns:1fr 1fr}
  .awards-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .brand-name{font-size:1.15rem}
  .header-actions .btn-cta-header{display:none}
  .hero h1{max-width:17ch}
  .hero .lede{max-width:100%}
  .hero--home .container{padding-inline:clamp(1.1rem,4vw,2rem)}
  .hero--home .hero-copy{padding-inline-start:0}
  body{font-size:16px}
}
@media(max-width:420px){
  .cols-4,.cert-grid,.awards-grid{grid-template-columns:1fr 1fr}
  .trustbar__grid{grid-template-columns:1fr}
  .hero-stats{gap:1.1rem}
  h1{font-size:clamp(2rem,12vw,2.65rem)}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal,.hero-copy .eyebrow,.hero-copy h1,.hero-copy .lede,.hero-copy .btn-row{opacity:1;transform:none;transition:none;animation:none!important}
  .hero-video-bg{transform:none!important}
}
