/* ============================================================
   PLH Logistik — Design System v3 "Klar"
   Clean & modern. Confident type, bold gold, strong photography,
   generous whitespace. No technical detailing, no serifs.
   Type: Plus Jakarta Sans (display) + Inter (body).
   Token-driven, framework-free. Shared by all pages.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* brand — kept from v1/v2 (palette loved) */
  --gold:#F2A900;
  --gold-bright:#FFC01E;
  --gold-deep:#8A5A00;

  /* dark */
  --ink:#12100B;
  --ink-2:#1C1A13;
  --ink-3:#26241A;
  --char:#3A362C;

  /* light */
  --paper:#FBF8F1;
  --paper-2:#F3EEE1;
  --line:#E4DCCA;
  --muted:#6B6455;
  --success:#3F7D4E;

  /* on-dark — legible links/text on dark (contrast fix kept) */
  --on-dark:#F3EEE1;
  --on-dark-muted:#C3BCAC;
  --link-dark:var(--gold-bright);
  --hair-dark:rgba(243,238,225,.12);

  /* type */
  --display:"Plus Jakarta Sans","Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  /* scale — bigger, more confident */
  --fs-eyebrow:.8rem;
  --fs-sm:.9rem;
  --fs-base:1.0625rem;
  --fs-lead:1.25rem;
  --fs-h3:1.4rem;
  --fs-h2:clamp(2rem,1.3rem + 2.8vw,3rem);
  --fs-h1:clamp(2.6rem,1.4rem + 5vw,4.6rem);

  /* layout — roomier */
  --container:1180px;
  --gutter:clamp(1.25rem,4.5vw,2.6rem);
  --radius:20px;
  --radius-sm:14px;

  /* soft depth (cards) */
  --shadow-sm:0 1px 2px rgba(18,16,11,.04),0 8px 24px -16px rgba(18,16,11,.22);
  --shadow-md:0 2px 4px rgba(18,16,11,.05),0 24px 48px -28px rgba(18,16,11,.34);

  /* motion */
  --ease:cubic-bezier(.2,.7,.2,1);
  --dur:.24s;
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  font-size:var(--fs-base);
  line-height:1.65;
  color:var(--char);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-family:var(--display);font-weight:800;line-height:1.08;
  letter-spacing:-.025em;color:var(--ink);overflow-wrap:break-word}
h1{font-size:var(--fs-h1);font-weight:800;letter-spacing:-.035em;line-height:1.02}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
p{margin:0 0 1rem}
ul{margin:0;padding:0;list-style:none}
strong,b{font-weight:700;color:var(--ink)}
.on-dark-block strong,.on-dark-block b{color:var(--paper)}
.tnum{font-variant-numeric:tabular-nums}

:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:6px}
.section-dark :focus-visible,.hero :focus-visible,.cta-band :focus-visible,
.site-footer :focus-visible{outline-color:var(--gold-bright)}

.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
/* grid/flex children may hold long compounds — allow shrink */
.pillar,.card,.why .item,.step,.aud-card,.split > *,.cta-inner > *,
.contact-grid > *,.formrow > *,.feature{min-width:0}
.center{text-align:center}
.measure{max-width:60ch}
.measure-sm{max-width:46ch}

/* section rhythm — generous */
.section{padding-block:clamp(4rem,9vw,8rem)}
.section-soft{background:var(--paper-2)}
.section-dark{background:var(--ink);color:var(--on-dark)}
.section-dark h1,.section-dark h2,.section-dark h3,.section-dark h4{color:var(--paper)}
.section-dark p{color:var(--on-dark)}
.lead{font-size:var(--fs-lead);line-height:1.6;color:var(--char)}
.section-dark .lead{color:var(--on-dark)}
.muted{color:var(--muted)}
.section-dark .muted{color:var(--on-dark-muted)}

/* ---------- Eyebrow — small friendly label ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--display);font-weight:700;
  font-size:var(--fs-eyebrow);letter-spacing:.02em;
  color:var(--gold-deep);margin:0 0 1.1rem;
}
.eyebrow::before{content:"";width:22px;height:3px;border-radius:3px;background:var(--gold);flex:none}
.section-dark .eyebrow,.hero .eyebrow,.cta-band .eyebrow{color:var(--gold-bright)}

/* ---------- Buttons ---------- */
.btn{
  --_bg:var(--gold);--_fg:var(--ink);--_bd:var(--gold);
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  min-height:52px;padding:.8rem 1.6rem;
  font-family:var(--display);font-weight:700;font-size:1rem;letter-spacing:-.01em;
  color:var(--_fg);background:var(--_bg);border:0;
  box-shadow:inset 0 0 0 1.5px var(--_bd);
  border-radius:999px;cursor:pointer;
  transition:transform var(--dur) var(--ease),background var(--dur) var(--ease),
    box-shadow var(--dur) var(--ease),color var(--dur) var(--ease);
}
.btn svg{width:19px;height:19px;flex:none}
.btn:hover{transform:translateY(-2px)}
.btn-gold{--_bg:var(--gold);--_fg:#1A1305;--_bd:var(--gold);
  box-shadow:0 8px 20px -8px rgba(242,169,0,.65)}
.btn-gold:hover{--_bg:var(--gold-bright);box-shadow:0 14px 30px -10px rgba(242,169,0,.8)}
.btn-dark{--_bg:var(--ink);--_fg:var(--paper);--_bd:var(--ink)}
.btn-dark:hover{--_bg:#241f14}
.btn-ghost{--_bg:transparent;--_fg:var(--ink);--_bd:var(--line)}
.btn-ghost:hover{--_bd:var(--ink)}
.section-dark .btn-ghost,.hero .btn-ghost,.cta-band .btn-ghost{
  --_fg:var(--paper);--_bd:rgba(243,238,225,.35)}
.section-dark .btn-ghost:hover,.hero .btn-ghost:hover,.cta-band .btn-ghost:hover{
  --_bd:var(--gold-bright);--_fg:var(--gold-bright)}
.btn-lg{min-height:58px;padding:.9rem 1.9rem;font-size:1.075rem}

/* text link with arrow */
.more{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--display);
  font-weight:700;color:var(--gold-deep);font-size:1rem}
.more svg{width:18px;height:18px;transition:transform var(--dur) var(--ease)}
.section-dark .more,.hero .more,.cta-band .more{color:var(--gold-bright)}
.more:hover svg{transform:translateX(4px)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:sticky;top:0;z-index:100;
  background:rgba(251,248,241,.92);backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--line);
  transition:background-color .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease)}
.site-header.on-dark{background:rgba(10,9,6,.78);border-bottom-color:transparent}
.nav{display:flex;align-items:center;gap:1.5rem;min-height:78px}
.brand{display:inline-flex;align-items:center;gap:.65rem;font-family:var(--display);
  font-size:1.35rem;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.brand .mark{width:32px;height:auto;flex:none}
.on-dark .brand{color:var(--paper)}
.brand b{color:var(--gold)}
.on-dark .brand b{color:var(--gold-bright)}
.nav-spacer{flex:1}
.nav-links{display:flex;align-items:center;gap:1.9rem}
.nav-links a.link{font-family:var(--display);font-weight:600;font-size:1rem;
  color:var(--char);padding:.4rem 0;position:relative}
.on-dark .nav-links a.link{color:#DED8CA}
.nav-links a.link::after{content:"";position:absolute;left:0;bottom:-4px;height:2px;width:0;
  border-radius:2px;background:var(--gold);transition:width var(--dur) var(--ease)}
.nav-links a.link:hover::after,.nav-links a.link[aria-current="page"]::after{width:100%}
.nav-links a.link:hover{color:var(--ink)}
.on-dark .nav-links a.link:hover{color:#fff}
.nav-actions{display:flex;align-items:center;gap:.7rem}
.tel-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);
  font-weight:700;font-size:1rem;color:var(--ink);padding:.5rem .4rem}
.on-dark .tel-btn{color:var(--paper)}
.tel-btn svg{width:18px;height:18px;color:var(--gold-deep)}
.on-dark .tel-btn svg{color:var(--gold-bright)}

/* mobile nav */
.nav-toggle{display:none}
.nav-toggle-label{display:none;flex-direction:column;gap:5px;width:46px;height:46px;
  align-items:center;justify-content:center;cursor:pointer;border-radius:14px;
  background:rgba(18,16,11,.05)}
.on-dark .nav-toggle-label{background:rgba(243,238,225,.1)}
.nav-toggle-label span{width:20px;height:2px;background:var(--ink);border-radius:2px}
.on-dark .nav-toggle-label span{background:var(--paper)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center 42%}
.hero-scrim{position:absolute;inset:0;
  background:
    linear-gradient(100deg,rgba(12,10,7,.92) 0%,rgba(12,10,7,.72) 46%,rgba(12,10,7,.28) 100%),
    linear-gradient(0deg,rgba(12,10,7,.82) 0%,transparent 48%)}
.hero .container{position:relative;z-index:2}
.hero-inner{padding-block:clamp(4rem,11vw,8rem);min-height:min(82vh,720px);
  display:flex;flex-direction:column;justify-content:center}
.hero h1{color:#fff;max-width:15ch;margin-bottom:1.4rem}
.hero .accent{color:var(--gold)}
.hero .lead{color:#EDE7D9;max-width:52ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.2rem}
.hero-sub{display:flex;flex-wrap:wrap;gap:1rem 2.2rem;margin-top:2.6rem}
.hero-sub span{display:inline-flex;align-items:center;gap:.55rem;font-size:1rem;
  font-weight:500;color:#E4DDCE}
.hero-sub svg{width:20px;height:20px;color:var(--gold-bright);flex:none}

/* ============================================================
   TWO PILLARS — clean soft cards
   ============================================================ */
.pillars{display:grid;gap:1.8rem;grid-template-columns:1fr}
.pillar{position:relative;display:flex;flex-direction:column;
  border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pillar-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.pillar-media img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease)}
.pillar:hover .pillar-media img{transform:scale(1.05)}
.pillar-tag{position:absolute;top:16px;left:16px;z-index:2;
  display:inline-flex;align-items:center;gap:.4rem;
  background:var(--gold);color:#1A1305;font-family:var(--display);font-weight:700;font-size:.85rem;
  padding:.4rem .85rem;border-radius:999px}
.pillar-body{padding:1.9rem 2rem 2.1rem;display:flex;flex-direction:column;flex:1}
.pillar-body h3{font-size:clamp(1.5rem,1.1rem + 1.3vw,2rem);margin-bottom:.6rem}
.pillar-body .sub{color:var(--gold-deep);font-family:var(--display);font-weight:700;
  font-size:.95rem;margin-bottom:.7rem}
.pillar-body > p{color:var(--char)}
.pillar-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:.6rem 0 1.5rem}
.pillar-list li{font-size:.9rem;font-weight:500;color:var(--char);
  background:var(--paper-2);padding:.4rem .85rem;border-radius:999px}
.pillar-body .more{margin-top:auto}
.pillar:hover .more svg{transform:translateX(4px)}
/* flagship = gentle gold wash, no hard spine */
.pillar.flagship .pillar-body{background:linear-gradient(180deg,#FFFDF7,#fff)}

/* ============================================================
   SERVICE CARDS GRID — clean soft cards, gold icon tiles
   ============================================================ */
.grid{display:grid;gap:1.6rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{position:relative;display:flex;flex-direction:column;
  padding:2rem 1.9rem;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.card-link:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card .ico{display:inline-flex;width:56px;height:56px;align-items:center;justify-content:center;
  border-radius:16px;background:var(--paper-2);color:var(--gold-deep);
  margin-bottom:1.3rem;transition:background var(--dur),color var(--dur),transform var(--dur)}
.card .ico svg{width:27px;height:27px}
.card-link:hover .ico{background:var(--gold);color:#1A1305;transform:scale(1.05)}
.card h3{font-size:1.3rem;margin-bottom:.55rem}
.card p{font-size:1rem;color:var(--muted);margin-bottom:1.3rem}
.card .more{margin-top:auto;font-size:.98rem}
.card-link:hover .more svg{transform:translateX(4px)}

/* ============================================================
   WHY-US strengths grid — light, borderless
   ============================================================ */
.why{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.why .item{padding:1.7rem 1.6rem;border-radius:var(--radius);background:#fff;
  box-shadow:var(--shadow-sm)}
.why .ico{width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:15px;background:var(--paper-2);color:var(--gold-deep);margin-bottom:1.1rem}
.why .ico svg{width:25px;height:25px}
.why h3{font-size:1.2rem;margin-bottom:.45rem}
.why p{font-size:.98rem;color:var(--muted);margin:0}

/* ============================================================
   QUOTE / social proof — big clean pull-quote
   ============================================================ */
.quote{position:relative;margin:0;padding:0;
  font-family:var(--display);font-weight:700;
  font-size:clamp(1.5rem,1.1rem + 1.8vw,2.3rem);line-height:1.28;
  color:var(--ink);letter-spacing:-.025em}
.quote::before{content:"";display:block;width:48px;height:5px;border-radius:5px;
  background:var(--gold);margin-bottom:1.6rem}
.quote-cite{margin-top:1.3rem;font-size:1rem;color:var(--muted);font-weight:500}
.logo-row{display:flex;flex-wrap:wrap;gap:1.2rem 1.8rem;align-items:center;margin-top:1.8rem}
.logo-row .ph{height:44px;min-width:130px;border-radius:14px;background:var(--paper-2);
  display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--muted);
  font-weight:500}

/* ============================================================
   TRUST FACTS BAND (dark) — clean, no grid lines
   ============================================================ */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.fact{background:var(--ink-2);padding:1.9rem 1.7rem;border-radius:var(--radius);
  display:flex;flex-direction:column;gap:.5rem}
.fact .n{font-family:var(--display);font-weight:800;font-size:2.7rem;line-height:1;
  color:var(--gold-bright);letter-spacing:-.04em;font-variant-numeric:tabular-nums}
.fact .t{font-weight:700;color:var(--paper);font-size:1.05rem}
.fact .d{font-size:.92rem;color:var(--on-dark-muted)}

/* ============================================================
   SPLIT (media + text) — shared
   ============================================================ */
.split{display:grid;gap:clamp(2rem,5vw,4rem);align-items:center;grid-template-columns:1fr}
.split.reverse .split-media{order:-1}
.split-media{border-radius:var(--radius);overflow:hidden;position:relative;
  box-shadow:var(--shadow-md)}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;display:block}
.split-media .badge{position:absolute;left:18px;bottom:18px;
  display:inline-flex;align-items:center;gap:.5rem;background:rgba(18,16,11,.86);
  backdrop-filter:blur(6px);color:var(--paper);
  font-family:var(--display);font-weight:600;font-size:.92rem;
  padding:.6rem 1rem;border-radius:999px}
.split-media .badge svg{width:18px;height:18px;color:var(--gold-bright)}

/* checklist — clean, gold check tiles */
.checklist{display:flex;flex-direction:column;gap:1.1rem;margin:1.5rem 0}
.checklist li{display:flex;gap:.85rem;align-items:flex-start;font-size:1.05rem;line-height:1.5}
.checklist li > svg{width:26px;height:26px;flex:none;color:var(--gold-deep);margin-top:1px}
.section-dark .checklist li > svg,.aud-card.dark .checklist li > svg{color:var(--gold-bright)}
.checklist li b{display:block;margin-bottom:.1rem}
.checklist li span.d{color:var(--muted);font-weight:400;font-size:1rem}
.section-dark .checklist li span.d,.aud-card.dark .checklist li span.d{color:var(--on-dark-muted)}

/* ============================================================
   SERVICE PAGE — clean feature list (no datasheet)
   ============================================================ */
.features{display:grid;grid-template-columns:1fr;gap:1.6rem}
.feature{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);
  padding:1.8rem 1.8rem}
.feature .ico{width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:15px;background:var(--paper-2);color:var(--gold-deep);margin-bottom:1.1rem}
.feature .ico svg{width:25px;height:25px}
.feature h3{font-size:1.25rem;margin-bottom:.5rem}
.feature p{margin:0;color:var(--muted);font-size:1rem}

/* ============================================================
   PROCESS — 4-step, clean big numbers (real sequence)
   ============================================================ */
.steps{display:grid;grid-template-columns:1fr;gap:1.6rem;counter-reset:st}
.step{position:relative;counter-increment:st;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);
  padding:1.8rem 1.7rem}
.section-dark .step{background:var(--ink-2);box-shadow:none}
.step .n{font-family:var(--display);font-weight:800;font-size:1.15rem;
  color:#1A1305;background:var(--gold);width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;
  font-variant-numeric:tabular-nums}
.step h3{font-size:1.2rem;margin-bottom:.45rem}
.step p{font-size:1rem;color:var(--muted);margin:0}
.section-dark .step p{color:var(--on-dark-muted)}

/* ============================================================
   AUDIENCE cards (service page) — clean soft
   ============================================================ */
.audience{display:grid;grid-template-columns:1fr;gap:1.8rem}
.aud-card{padding:2.2rem;border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;min-width:0}
.aud-card.dark{background:var(--ink);color:var(--on-dark)}
.aud-card.dark h3{color:var(--paper)}
.aud-card.dark p{color:var(--on-dark)}
.aud-card .tag{display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--display);font-weight:700;font-size:.95rem;
  color:var(--gold-deep);margin-bottom:1rem}
.aud-card.dark .tag{color:var(--gold-bright)}
.aud-card .tag svg{width:20px;height:20px}
.aud-card h3{font-size:1.55rem;margin-bottom:.7rem}
.aud-card .btn,.aud-card .more{margin-top:auto}

/* ============================================================
   CTA band (dark) — bold clean
   ============================================================ */
.cta-band{background:var(--ink);color:var(--on-dark);position:relative;overflow:hidden}
.cta-band .container{position:relative;z-index:2}
.cta-glow{position:absolute;right:-8%;top:-40%;width:56%;height:180%;
  background:radial-gradient(closest-side,rgba(242,169,0,.26),transparent 70%);pointer-events:none}
.cta-inner{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center}
.cta-inner h2{color:#fff;max-width:16ch;margin-bottom:.7rem}
.cta-inner p{color:#EDE7D9;margin:0;max-width:46ch}
.cta-actions{display:flex;flex-direction:column;align-items:flex-start;gap:1.3rem}
.cta-phone{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--display);
  font-weight:800;font-size:clamp(1.5rem,1.1rem + 1.5vw,2.1rem);color:var(--gold-bright);
  letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.cta-phone svg{width:24px;height:24px}
.cta-row{display:flex;gap:.8rem;flex-wrap:wrap}

/* ============================================================
   CONTACT PAGE — form
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,3.6rem);align-items:start}
.contact-aside .eyebrow{margin-top:0}
.contact-cards{display:flex;flex-direction:column;gap:1rem;margin-top:1.8rem}
.contact-card{display:flex;gap:1rem;align-items:flex-start;
  border-radius:var(--radius-sm);background:#fff;box-shadow:var(--shadow-sm);padding:1.2rem 1.3rem}
.contact-card .ico{width:46px;height:46px;flex:none;border-radius:14px;
  display:flex;align-items:center;justify-content:center;background:var(--paper-2);
  color:var(--gold-deep)}
.contact-card .ico svg{width:22px;height:22px}
.contact-card .k{font-size:.85rem;color:var(--muted);margin-bottom:.15rem}
.contact-card .v{font-family:var(--display);font-weight:700;color:var(--ink);font-size:1.1rem}
.contact-card a.v:hover{color:var(--gold-deep)}
.contact-hours{margin-top:1.6rem;font-size:.98rem;color:var(--muted);
  background:var(--paper-2);border-radius:var(--radius-sm);padding:1.3rem 1.4rem}
.contact-hours b{color:var(--ink);font-family:var(--display);font-weight:700}

/* form card */
.formcard{border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-md);overflow:hidden}
.formcard .fhead{background:var(--ink);color:var(--paper);padding:1.4rem clamp(1.4rem,3vw,2rem)}
.formcard .fhead .t{font-family:var(--display);font-weight:800;font-size:1.3rem;letter-spacing:-.02em}
.formcard .fhead .s{color:var(--on-dark-muted);font-size:.98rem;margin-top:.2rem}
.formcard form{padding:clamp(1.5rem,3vw,2.2rem)}
.formrow{display:grid;grid-template-columns:1fr;gap:1.2rem;margin-bottom:1.2rem}
@media(min-width:600px){.formrow.two{grid-template-columns:1fr 1fr}}
.formfield{display:flex;flex-direction:column;gap:.5rem}
.formfield label{font-family:var(--display);font-size:.98rem;font-weight:600;color:var(--ink);
  display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}
.formfield label .req{color:var(--gold-deep)}
.formfield label .opt{color:var(--muted);font-weight:400;font-size:.88rem}
.formfield input,.formfield select,.formfield textarea{
  font-family:var(--body);font-size:1.0625rem;color:var(--ink);
  background:var(--paper);border:1.5px solid transparent;border-radius:14px;
  padding:.85rem 1rem;min-height:52px;width:100%;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),
    background var(--dur) var(--ease)}
.formfield textarea{min-height:140px;resize:vertical;line-height:1.5}
.formfield select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%238A5A00' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.6rem}
.formfield input:hover,.formfield select:hover,.formfield textarea:hover{background:#fff;border-color:var(--line)}
.formfield input:focus,.formfield select:focus,.formfield textarea:focus{
  outline:none;border-color:var(--gold);background:#fff;
  box-shadow:0 0 0 4px rgba(242,169,0,.18)}
.formfield .hint{font-size:.9rem;color:var(--muted)}
.formfield .cnt{font-size:.85rem;color:var(--muted);font-variant-numeric:tabular-nums}
.form-consent{display:flex;gap:.7rem;align-items:flex-start;margin:.4rem 0 1.4rem;
  font-size:.95rem;color:var(--muted)}
.form-consent input{width:22px;height:22px;min-height:0;flex:none;margin-top:2px;accent-color:var(--gold-deep)}
.form-consent a{color:var(--gold-deep);text-decoration:underline}
.form-submit{display:flex;flex-wrap:wrap;gap:1.1rem;align-items:center}
.form-submit .note{font-size:.92rem;color:var(--muted);display:inline-flex;align-items:center;gap:.45rem}
.form-submit .note svg{width:17px;height:17px;color:var(--gold-deep)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:var(--on-dark-muted);padding-block:4rem 1.8rem}
.foot-grid{display:grid;grid-template-columns:1fr;gap:2.4rem;padding-bottom:2.6rem}
.foot-brand{display:inline-flex;align-items:center;gap:.65rem;font-family:var(--display);
  font-size:1.35rem;font-weight:800;color:var(--paper)}
.foot-brand .mark{width:32px}
.foot-brand b{color:var(--gold-bright)}
.site-footer h4{font-family:var(--display);font-size:1rem;color:var(--paper);
  margin:0 0 1.1rem;font-weight:700}
.foot-links{display:flex;flex-direction:column;gap:.65rem}
.foot-links a{font-size:1rem;color:var(--on-dark-muted)}
.foot-links a:hover{color:var(--gold-bright)}
.foot-contact{display:flex;flex-direction:column;gap:.95rem}
.foot-contact li{display:flex;gap:.75rem;align-items:flex-start;font-size:1rem;color:var(--on-dark)}
.foot-contact svg{width:20px;height:20px;color:var(--gold-bright);flex:none;margin-top:2px}
.foot-contact a{color:var(--on-dark)}
.foot-contact a:hover{color:var(--gold-bright)}
.foot-bottom{display:flex;flex-wrap:wrap;gap:.7rem 1.4rem;justify-content:space-between;
  padding-top:1.8rem;margin-top:.4rem;border-top:1px solid var(--hair-dark);font-size:.92rem}
.foot-bottom a{color:var(--on-dark-muted)}
.foot-bottom a:hover{color:var(--gold-bright)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(min-width:721px){
  .pillars{grid-template-columns:1.1fr 1fr}
  .split{grid-template-columns:1fr 1fr}
  .audience{grid-template-columns:1fr 1fr}
  .features{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:.85fr 1.15fr}
  .cta-inner{grid-template-columns:1.25fr 1fr}
  .cta-actions{align-items:flex-start}
  .steps{grid-template-columns:repeat(4,1fr)}
  .foot-grid{grid-template-columns:1.6fr 1fr 1.2fr}
}
@media(max-width:960px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .why{grid-template-columns:repeat(2,1fr)}
  .facts{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
  .nav-links,.nav-actions .tel-btn span{display:none}
  .nav-toggle-label{display:flex}
  .nav{position:relative}
  .nav-toggle:checked ~ .nav-links{
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    position:absolute;left:0;right:0;top:100%;
    background:var(--paper);padding:.5rem var(--gutter) 1.4rem;z-index:99;
    box-shadow:var(--shadow-md);border-radius:0 0 20px 20px}
  .on-dark .nav-toggle:checked ~ .nav-links{background:var(--ink)}
  .nav-toggle:checked ~ .nav-links a.link{padding:1rem 0;border-bottom:1px solid var(--line)}
  .on-dark .nav-toggle:checked ~ .nav-links a.link{border-color:var(--hair-dark)}
  .nav-toggle:checked ~ .nav-links .nav-cta{padding-top:1.1rem}
  .nav-toggle:checked ~ .nav-links .btn{width:100%}
}
@media(max-width:560px){
  .grid-3,.why,.facts{grid-template-columns:1fr}
  .hero-actions .btn,.cta-row .btn{flex:1 1 auto}
}

/* ---------- Motion / a11y ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important;
    scroll-behavior:auto !important}
  .btn:hover,.pillar:hover,.card-link:hover,.pillar:hover .pillar-media img{transform:none}
}
.skip{position:absolute;left:-999px;top:0;background:var(--gold);color:#1A1305;
  padding:.7rem 1.1rem;border-radius:12px;font-family:var(--display);font-weight:700;z-index:200}
.skip:focus{left:12px;top:12px}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}
