/* =========================================================
   K9OS — final v3.1
   Shared stylesheet across index, cohort, contact pages.
   ========================================================= */

:root{
  --bg:#0a0c10;
  --bg-2:#0d1016;
  --surface:#11151c;
  --surface-2:#161b24;
  --line:#1e2530;
  --line-2:#262e3c;
  --text:#e8eaf0;
  --text-dim:#8a93a3;
  --text-faint:#525a69;
  --warm:#f5a623;
  --warm-deep:#d6881a;
  --cool:#4af0c8;
  --warn:#ff7a59;
  --whatsapp:#25d366;
  --whatsapp-deep:#075e54;
  --warm-soft:rgba(245,166,35,.12);
  --cool-soft:rgba(74,240,200,.10);
  --warn-soft:rgba(255,122,89,.12);
  --radius:6px;
  --radius-lg:10px;
  --mono:"DM Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  --display:"Syne", Inter, sans-serif;
  --body:"Inter", system-ui, sans-serif;
  --max:1240px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--body);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
body{
  background:
    radial-gradient(900px 600px at 80% -10%, rgba(245,166,35,.06), transparent 60%),
    radial-gradient(800px 500px at 5% 20%, rgba(74,240,200,.04), transparent 60%),
    var(--bg);
  background-attachment:fixed;
}
.dot-grid{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.035) 1px, transparent 0);
  background-size:28px 28px;
  mask-image:linear-gradient(to bottom, black, transparent 95%);
}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
hr{border:none;border-top:1px solid var(--line);margin:0}
em{font-style:normal;color:var(--warm)}

.wrap{max-width:var(--max);margin:0 auto;padding:0 28px;position:relative;z-index:1}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;backdrop-filter:blur(10px);background:rgba(10,12,16,.78);border-bottom:1px solid var(--line);z-index:50}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:20px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:800;letter-spacing:-.01em;font-size:18px}
.logo-mark{width:22px;height:22px;border:1px solid var(--line-2);border-radius:5px;display:grid;place-items:center;background:var(--surface)}
.logo-mark::after{content:"";width:8px;height:8px;background:var(--warm);border-radius:2px;box-shadow:0 0 0 3px rgba(245,166,35,.18)}
.nav-links{display:flex;gap:20px;font-size:13px;color:var(--text-dim);font-family:var(--mono)}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--warm)}
.nav-cta{display:flex;gap:10px;align-items:center}
.tag{font-family:var(--mono);font-size:11px;color:var(--text-dim);border:1px solid var(--line);padding:4px 8px;border-radius:4px;background:var(--surface)}
.tag .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--cool);box-shadow:0 0 8px var(--cool);margin-right:6px;vertical-align:middle}

/* lang toggle */
.lang-toggle{display:inline-flex;gap:0;font-family:var(--mono);font-size:11px;letter-spacing:.1em;border:1px solid var(--line);border-radius:4px;background:var(--surface);overflow:hidden}
.lang-toggle button{
  background:transparent;color:var(--text-faint);border:none;
  padding:5px 10px;cursor:pointer;letter-spacing:.1em;
  text-transform:uppercase;transition:all .15s ease;
}
.lang-toggle button:hover{color:var(--text)}
.lang-toggle button.on{color:var(--warm);background:var(--warm-soft)}
.lang-toggle .sep{color:var(--text-faint);align-self:center;padding:0 2px}

/* nav toggle (hamburger) — hidden on desktop, visible ≤1080px */
.nav-toggle{
  display:none;
  -webkit-appearance:none;
  appearance:none;
  background:transparent;
  border:0;
  cursor:pointer;
  width:44px;
  height:44px;
  padding:11px 11px;
  border-radius:6px;
  color:inherit;
  font:inherit;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.nav-toggle:hover,.nav-toggle:active{background:var(--surface)}
.nav-toggle:focus-visible{outline:2px solid var(--warm);outline-offset:2px}
.nav-toggle span{
  display:block;
  width:22px;
  height:2px;
  background:var(--text);
  margin:0 auto;
  border-radius:1px;
  transition:transform .2s ease,opacity .2s ease;
}
.nav-toggle span+span{margin-top:5px}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:1080px){
  .nav-toggle{display:block}
  .nav-links{display:none}
  .nav.is-open .nav-links{
    display:flex;
    position:absolute;
    top:100%;left:0;right:0;
    flex-direction:column;
    background:rgba(10,12,16,.96);
    backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);
    padding:8px 28px 16px;
    gap:0;
    font-size:15px;
    z-index:49;
  }
  .nav.is-open .nav-links a{
    padding:14px 0;
    border-bottom:1px solid var(--line);
    color:var(--text);
  }
  .nav.is-open .nav-links a:last-child{border-bottom:none}
}
@media (max-width:520px){
  .nav-cta .tag{display:none}
  .nav-inner{gap:10px;padding:12px 0}
}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 16px;border-radius:6px;font-size:14px;font-weight:500;border:1px solid var(--line-2);background:var(--surface);color:var(--text);transition:all .15s ease;cursor:pointer}
.btn:hover{border-color:#3a4456;background:var(--surface-2)}
.btn-primary{background:var(--warm);color:#1a1306;border-color:var(--warm);font-weight:600}
.btn-primary:hover{background:#ffb538;border-color:#ffb538}
.btn-ghost{background:transparent}
.btn .arrow{font-family:var(--mono);font-size:13px;opacity:.7}
.btn[disabled]{opacity:.45;cursor:not-allowed}

/* ---------- hero ---------- */
.hero{padding:88px 0 68px;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;color:var(--text-dim);border:1px solid var(--line);padding:6px 10px;border-radius:999px;background:var(--surface);flex-wrap:wrap}
.eyebrow .sep{color:var(--text-faint)}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(44px,7vw,96px);line-height:1.02;letter-spacing:-.025em;margin:24px 0 20px;max-width:18ch}
.hero h1 em{font-style:italic;color:var(--warm)}
.hero .lede{max-width:64ch;color:var(--text-dim);font-size:clamp(16px,1.4vw,19px);line-height:1.6}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.hero-strip{
  margin-top:40px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:14px 0;
  font-family:var(--mono);font-size:12px;color:var(--text-dim);
  display:flex;flex-wrap:wrap;gap:22px;letter-spacing:.06em;text-transform:uppercase;
}
.hero-strip .k{color:var(--text-faint)}
.hero-strip .v{color:var(--text)}
.hero-strip .v.warm{color:var(--warm)}
.hero-strip .v.cool{color:var(--cool)}
.hero-strip .sep{color:var(--text-faint)}
.hero-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:36px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.hero-meta div{padding:18px 20px;border-right:1px solid var(--line)}
.hero-meta div:last-child{border-right:none}
.hero-meta .k{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em}
.hero-meta .v{font-family:var(--display);font-weight:700;font-size:20px;margin-top:4px;letter-spacing:-.01em}
.hero-meta .v small{font-family:var(--mono);font-weight:400;color:var(--text-dim);font-size:12px;margin-left:6px}
@media (max-width:780px){
  .hero-meta{grid-template-columns:repeat(2,1fr)}
  .hero-meta div{border-right:none;border-bottom:1px solid var(--line)}
}

/* ---------- section ---------- */
section{padding:84px 0;position:relative}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:28px;margin-bottom:36px;flex-wrap:wrap}
.section-head .lbl,.lbl{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.14em;margin-bottom:10px}
.section-head h2{font-family:var(--display);font-weight:700;font-size:clamp(30px,4.2vw,50px);line-height:1.05;letter-spacing:-.02em;margin:0;max-width:22ch}
.section-head p{color:var(--text-dim);max-width:54ch;margin:0;font-size:15px}

/* ---------- chapter divider (v3.1) ---------- */
.chapter-divider{
  padding:38px 0 30px;position:relative;
}
.chapter-divider::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(245,166,35,.35) 30%, rgba(245,166,35,.35) 70%, transparent);
}
.chapter-divider .lbl-chap{
  font-family:var(--mono);font-size:11px;color:var(--warm);
  letter-spacing:.22em;text-transform:uppercase;
}
.chapter-divider .chap-sub{
  font-family:var(--display);font-weight:500;font-size:14px;color:var(--text-dim);
  margin-top:8px;letter-spacing:-.005em;
}

/* ---------- chapter I — lighthouse ---------- */
.lighthouse-section{padding:60px 0 64px}
.lighthouse-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface)}
.lh-copy{padding:40px 40px 36px}
.lh-copy h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,3vw,40px);line-height:1.08;letter-spacing:-.02em;margin:14px 0 16px;max-width:24ch}
.lh-copy p{color:var(--text-dim);font-size:15px;line-height:1.7;margin:0 0 14px;max-width:62ch}
.lh-copy p.lede{color:var(--text);font-size:16.5px}
.lh-pull{
  margin:22px 0 4px;padding:18px 0 18px 22px;
  border-left:2px solid var(--warm);
  font-family:var(--display);font-style:italic;
  color:var(--text);font-size:18px;line-height:1.45;max-width:54ch;
}
.lh-pull cite{display:block;margin-top:10px;font-style:normal;font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.12em}
.lh-stats{padding:32px 32px 28px;background:var(--bg-2);border-left:1px solid var(--line);display:flex;flex-direction:column;gap:0}
.lh-stat{padding:14px 0;border-bottom:1px dashed var(--line)}
.lh-stat:last-of-type{border-bottom:none}
.lh-stat .v{font-family:var(--display);font-weight:800;font-size:34px;color:var(--text);letter-spacing:-.015em;line-height:1}
.lh-stat .v.warm{color:var(--warm)}
.lh-stat .l{font-family:var(--mono);font-size:10.5px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.12em;margin-top:6px}
.lh-stats .lh-note{
  margin-top:14px;padding-top:14px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:11.5px;line-height:1.6;color:var(--text-dim)
}
@media (max-width:980px){
  .lighthouse-grid{grid-template-columns:1fr}
  .lh-stats{border-left:none;border-top:1px solid var(--line)}
}

/* ---------- K9P all-six stat block (moved to standalone strip after lighthouse) ---------- */
.k9p-strip{
  padding:24px 0 36px;
}
.k9p-stats{
  border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);
  display:grid;grid-template-columns:repeat(6,1fr);
}
.k9p-stats-head{
  grid-column:1/-1;padding:14px 20px;border-bottom:1px dashed var(--line);
  font-family:var(--mono);font-size:11px;color:var(--text-faint);
  letter-spacing:.14em;text-transform:uppercase;
}
.k9p-stat{padding:22px 18px;border-right:1px solid var(--line)}
.k9p-stat:last-child{border-right:none}
.k9p-stat .v{font-family:var(--display);font-weight:800;font-size:28px;color:var(--warm);letter-spacing:-.015em;line-height:1}
.k9p-stat .l{font-family:var(--mono);font-size:10.5px;color:var(--text-faint);letter-spacing:.12em;text-transform:uppercase;margin-top:8px}
@media (max-width:980px){.k9p-stats{grid-template-columns:repeat(3,1fr)}.k9p-stat{border-bottom:1px solid var(--line)}}
@media (max-width:520px){.k9p-stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- author's note ---------- */
.authors-note{padding:64px 0 56px}
.an-frame{
  max-width:720px;margin:0 auto;
  padding:36px 8px;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.an-label{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.an-frame p{
  font-family:var(--display);font-weight:500;font-size:18px;line-height:1.55;color:var(--text);
  max-width:46ch;margin:0 0 16px;
}
.an-frame p.first-person{
  font-family:var(--mono);font-style:italic;font-size:14px;line-height:1.7;color:var(--warm);
  border-left:2px solid var(--warm);padding-left:16px;max-width:50ch;
  margin:18px 0;
}
.an-sig{
  margin-top:20px;font-family:var(--mono);font-size:11px;color:var(--text-faint);
  letter-spacing:.12em;text-transform:uppercase;
}

/* ---------- long arc ---------- */
.long-arc{padding:60px 0}
.la-frame{
  max-width:920px;margin:0 auto;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:34px 0;
}
.la-label{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.la-body{
  font-family:var(--display);font-weight:500;font-size:clamp(20px,1.8vw,26px);line-height:1.45;
  letter-spacing:-.01em;color:var(--text);margin:0;max-width:50ch;
}
.la-body em{color:var(--warm);font-style:italic}

/* ---------- magic moment ---------- */
.magic{padding:80px 0 70px}
.magic-steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  margin-top:30px;
}
.step{
  border:1px solid var(--line);background:var(--surface);
  border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;
  transition:all .18s ease;
}
.step:hover{border-color:var(--line-2);background:var(--surface-2);transform:translateY(-2px)}
.step-stage{
  padding:14px 18px;font-family:var(--mono);font-size:11px;color:var(--text-faint);
  letter-spacing:.14em;text-transform:uppercase;
  border-bottom:1px dashed var(--line);
  display:flex;align-items:center;justify-content:space-between;
}
.step-stage .num{color:var(--warm)}
.step.s2 .step-stage .num{color:var(--cool)}
.step.s2 .step-stage .ai{font-family:var(--mono);font-size:10px;color:var(--cool);border:1px solid rgba(74,240,200,.4);padding:2px 7px;border-radius:3px;background:var(--cool-soft)}
.step-art{
  height:220px;display:grid;place-items:center;position:relative;
  background:linear-gradient(135deg, rgba(245,166,35,.05), rgba(245,166,35,.02));
  border-bottom:1px dashed var(--line);
  overflow:hidden;
}
.step.s2 .step-art{background:linear-gradient(135deg, rgba(74,240,200,.05), rgba(74,240,200,.02))}
/* v3.1 — Stage 03 gets a single subtle warm-tinted accent on top of WhatsApp green */
.step.s3 .step-art{
  background:
    radial-gradient(circle at 75% 20%, rgba(245,166,35,.10), transparent 55%),
    linear-gradient(135deg, rgba(37,211,102,.05), rgba(37,211,102,.02));
}
.step.s3 .step-art::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(245,166,35,.55), transparent);
}
.step.s3 .step-art::after{
  content:"";position:absolute;inset:14px;border-radius:8px;pointer-events:none;
  box-shadow:0 0 32px rgba(245,166,35,.08);
}
.wave{display:flex;align-items:center;gap:5px;height:90px}
.wave i{display:block;width:5px;background:var(--warm);border-radius:2px;animation:wbounce 1.1s ease-in-out infinite}
.wave i:nth-child(1){height:18px;animation-delay:0s}
.wave i:nth-child(2){height:36px;animation-delay:.08s}
.wave i:nth-child(3){height:56px;animation-delay:.16s}
.wave i:nth-child(4){height:72px;animation-delay:.24s}
.wave i:nth-child(5){height:88px;animation-delay:.32s}
.wave i:nth-child(6){height:64px;animation-delay:.40s}
.wave i:nth-child(7){height:42px;animation-delay:.48s}
.wave i:nth-child(8){height:26px;animation-delay:.56s}
.wave i:nth-child(9){height:48px;animation-delay:.64s}
.wave i:nth-child(10){height:30px;animation-delay:.72s}
.wave i:nth-child(11){height:18px;animation-delay:.80s}
@keyframes wbounce{0%,100%{transform:scaleY(.4);opacity:.55}50%{transform:scaleY(1);opacity:1}}
.wave-time{position:absolute;bottom:14px;right:18px;font-family:var(--mono);font-size:11px;color:var(--warm);letter-spacing:.06em}
.bubble{
  background:#fff;color:#111;padding:11px 14px;border-radius:8px 8px 8px 2px;
  max-width:84%;font-size:12px;line-height:1.4;box-shadow:0 1px 1px rgba(0,0,0,.18);
}
.bubble strong{display:block;margin-bottom:4px;font-weight:600;color:#111}
.bubble small{display:block;text-align:right;font-size:10px;color:#7a7a7a;margin-top:6px}
.owner-svg{width:140px;height:auto;filter:drop-shadow(0 4px 16px rgba(245,166,35,.18))}
.step-body{padding:18px 20px 20px;flex:1}
.step-body h3{font-family:var(--display);font-weight:700;font-size:17px;margin:0 0 8px;letter-spacing:-.005em;line-height:1.25}
.step-body p{color:var(--text-dim);font-size:13.5px;line-height:1.6;margin:0}
@media (max-width:900px){.magic-steps{grid-template-columns:1fr}}

/* ---------- live language switcher ---------- */
.languages{padding:80px 0 80px;background:linear-gradient(180deg,rgba(74,240,200,.025),transparent 40%)}
.lang-tabs{
  display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;margin-bottom:28px;
  font-family:var(--mono);
}
.lang-tab{
  background:var(--surface);color:var(--text-dim);
  border:1px solid var(--line);padding:8px 14px;
  border-radius:4px;font-size:12px;letter-spacing:.06em;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .15s ease;
}
.lang-tab:hover{border-color:var(--line-2);color:var(--text)}
.lang-tab.active{border-color:var(--warm);color:var(--warm);background:var(--warm-soft)}
.lang-tab .flag{width:16px;height:11px;border-radius:1px;display:inline-block;border:1px solid rgba(255,255,255,.2)}
.fl-ro{background:linear-gradient(to right,#002B7F 33%,#FCD116 33% 66%,#CE1126 66%)}
.fl-en{background:linear-gradient(135deg,#012169 50%,#C8102E 50%)}
.fl-de{background:linear-gradient(to bottom,#000 33%,#DD0000 33% 66%,#FFCE00 66%)}
.fl-it{background:linear-gradient(to right,#009246 33%,#fff 33% 66%,#CE2B37 66%)}

.lang-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
@media (max-width:900px){.lang-grid{grid-template-columns:1fr}}
.phone{
  background:#0d0e10;border-radius:32px;padding:10px;max-width:330px;margin:0 auto;
  box-shadow:0 30px 60px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.06);
  position:relative;border:1px solid #20232a;
}
.phone::before{
  content:"";position:absolute;top:18px;left:50%;transform:translateX(-50%);
  width:80px;height:18px;background:#000;border-radius:999px;z-index:2;
}
.phone-screen{background:#ECE5DD;border-radius:24px;overflow:hidden;min-height:520px}
.wa-header{
  background:var(--whatsapp-deep);color:#fff;
  padding:42px 14px 12px;display:flex;align-items:center;gap:10px;
}
.wa-avatar{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg, var(--warm), #b87214);
  display:grid;place-items:center;color:#1a1306;
  font-family:var(--display);font-weight:800;font-size:13px;
}
.wa-meta-name{font-weight:600;font-size:13.5px}
.wa-meta-status{font-size:11px;opacity:.85}
.wa-body{padding:14px}
.wa-msg{
  background:#fff;border-radius:8px 8px 8px 2px;padding:10px 12px;max-width:88%;
  margin-bottom:8px;font-size:12px;line-height:1.45;color:#111;
  box-shadow:0 1px 1px rgba(0,0,0,.08);
}
.wa-msg.sent{background:#DCF8C6;margin-left:auto;border-radius:8px 8px 2px 8px}
.wa-msg .photo{
  background:linear-gradient(135deg,#7BA88F,#4f7762);
  height:84px;border-radius:4px;margin:-2px -4px 6px;position:relative;overflow:hidden;
}
.wa-msg .photo::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 60%,rgba(0,0,0,.32) 0 16%,transparent 17%),
    radial-gradient(circle at 70% 78%,rgba(0,0,0,.20) 0 9%,transparent 10%);
}
.wa-msg strong{display:block;margin-bottom:4px;font-weight:600}
.wa-msg time{display:block;text-align:right;font-size:10px;color:#7a7a7a;margin-top:5px}

.lang-side h3{font-family:var(--display);font-weight:700;font-size:24px;margin:0 0 12px;letter-spacing:-.01em;line-height:1.2}
.lang-side p{color:var(--text-dim);font-size:14.5px;line-height:1.65;margin:0 0 14px;max-width:50ch}
.lang-list{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:10px}
.lang-list li{display:flex;gap:12px;color:var(--text-dim);font-size:13.5px;line-height:1.6;align-items:flex-start}
.lang-list .check{
  flex:none;width:18px;height:18px;border-radius:3px;
  background:var(--cool-soft);color:var(--cool);
  border:1px solid rgba(74,240,200,.4);
  display:grid;place-items:center;font-family:var(--mono);font-size:11px;font-weight:600;
  margin-top:1px;
}

/* ---------- modules / dock ---------- */
.layer-label{
  display:flex;align-items:center;gap:14px;margin:0 0 14px;
  padding:10px 14px;border:1px dashed var(--line);border-radius:6px;background:rgba(255,255,255,.015);
  flex-wrap:wrap;
}
.layer-label-2{margin-top:36px}
.layer-tag{font-family:var(--mono);font-size:11px;color:var(--warm);letter-spacing:.1em}
.layer-name{font-family:var(--display);font-weight:600;font-size:14px;color:var(--text)}
.layer-meter{display:inline-flex;gap:4px;margin-left:auto}
.layer-meter i{display:block;width:12px;height:6px;background:var(--warm);border-radius:1px;opacity:.85}
.layer-label-2 .layer-meter i{background:var(--cool)}

.dock{display:grid;gap:14px}
.dock-vertical{grid-template-columns:repeat(4,1fr)}
.dock-horizontal{grid-template-columns:repeat(2,1fr)}
.module{
  position:relative;border:1px solid var(--line);background:var(--surface);
  border-radius:var(--radius-lg);padding:20px 18px 18px;
  display:flex;flex-direction:column;min-height:240px;transition:all .2s ease;
}
.module:hover{border-color:var(--line-2);background:var(--surface-2);transform:translateY(-2px)}
.module .num{font-family:var(--mono);font-size:11px;color:var(--text-faint)}
.module .roman{font-family:var(--display);font-weight:800;font-size:24px;color:var(--warm);margin-top:2px;line-height:1;letter-spacing:.02em}
.module h3{font-family:var(--display);font-weight:700;font-size:17px;margin:8px 0 4px;letter-spacing:-.01em;line-height:1.25}
.module .tagline{color:var(--text-dim);font-size:13.5px;line-height:1.5;flex:1}
.module .price{font-family:var(--mono);font-size:12px;color:var(--text);margin-top:14px;padding-top:12px;border-top:1px dashed var(--line)}
.module .price b{color:var(--warm);font-weight:500}
.module .icon{width:36px;height:36px;border:1px solid var(--line-2);border-radius:6px;display:grid;place-items:center;margin-bottom:8px;background:var(--bg-2)}
.module.featured{border-color:rgba(245,166,35,.4);background:linear-gradient(180deg,rgba(245,166,35,.05),var(--surface) 50%)}
.module .pill{position:absolute;top:14px;right:14px;font-family:var(--mono);font-size:10px;color:var(--warm);border:1px solid var(--warm);padding:2px 6px;border-radius:3px;letter-spacing:.05em;text-transform:uppercase}
.module-horizontal{
  background:linear-gradient(180deg,rgba(74,240,200,.04),var(--surface) 50%);
  border-color:rgba(74,240,200,.18);
}
.module-horizontal .roman{color:var(--cool)}
.module-horizontal .icon{border-color:rgba(74,240,200,.3)}
.module-horizontal:hover{border-color:rgba(74,240,200,.4)}
.module-horizontal.new .new-pill{color:var(--cool);border-color:var(--cool)}
.iconsvg{width:18px;height:18px;stroke:currentColor;stroke-width:1.6;fill:none}

@media (max-width:1080px){.dock-vertical{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.dock-vertical,.dock-horizontal{grid-template-columns:1fr}}

/* ---------- balance ---------- */
.balance-section{padding-top:60px}
.balance-frame{
  border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);
  display:grid;grid-template-columns:1.05fr 1.4fr;overflow:hidden;
}
.balance-meta{padding:28px;border-right:1px solid var(--line);background:var(--bg-2);display:flex;flex-direction:column;gap:18px;justify-content:center}
.balance-row{font-family:var(--mono);font-size:12.5px;line-height:1.5;display:flex;flex-direction:column;gap:4px}
.bm-l{color:var(--text-faint);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase}
.bm-v{color:var(--text)}
.bm-v.warm{color:var(--warm)}
.balance-viz{padding:24px 24px 12px;display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}
.radar{width:100%;height:auto;max-width:480px;display:block;margin:0 auto}
.dim-bars{display:flex;flex-direction:column;gap:6px;font-family:var(--mono);font-size:11px}
.dim{display:grid;grid-template-columns:84px 1fr 38px;gap:10px;align-items:center;color:var(--text-dim)}
.dim-bar{height:6px;background:var(--bg-2);border-radius:3px;overflow:hidden;border:1px solid var(--line)}
.dim-bar i{display:block;height:100%;background:var(--warm);opacity:.85}
.dim-v{color:var(--text);text-align:right;font-size:10.5px}
.dim.warn .dim-bar i{background:var(--warn)}
.dim.warn .dim-v{color:var(--warn)}
.balance-note{
  margin:24px 0 0;padding:18px 22px;
  border:1px dashed var(--line);border-radius:6px;
  font-size:14px;color:var(--text-dim);max-width:90ch;
  background:rgba(255,255,255,.015);
}
.balance-axes-note{
  margin:10px 0 0;padding:0 22px;
  font-family:var(--mono);font-size:11px;
  color:var(--text-faint);font-style:italic;
  letter-spacing:.02em;
}
@media (max-width:1080px){
  .balance-frame{grid-template-columns:1fr}
  .balance-meta{border-right:none;border-bottom:1px solid var(--line)}
  .balance-viz{grid-template-columns:1fr}
}

/* ---------- flywheel ---------- */
.flywheel{display:grid;grid-template-columns:1fr 24px 1fr 24px 1fr 24px 1fr;gap:8px;align-items:stretch}
.fw-stage{
  border:1px solid var(--line);background:var(--surface);border-radius:var(--radius-lg);
  padding:22px 20px;display:flex;flex-direction:column;gap:10px;min-height:220px;
}
.fw-stage.fw-end{border-color:rgba(74,240,200,.4);background:linear-gradient(180deg,rgba(74,240,200,.05),var(--surface) 60%)}
.fw-step{font-family:var(--mono);font-size:10.5px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.12em}
.fw-id{font-family:var(--display);font-weight:800;font-size:36px;color:var(--warm);letter-spacing:-.01em;line-height:1}
.fw-id.cool{color:var(--cool);font-size:24px;letter-spacing:.02em}
.fw-stage h4{font-family:var(--display);font-weight:600;font-size:15px;margin:0;letter-spacing:-.005em}
.fw-stage p{font-size:13px;color:var(--text-dim);margin:0;line-height:1.55;flex:1}
.fw-vol{display:flex;flex-direction:column;gap:2px;border-top:1px dashed var(--line);padding-top:10px;font-family:var(--mono);font-size:11px}
.fw-vol .vl{color:var(--text-faint);font-size:10px;letter-spacing:.1em;text-transform:uppercase}
.fw-vol .vv{color:var(--text)}
.fw-vol .vv.cool{color:var(--cool)}
.fw-arrow{display:flex;align-items:center;justify-content:center}
.fw-arrow svg{width:50px;height:20px}
@media (max-width:1080px){
  .flywheel{grid-template-columns:1fr;gap:8px}
  .fw-arrow{transform:rotate(90deg);height:30px}
}

/* ---------- founding cohort (index) ---------- */
.founding-section{background:linear-gradient(180deg,rgba(245,166,35,.04),transparent 30%)}
.founding-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:36px}
.founding-card{
  border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);
  padding:18px 20px;display:flex;flex-direction:column;gap:14px;transition:all .15s ease;
}
.founding-card:hover{border-color:var(--line-2);background:var(--surface-2)}
.fc-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.fc-id{font-family:var(--mono);font-size:12px;color:var(--warm);background:var(--warm-soft);border:1px solid rgba(245,166,35,.3);padding:3px 7px;border-radius:3px;letter-spacing:.05em}
.fc-name{font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-.005em;flex:1}
.fc-status{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;padding:3px 7px;border-radius:3px;border:1px solid var(--line);color:var(--text-dim)}
.fc-status.open{color:var(--cool);border-color:rgba(74,240,200,.35);background:var(--cool-soft)}
.fc-status.pending{color:var(--text-faint);border-color:var(--line)}
.fc-status.horizontal{color:var(--cool);border-color:rgba(74,240,200,.25);background:rgba(74,240,200,.04)}
.fc-id.cool{color:var(--cool);background:rgba(74,240,200,.08);border-color:rgba(74,240,200,.3)}
.founding-card.horizontal{border-style:solid}
.fc-slots{display:flex;gap:6px}
.fc-slots i{
  flex:1;height:28px;border-radius:4px;display:block;
  background:var(--bg-2);border:1px solid var(--line);
}
.fc-slots i.filled{background:var(--warm);border-color:var(--warm);box-shadow:inset 0 0 0 1px rgba(0,0,0,.15)}
.fc-slots i.open{background:repeating-linear-gradient(45deg,rgba(74,240,200,.14),rgba(74,240,200,.14) 4px,transparent 4px,transparent 8px);border-color:rgba(74,240,200,.4)}
.fc-slots i.locked{background:repeating-linear-gradient(45deg,rgba(255,255,255,.04),rgba(255,255,255,.04) 4px,transparent 4px,transparent 8px);border-color:var(--line)}
.fc-slots i.bundled{background:rgba(74,240,200,.55);border-color:rgba(74,240,200,.7);box-shadow:inset 0 0 0 1px rgba(0,0,0,.15)}
.fc-meta{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-family:var(--mono);font-size:11px;border-top:1px dashed var(--line);padding-top:10px}
.fc-meta span:nth-child(odd){color:var(--text-faint);letter-spacing:.05em}
.fc-meta span:nth-child(even){color:var(--text)}
@media (max-width:1080px){.founding-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.founding-grid{grid-template-columns:1fr}}

.founding-deal{
  border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);
  padding:28px 30px;display:flex;flex-direction:column;gap:18px;
}
.fd-head{display:flex;flex-direction:column;gap:6px}
.fd-tag{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.14em}
.fd-head h3{font-family:var(--display);font-weight:700;font-size:24px;margin:0;letter-spacing:-.015em}
.fd-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.fd-col h5{font-family:var(--display);font-weight:600;font-size:14px;margin:0 0 12px;color:var(--warm);letter-spacing:.005em}
.fd-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:13.5px;color:var(--text-dim)}
.fd-col li{padding-left:18px;position:relative;line-height:1.5}
.fd-col li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:1px;background:var(--warm)}
.fd-col li b{color:var(--text);font-weight:600}
@media (max-width:780px){.fd-cols{grid-template-columns:1fr}}

/* ---------- pricing matrix ---------- */
.pricing-table{
  border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);
  margin-bottom:36px;
}
.pt-row{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  border-bottom:1px solid var(--line);font-family:var(--mono);font-size:13px;
  position:relative;
}
.pt-row:last-child{border-bottom:none}
.pt-row.pt-head{background:var(--bg-2);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}
.pt-mod{padding:14px 18px;border-right:1px solid var(--line);color:var(--text);display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.pt-mod b{color:var(--warm);font-weight:500;margin-right:6px}
.pt-cell{padding:14px 18px;border-right:1px solid var(--line);text-align:right;color:var(--text)}
.pt-cell:last-child{border-right:none}
.pt-row.pt-bundle{background:linear-gradient(90deg,rgba(245,166,35,.06),transparent 70%)}
.pt-row.pt-bundle .pt-mod b{color:var(--warm)}
.pt-row.pt-bundle .pt-cell{color:var(--warm)}
.pt-recommended{
  display:inline-block;font-family:var(--mono);font-size:9.5px;
  color:#1a1306;background:var(--warm);padding:2px 6px;border-radius:3px;
  letter-spacing:.14em;text-transform:uppercase;font-weight:600;
}
@media (max-width:780px){
  .pt-row{grid-template-columns:1.6fr 1fr 1fr 1fr;font-size:11.5px}
  .pt-mod,.pt-cell{padding:11px 12px}
}
@media (max-width:560px){
  /* Allow the pricing matrix to scroll horizontally on narrow phones
     so columns stay readable instead of getting squashed. */
  .pricing-table{
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
  }
  .pt-row{
    min-width:460px;
    grid-template-columns:1.6fr 1fr 1fr 1.2fr;
    font-size:11px;
  }
  .pt-mod,.pt-cell{padding:10px 10px}
}

/* ---------- configurator ---------- */
.config{margin-top:36px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden}
.config-head{padding:22px 26px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.config-head h3{font-family:var(--display);font-weight:700;font-size:22px;margin:0;letter-spacing:-.01em}
.config-head .lbl{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.config-badge{font-family:var(--mono);font-size:11px;color:var(--cool);border:1px solid rgba(74,240,200,.3);padding:5px 10px;border-radius:999px;background:var(--cool-soft);display:inline-flex;align-items:center;gap:8px}
.config-badge .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--cool);box-shadow:0 0 8px var(--cool)}

/* v3.1 mode toggle */
.config-mode{
  padding:14px 26px;border-bottom:1px solid var(--line);
  display:flex;gap:8px;align-items:center;flex-wrap:wrap;
  background:rgba(255,255,255,.012);
}
.config-mode .mlbl{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em;margin-right:8px}
.mode-btn{
  padding:8px 16px;border:1px solid var(--line);border-radius:4px;
  background:var(--bg-2);color:var(--text-dim);
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;cursor:pointer;
  transition:all .15s ease;
}
.mode-btn:hover{color:var(--text);border-color:var(--line-2)}
.mode-btn.on{background:var(--warm);color:#1a1306;border-color:var(--warm)}

.config-tier{padding:18px 26px;display:flex;gap:10px;border-bottom:1px solid var(--line);align-items:center;flex-wrap:wrap}
.config-tier .tlbl{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em;margin-right:6px}
.config-tier .tlbl-2{margin-left:14px}
.tier-btn{padding:7px 13px;border:1px solid var(--line);border-radius:4px;background:var(--bg-2);color:var(--text-dim);font-family:var(--mono);font-size:12px;cursor:pointer;transition:all .15s ease}
.tier-btn:hover{border-color:var(--line-2);color:var(--text)}
.tier-btn.on{border-color:var(--warm);color:var(--warm);background:var(--warm-soft)}
.tier-btn[data-cohort].on{border-color:var(--cool);color:var(--cool);background:var(--cool-soft)}
.config-toggles{padding:20px 26px;display:grid;grid-template-columns:repeat(6,1fr);gap:10px;border-bottom:1px solid var(--line)}
.config-toggles.locked .toggle{cursor:not-allowed;opacity:.95}
.toggle{border:1px solid var(--line);border-radius:6px;padding:14px;cursor:pointer;background:var(--bg-2);transition:all .15s ease;user-select:none;display:flex;flex-direction:column;gap:6px}
.toggle:hover{border-color:var(--line-2)}
.toggle.on{border-color:var(--warm);background:var(--warm-soft)}
.toggle .t{font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:-.005em}
.toggle .p{font-family:var(--mono);font-size:11px;color:var(--text-dim);display:flex;align-items:center;gap:8px}
.toggle.on .p{color:var(--warm)}
.toggle .check{width:14px;height:14px;border:1px solid var(--line-2);border-radius:3px;display:inline-block;position:relative;flex:none}
.toggle.on .check{background:var(--warm);border-color:var(--warm)}
.toggle.on .check::after{content:"";position:absolute;left:3px;top:0px;width:5px;height:9px;border:solid #1a1306;border-width:0 2px 2px 0;transform:rotate(45deg)}
.config-callout{
  padding:14px 26px;border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,rgba(245,166,35,.08),transparent 70%);
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:13px;color:var(--text);
}
.config-callout .ch-tag{color:var(--warm);font-size:11px;letter-spacing:.1em;text-transform:uppercase}
.config-callout b{color:var(--warm);font-weight:500}
.config-savings{
  padding:14px 26px;border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,rgba(74,240,200,.06),transparent 70%);
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:13px;color:var(--text);
}
.config-savings .cs-tag{color:var(--cool);font-size:11px;letter-spacing:.1em;text-transform:uppercase}
.config-savings b{color:var(--cool);font-weight:500}
.config-total{padding:24px 26px;display:flex;justify-content:space-between;align-items:center;background:var(--bg-2);flex-wrap:wrap;gap:24px}
.config-total .label{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}
.config-total .total{font-family:var(--display);font-weight:800;font-size:56px;color:var(--text);letter-spacing:-.02em;line-height:1;margin-top:4px}
.config-total .total small{font-family:var(--mono);font-size:13px;font-weight:400;color:var(--text-dim);margin-left:6px}
.config-total .total .warm{color:var(--warm)}
.ct-side{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.ct-side-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;color:var(--text-dim);min-width:200px;gap:18px}
.ct-side-row span:last-child{color:var(--text)}
@media (max-width:980px){.config-toggles{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){
  .config-toggles{grid-template-columns:repeat(2,1fr);padding:18px 16px}
  .config-total{padding:24px 16px}
  .config-total .total{font-size:42px}
  .ct-side{align-items:flex-start;width:100%}
  .ct-side-row{min-width:0;width:100%}

  /* Configurator: stack each label centered above its button row.
     Uses flex-basis:100% on labels to force a row break via flex-wrap. */
  .config-mode{
    justify-content:center;
    padding:16px 16px;
    gap:8px;
  }
  .config-mode .mlbl{
    flex-basis:100%;
    text-align:center;
    margin:0 0 4px;
  }

  .config-tier{
    justify-content:center;
    padding:18px 16px;
    gap:8px;
  }
  .config-tier .tlbl{
    flex-basis:100%;
    text-align:center;
    margin:0 0 4px;
  }
  .config-tier .tlbl-2{
    margin-top:16px;
    padding-top:14px;
    border-top:1px solid var(--line);
  }

  .config-head{padding:20px 16px}
  .config-callout,
  .config-savings{padding:14px 16px}
}

/* ---------- FAQ ---------- */
.faq{padding:80px 0}
.faq-grid{display:grid;grid-template-columns:1fr;gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface)}
.faq-item{border-bottom:1px solid var(--line);padding:22px 26px;display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:flex-start}
.faq-item:last-child{border-bottom:none}
.faq-q{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.14em;text-transform:uppercase;padding-top:4px}
.faq-body h4{font-family:var(--display);font-weight:700;font-size:17px;margin:0 0 8px;letter-spacing:-.005em}
.faq-body p{color:var(--text-dim);font-size:14px;line-height:1.65;margin:0;max-width:60ch}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:48px 0 36px;margin-top:60px;background:var(--bg-2)}
footer .wrap{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.2fr;gap:28px}
footer h6{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.12em;margin:0 0 14px}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:13.5px;color:var(--text-dim)}
footer ul a:hover{color:var(--text)}
footer ul a{color:var(--text-dim);transition:color .15s ease}
footer .brand p{color:var(--text-dim);font-size:13.5px;max-width:36ch;margin:10px 0 16px}
footer .brand .built-in{display:block;margin-top:8px;font-family:var(--mono);font-size:11.5px;color:var(--text-faint);letter-spacing:.06em}
footer .impressum-mini{font-family:var(--mono);font-size:11.5px;color:var(--text-dim);line-height:1.6;gap:4px}
footer .impressum-mini li{font-size:11.5px}
footer .impressum-mini strong{color:var(--text);font-weight:600;letter-spacing:.02em}
footer .impressum-mini em{font-style:italic;color:var(--text-faint)}
footer .impressum-mini .todo{font-style:italic;color:var(--text-faint);padding:0 4px;border:1px dashed var(--line);border-radius:3px}
footer .impressum-mini a{color:var(--warm);transition:color .15s ease}
footer .impressum-mini a:hover{color:#ffb538}
footer .legal{grid-column:1/-1;border-top:1px solid var(--line);margin-top:24px;padding-top:20px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;color:var(--text-faint);flex-wrap:wrap;gap:14px}
footer .legal a{color:var(--text-dim);text-decoration:underline;text-underline-offset:2px}
footer .legal a:hover{color:var(--warm)}
@media (max-width:1080px){footer .wrap{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:780px){footer .wrap{grid-template-columns:1fr 1fr}}
@media (max-width:480px){footer .wrap{grid-template-columns:1fr}}

/* ---------- Form privacy notice (cohort + contact) ---------- */
.form-privacy-notice{font-size:12px;color:var(--text-dim);margin:16px 0 0;line-height:1.5;max-width:600px}
.form-privacy-notice a{color:var(--warm);text-decoration:underline;text-underline-offset:2px}
.form-privacy-notice a:hover{color:#ffb538}

/* ---------- Social icons (footer brand column) ---------- */
.socials{margin-top:18px}
.socials-lbl{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);margin-bottom:8px}
.socials-row{display:flex;gap:8px;flex-wrap:wrap}
.socials-row a{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:6px;
  border:1px solid var(--line);background:var(--surface);
  color:var(--text-dim);text-decoration:none;
  transition:color .15s,border-color .15s,background .15s,transform .15s;
}
.socials-row a:hover{color:var(--warm);border-color:rgba(245,166,35,.45);background:rgba(245,166,35,.06);transform:translateY(-1px)}
.socials-row a:focus-visible{outline:2px solid var(--warm);outline-offset:2px}
.socials-row svg{width:14px;height:14px;display:block;fill:currentColor}

/* ---------- Footer .legal right cluster (anchor links separated from i18n string) ---------- */
.legal-right{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}
.legal-right a{color:var(--text-dim);text-decoration:underline;text-underline-offset:2px}
.legal-right a:hover{color:var(--warm)}
.legal-right .sep{color:var(--text-faint);opacity:.6}

/* ---------- Cookie banner (sitewide) ---------- */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;
  background:rgba(13,16,22,.94);
  border-top:1px solid var(--line-2);
  padding:14px 0;
  z-index:200;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.cookie-banner .cookie-inner{display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:space-between}
.cookie-banner .cookie-body{flex:1;min-width:280px}
.cookie-banner .cookie-lbl{display:block;font-size:10px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;font-family:var(--mono);color:var(--cool)}
.cookie-banner p{margin:0;font-size:13px;line-height:1.55;color:var(--text-dim)}
.cookie-banner p strong{color:var(--text);font-weight:600}
.cookie-banner p a{color:var(--warm);text-decoration:underline;text-underline-offset:2px}
.cookie-banner .cookie-ok{
  background:var(--warm);color:#0a0c10;border:0;font-weight:600;
  font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  padding:10px 22px;border-radius:6px;cursor:pointer;flex-shrink:0;
  transition:background .15s ease;
}
.cookie-banner .cookie-ok:hover{background:#ffb43c}
@media (max-width:560px){
  .cookie-banner .cookie-inner{flex-direction:column;align-items:stretch}
  .cookie-banner .cookie-ok{align-self:flex-end}
}

/* ---------- Legal pages ---------- */
.legal-hero{padding:80px 0 40px;border-bottom:1px solid var(--line)}
.legal-breadcrumb{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-decoration:none;letter-spacing:.05em;text-transform:uppercase;display:inline-block;margin-bottom:18px}
.legal-breadcrumb:hover{color:var(--warm)}
.legal-hero h1{font-family:var(--display);font-weight:700;font-size:clamp(32px,5vw,52px);line-height:1.05;letter-spacing:-.02em;margin-bottom:20px;max-width:22ch}
.legal-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text-dim);font-family:var(--mono)}
.legal-meta .sep{opacity:.4}
.legal-lawyer-note{margin-top:18px;padding:10px 14px;border:1px solid rgba(245,166,35,.25);background:rgba(245,166,35,.06);border-radius:6px;font-size:13px;color:var(--text);max-width:680px;line-height:1.55}
.legal-lawyer-note a{color:var(--warm);text-decoration:underline;text-underline-offset:2px}
.legal-translation-note{margin-top:14px;padding:8px 12px;border-left:2px solid var(--cool);background:rgba(74,240,200,.04);font-size:12px;color:var(--text-dim);max-width:680px;font-style:italic;line-height:1.55}

.legal-content{padding:48px 0 80px}
.legal-content .wrap.narrow{max-width:760px}
.legal-content h2{font-family:var(--display);font-weight:600;font-size:24px;margin:48px 0 16px;letter-spacing:-.01em;color:var(--text);padding-bottom:8px;border-bottom:1px solid var(--line)}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{font-family:var(--display);font-weight:600;font-size:17px;margin:32px 0 12px;color:var(--text)}
.legal-content p{font-size:15px;line-height:1.7;color:var(--text-dim);margin:0 0 16px}
.legal-content ul,.legal-content ol{margin:0 0 16px 0;padding-left:20px}
.legal-content li{font-size:15px;line-height:1.7;color:var(--text-dim);margin-bottom:6px}
.legal-content strong{color:var(--text);font-weight:600}
.legal-content em{font-style:italic;color:var(--text-dim)}
.legal-content a{color:var(--warm);text-decoration:underline;text-underline-offset:3px}
.legal-content a:hover{color:#ffb538}
.legal-content code{font-family:var(--mono);font-size:13px;background:var(--surface);padding:2px 6px;border-radius:3px;color:var(--cool)}
.legal-content .todo-srl{font-style:italic;color:var(--text-faint);background:rgba(255,255,255,.03);padding:1px 6px;border-radius:3px;border:1px dashed var(--line)}
.legal-content blockquote{margin:24px 0;padding:18px 22px;border-left:3px solid var(--line-2);background:var(--surface);color:var(--text-mid,var(--text));font-size:14px;line-height:1.7;border-radius:0 6px 6px 0}
.legal-content blockquote p:last-child{margin-bottom:0}
.legal-content blockquote strong{color:var(--text)}
.legal-content hr{border:0;border-top:1px solid var(--line);margin:32px 0}
.legal-content details{margin:32px 0;border:1px solid var(--line);border-radius:8px;background:var(--surface);overflow:hidden}
.legal-content details summary{padding:14px 18px;cursor:pointer;font-family:var(--mono);font-size:12px;color:var(--text-dim);letter-spacing:.04em;text-transform:uppercase;user-select:none}
.legal-content details summary:hover{color:var(--text)}
.legal-content details[open] summary{border-bottom:1px solid var(--line);color:var(--warm)}
.legal-content details > *:not(summary){padding:0 18px}
.legal-content details > p,
.legal-content details > h3,
.legal-content details > ul{padding-left:18px;padding-right:18px}
.legal-content details p:first-of-type{margin-top:14px}
.legal-content details p:last-of-type{margin-bottom:14px}
.legal-content .legal-status{margin-top:48px;padding:16px 0 0;border-top:1px dashed var(--line);font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.03em;line-height:1.7}
.legal-content .legal-section-lbl{font-family:var(--mono);font-size:11px;color:var(--cool);letter-spacing:.08em;text-transform:uppercase;display:block;margin:36px 0 6px}
.legal-content .legal-callout{margin:24px 0;padding:18px 22px;border-left:3px solid var(--warm);background:rgba(245,166,35,.05);font-size:14px;line-height:1.7;border-radius:0 6px 6px 0}
.legal-content .legal-callout strong{color:var(--text)}

.legal-table{width:100%;border-collapse:collapse;margin:16px 0 24px;font-size:14px}
.legal-table th,.legal-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.legal-table th{font-family:var(--mono);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);background:var(--surface)}
.legal-table td{color:var(--text-dim);line-height:1.55}
.legal-table tbody tr:hover{background:rgba(255,255,255,.02)}
.legal-table td strong{color:var(--text)}

.legal-index-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:32px}
.legal-index-card{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:20px;transition:border-color .2s,background .2s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.legal-index-card:hover{border-color:var(--warm);background:var(--surface-2)}
.legal-index-card .lic-lbl{font-family:var(--mono);font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.legal-index-card h3{font-family:var(--display);font-size:18px;margin:0 0 8px;color:var(--text);font-weight:600;letter-spacing:-.01em}
.legal-index-card p{font-size:13px;line-height:1.55;color:var(--text-dim);margin:0 0 14px;flex:1}
.legal-index-card .lic-link{color:var(--warm);font-size:12px;font-family:var(--mono);text-decoration:none;letter-spacing:.05em}
.legal-index-card:hover .lic-link{text-decoration:underline}

/* ---------- utils ---------- */
.mono{font-family:var(--mono)}
.warm{color:var(--warm)}
.cool{color:var(--cool)}
.muted{color:var(--text-dim)}

/* =========================================================
   COHORT PAGE
   ========================================================= */
.cohort-hero{padding:64px 0 36px}
.cohort-hero h1{
  font-family:var(--display);font-weight:800;font-size:clamp(36px,5vw,64px);
  line-height:1.04;letter-spacing:-.025em;margin:18px 0 16px;max-width:18ch;
}
.cohort-hero h1 em{font-style:italic;color:var(--warm)}
.cohort-hero p.lede{max-width:60ch;color:var(--text-dim);font-size:17px;line-height:1.6}

.cohort-modules{padding:40px 0 24px}
.cm-grid-vertical{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
.cm-grid-horizontal{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media (max-width:1080px){.cm-grid-vertical{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.cm-grid-vertical,.cm-grid-horizontal{grid-template-columns:1fr}}

.cm-horizontals-note{
  margin:14px 0 4px;
  padding:18px 22px;
  border:1px dashed rgba(255,255,255,0.10);
  border-radius:10px;
  background:rgba(74,240,200,0.03);
}
.cm-horizontals-note .mono{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.cm-horizontals-note .cool{color:var(--cool)}
.cm-horizontals-note p{margin:0;font-size:14px;color:var(--text-dim);max-width:760px;line-height:1.55}

.cm-card{
  position:relative;border:1px solid var(--line);background:var(--surface);
  border-radius:var(--radius-lg);padding:20px 18px 16px;
  display:flex;flex-direction:column;gap:10px;min-height:230px;cursor:pointer;
  transition:all .2s ease;
}
.cm-card:hover{border-color:var(--line-2);background:var(--surface-2);transform:translateY(-2px)}
.cm-card.selected{
  border-color:var(--warm);
  background:linear-gradient(180deg,rgba(245,166,35,.08),var(--surface) 70%);
  box-shadow:0 0 0 1px rgba(245,166,35,.4), 0 10px 30px rgba(245,166,35,.06);
}
.cm-card .corner-badge{
  position:absolute;top:0;right:0;
  font-family:var(--mono);font-size:9.5px;color:#1a1306;background:var(--warm);
  padding:3px 8px;border-radius:0 var(--radius-lg) 0 6px;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;opacity:0;pointer-events:none;
  transition:opacity .15s ease;
}
.cm-card.selected .corner-badge{opacity:1}
.cm-card .num{font-family:var(--mono);font-size:11px;color:var(--text-faint)}
.cm-card .roman{font-family:var(--display);font-weight:800;font-size:24px;color:var(--warm);margin-top:2px;line-height:1}
.cm-card h3{font-family:var(--display);font-weight:700;font-size:16px;margin:6px 0 4px;letter-spacing:-.005em;line-height:1.25}
.cm-card .tagline{color:var(--text-dim);font-size:13px;line-height:1.5;flex:1}
.cm-dots{display:flex;gap:4px;margin-top:8px}
.cm-dots i{width:8px;height:8px;border-radius:50%;background:var(--bg-2);border:1px solid var(--line);display:inline-block}
.cm-dots i.filled{background:var(--warm);border-color:var(--warm)}
.cm-dots i.locked{background:repeating-linear-gradient(45deg,rgba(255,255,255,.08),rgba(255,255,255,.08) 2px,transparent 2px,transparent 4px)}
.cm-slot-line{
  font-family:var(--mono);font-size:10.5px;color:var(--text-faint);
  letter-spacing:.08em;text-transform:uppercase;margin-top:4px;
}

/* selection panel */
.cohort-panel{
  margin-top:32px;border:1px solid var(--warm);border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(245,166,35,.05),var(--surface) 50%);
  padding:32px 32px 28px;display:none;
}
.cohort-panel.open{display:block}
.cp-head{
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  margin-bottom:24px;padding-bottom:18px;border-bottom:1px dashed var(--line);
}
.cp-head .cp-eyebrow{font-family:var(--mono);font-size:11px;color:var(--warm);letter-spacing:.14em;text-transform:uppercase}
.cp-head h2{font-family:var(--display);font-weight:700;font-size:26px;margin:6px 0 0;letter-spacing:-.01em}
.cp-cols{display:grid;grid-template-columns:1fr 1fr;gap:32px}
@media (max-width:780px){.cp-cols{grid-template-columns:1fr}}
.cp-col h4{font-family:var(--display);font-weight:600;font-size:14px;margin:0 0 12px;color:var(--warm);letter-spacing:.005em}
.cp-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--text-dim)}
.cp-col li{padding-left:18px;position:relative;line-height:1.55}
.cp-col li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:1px;background:var(--warm)}
.cp-col li.load-bearing{color:var(--text);font-weight:500}
.cp-col li.load-bearing::before{background:var(--cool);width:10px;height:2px;top:10px}

.cp-tier-block{margin-top:26px;padding-top:24px;border-top:1px dashed var(--line)}
.cp-tier-label{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px}
.cp-tier-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cp-tier-pill{
  display:flex;flex-direction:column;gap:4px;align-items:flex-start;
  padding:12px 18px;border:1px solid var(--line);border-radius:6px;
  background:var(--bg-2);color:var(--text);
  font-family:var(--mono);font-size:12px;cursor:pointer;transition:all .15s ease;min-width:160px;
}
.cp-tier-pill:hover{border-color:var(--line-2)}
.cp-tier-pill.on{border-color:var(--warm);background:var(--warm-soft);color:var(--warm)}
.cp-tier-pill .tier-name{font-family:var(--display);font-weight:700;font-size:14px;color:var(--text);letter-spacing:-.005em}
.cp-tier-pill.on .tier-name{color:var(--warm)}
.cp-tier-pill .tier-price{font-size:12px;color:var(--text-dim)}
.cp-tier-pill .tier-list{font-size:10.5px;color:var(--text-faint);text-decoration:line-through}
.cp-tier-pill.locked{cursor:not-allowed;opacity:.55;display:flex;align-items:center;flex-direction:row;gap:8px}
.cp-tier-pill.locked .lock-svg{width:14px;height:14px;stroke:var(--text-faint);fill:none}

/* m1 byo toggle inside panel */
.cp-m1-toggle{
  margin-top:18px;display:flex;gap:8px;align-items:center;font-family:var(--mono);font-size:12px;color:var(--text-dim);
  padding:12px 14px;border:1px dashed var(--line);border-radius:6px;background:rgba(255,255,255,.012);flex-wrap:wrap;
}
.cp-m1-toggle .ml{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;font-size:11px;margin-right:6px}
.cp-m1-toggle .m1-btn{
  padding:6px 12px;border:1px solid var(--line);border-radius:4px;
  background:var(--bg-2);color:var(--text-dim);font-family:var(--mono);font-size:12px;cursor:pointer;
}
.cp-m1-toggle .m1-btn.on{border-color:var(--warm);color:var(--warm);background:var(--warm-soft)}

.cp-cta{
  margin-top:26px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding-top:24px;border-top:1px dashed var(--line);
}
.cp-cta .btn{padding:13px 22px;font-size:15px}
.cp-foot{font-family:var(--mono);font-size:11px;color:var(--text-faint);margin-top:18px;letter-spacing:.04em}

.cp-form{
  margin-top:22px;display:none;
  padding:22px;border:1px dashed var(--warm);border-radius:8px;background:rgba(245,166,35,.04);
}
.cp-form.open{display:block}
.cp-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px}
.cp-form input,.cp-form textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);background:var(--bg-2);
  color:var(--text);font-family:var(--body);font-size:14px;border-radius:4px;
}
.cp-form input:focus,.cp-form textarea:focus{outline:none;border-color:var(--warm)}
.cp-form label{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:5px}
.cp-form textarea{min-height:90px;resize:vertical}
.cp-form .stripe-notice{
  margin-top:14px;padding:12px 14px;border:1px dashed var(--line);border-radius:6px;
  background:rgba(255,255,255,.02);font-family:var(--mono);font-size:11.5px;
  color:var(--text-dim);line-height:1.55;display:none;
}
.cp-form .stripe-notice.show{display:block}
@media (max-width:680px){.cp-form .form-row{grid-template-columns:1fr}}

/* "what happens next" 3-step strip */
.next-strip{padding:60px 0 40px}
.next-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:780px){.next-grid{grid-template-columns:1fr}}
.next-card{
  border:1px solid var(--line);background:var(--surface);border-radius:var(--radius-lg);
  padding:22px 22px 20px;display:flex;flex-direction:column;gap:8px;
}
.next-card .step-n{font-family:var(--display);font-weight:800;font-size:34px;color:var(--warm);line-height:1;letter-spacing:-.02em}
.next-card h4{font-family:var(--display);font-weight:600;font-size:16px;margin:8px 0 4px}
.next-card p{font-size:13.5px;color:var(--text-dim);margin:0;line-height:1.55}

/* =========================================================
   CONTACT PAGE
   ========================================================= */
.contact-hero{padding:64px 0 28px}
.contact-hero h1{
  font-family:var(--display);font-weight:800;font-size:clamp(34px,4.6vw,58px);
  line-height:1.05;letter-spacing:-.025em;margin:18px 0 18px;max-width:22ch;
}
.contact-hero h1 em{font-style:italic;color:var(--warm)}
.contact-hero p.lede{max-width:62ch;color:var(--text-dim);font-size:17px;line-height:1.65}

.contact-cols{display:grid;grid-template-columns:1fr 1.4fr;gap:32px;padding-bottom:48px}
@media (max-width:900px){.contact-cols{grid-template-columns:1fr}}
.contact-col{
  border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);
  padding:28px 28px 26px;display:flex;flex-direction:column;gap:14px;
}
.contact-col h2{font-family:var(--display);font-weight:700;font-size:22px;margin:0;letter-spacing:-.01em}
.contact-col .lbl{margin-bottom:0}
.contact-col p{color:var(--text-dim);font-size:14.5px;line-height:1.6;margin:0}
.contact-col .col-cta{margin-top:12px}

.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.contact-form label{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:5px}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:11px 13px;border:1px solid var(--line);background:var(--bg-2);
  color:var(--text);font-family:var(--body);font-size:14px;border-radius:4px;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--warm)}
.contact-form textarea{min-height:130px;resize:vertical;font-family:var(--body)}
.contact-form select{font-family:var(--body)}
@media (max-width:680px){.contact-form .form-row{grid-template-columns:1fr}}

.promise-block{
  margin-top:18px;padding:28px 0;
  border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);
  max-width:760px;
}
.promise-block h3{
  font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:.005em;
  margin:0 0 14px;color:var(--warm);text-transform:none;
}
.promise-block ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.promise-block li{
  font-family:var(--display);font-weight:500;font-size:17px;line-height:1.5;color:var(--text);
  padding-left:18px;position:relative;max-width:54ch;
}
.promise-block li::before{content:"—";position:absolute;left:0;color:var(--warm)}
.promise-block .sig{font-family:var(--mono);font-size:11.5px;color:var(--text-faint);margin-top:16px;letter-spacing:.1em}

.operator-block{
  margin-top:36px;padding:20px 22px;
  border:1px dashed var(--line);border-radius:8px;background:rgba(255,255,255,.012);
  font-family:var(--mono);font-size:12px;color:var(--text-dim);line-height:1.7;
  max-width:380px;
}
.operator-block strong{color:var(--text);font-weight:500}

/* locked logo in nav (2026-06-04) */
.logo-img{height:46px;width:auto;display:block;filter:drop-shadow(0 0 6px rgba(245,166,35,.22))}
.logo{gap:9px}

/* tier capacity sublabel + Command line (2026-06-06) */
.tier-cap{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.03em;color:var(--warm);opacity:.9;margin:3px 0 5px}
.cp-tier-pill.locked .tier-cap{color:var(--text-dim);opacity:.8}
.cp-tier-more{margin-top:10px;font-family:var(--mono);font-size:11px;color:var(--text-dim)}
.cp-tier-more a{color:var(--warm);text-decoration:none;border-bottom:1px solid rgba(245,166,35,.4)}
.cp-tier-more a:hover{border-bottom-color:var(--warm)}

/* tier sizing legend under pricing matrix (2026-06-06) */
.tier-sizing-wrap{margin-top:24px}
.ts-title{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--text-faint);margin:0 0 10px}
.ts-table .pt-row{font-size:12.5px}
.ts-table .pt-cell{color:var(--warm);font-family:var(--mono)}
.ts-note{font-family:var(--mono);font-size:11px;color:var(--text-dim);margin-top:12px;line-height:1.55;max-width:680px}

/* VAT/TVA suffix — appears next to every visible price.
   Two delivery modes:
   1. Explicit inline <small class="vat-sfx" data-i18n="price.vat"> spans
      (used in cohort tier pills + module section narrative prices)
   2. CSS ::after pseudo-elements that auto-append on high-density surfaces
      (pricing matrix cells, configurator total + side totals + per-module prices).
   Pseudo-elements use the [lang="ro"] selector for the TVA variant —
   the i18n.js setLang() writes document.documentElement.lang so this just works. */
.vat-sfx{font-family:var(--mono);font-size:10.5px;color:var(--text-faint);letter-spacing:.03em;margin-left:3px;font-weight:400;opacity:.85}

/* English: "+ VAT" auto-appended via pseudo-element */
.pricing-table:not(.ts-table) .pt-row:not(.pt-head) .pt-cell::after,
.mod-price::after,
.config-total .total::after,
#list-total::after,
#founding-total::after{
  content:" + VAT";
  font-family:var(--mono);
  font-size:10.5px;
  color:var(--text-faint);
  opacity:.85;
  margin-left:3px;
  letter-spacing:.03em;
  font-weight:400;
}

/* Romanian: "+ TVA" override when <html lang="ro"> */
[lang="ro"] .pricing-table:not(.ts-table) .pt-row:not(.pt-head) .pt-cell::after,
[lang="ro"] .mod-price::after,
[lang="ro"] .config-total .total::after,
[lang="ro"] #list-total::after,
[lang="ro"] #founding-total::after{
  content:" + TVA";
}

/* BYO/Bundled explainer note shown on cohort M1 selection panel
   and below the pricing matrix on the homepage */
.cp-m1-note,
.pr-byo-note{
  margin:10px 0 0;
  font-family:var(--mono);
  font-size:11.5px;
  color:var(--text-dim);
  line-height:1.55;
  max-width:680px;
  border-left:2px solid var(--cool);
  padding:8px 12px;
  background:rgba(74,240,200,0.04);
  border-radius:0 4px 4px 0;
}

/* Pricing-matrix explainer: extra top margin so it breathes below the table */
.pr-byo-note{
  margin:24px auto 0;
}

/* ---------- Form: honeypot (anti-bot) ----------
   Wrapped div is removed from layout AND hidden from accessibility tree.
   Bots that parse forms will fill the input; humans never see it. */
.hp-field{
  position:absolute;
  left:-10000px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}

/* ---------- Form: inline success / error state after fetch ----------
   Shown by JS after the user clicks Send. Replaces the need for an alert(). */
.cp-form-state,
.ct-form-state{
  margin-top:18px;
  padding:14px 18px;
  border-radius:8px;
  font-family:var(--mono);
  font-size:13px;
  line-height:1.55;
  border:1px solid transparent;
}
.cp-form-state.success,
.ct-form-state.success{
  background:rgba(74,240,200,0.08);
  border-color:rgba(74,240,200,0.35);
  color:var(--cool);
}
.cp-form-state.error,
.ct-form-state.error{
  background:rgba(232,93,138,0.06);
  border-color:rgba(232,93,138,0.30);
  color:#e85d8a;
}

/* =====================================================================
   Mobile polish v1.1 — 24 narrow-viewport fixes from the mobile audit.
   Ordered widest → narrowest so cascade applies correctly.
   Desktop (>1080px) is intentionally untouched.
   ===================================================================== */

/* ── ≤1080px ──────────────────────────────────────────────────────────── */
@media (max-width:1080px){
  /* #21 — lang-toggle RO/EN tap target was ~21×32, below WCAG 44px */
  .lang-toggle button{padding:10px 14px;font-size:13px;min-height:44px;min-width:44px}
}

/* ── ≤780px ───────────────────────────────────────────────────────────── */
@media (max-width:780px){
  /* #11 — section padding 84px way too generous on phones, reduce to 56px */
  section{padding:56px 0}
  /* #10 — footer link tap targets were ~21-23px tall, fails WCAG */
  footer ul a{display:inline-block;padding:8px 0;min-height:44px;line-height:1.4}
  footer ul{gap:0}
  /* #24 — Impressum mini was 11.5px mono, borderline illegible for regulator-required info */
  footer .impressum-mini,
  footer .impressum-mini li{font-size:13px;line-height:1.7}
}

/* ── ≤680px ───────────────────────────────────────────────────────────── */
@media (max-width:680px){
  /* #6 — form inputs at 14px triggered iOS Safari auto-zoom on focus.
     Bumping to 16px is the universal cure. Affects contact + cohort forms. */
  .contact-form input,
  .contact-form select,
  .contact-form textarea,
  .cp-form input,
  .cp-form select,
  .cp-form textarea{font-size:16px}
}

/* ── ≤560px ───────────────────────────────────────────────────────────── */
@media (max-width:560px){
  /* #1 (CRITICAL) — cookie banner min-width:280px forced horizontal page scroll */
  .cookie-banner .cookie-body{min-width:0}
  /* #12 — cookie banner consumed 25-30% of viewport, occluded Send button */
  .cookie-banner{padding:10px 0}
  .cookie-banner p{font-size:12px;line-height:1.45}
  .cookie-banner .cookie-lbl{display:none}
  /* #13 — cookie "Got it" was ~32-36px, bump to 44px min */
  .cookie-banner .cookie-ok{min-height:44px;padding:12px 24px}

  /* #15 — hero-strip `·` separators stranded as orphans on wrap.
     Stack vertically instead, drop dots. */
  .hero-strip .sep{display:none}
  .hero-strip{gap:8px 18px;flex-direction:column;align-items:flex-start}

  /* #16 — .step-art fixed 220px stacked 660px of decorative chrome on 3 cards */
  .step-art{height:160px}

  /* #17 — .phone-screen min-height:520px dominated 568px iPhone SE viewport */
  .phone{max-width:280px}
  .phone-screen{min-height:420px}

  /* #18 — Pricing matrix sticky module column.
     Without this, swiping right to see Enterprise prices scrolled the
     module label off-screen. Sticky keeps "M1 Boarding..." pinned left
     while the price columns scroll. */
  .pricing-table .pt-mod{
    position:sticky;left:0;
    background:var(--surface);
    z-index:1;
    box-shadow:1px 0 0 var(--line);
  }
  .pricing-table .pt-row.pt-head .pt-mod{background:var(--bg-2)}

  /* #20 — 9 social icons at 30×30 wrapped to 2 unbalanced rows + failed 44px target.
     Bump to 36×36 with tighter gap; still fits in one row at 320px. */
  .socials-row{gap:6px;justify-content:flex-start}
  .socials-row a{width:36px;height:36px}
  .socials-row svg{width:15px;height:15px}

  /* #14 — FAQ items at 320px had only 144px usable for question text.
     Collapse the "Q1" label column into the question flow. */
  .faq-item{padding:18px 16px;gap:10px;grid-template-columns:1fr}
  .faq-q{padding-top:0;margin-bottom:-4px}
  .faq-body h4{font-size:16px;line-height:1.25}
  .faq-body p{font-size:13.5px}

  /* #5 (HIGH) — radar SVG axis labels at font-size="10" rendered ~4.5px
     after scaling to phone. Bump up so DRIVE/PREY/DEFENSE etc. stay legible. */
  .radar text{font-size:20px}

  /* #7 — contact-hero h1 has hardcoded <br> tags that forced "partnerships,
     or working-dog" to render whole and overflow at 320px. Let it wrap. */
  .contact-hero h1 br{display:none}

  /* #22 — legal pages 2-col <table> cells got extremely narrow at 320px.
     Allow horizontal scroll on the table itself. */
  .legal-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
}

/* ── ≤520px ───────────────────────────────────────────────────────────── */
@media (max-width:520px){
  /* #3 (HIGH) — .wrap 28px padding ate 17.5% of 320px viewport.
     Single biggest win: drop to 18px → +20px content width everywhere. */
  .wrap{padding:0 18px}

  /* #11 — section padding further reduce on narrow phones */
  section{padding:44px 0}

  /* #8 — cohort-panel had 32px internal padding inside .wrap's 28px = 120px chrome */
  .cohort-panel{padding:20px 16px 18px;margin-top:20px}

  /* #9 — cp-tier-pill min-width:160px left orphan gutters when stacked.
     Stack the 3 tier pills vertically full-width instead. */
  .cp-tier-row{flex-direction:column;align-items:stretch}
  .cp-tier-pill{min-width:0;width:100%}

  /* #4 (HIGH) — Chapter I "RO · EN · DE · IT" at 34px Syne overflowed.
     overflow-wrap:anywhere is a safety net if any chapter title is too long. */
  .lh-stat .v{font-size:24px;overflow-wrap:anywhere}

  /* #19 — hero-meta cells: inline <small> wrapped with leading 6px indent.
     Stack the small descriptor under the value cleanly. */
  .hero-meta div{padding:14px 12px}
  .hero-meta .v{font-size:17px;display:flex;flex-direction:column;align-items:flex-start;gap:2px}
  .hero-meta .v small{margin-left:0}

  /* #23 — .module .pill positioned absolute top-right could collide with
     .num text on featured M2/M3 cards. Inline it instead. */
  .module .pill{position:static;align-self:flex-start;margin-bottom:4px}

  /* Lighthouse copy padding tightening (supports #4 by giving stats more room) */
  .lh-copy{padding:24px 18px}
  .lh-stats{padding:24px 18px}
}

/* ── ≤480px ───────────────────────────────────────────────────────────── */
@media (max-width:480px){
  /* #2 (CRITICAL) — hero h1 clamp(44px,7vw,96px) had floor of 44px below 628px.
     "for working dogs." at Syne 800 / 44px = ~420px wide, overflowed 264px content.
     Lower the floor to 32px and add overflow-wrap as final safety net. */
  .hero h1{
    font-size:clamp(32px,9.5vw,42px);
    overflow-wrap:break-word;
  }
}
