/* ============================================================================
   Cleanmachines.eu — PoC design system  ·  "Tweede leven"
   Industrial-premium, honest. Charcoal ink + off-white, teal-green primary
   (circular / second-life, not the usual cleaning-blue), amber savings accent.
   Space Grotesk (display) + Hanken Grotesk (body). Self-hosted, latin subset.

   SECTION MAP
   01  Tokens (:root)
   02  Reset / base
   03  Typography
   04  Layout helpers (.wrap, .section, eyebrow, lead)
   05  Buttons
   06  Header / nav / topbar
   07  Hero
   08  Proof band (counters + brands)
   09  Reframe (uptime is the product)
   10  Offer (3-tier comparison)
   11  How it works (4 steps)
   12  Services
   13  Founder
   14  Applications
   15  CTA / contact
   16  Footer
   17  Reveal / motion / a11y
   ========================================================================== */

/* 01 ── Tokens ───────────────────────────────────────────────────────────── */
:root{
  --ink:#14191b;          /* near-black charcoal */
  --ink-soft:#384247;
  --muted:#5d686d;
  --line:#e3e6e2;
  --paper:#f5f7f4;        /* off-white, faintly cool */
  --surface:#ffffff;
  --panel:#eef1ec;        /* light machine-grey panel */

  --teal:#0c8f6b;         /* primary — circular, trustworthy */
  --teal-dk:#097355;
  --teal-soft:#e4f3ee;
  --amber:#f3a626;        /* savings / highlight — beacon amber */
  --amber-dk:#cf8410;
  --red:#d23030;          /* used sparingly (their machines) */

  --radius:16px;
  --radius-sm:11px;
  --shadow:0 1px 2px rgba(20,25,27,.05), 0 10px 30px -12px rgba(20,25,27,.18);
  --shadow-lg:0 30px 70px -30px rgba(20,25,27,.40);

  --maxw:1180px;
  --gap:clamp(1.1rem,3vw,2rem);
  --sans:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --disp:"Space Grotesk",var(--sans);
}

/* 02 ── Reset / base ─────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
:focus-visible{outline:3px solid var(--teal);outline-offset:3px;border-radius:4px}

/* 03 ── Typography ───────────────────────────────────────────────────────── */
h1,h2,h3,.disp{font-family:var(--disp);font-weight:700;line-height:1.05;letter-spacing:-.02em;overflow-wrap:break-word}
h1{font-size:clamp(2.05rem,6vw,4.1rem)}
h2{font-size:clamp(1.75rem,4vw,2.85rem);letter-spacing:-.025em}
h3{font-size:clamp(1.15rem,2.2vw,1.4rem);letter-spacing:-.01em;line-height:1.15}
p{color:var(--ink-soft)}
strong{font-weight:700;color:var(--ink)}
.amber-text{color:var(--amber-dk)}
.teal-text{color:var(--teal-dk)}

/* 04 ── Layout helpers ───────────────────────────────────────────────────── */
.wrap{width:min(var(--maxw),100% - 2.4rem);margin-inline:auto}
.section{padding:clamp(3.4rem,8vw,6.2rem) 0}
.eyebrow{
  font-family:var(--disp);font-weight:600;font-size:.82rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--teal-dk);display:inline-flex;align-items:center;gap:.55rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--teal);border-radius:2px}
.lead{font-size:clamp(1.05rem,1.7vw,1.28rem);color:var(--ink-soft);max-width:60ch}
.center{text-align:center}
.center .lead{margin-inline:auto}
.section-head{max-width:62ch;margin-bottom:clamp(1.8rem,4vw,2.8rem)}
.section-head.center{margin-inline:auto}
.section-head h2{margin:.7rem 0 .9rem}

/* 05 ── Buttons ──────────────────────────────────────────────────────────── */
.btn{
  --bg:var(--teal);--fg:#fff;
  display:inline-flex;align-items:center;gap:.55rem;justify-content:center;
  font-family:var(--disp);font-weight:600;font-size:1rem;letter-spacing:-.01em;
  padding:.92rem 1.5rem;border-radius:999px;background:var(--bg);color:var(--fg);
  border:1.5px solid transparent;cursor:pointer;transition:transform .18s,box-shadow .18s,background .18s;
  box-shadow:0 8px 22px -10px rgba(12,143,107,.6);
}
.btn:hover{transform:translateY(-2px);background:var(--teal-dk)}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(3px)}
.btn--amber{--bg:var(--amber);--fg:#231a05;box-shadow:0 8px 22px -10px rgba(243,166,38,.7);font-weight:700}
.btn--amber:hover{background:var(--amber-dk)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line);box-shadow:none}
.btn--ghost:hover{background:var(--surface);border-color:var(--ink);transform:translateY(-2px)}
.btn--ink{--bg:var(--ink);--fg:#fff;box-shadow:0 8px 22px -12px rgba(20,25,27,.7)}
.btn--ink:hover{background:var(--teal-dk)}
.btn--lg{padding:1.05rem 1.8rem;font-size:1.06rem}
.btn--block{width:100%}

/* 06 ── Header / nav / topbar ────────────────────────────────────────────── */
.topbar{
  background:var(--ink);color:#aeb7b4;font-size:.84rem;
  font-family:var(--disp);font-weight:500;letter-spacing:.01em;
}
.topbar .wrap{display:flex;gap:.5rem 1.6rem;align-items:center;justify-content:space-between;flex-wrap:wrap;padding-block:.5rem}
.topbar .slog{line-height:1.38}
.topbar b{color:#fff}
.topbar .wa{color:#fff;display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap}
.topbar .wa:hover{color:var(--amber)}
.topbar .wa svg{color:#3ec39b}
@media(max-width:560px){
  .topbar .wrap{justify-content:center;text-align:center;gap:.4rem}
  .topbar .slog{width:100%}
}

header.site{
  position:sticky;top:0;z-index:60;background:rgba(245,247,244,.82);
  backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid transparent;transition:border-color .2s,box-shadow .2s;
}
header.site.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 20px -16px rgba(20,25,27,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:70px;gap:1rem}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--disp);font-weight:700;font-size:1.24rem;letter-spacing:-.03em}
.brand .mark{width:34px;height:34px;flex:none}
.brand .eu{color:var(--teal-dk)}
.nav-links{display:flex;gap:.3rem;align-items:center}
.nav-links a{font-family:var(--disp);font-weight:500;font-size:.96rem;padding:.5rem .8rem;border-radius:8px;color:var(--ink-soft);transition:color .15s,background .15s}
.nav-links a:hover{color:var(--ink);background:rgba(255,255,255,.7)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.lang{font-family:var(--disp);font-weight:600;font-size:.85rem;color:var(--muted);background:none;border:1px solid var(--line);padding:.4rem .7rem;border-radius:999px;cursor:pointer}
.lang:hover{border-color:var(--ink);color:var(--ink)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.5rem}
.burger span{width:24px;height:2.4px;background:var(--ink);border-radius:2px;transition:.25s}
.burger.open span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}

@media(max-width:900px){
  .nav-links{
    position:fixed;top:0;right:0;left:auto;
    width:min(82vw,330px);height:100vh;height:100dvh;
    background:var(--surface);
    flex-direction:column;align-items:stretch;gap:.2rem;padding:5.5rem 1.4rem 2rem;
    overflow-y:auto;box-shadow:var(--shadow-lg);
    opacity:0;visibility:hidden;transform:translateX(-12px);
    transition:opacity .26s ease,visibility .26s ease,transform .26s ease;
  }
  .nav-links.open{opacity:1;visibility:visible;transform:none}
  .nav-links a{font-size:1.1rem;padding:.85rem .8rem;border-bottom:1px solid var(--line);border-radius:0}
  .burger{display:flex;z-index:70}
  .nav-cta .btn{display:none}
  .scrim{position:fixed;inset:0;background:rgba(20,25,27,.45);opacity:0;visibility:hidden;transition:.3s;z-index:55}
  .scrim.show{opacity:1;visibility:visible}
}

/* 07 ── Hero ─────────────────────────────────────────────────────────────── */
.hero{position:relative;padding:clamp(2.6rem,6vw,4.6rem) 0 clamp(2rem,5vw,3.2rem)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.4rem);align-items:center}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;background:var(--teal-soft);color:var(--teal-dk);
  font-family:var(--disp);font-weight:600;font-size:.84rem;letter-spacing:.02em;
  padding:.42rem .85rem;border-radius:999px;margin-bottom:1.2rem;
}
.hero-badge .pulse{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(12,143,107,.5);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(12,143,107,.45)}70%{box-shadow:0 0 0 9px rgba(12,143,107,0)}100%{box-shadow:0 0 0 0 rgba(12,143,107,0)}}
.hero h1{margin-bottom:1.1rem}
.hero h1 .hl{color:var(--teal-dk);position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.16em;background:var(--amber);opacity:.55;border-radius:3px;z-index:-1}
.hero p.lead{margin-bottom:1.7rem}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.7rem}
.hero-assure{display:flex;gap:1.3rem;flex-wrap:wrap;color:var(--muted);font-size:.92rem;font-family:var(--disp);font-weight:500}
.hero-assure span{display:inline-flex;align-items:center;gap:.45rem}
.hero-assure svg{color:var(--teal)}

.hero-visual{position:relative}
.hero-card{
  position:relative;background:linear-gradient(160deg,#ffffff,var(--panel));
  border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow-lg);border:1px solid #fff;
}
.hero-card img{border-radius:11px;width:100%;aspect-ratio:1/1;object-fit:contain;mix-blend-mode:multiply}
.hero-save{
  position:absolute;right:-12px;top:-16px;background:var(--amber);color:#231a05;
  font-family:var(--disp);font-weight:700;text-align:center;line-height:1;
  width:104px;height:104px;border-radius:50%;display:grid;place-content:center;
  box-shadow:0 16px 32px -12px rgba(243,166,38,.8);rotate:8deg;
}
.hero-save b{font-size:1.9rem;display:block}
.hero-save small{font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;opacity:.8;margin-top:.2rem;display:block}
.hero-tag{
  position:absolute;left:-10px;bottom:18px;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;padding:.7rem .9rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.6rem;
  font-family:var(--disp);font-weight:600;font-size:.9rem;max-width:74%;
}
.hero-tag .ic{width:34px;height:34px;flex:none;border-radius:9px;background:var(--teal-soft);color:var(--teal-dk);display:grid;place-content:center}
.hero-tag small{display:block;font-family:var(--sans);font-weight:400;color:var(--muted);font-size:.78rem}

@media(max-width:820px){
  .hero{padding-top:1.8rem}
  .hero-grid{grid-template-columns:1fr;gap:2rem}
  .hero-visual{max-width:420px;margin:.4rem auto 0}   /* copy first, image after */
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%}
  .hero-assure{gap:.55rem;flex-direction:column}
  .hero-card{padding:1.1rem}
  .hero-save{width:74px;height:74px;right:6px;top:-10px}
  .hero-save b{font-size:1.3rem}.hero-save small{font-size:.58rem}
  /* tag no longer floats over the photo: sits below it inside the card */
  .hero-tag{position:static;left:auto;bottom:auto;max-width:100%;margin-top:1rem}
}
/* keep the eyebrow pill on one line on phones (scales down, never wraps) */
@media(max-width:560px){
  .hero-badge{white-space:nowrap;font-size:clamp(.58rem,2.9vw,.82rem);padding:.4rem .7rem;gap:.45rem}
  .hero-badge .pulse{width:7px;height:7px}
}
/* anchored sections clear the sticky header */
section[id],#aanbod,#keuze{scroll-margin-top:84px}

/* 08 ── Proof band ───────────────────────────────────────────────────────── */
.proof{background:var(--ink);color:#fff;position:relative}
.proof .slogan{font-family:var(--disp);font-weight:600;color:var(--amber);letter-spacing:.04em;font-size:.92rem;text-transform:uppercase}
.counters{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,3vw,2rem);margin:1.5rem 0 2.4rem}
.counter{border-left:2px solid rgba(255,255,255,.16);padding-left:1.1rem}
.counter b{font-family:var(--disp);font-weight:700;font-size:clamp(2rem,4.5vw,3.1rem);display:block;line-height:1;letter-spacing:-.03em}
.counter span{color:#aeb7b4;font-size:.95rem}
.counter:nth-child(1) b{color:var(--amber)}
.brands{padding-top:1.8rem;border-top:1px solid rgba(255,255,255,.12)}
.brands .lbl{display:block;font-family:var(--disp);font-weight:500;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:#8d9794;margin-bottom:1rem}
.brand-wall{display:flex;flex-wrap:wrap;gap:.7rem}
.brand-wall .chip{height:54px;min-width:104px;padding:0 1.15rem;background:#fff;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 22px -16px rgba(0,0,0,.6)}
.brand-wall .chip img{height:26px;width:auto;display:block}
.brand-wall .chip.word{font-family:var(--disp);font-weight:700;font-size:1.05rem;color:var(--ink);letter-spacing:.01em}
@media(max-width:560px){.brand-wall .chip{flex:1 1 28%;min-width:0}}
@media(max-width:560px){.counters{grid-template-columns:1fr;gap:1.2rem}}

/* 09 ── Reframe ──────────────────────────────────────────────────────────── */
.reframe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-top:.5rem}
.fear{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 1.5rem;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.fear:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.fear .ic{width:46px;height:46px;border-radius:12px;background:var(--teal-soft);color:var(--teal-dk);display:grid;place-content:center;margin-bottom:1rem}
.fear h3{margin-bottom:.5rem}
.fear p{font-size:.98rem}
.fear .pay{display:block;margin-top:.8rem;font-family:var(--disp);font-weight:600;color:var(--teal-dk);font-size:.95rem}
@media(max-width:780px){.reframe-grid{grid-template-columns:1fr}}

/* 10 ── Offer (3-tier) ───────────────────────────────────────────────────── */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);align-items:start}
.tier{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem 1.6rem;box-shadow:var(--shadow);position:relative;display:flex;flex-direction:column;height:100%}
.tier.feat{border:2px solid var(--teal);box-shadow:var(--shadow-lg);transform:translateY(-8px)}
.tier .flag{position:absolute;top:-13px;left:50%;translate:-50%;background:var(--teal);color:#fff;font-family:var(--disp);font-weight:600;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;padding:.32rem .9rem;border-radius:999px}
.tier .tname{font-family:var(--disp);font-weight:600;font-size:1.05rem;color:var(--muted);letter-spacing:.02em}
.tier .price{font-family:var(--disp);font-weight:700;font-size:2.5rem;letter-spacing:-.03em;margin:.2rem 0 .1rem;line-height:1}
.tier .price small{font-size:.95rem;font-weight:500;color:var(--muted);letter-spacing:0}
.tier .save{display:inline-block;background:var(--amber);color:#231a05;font-family:var(--disp);font-weight:700;font-size:.86rem;padding:.22rem .7rem;border-radius:999px;margin:.7rem 0 1rem}
.tier.feat .save{background:var(--teal-soft);color:var(--teal-dk)}
.tier .desc{font-size:.92rem;color:var(--muted);margin-bottom:1.1rem;min-height:2.6em}
.tier ul{list-style:none;padding:0;margin:0 0 1.4rem;display:grid;gap:.55rem}
.tier li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:var(--ink-soft)}
.tier li svg{color:var(--teal);flex:none;margin-top:.18em}
.tier .btn{margin-top:auto}
@media(max-width:860px){.tiers{grid-template-columns:1fr;max-width:430px;margin-inline:auto}.tier.feat{transform:none;order:-1}}

/* 10b ── Machines (curated selection) ────────────────────────────────────── */
.machines{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.machine{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.machine:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.machine .ph{position:relative;background:linear-gradient(160deg,#fff,var(--panel));aspect-ratio:4/3;display:grid;place-content:center;padding:.7rem;overflow:hidden}
.machine .ph img{max-height:225px;max-width:100%;width:auto;object-fit:contain;mix-blend-mode:multiply}
.machine .cond{position:absolute;top:.8rem;left:.8rem;font-family:var(--disp);font-weight:600;font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;padding:.26rem .62rem;border-radius:999px;background:var(--teal-soft);color:var(--teal-dk);z-index:2}
.machine .cond.used{background:#fdeccd;color:var(--amber-dk)}
.machine .brandchip{position:absolute;top:.7rem;right:.7rem;z-index:2;height:33px;min-width:48px;padding:0 .6rem;background:#fff;border:1px solid var(--line);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 16px -10px rgba(20,25,27,.5)}
.machine .brandchip img{height:20px;width:auto;max-width:140px;display:block;mix-blend-mode:normal}
.machine .brandchip.word{font-family:var(--disp);font-weight:700;font-size:.82rem;letter-spacing:.01em;line-height:1}
.machine .body{padding:1.05rem 1.2rem 1.3rem;display:flex;flex-direction:column;flex:1}
.machine h3{font-size:1.1rem;margin:.1rem 0 .35rem}
.machine .spec{font-size:.87rem;color:var(--muted);margin-bottom:1rem}
.machine .price{font-family:var(--disp);font-weight:700;font-size:1.4rem;color:var(--ink);margin-top:auto;line-height:1.1}
.machine .price small{display:block;font-family:var(--sans);font-size:.72rem;font-weight:500;color:var(--muted);letter-spacing:.03em;text-transform:uppercase}
.machine .btn{margin-top:.95rem}
.machines-note{margin-top:1.9rem;text-align:center;color:var(--muted);font-size:.96rem}
.machines-note a{color:var(--teal-dk);font-weight:600;text-decoration:underline;text-underline-offset:2px}
@media(max-width:860px){.machines{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.machines{grid-template-columns:1fr;max-width:420px;margin-inline:auto}}

/* 11 ── How it works ─────────────────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap);counter-reset:s}
.step{position:relative;padding-top:.5rem}
.step .num{font-family:var(--disp);font-weight:700;font-size:2.4rem;color:var(--teal);opacity:.28;line-height:1;letter-spacing:-.04em}
.step h3{margin:.4rem 0 .5rem}
.step p{font-size:.94rem}
.step::after{content:"";position:absolute;top:1.5rem;right:-.6rem;width:1.2rem;height:2px;background:var(--line)}
.step:last-child::after{display:none}
@media(max-width:780px){.steps{grid-template-columns:1fr 1fr}.step::after{display:none}}
@media(max-width:440px){.steps{grid-template-columns:1fr}}

/* 12 ── Services ─────────────────────────────────────────────────────────── */
.svc-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.6rem,4vw,3rem);align-items:center}
.svc-list{display:grid;gap:.9rem}
.svc{display:flex;gap:1rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.15rem 1.25rem;transition:border-color .2s,transform .2s}
.svc:hover{border-color:var(--teal);transform:translateX(4px)}
.svc .ic{width:42px;height:42px;flex:none;border-radius:11px;background:var(--teal-soft);color:var(--teal-dk);display:grid;place-content:center}
.svc h3{font-size:1.08rem;margin-bottom:.15rem}
.svc p{font-size:.92rem;margin:0}
.svc .fast{color:var(--amber-dk);font-weight:700}
.svc-aside{background:var(--ink);color:#fff;border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-lg)}
.svc-aside h3{color:#fff;margin-bottom:1rem}
.svc-aside .perk{display:flex;gap:.7rem;align-items:center;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.12);font-family:var(--disp);font-weight:500}
.svc-aside .perk:last-of-type{border-bottom:0}
.svc-aside .perk svg{color:var(--amber);flex:none}
.svc-aside .note{font-size:.8rem;color:#8d9794;margin-top:1rem}
@media(max-width:820px){.svc-wrap{grid-template-columns:1fr}}

/* 13 ── Founder ──────────────────────────────────────────────────────────── */
.founder{background:linear-gradient(180deg,var(--teal-soft),var(--paper))}
.founder-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.founder-photo{position:relative}
.founder-photo img{border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:4/5;object-fit:cover}
.founder-quote{position:absolute;right:-14px;bottom:-18px;background:var(--surface);border-radius:14px;padding:.9rem 1.1rem;box-shadow:var(--shadow);font-family:var(--disp);font-weight:700;font-size:1rem;max-width:62%}
.founder-quote span{color:var(--teal-dk)}
.founder blockquote{font-family:var(--disp);font-weight:500;font-size:clamp(1.2rem,2.4vw,1.65rem);line-height:1.35;letter-spacing:-.01em;color:var(--ink);margin:.6rem 0 1.1rem}
.founder blockquote .em{color:var(--teal-dk)}
.founder .sig{font-family:var(--disp);font-weight:600;color:var(--ink-soft)}
.founder .sig small{display:block;font-family:var(--sans);font-weight:400;color:var(--muted)}
@media(max-width:760px){.founder-grid{grid-template-columns:1fr}.founder-photo{max-width:360px;margin:0 auto 1.5rem}}

/* 14 ── Applications ─────────────────────────────────────────────────────── */
.apps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.app{border-radius:var(--radius);overflow:hidden;position:relative;box-shadow:var(--shadow);aspect-ratio:4/5}
.app img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.app:hover img{transform:scale(1.05)}
.app .cap{position:absolute;inset:auto 0 0 0;padding:1.6rem 1.2rem 1.1rem;background:linear-gradient(transparent,rgba(20,25,27,.85));color:#fff}
.app .cap b{font-family:var(--disp);font-weight:600;font-size:1.05rem;display:block}
.app .cap span{font-size:.86rem;color:#d5dad7}
.apps-third{grid-column:span 1}
@media(max-width:760px){.apps{grid-template-columns:1fr 1fr}.apps .app:last-child{grid-column:span 2;aspect-ratio:16/9}}
@media(max-width:460px){.apps{grid-template-columns:1fr}.apps .app:last-child{grid-column:span 1;aspect-ratio:4/5}}

/* 15 ── CTA / contact ────────────────────────────────────────────────────── */
.cta{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(12,143,107,.35),transparent 70%);top:-180px;right:-120px}
.cta::after{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(243,166,38,.18),transparent 70%);bottom:-200px;left:-100px}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,5vw,4rem);align-items:center;position:relative;z-index:1}
.cta h2{color:#fff}
.cta .lead{color:#c7cecb}
.cta-contact{display:flex;flex-direction:column;gap:.8rem;margin-top:1.6rem}
.cta-contact a{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--disp);font-weight:600;font-size:1.05rem}
.cta-contact a svg{color:var(--amber);flex:none}
.cta-contact a:hover{color:var(--amber)}
.form{background:var(--surface);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.2rem);box-shadow:var(--shadow-lg)}
.form h3{color:var(--ink);margin-bottom:.3rem}
.form .sub{color:var(--muted);font-size:.92rem;margin-bottom:1.3rem}
.field{margin-bottom:.9rem}
.field label{display:block;font-family:var(--disp);font-weight:500;font-size:.84rem;color:var(--ink-soft);margin-bottom:.3rem}
.field input,.field textarea,.field select{
  width:100%;font:inherit;font-size:.98rem;color:var(--ink);background:var(--paper);
  border:1.5px solid var(--line);border-radius:10px;padding:.72rem .85rem;transition:border-color .15s,background .15s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--teal);background:#fff}
.field textarea{resize:vertical;min-height:90px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.form .fineprint{font-size:.78rem;color:var(--muted);margin-top:.7rem;text-align:center}
.form-ok{display:none;text-align:center;padding:1rem 0}
.form-ok.show{display:block}
.form-ok .check{width:58px;height:58px;border-radius:50%;background:var(--teal-soft);color:var(--teal-dk);display:grid;place-content:center;margin:0 auto 1rem}
@media(max-width:840px){.cta-grid{grid-template-columns:1fr}.row2{grid-template-columns:1fr}}

/* 16 ── Footer ───────────────────────────────────────────────────────────── */
footer.site{background:#0d1113;color:#9aa3a0;padding:clamp(2.6rem,6vw,3.6rem) 0 2rem;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:1.4fr minmax(0,1fr) minmax(0,1fr);gap:2rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-grid a{overflow-wrap:anywhere}
.cta-contact a{overflow-wrap:anywhere;min-width:0}
.foot-grid h4{font-family:var(--disp);font-weight:600;color:#fff;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.9rem}
.foot-brand{font-family:var(--disp);font-weight:700;font-size:1.3rem;color:#fff;letter-spacing:-.03em;margin-bottom:.7rem;display:flex;align-items:center;gap:.5rem}
.foot-brand .eu{color:var(--teal)}
.foot-grid ul{list-style:none;padding:0;display:grid;gap:.5rem}
.foot-grid a:hover{color:#fff}
.foot-grid .ctc a{display:flex;gap:.5rem;align-items:center}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.5rem;font-size:.82rem;color:#717a77}
.foot-bottom a{color:#aeb7b4;text-decoration:underline;text-underline-offset:2px}
.foot-bottom a:hover{color:#fff}
.disclosure{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.8rem 1rem;margin-top:1.6rem;font-size:.78rem;color:#717a77;line-height:1.5}
@media(max-width:700px){.foot-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.foot-grid .about{grid-column:span 2}}

/* 17 ── Reveal / motion / a11y ───────────────────────────────────────────── */
html.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js .reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto !important}
  html.js .reveal{opacity:1;transform:none;transition:none}
}
