/* =====================================================================
   ScalePilot v2 — "Control Plane"
   Dark engineering / observability-console aesthetic.
   Near-black canvas, blueprint grid, IBM Plex Sans/Mono.
   Brand vermillion = action. Signal green = systems healthy.
   ===================================================================== */

:root {
  --bg:      #0a0c12;
  --bg-1:    #0e1119;
  --bg-2:    #141926;
  --bg-3:    #1a2030;
  --line:    #1f2736;
  --line-2:  #2b3547;
  --text:    #e8ebf2;
  --muted:   #909bb1;
  --faint:   #5d6678;
  --brand:   #e8431f;
  --brand-2: #ff5b39;
  --brand-ink: #ff6a47;   /* use for any brand-colored TEXT/labels < 24px (AA on near-black) */
  --ok:      #36d99a;
  --ok-dim:  #1f7d5b;
  --ok-deep: #115e44;
  --radius:  10px;
  --radius-sm: 7px;
  --maxw: 1200px;
  --gut: clamp(1.1rem, 3.5vw, 2.75rem);
  --sans: 'IBM Plex Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --mono: 'IBM Plex Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: clip; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  font-size: clamp(.95rem,.9rem+.2vw,1.02rem);
  -webkit-font-smoothing: antialiased;
  position: relative;
}

/* ---- Background: blueprint grid + glows + noise ---- */
.bg {
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background-color: var(--bg);
}
.bg::before { /* grid */
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 52px 52px;
  opacity: .35;
  -webkit-mask-image: radial-gradient(120% 90% at 70% 0%, #000 0%, transparent 75%);
          mask-image: radial-gradient(120% 90% at 70% 0%, #000 0%, transparent 75%);
}
.bg::after { /* glows */
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(42% 32% at 82% -5%, rgba(232,67,31,.07), transparent 70%),
    radial-gradient(45% 35% at 5% 12%, rgba(54,217,154,.08), transparent 70%);
}
.grain {
  position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img,svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
input,textarea { font: inherit; color: inherit; }
::selection { background: var(--brand); color: #fff; }
:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }

h1,h2,h3,h4 { font-family: var(--sans); font-weight: 600; line-height: 1.18; letter-spacing: -.02em; }
/* Tight display overrides + balanced wrapping (handles long Danish headings) */
.hero__h1 { line-height:1.04; text-wrap:balance; }
.band__title,.sec-head .h2 { line-height:1.1; text-wrap:balance; }

.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.mono { font-family: var(--mono); }
.vh { position:absolute!important; width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0; }
.skip { position:absolute; left:1rem; top:-3rem; z-index:200; background:var(--brand); color:#fff; padding:.5rem .9rem; font-family:var(--mono); font-size:.8rem; transition:top .2s; }
.skip:focus { top:1rem; }

/* ---- Tags / kickers ---- */
.kicker {
  display:inline-flex; align-items:center; gap:.55rem;
  font-family: var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  color: var(--muted);
}
.kicker::before { content:""; width:7px; height:7px; border-radius:2px; background:var(--line-2); }
.kicker--ok::before { background:var(--ok); box-shadow:0 0 10px rgba(54,217,154,.7); }

/* ---- Status pill (live) ---- */
.pill {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.04em;
  color:var(--ok); border:1px solid var(--line-2); background:rgba(54,217,154,.06);
  padding:.34rem .7rem; border-radius:100px;
}
.dot { width:8px; height:8px; border-radius:50%; background:var(--ok); box-shadow:0 0 0 0 rgba(54,217,154,.6); animation:ping 2.4s var(--ease) infinite; }
@keyframes ping { 0%{box-shadow:0 0 0 0 rgba(54,217,154,.55)} 70%{box-shadow:0 0 0 7px rgba(54,217,154,0)} 100%{box-shadow:0 0 0 0 rgba(54,217,154,0)} }

/* ---- Buttons ----
   No solid-orange slabs. Refined, restrained, editorial.
   .btn          base (bordered, transparent)
   .btn--cta     primary action — bordered, vermillion arrow only, border lifts to brand on hover
   .btn--ghost   secondary action — subtle white sheen
   .cta-link     quiet text CTA for nav/footers — no fill, no border-box, underline rule only
   .btn--block   full-width utility (kept slim, for the contact submit) */
.btn {
  --bg:transparent; --fg:var(--text); --bd:var(--line-2);
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--mono); font-size:.82rem; letter-spacing:.04em;
  padding:.8rem 1.25rem; border:1px solid var(--bd); background:var(--bg); color:var(--fg);
  border-radius:var(--radius-sm); transition:.25s var(--ease);
}
.btn:hover { transform:translateY(-1px); }
.btn:active { transform:translateY(0); }

/* Primary action — bordered, mono label, vermillion arrow only */
.btn--cta {
  --fg:var(--text); --bd:var(--line-2);
  position:relative; padding:.85rem 1.4rem;
  background:transparent;
}
.btn--cta .ar { color:var(--brand); }
.btn--cta:hover { --bd:var(--brand); transform:translateY(-1px); }
.btn--cta:hover .ar { transform:translateX(3px); }

/* Quiet text CTA — for nav + footers, no fill, no border */
.cta-link {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--mono); font-size:.82rem; letter-spacing:.04em;
  color:var(--text); border-bottom:1px solid var(--line-2);
  padding-bottom:2px; transition:border-color .2s, color .2s;
}
.cta-link .ar { color:var(--brand); transition:transform .25s var(--ease); }
.cta-link:hover { border-color:var(--brand); }
.cta-link:hover .ar { transform:translateX(3px); }

.btn--ghost {
  --fg:var(--text); --bd:var(--line-2);
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.015));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.btn--ghost:hover { --bd:var(--faint); transform:translateY(-2px); background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.03)); box-shadow: inset 0 1px 0 rgba(255,255,255,.07), 0 0 0 1px rgba(255,255,255,.06), 0 10px 26px -16px #000; }
.btn--block { width:100%; justify-content:center; }
.btn .ar { transition:transform .25s var(--ease); }
.btn:hover .ar { transform:translateX(3px); }

/* =====================================================================
   App bar
   ===================================================================== */
.appbar {
  position:sticky; top:0; z-index:100;
  background:rgba(10,12,18,.72); backdrop-filter:blur(12px) saturate(1.2);
  border-bottom:1px solid transparent; transition:border-color .3s, background .3s;
}
.appbar.scrolled { border-bottom-color:var(--line); background:rgba(10,12,18,.9); }
.appbar__in { display:flex; align-items:center; gap:1.25rem; height:66px; }
.brand { display:inline-flex; align-items:center; gap:.6rem; color:var(--text); }
.brand__mark { width:30px; height:30px; }
.brand__word { font-family:var(--sans); font-weight:600; font-size:1.2rem; letter-spacing:-.02em; }
.nav { display:flex; align-items:center; gap:1.6rem; margin-left:auto; }
.navlink { font-family:var(--sans); font-size:.82rem; font-weight:500; letter-spacing:0; color:var(--muted); transition:color .2s; position:relative; }
.navlink:hover, .navlink.active { color:var(--text); }
.navlink::after { content:""; position:absolute; left:0; bottom:-6px; height:1px; width:0; background:var(--brand); transition:width .25s var(--ease); }
.navlink:hover::after, .navlink.active::after { width:100%; }
.nav__end { display:flex; align-items:center; gap:1rem; }
.lang { display:inline-flex; border:1px solid var(--line-2); border-radius:6px; overflow:hidden; }
.langbtn { font-family:var(--mono); font-size:.7rem; padding:.3rem .55rem; color:var(--faint); transition:.2s; }
.langbtn+.langbtn { border-left:1px solid var(--line-2); }
.langbtn.active { background:var(--brand); color:#fff; }

.burger { display:none; width:42px; height:42px; position:relative; margin-left:auto; }
.burger span { position:absolute; left:11px; width:20px; height:1.5px; background:var(--text); transition:.3s var(--ease); }
.burger span:nth-child(1){top:15px} .burger span:nth-child(2){top:20px} .burger span:nth-child(3){top:25px}
.appbar.open .burger span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.appbar.open .burger span:nth-child(2){opacity:0}
.appbar.open .burger span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

/* =====================================================================
   Hero
   ===================================================================== */
.hero { padding-block: clamp(2.5rem,6vw,5rem) clamp(3rem,6vw,5.5rem); }
.hero__grid { display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,4vw,3.5rem); align-items:center; }
.hero__h1 { font-size:clamp(2.3rem,1.2rem+4.6vw,4.4rem); letter-spacing:-.03em; margin-top:1.4rem; }
.hero__h1 .hl { color:var(--brand); }
.hero__lede { margin-top:1.5rem; max-width:38rem; color:var(--muted); font-size:1.1rem; }
.hero__actions { margin-top:2rem; display:flex; flex-wrap:wrap; gap:.85rem; }
.hero__meta { margin-top:1.75rem; display:flex; gap:1.5rem; flex-wrap:wrap; font-family:var(--mono); font-size:.74rem; color:var(--faint); }
.hero__meta b { color:var(--muted); font-weight:500; }

/* ---- Control-plane panel ---- */
.panel { border:1px solid var(--line); background:linear-gradient(180deg,var(--bg-1),var(--bg)); border-radius:var(--radius); overflow:hidden; box-shadow:0 30px 80px -40px #000; }
.panel__bar { display:flex; align-items:center; gap:.6rem; padding:.7rem .9rem; border-bottom:1px solid var(--line); background:var(--bg-1); }
.panel__bar .tl { display:flex; gap:.4rem; }
.panel__bar .tl i { width:10px; height:10px; border-radius:50%; background:var(--line-2); }
.panel__bar .tl i:first-child { background:var(--line-2); }
.panel__name { font-family:var(--mono); font-size:.74rem; color:var(--muted); letter-spacing:.02em; }
.panel__bar .pill { margin-left:auto; }
.tiles { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); }
.tile { background:var(--bg-1); padding:1rem 1.1rem; }
.tile__k { font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--faint); display:flex; align-items:center; gap:.4rem; }
.tile__v { font-family:var(--mono); font-weight:600; font-size:clamp(1.5rem,1.1rem+1.3vw,2.05rem); margin-top:.45rem; letter-spacing:-.01em; }
.tile__v.ok { color:var(--ok); } .tile__v.brand { color:var(--brand-ink); }
.spark { margin-top:.5rem; width:100%; height:26px; color:var(--ok); }
.spark path { fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; stroke-dasharray:300; stroke-dashoffset:300; animation:draw 2s var(--ease) forwards; }
.spark .area { fill:currentColor; opacity:.1; stroke:none; }
.spark--ok    { color:var(--ok); }
.spark--brand { color:var(--brand); }
.spark--muted { color:var(--muted); }
@keyframes draw { to { stroke-dashoffset:0; } }
.logwrap { border-top:1px solid var(--line); background:var(--bg); padding:.7rem .9rem; }
.logwrap .lh { font-family:var(--mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); margin-bottom:.45rem; }
.log { font-family:var(--mono); font-size:.72rem; line-height:1.7; min-height:5.2em; color:var(--muted); }
.log .ll { display:block; opacity:0; animation:logIn .35s var(--ease) forwards; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.log .t { color:var(--faint); } .log .ok { color:var(--ok); } .log .br { color:var(--brand); }
@keyframes logIn { from{opacity:0; transform:translateY(4px)} to{opacity:1; transform:none} }

/* =====================================================================
   Sections
   ===================================================================== */
.section { padding-block: clamp(3.5rem,7vw,6.5rem); }
.section--line { border-top:1px solid var(--line); }
.sec-head { max-width:54rem; margin-bottom:clamp(2rem,4vw,3rem); }
.sec-head .h2 { font-size:clamp(1.7rem,1.2rem+2.2vw,2.9rem); margin-top:1rem; }
.sec-head .sub { margin-top:1rem; color:var(--muted); max-width:38rem; }

/* ---- Modules (services) ---- */
.modules { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.module { background:var(--bg-1); padding:clamp(1.4rem,2.5vw,2rem); position:relative; transition:background .3s var(--ease); }
.module:hover { background:var(--bg-2); }
.module::after { content:""; position:absolute; left:0; top:0; height:2px; width:0; background:var(--brand); transition:width .35s var(--ease); }
.module:hover::after { width:100%; }
.module__tag { font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--faint); display:flex; justify-content:space-between; }
.module__tag .n { color:var(--brand-ink); }
.module__icon {
  width:48px; height:48px; border-radius:12px; display:grid; place-items:center;
  color:var(--ok); margin:0 0 1.1rem;
  background:linear-gradient(160deg, rgba(54,217,154,.18), rgba(54,217,154,.02));
  border:1px solid var(--line-2);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
  transition: box-shadow .3s var(--ease), transform .3s var(--ease);
}
.module__icon svg { width:24px; height:24px; }
.module__icon .duo { fill:currentColor; opacity:.16; stroke:none; }
.module__icon .ln { fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.module:hover .module__icon { transform:translateY(-2px); box-shadow: 0 0 0 1px rgba(54,217,154,.5), 0 12px 28px -10px rgba(54,217,154,.45); }
.module__title { font-size:1.18rem; font-weight:600; }
.module__text { margin-top:.6rem; color:var(--muted); font-size:.93rem; }
.modules--2 { grid-template-columns:1fr 1fr; }
.module__bul { margin-top:1rem; display:grid; gap:.35rem; }
.module__bul li { font-family:var(--mono); font-size:.74rem; color:var(--muted); display:flex; gap:.5rem; }
.module__bul li::before { content:"\203a"; color:var(--ok); }

/* ---- Case tiles (cases page) ---- */
.cases-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.case { background:var(--bg-1); padding:clamp(1.5rem,2.6vw,2.1rem); display:flex; flex-direction:column; transition:background .3s var(--ease); }
.case:hover { background:var(--bg-2); }
.case__metric { font-family:var(--mono); font-weight:600; font-size:clamp(2.3rem,1.6rem+2.4vw,3.4rem); line-height:1; color:var(--ok); letter-spacing:-.02em; }
.case__metric.brand { color:var(--brand-ink); }
.case__label { font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; color:var(--faint); margin-top:.6rem; }
.case__client { font-size:1.1rem; font-weight:600; margin-top:1.4rem; padding-top:1.1rem; border-top:1px solid var(--line); }
.case__text { margin-top:.55rem; color:var(--muted); font-size:.92rem; }

/* ---- Pipeline (process) ---- */
.pipeline { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.stage { position:relative; padding:1.6rem 1.4rem 1.6rem 0; }
.stage:not(:last-child){ padding-right:2rem; }
.stage__top { display:flex; align-items:center; gap:.7rem; }
.stage__n { font-family:var(--mono); font-size:.72rem; color:var(--muted); border:1px solid var(--line-2); border-radius:5px; padding:.2rem .45rem; }
.stage__line { flex:1; height:1px; background:repeating-linear-gradient(90deg,var(--line-2) 0 6px, transparent 6px 12px); position:relative; }
.stage:last-child .stage__line { display:none; }
.stage__line::after { content:"›"; position:absolute; right:-2px; top:-11px; color:var(--faint); font-size:1rem; }
.stage__title { font-size:1.18rem; font-weight:600; margin-top:1.1rem; }
.stage__text { margin-top:.6rem; color:var(--muted); font-size:.93rem; max-width:34rem; }

/* ---- Columns (why) ---- */
.cols { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.25rem,2.5vw,2.25rem); }
.col { border-top:1px solid var(--line-2); padding-top:1.25rem; }
.col__k { font-family:var(--mono); font-size:.7rem; color:var(--ok); letter-spacing:.08em; }
.col__title { font-size:1.25rem; font-weight:600; margin-top:.7rem; }
.col__text { margin-top:.7rem; color:var(--muted); max-width:34rem; }

/* ---- CTA band ---- */
.band { border:1px solid var(--line); border-radius:var(--radius); background:linear-gradient(135deg,var(--bg-2),var(--bg-1)); padding:clamp(1.75rem,4vw,3rem); position:relative; overflow:hidden; }
.band::before { content:""; position:absolute; inset:0; background:radial-gradient(60% 120% at 100% 0%, rgba(232,67,31,.06), transparent 60%); pointer-events:none; }
.band__in { display:grid; grid-template-columns:1.4fr auto; gap:1.75rem; align-items:center; position:relative; }
.band__title { font-size:clamp(1.5rem,1.1rem+1.8vw,2.4rem); }
.band__sub { margin-top:.7rem; color:var(--muted); max-width:38rem; }

/* ---- Contact ---- */
.contact__grid { display:grid; grid-template-columns:1.3fr .9fr; gap:clamp(2rem,4vw,3.5rem); align-items:start; }
.form { display:grid; gap:1.4rem; }
.form__row { display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
.field { display:flex; flex-direction:column; gap:.5rem; }
.field,.input,.textarea { min-width:0; }   /* overflow safety: stop long placeholders blowing out the grid */
.label { font-family:var(--mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.input,.textarea {
  background:var(--bg-1); border:1px solid var(--line-2); border-radius:var(--radius-sm);
  padding:.75rem .85rem; color:var(--text); transition:border-color .2s, box-shadow .2s;
}
.input::placeholder,.textarea::placeholder { color:var(--faint); }
.input:focus,.textarea:focus { outline:none; border-color:var(--brand); box-shadow:0 0 0 2px rgba(232,67,31,.16); }
.textarea { min-height:140px; resize:vertical; line-height:1.5; }
.note { font-family:var(--mono); font-size:.72rem; color:var(--faint); border-left:2px solid var(--line-2); padding-left:.7rem; }
.note--mb { margin-bottom:2rem; }
.infocard { border:1px solid var(--line); border-radius:var(--radius); background:var(--bg-1); padding:clamp(1.4rem,3vw,2rem); }
.infocard h3 { font-size:1.2rem; }
.infoblock { margin-top:1.4rem; }
.infoblock .label { margin-bottom:.35rem; }
.infoblock a { color:var(--ok); font-family:var(--mono); font-size:.9rem; }
.infoblock a:hover { color:var(--brand); }

/* ---- Footer ---- */
.foot { border-top:1px solid var(--line); padding-block:clamp(2.5rem,5vw,4rem) 2rem; }
.foot__grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:clamp(1.5rem,4vw,3.5rem); }
.foot__brand p { color:var(--muted); max-width:22rem; margin-top:.9rem; }
.foot__brand a { color:var(--ok); font-family:var(--mono); font-size:.84rem; }
.foot__col h3 { font-family:var(--mono); font-weight:400; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); margin-bottom:.9rem; }
.foot__col a,.foot__col p { display:block; color:var(--muted); padding:.22rem 0; }
.foot__col a:hover { color:var(--text); }
.foot__bottom { margin-top:2.5rem; padding-top:1.4rem; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-family:var(--mono); font-size:.72rem; color:var(--faint); }
.foot__status { display:inline-flex; align-items:center; gap:.5rem; color:var(--ok); }

/* ---- Reveal ---- */
.reveal { opacity:0; transform:translateY(18px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in { opacity:1; transform:none; }

/* =====================================================================
   Responsive — one coherent ladder: 1024 / 900 (nav) / 768 / 480
   ===================================================================== */

/* ---- Tablet (<=1024): tame the dead-zone, fix pipeline connector bug ---- */
@media (max-width:1024px){
  .hero__grid{ grid-template-columns:1fr; }
  .panel{ max-width:520px; margin-inline:auto; margin-top:clamp(2rem,5vw,3rem); }  /* center stacked panel */
  .modules{ grid-template-columns:1fr 1fr; }
  .cols{ grid-template-columns:1fr 1fr; }            /* was stuck 3-up between 761–1024 */
  .pipeline{ grid-template-columns:1fr 1fr; gap:1.5rem 2rem; }
  .stage{ padding:1.4rem 0; }
  .stage:not(:last-child){ padding-right:0; }
  .stage__line{ display:none; }                      /* kill dangling arrows when stages wrap */
  .band__in{ grid-template-columns:1fr; }
  .contact__grid{ grid-template-columns:1fr; }
}

/* ---- Nav collapse (<=900): 5-link bar never crams a shrinking tablet ---- */
@media (max-width:900px){
  .nav{ position:absolute; left:0; right:0; top:100%; flex-direction:column; align-items:flex-start;
        gap:1.1rem; background:var(--bg-1); border-bottom:1px solid var(--line); padding:1.5rem var(--gut) 2rem;
        transform:translateY(-10px); opacity:0; pointer-events:none; transition:.3s var(--ease); margin-left:0;
        max-height:calc(100dvh - 66px); overflow-y:auto; -webkit-overflow-scrolling:touch; }
  .appbar.open .nav{ transform:none; opacity:1; pointer-events:auto; }
  .nav .navlink{ display:block; width:100%; padding:.7rem 0; }
  .nav__end{ width:100%; flex-direction:column; align-items:stretch; gap:1rem; }
  .langbtn{ padding:.55rem .8rem; }                  /* ~44px touch target */
  .burger{ display:block; }
}

/* ---- Phone / single-column (<=768): one source of truth for stacking ---- */
@media (max-width:768px){
  .modules,.modules--2,.cols,.pipeline,.cases-grid{ grid-template-columns:1fr; }
  .tiles{ grid-template-columns:1fr 1fr; }
  .form__row,.foot__grid{ grid-template-columns:1fr; }
  .stage:not(:last-child){ padding-right:0; }
}

/* ---- Small phone (<=480): fluid type, touch targets, no truncation ---- */
@media (max-width:480px){
  :root{ --gut:1.1rem; }
  .hero__h1{ letter-spacing:-.02em; }
  .tiles{ grid-template-columns:1fr 1fr; }
  .tile{ padding:.85rem .9rem; }
  .tile__v{ font-size:1.5rem; }
  .spark{ height:20px; }
  .log .ll{ white-space:normal; }                    /* stop "[ok] autoscale · eu-…" truncation */
  .panel__name{ font-size:.66rem; }
  .band{ padding:1.5rem 1.25rem; }
  .btn,.btn--cta{ min-height:44px; }                 /* touch target */
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .reveal{ opacity:1; transform:none; } .spark path{ stroke-dashoffset:0; } .dot{ animation:none; }
}

/* ── Contact form confirmation (JS-populated, see v2.js §6) ───────────────── */
.form__status:empty{ display:none; }
.form__status.is-success{
  display:block;
  margin-top:1rem;
  padding:.85rem 1.05rem;
  border:1px solid var(--ok-dim);
  border-left:3px solid var(--ok);
  border-radius:var(--radius-sm);
  background:rgba(54,217,154,.08);
  color:var(--text);
  font-size:.92rem;
  line-height:1.45;
  outline:none;
}
