/*
Theme Name: CodeDeutsch
Theme URI: https://codedeutsch.com
Author: CodeDeutsch
Description: Editorial "Korrektur" theme for CodeDeutsch - work-ready German for IT professionals. Warm paper, ink, and a single red correction accent.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: codedeutsch
*/

/* ════════════════════════════════════════════════════════════
   TOKENS
   ════════════════════════════════════════════════════════════ */
:root{
  --paper:   #f3eee5;
  --sheet:   #faf7f0;
  --paper-2: #e8e0d3;
  --ink:     #1b1813;
  --ink-soft:#5b554a;
  --ink-mute:#8a8475;
  --rule:    #d2cbbb;
  --rule-2:  #c4bca9;
  --red:     #ce3b2b;
  --red-btn: #bf3422;
  --red-hov: #a52d1c;
  --red-soft:rgba(206,59,43,0.12);

  --font:'Schibsted Grotesk', system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;

  --container: 1180px;
  --pad: 36px;
  --radius: 8px;
  --radius-sm: 4px;
}

/* ════════════════════════════════════════════════════════════
   RESET + BASE
   ════════════════════════════════════════════════════════════ */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--paper); color:var(--ink);
  font-family:var(--font); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; height:auto; display:block; }
::selection{ background:var(--red); color:#fff; }
:focus-visible{ outline:2px solid var(--red); outline-offset:3px; border-radius:2px; }

/* ════════════════════════════════════════════════════════════
   LAYOUT - one consistent width everywhere
   ════════════════════════════════════════════════════════════ */
.container,
.container-narrow{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--pad);
}

.section{ padding:104px 0; }
.section--rule{ border-top:1px solid var(--rule); }

/* reading measure for long-form text, kept flush-left so block edges align */
.measure{ max-width:760px; }

/* ════════════════════════════════════════════════════════════
   SHARED BITS
   ════════════════════════════════════════════════════════════ */
.word{ font-family:var(--font); font-weight:700; letter-spacing:-0.02em; color:var(--ink); }
.word .stop{ color:var(--red); }
.mono{ font-family:var(--mono); }
.muted{ color:var(--ink-mute); }

.kicker{
  display:inline-flex; align-items:center; gap:11px;
  font-family:var(--font); font-weight:500; font-size:13px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft);
}
.kicker .sq{ width:7px; height:7px; background:var(--red); display:block; flex:0 0 auto; }

.section-head{ max-width:680px; margin-bottom:56px; }
.section-head .kicker{ margin-bottom:20px; }
.section-head h2{
  font-family:var(--font); font-weight:900; letter-spacing:-0.03em; line-height:1.0;
  font-size:clamp(34px, 4.4vw, 52px);
}
.section-head h2 em{ font-style:normal; color:var(--red); }
.section-head p{ font-size:18px; color:var(--ink-soft); margin-top:16px; max-width:560px; }

/* buttons */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font); font-weight:600; font-size:15px;
  padding:13px 22px; border-radius:var(--radius-sm); cursor:pointer; border:none;
  transition:transform .12s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.btn .arr{ font-family:var(--mono); }
.btn-red{ background:var(--red-btn); color:#fff; }
.btn-red:hover{ transform:translateY(-1px); background:var(--red-hov); }
.btn-line{ color:var(--ink); border-bottom:2px solid var(--ink); border-radius:0; padding:5px 0; font-weight:500; }
.btn-line:hover{ color:var(--red); border-color:var(--red); }
.btn-ghost{ color:var(--ink); border:1px solid var(--rule-2); background:transparent; }
.btn-ghost:hover{ border-color:var(--ink); }

/* a plain inline text link with arrow */
.txtlink{ font-family:var(--font); font-weight:500; color:var(--ink); display:inline-flex; align-items:center; gap:8px; }
.txtlink .arr{ font-family:var(--mono); color:var(--red); transition:transform .18s ease; }
.txtlink:hover .arr{ transform:translateX(3px); }
.txtlink:hover{ color:var(--red); }

/* ════════════════════════════════════════════════════════════
   HEADER / NAV
   ════════════════════════════════════════════════════════════ */
#site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(243,238,229,0.82); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--rule);
}
.nav-inner{
  max-width:var(--container); margin:0 auto; padding:0 var(--pad);
  height:74px; display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.nav-logo{ font-family:var(--font); font-weight:700; font-size:21px; letter-spacing:-0.02em; color:var(--ink); display:inline-block; }
.nav-logo .stop{ color:var(--red); }
.logo-dot{ display:inline-block; width:0.30em; height:0.30em; background:var(--red); margin-left:0.09em; vertical-align:baseline; }
#site-navigation{ display:flex; align-items:center; gap:30px; }
#site-navigation ul{ list-style:none; display:flex; align-items:center; gap:30px; }
#site-navigation a{ font-size:14px; color:var(--ink-soft); transition:color .18s; }
#site-navigation a:hover{ color:var(--ink); }
.nav-cta{ font-family:var(--font); font-weight:600; font-size:14px; background:var(--red-btn); color:#fff !important; padding:9px 16px; border-radius:var(--radius-sm); transition:background .18s, transform .12s; }
.nav-cta:hover{ background:var(--red-hov); transform:translateY(-1px); }

/* mobile hamburger (hidden on desktop) */
.nav-toggle{ display:none; width:42px; height:38px; border:1px solid var(--rule-2); border-radius:var(--radius-sm); background:transparent; cursor:pointer; position:relative; padding:0; }
.nav-toggle span{ position:absolute; left:11px; right:11px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s ease, opacity .2s ease; }
.nav-toggle span:nth-child(1){ top:12px; }
.nav-toggle span:nth-child(2){ top:18px; }
.nav-toggle span:nth-child(3){ top:24px; }
#site-header.nav-open .nav-toggle span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
#site-header.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
#site-header.nav-open .nav-toggle span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* language switcher */
.lang-switcher{ display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:12px; color:var(--ink-mute); letter-spacing:.04em; }
.lang-btn{ background:none; border:none; cursor:pointer; font-family:var(--mono); font-size:12px; color:var(--ink-mute); padding:2px; transition:color .15s; }
.lang-btn.active{ color:var(--ink); font-weight:500; }
.lang-btn:hover{ color:var(--ink); }
.lang-divider{ opacity:.4; }

/* ════════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════════ */
.hero{ padding:118px 0 112px; }
.hero-grid{
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.06fr);
  gap:72px; align-items:center;
}
.hero-copy .kicker{ margin-bottom:32px; }
.hero-copy h1{
  font-family:var(--font); font-weight:900; letter-spacing:-0.035em; line-height:1.0;
  font-size:clamp(44px, 6vw, 80px); margin-bottom:26px;
}
.hero-copy h1 .l2{ display:block; }
.hero-copy .sub{
  font-size:19px; line-height:1.62; color:var(--ink-soft);
  max-width:540px; margin-bottom:30px;
}
.struck{ text-decoration:line-through; text-decoration-color:var(--red); text-decoration-thickness:2px; color:var(--ink-mute); }
.scenarios{
  font-family:var(--mono); font-size:13px; letter-spacing:.03em; color:var(--ink-mute);
  display:flex; flex-wrap:wrap; gap:9px 13px; align-items:center; margin-bottom:42px;
}
.scenarios .d{ color:var(--rule-2); }
.hero-actions{ display:flex; align-items:center; gap:26px; flex-wrap:wrap; }

/* ── the correction sheet (signature) - enlarged ── */
.sheet{
  background:var(--sheet); border:1px solid var(--rule); border-radius:14px;
  padding:40px 42px 44px; box-shadow:0 38px 70px -42px rgba(27,24,19,0.5);
  position:relative;
}
.sheet::before{ content:''; position:absolute; left:18px; top:34px; bottom:34px; width:2px; background:var(--red-soft); }
.sheet-inner{ padding-left:24px; }
.sheet-head{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding-bottom:20px; margin-bottom:24px; border-bottom:1px solid var(--rule);
}
.sheet-head .label{ font-family:var(--mono); font-size:12.5px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-mute); }
.korr{ font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--red); border:1px solid var(--red-soft); padding:5px 10px; border-radius:4px; white-space:nowrap; }

.seg-label{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:11px; }
.draft{ position:relative; display:inline; color:var(--ink-soft); font-size:18px; line-height:1.55; }
.draft::after{
  content:''; position:absolute; left:0; right:0; top:53%; height:2px; background:var(--red);
  transform:scaleX(0); transform-origin:left; animation:strike .55s cubic-bezier(.5,0,.3,1) forwards .9s;
}
.besser{ display:flex; align-items:center; gap:12px; margin:26px 0 18px; }
.besser .mk{ font-family:var(--mono); font-size:13.5px; color:var(--red); }
.besser .ln{ flex:1; height:1px; background:var(--rule); }
.correction{ opacity:0; transform:translateY(6px); animation:fadein .5s ease forwards 1.55s; }
.correction .seg-label{ color:var(--red); }
.de{ font-family:var(--mono); font-size:15.5px; line-height:1.95; color:var(--ink); }
.de b{ color:var(--red); font-weight:500; }

@keyframes strike{ to{ transform:scaleX(1); } }
@keyframes fadein{ to{ opacity:1; transform:none; } }

/* ════════════════════════════════════════════════════════════
   FREE CALL
   ════════════════════════════════════════════════════════════ */
.fc-grid{ display:grid; grid-template-columns:minmax(0,1.1fr) minmax(0,0.9fr); gap:64px; align-items:center; }
.fc-steps{ display:flex; flex-direction:column; gap:30px; margin-top:36px; }
.fc-step{ display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start; }
.fc-step .n{ font-family:var(--mono); font-size:13px; color:var(--red); padding-top:3px; }
.fc-step h4{ font-family:var(--font); font-weight:700; font-size:18px; margin-bottom:6px; letter-spacing:-0.01em; }
.fc-step p{ font-size:15px; color:var(--ink-soft); line-height:1.55; }

.fc-card{ background:var(--sheet); border:1px solid var(--rule); border-radius:var(--radius); padding:34px; box-shadow:0 30px 60px -42px rgba(27,24,19,0.45); }
.fc-card .tag{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:18px; }
.fc-card h3{ font-family:var(--font); font-weight:700; font-size:23px; letter-spacing:-0.02em; margin-bottom:18px; }
.fc-price{ display:flex; align-items:baseline; gap:10px; padding:18px 0; border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); margin-bottom:22px; }
.fc-price .amt{ font-family:var(--font); font-weight:900; font-size:30px; color:var(--ink); letter-spacing:-0.02em; }
.fc-price .note{ font-family:var(--mono); font-size:12px; color:var(--ink-mute); }
.fc-card ul{ list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:26px; }
.fc-card li{ font-size:14.5px; color:var(--ink-soft); display:flex; gap:10px; line-height:1.45; }
.fc-card li::before{ content:'✓'; color:var(--red); font-weight:700; }
.fc-card .btn{ width:100%; justify-content:center; }
.fc-disclaimer{ font-family:var(--mono); font-size:12px; color:var(--ink-mute); margin-top:16px; line-height:1.5; }

/* ════════════════════════════════════════════════════════════
   THREE MODES
   ════════════════════════════════════════════════════════════ */
.modes-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.mode-card{ background:var(--sheet); border:1px solid var(--rule); border-radius:var(--radius); padding:32px; display:flex; flex-direction:column; transition:transform .18s, box-shadow .18s; }
.mode-card:hover{ transform:translateY(-4px); box-shadow:0 24px 48px -34px rgba(27,24,19,0.4); }
.mode-tag{ display:inline-block; font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); border:1px solid var(--rule-2); border-radius:3px; padding:5px 10px; margin-bottom:20px; align-self:flex-start; }
.mode-card h3{ font-family:var(--font); font-weight:700; font-size:20px; letter-spacing:-0.01em; margin-bottom:12px; line-height:1.2; }
.mode-card p{ font-size:14.5px; color:var(--ink-soft); line-height:1.55; margin-bottom:22px; }
.mode-card .txtlink{ margin-top:auto; font-size:13.5px; }

/* ════════════════════════════════════════════════════════════
   DELIVERABLES
   ════════════════════════════════════════════════════════════ */
.del-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--rule); border:1px solid var(--rule); border-radius:var(--radius); overflow:hidden; }
.del-item{ background:var(--paper); padding:34px; }
.del-item .mk{ width:9px; height:9px; background:var(--red); display:block; margin-bottom:18px; }
.del-item h4{ font-family:var(--font); font-weight:700; font-size:19px; letter-spacing:-0.01em; margin-bottom:8px; }
.del-item p{ font-size:14.5px; color:var(--ink-soft); line-height:1.55; }

/* ════════════════════════════════════════════════════════════
   PACKAGES - Pick your focus (core, exposed)
   ════════════════════════════════════════════════════════════ */
.focus-top{ border-top:2px solid var(--ink); padding-top:42px; margin-bottom:64px; display:flex; align-items:flex-end; justify-content:space-between; gap:34px; flex-wrap:wrap; }
.focus-top .lead{ max-width:680px; }
.focus-top .kicker{ margin-bottom:20px; }
.focus-top h2{ font-family:var(--font); font-weight:900; letter-spacing:-0.03em; line-height:0.98; font-size:clamp(40px, 5.2vw, 62px); }
.focus-top p{ font-size:17px; color:var(--ink-soft); max-width:420px; }

.packages-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.package{ position:relative; display:flex; flex-direction:column; background:var(--sheet); border:1px solid var(--rule); border-radius:var(--radius); padding:34px; transition:transform .18s, box-shadow .18s; }
.package:hover{ transform:translateY(-4px); box-shadow:0 24px 48px -34px rgba(27,24,19,0.4); }
.package.featured{ border-top:4px solid var(--red); }
.pkg-flag{ position:absolute; top:28px; right:30px; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--red); }
.pkg-tag{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:18px; }
.package h3{ font-family:var(--font); font-weight:700; font-size:24px; letter-spacing:-0.02em; margin-bottom:10px; }
.pkg-for{ font-size:14px; color:var(--ink-soft); margin-bottom:26px; min-height:40px; line-height:1.45; }
.pkg-list{ list-style:none; display:flex; flex-direction:column; gap:13px; margin-bottom:26px; }
.pkg-list li{ font-size:14.5px; color:var(--ink-soft); line-height:1.5; display:flex; gap:11px; }
.pkg-list li::before{ content:''; flex:0 0 auto; width:6px; height:6px; margin-top:7px; background:var(--red); }
.pkg-price{ display:flex; align-items:baseline; gap:9px; padding:20px 0; margin-top:auto; border-top:1px solid var(--rule); }
.pkg-price .amt{ font-family:var(--font); font-weight:900; font-size:28px; color:var(--ink); letter-spacing:-0.02em; }
.pkg-price .unit{ font-family:var(--mono); font-size:12px; color:var(--ink-mute); }
.pkg-deliverables{ list-style:none; display:flex; flex-direction:column; gap:8px; padding:18px 0 22px; }
.pkg-deliverables li{ font-family:var(--mono); font-size:12px; color:var(--ink-mute); display:flex; gap:9px; }
.pkg-deliverables li::before{ content:'+'; color:var(--red); }
.pkg-cta{ margin-top:auto; }
.pkg-note{ margin-top:36px; font-family:var(--mono); font-size:12.5px; color:var(--ink-mute); letter-spacing:.02em; }

/* ════════════════════════════════════════════════════════════
   PROCESS - How a session runs (real sequence)
   ════════════════════════════════════════════════════════════ */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.step{ border-top:2px solid var(--ink); padding-top:24px; }
.step .step-num{ font-family:var(--font); font-weight:900; font-size:40px; color:var(--ink); letter-spacing:-0.03em; line-height:1; margin-bottom:18px; }
.step h4{ font-family:var(--font); font-weight:700; font-size:20px; letter-spacing:-0.01em; margin-bottom:10px; }
.step p{ font-size:15px; color:var(--ink-soft); line-height:1.6; }

/* ════════════════════════════════════════════════════════════
   BEFORE / AFTER - What changes (corrections)
   ════════════════════════════════════════════════════════════ */
.ba-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.ba-card{ background:var(--sheet); border:1px solid var(--rule); border-radius:var(--radius); padding:32px 34px 34px; position:relative; }
.ba-card::before{ content:''; position:absolute; left:16px; top:30px; bottom:30px; width:2px; background:var(--red-soft); }
.ba-inner{ padding-left:20px; }
.ba-context{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-mute); padding-bottom:18px; margin-bottom:20px; border-bottom:1px solid var(--rule); display:flex; align-items:center; justify-content:space-between; gap:12px; }
.ba-context .korr{ font-size:10.5px; }
.ba-seg{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:10px; }
.ba-before .ba-text{ font-size:16px; color:var(--ink-soft); line-height:1.55; text-decoration:line-through; text-decoration-color:var(--red); text-decoration-thickness:1.5px; }
.ba-divider{ display:flex; align-items:center; gap:12px; margin:24px 0 18px; }
.ba-divider .mk{ font-family:var(--mono); font-size:12.5px; color:var(--red); }
.ba-divider .ln{ flex:1; height:1px; background:var(--rule); }
.ba-after .ba-seg{ color:var(--red); }
.ba-after .ba-text{ font-family:var(--mono); font-size:14px; line-height:1.9; color:var(--ink); }
.ba-after .ba-text b{ color:var(--red); font-weight:500; }
.ba-note{ margin-top:32px; font-family:var(--mono); font-size:12px; color:var(--ink-mute); }

/* ════════════════════════════════════════════════════════════
   BLOG - preview + archive
   ════════════════════════════════════════════════════════════ */
.blog-head-row{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; margin-bottom:48px; }
.posts-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.post-card{ background:var(--sheet); border:1px solid var(--rule); border-radius:var(--radius); transition:transform .18s, box-shadow .18s; }
.post-card:hover{ transform:translateY(-4px); box-shadow:0 24px 48px -34px rgba(27,24,19,0.4); }
.post-card a{ display:flex; flex-direction:column; height:100%; padding:30px; }
.post-mode-tag{ display:inline-block; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); border:1px solid var(--rule-2); border-radius:3px; padding:4px 9px; margin-bottom:18px; align-self:flex-start; }
.post-card h2{ font-family:var(--font); font-weight:700; font-size:21px; letter-spacing:-0.02em; line-height:1.2; margin-bottom:12px; }
.post-card p{ font-size:14.5px; color:var(--ink-soft); line-height:1.55; margin-bottom:24px; }
.post-card-footer{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:18px; border-top:1px solid var(--rule); }
.post-readtime{ font-family:var(--mono); font-size:12px; color:var(--ink-mute); }
.post-arrow{ font-family:var(--mono); color:var(--red); transition:transform .18s; }
.post-card:hover .post-arrow{ transform:translateX(3px); }

/* blog archive header */
.blog-header{ padding:104px 0 56px; }
.blog-header h1{ font-family:var(--font); font-weight:900; letter-spacing:-0.03em; line-height:1.0; font-size:clamp(38px,5vw,58px); margin:18px 0 14px; }
.blog-header .section-sub{ font-size:18px; color:var(--ink-soft); max-width:560px; }
.blog-filters{ display:flex; flex-wrap:wrap; gap:10px; margin-top:34px; }
.filter-btn{ font-family:var(--mono); font-size:12.5px; letter-spacing:.04em; color:var(--ink-soft); background:transparent; border:1px solid var(--rule-2); border-radius:999px; padding:8px 16px; cursor:pointer; transition:all .15s; }
.filter-btn:hover{ border-color:var(--ink); color:var(--ink); }
.filter-btn.active{ background:var(--ink); border-color:var(--ink); color:var(--paper); }

/* pagination */
.pagination{ margin-top:64px; }
.pagination ul{ list-style:none; display:flex; gap:8px; flex-wrap:wrap; }
.pagination a,.pagination span{ font-family:var(--mono); font-size:13px; padding:9px 14px; border:1px solid var(--rule-2); border-radius:var(--radius-sm); color:var(--ink-soft); }
.pagination .current{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.pagination a:hover{ border-color:var(--ink); color:var(--ink); }

/* ════════════════════════════════════════════════════════════
   FAQ
   ════════════════════════════════════════════════════════════ */
.faq-list{ border-top:1px solid var(--rule); }
.faq-item{ border-bottom:1px solid var(--rule); }
.faq-question{ width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:26px 0; display:flex; align-items:center; justify-content:space-between; gap:20px; font-family:var(--font); font-weight:600; font-size:18px; color:var(--ink); letter-spacing:-0.01em; }
.faq-chevron{ font-family:var(--mono); color:var(--red); flex:0 0 auto; transition:transform .25s; }
.faq-item.open .faq-chevron{ transform:rotate(45deg); }
.faq-answer{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-item.open .faq-answer{ max-height:420px; }
.faq-answer p{ padding:0 0 26px; font-size:16px; color:var(--ink-soft); line-height:1.65; max-width:760px; }

/* ════════════════════════════════════════════════════════════
   INTAKE - CF7 form
   ════════════════════════════════════════════════════════════ */
.intake-grid{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.1fr); gap:64px; align-items:start; }
.intake-rules{ list-style:none; display:flex; flex-direction:column; gap:16px; margin-top:32px; }
.intake-rules li{ font-size:15px; color:var(--ink-soft); display:flex; gap:12px; line-height:1.5; }
.intake-rules li::before{ content:''; flex:0 0 auto; width:7px; height:7px; margin-top:7px; background:var(--red); }
.intake-alt{ margin-top:30px; }

.form-wrap{ background:var(--sheet); border:1px solid var(--rule); border-radius:var(--radius); padding:34px; }
.form-prompt{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); padding-bottom:20px; margin-bottom:24px; border-bottom:1px solid var(--rule); }

/* CF7 layout: tighten spacing and neutralize wpautop artifacts */
.wpcf7-form > p,
.wpcf7-form p{ margin:0 0 16px; line-height:1.3; }
.wpcf7-form p:empty{ display:none; }
.wpcf7-form br{ display:none; }
.wpcf7-form .wpcf7-form-control-wrap{ display:block; margin-top:7px; }
.wpcf7-form label{ display:block; font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:0; line-height:1.25; }
.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form input[type=tel],
.wpcf7-form input[type=url],
.wpcf7-form select,
.wpcf7-form textarea{
  width:100%; font-family:var(--font); font-size:15px; color:var(--ink);
  background:var(--paper); border:1px solid var(--rule-2); border-radius:var(--radius-sm);
  padding:12px 14px; transition:border-color .15s, box-shadow .15s;
}
.wpcf7-form textarea{ min-height:130px; resize:vertical; }
.wpcf7-form input:focus,.wpcf7-form select:focus,.wpcf7-form textarea:focus{ outline:none; border-color:var(--red); box-shadow:0 0 0 3px var(--red-soft); }
.wpcf7-form input[type=submit]{
  font-family:var(--font); font-weight:600; font-size:15px; color:#fff;
  background:var(--red-btn); border:none; border-radius:var(--radius-sm);
  padding:14px 26px; cursor:pointer; transition:background .18s, transform .12s; width:100%;
}
.wpcf7-form input[type=submit]:hover{ background:var(--red-hov); transform:translateY(-1px); }
.wpcf7 .wpcf7-response-output{ font-family:var(--mono); font-size:13px; border-radius:var(--radius-sm); margin:14px 0 0; padding:12px 14px; }
.wpcf7-not-valid-tip{ font-family:var(--mono); font-size:11.5px; color:var(--red); }
.form-fallback{ font-size:15px; color:var(--ink-soft); line-height:1.6; }

/* ════════════════════════════════════════════════════════════
   SINGLE POST
   ════════════════════════════════════════════════════════════ */
.post-header{ padding:96px 0 36px; }
.post-meta{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:24px; }
.post-meta .post-date,.post-meta .post-readtime{ font-family:var(--mono); font-size:12.5px; color:var(--ink-mute); }
.post-header h1{ font-family:var(--font); font-weight:900; letter-spacing:-0.03em; line-height:1.05; font-size:clamp(34px,4.6vw,52px); max-width:880px; }
.post-intro{ font-size:20px; color:var(--ink-soft); line-height:1.55; max-width:760px; margin-top:22px; }

.post-body{ padding:40px 0 80px; }
.post-content{ max-width:760px; }

/* entry-content prose */
.entry-content{ font-size:17.5px; line-height:1.75; color:var(--ink); max-width:760px; }
.entry-content > * + *{ margin-top:1.4em; }
.entry-content h2{ font-family:var(--font); font-weight:800; font-size:30px; letter-spacing:-0.02em; line-height:1.15; margin-top:1.8em; }
.entry-content h3{ font-family:var(--font); font-weight:700; font-size:23px; letter-spacing:-0.01em; margin-top:1.6em; }
.entry-content h4{ font-family:var(--font); font-weight:700; font-size:19px; margin-top:1.4em; }
.entry-content a{ color:var(--red); text-decoration:underline; text-decoration-thickness:1.5px; text-underline-offset:3px; }
.entry-content ul,.entry-content ol{ padding-left:1.3em; }
.entry-content li{ margin-top:.5em; }
.entry-content blockquote{ border-left:3px solid var(--red); padding:6px 0 6px 22px; color:var(--ink-soft); font-size:19px; }
.entry-content code{ font-family:var(--mono); font-size:.88em; background:var(--paper-2); padding:2px 6px; border-radius:4px; }
.entry-content pre{ font-family:var(--mono); font-size:14px; background:var(--ink); color:var(--sheet); padding:22px; border-radius:var(--radius); overflow-x:auto; line-height:1.7; }
.entry-content pre code{ background:none; padding:0; color:inherit; }
.entry-content img{ border-radius:var(--radius); }
.entry-content hr{ border:none; border-top:1px solid var(--rule); margin:2.2em 0; }

/* author content blocks (pasted in editor) */
.vocab-block,.template-block{ background:var(--sheet); border:1px solid var(--rule); border-radius:var(--radius); padding:26px 28px; }
.vocab-block h3,.template-block h3{ margin-top:0; font-size:14px; font-family:var(--mono); letter-spacing:.08em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:18px; font-weight:500; }
.vocab-item{ display:flex; justify-content:space-between; gap:16px; padding:11px 0; border-bottom:1px solid var(--rule); }
.vocab-item:last-child{ border-bottom:none; }
.vocab-de{ font-family:var(--mono); font-size:15px; color:var(--ink); }
.vocab-en{ font-size:15px; color:var(--ink-soft); }
.template-block pre{ background:var(--ink); color:var(--sheet); border-radius:var(--radius-sm); margin-top:0; }
.post-modes{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.post-mode{ background:var(--sheet); border:1px solid var(--rule); border-radius:var(--radius); padding:24px; border-top:3px solid var(--rule-2); }
.post-mode.mode-applying{ border-top-color:var(--red); }
.post-mode.mode-enfirst{ border-top-color:var(--ink); }
.post-mode.mode-germanative{ border-top-color:var(--ink-mute); }
.post-mode-label{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:12px; }
.post-mode h4{ margin-top:0; font-size:17px; margin-bottom:8px; }
.post-mode p{ font-size:14px; color:var(--ink-soft); line-height:1.55; }

/* post CTA + nav */
.post-cta{ max-width:760px; margin-top:56px; background:var(--ink); color:var(--paper); border-radius:var(--radius); padding:40px; }
.post-cta h3{ font-family:var(--font); font-weight:800; font-size:26px; letter-spacing:-0.02em; margin-bottom:12px; color:#fff; }
.post-cta p{ font-size:16px; color:#cfc8b8; line-height:1.6; margin-bottom:24px; max-width:560px; }
.post-cta .btn-primary{ display:inline-flex; align-items:center; gap:9px; background:var(--red-btn); color:#fff; font-family:var(--font); font-weight:600; font-size:15px; padding:13px 24px; border-radius:var(--radius-sm); transition:background .18s, transform .12s; }
.post-cta .btn-primary:hover{ background:var(--red-hov); transform:translateY(-1px); }

.post-nav{ max-width:760px; display:flex; justify-content:space-between; gap:24px; margin-top:48px; padding-top:26px; border-top:1px solid var(--rule); }
.post-nav .pn-label{ font-family:var(--mono); font-size:11px; color:var(--ink-mute); margin-bottom:5px; }
.post-nav a.pn-title{ font-size:15px; color:var(--ink); font-weight:500; }
.post-nav a.pn-title:hover{ color:var(--red); }
.post-nav .pn-next{ text-align:right; }

/* ════════════════════════════════════════════════════════════
   GENERIC PAGE
   ════════════════════════════════════════════════════════════ */
.page-hero{ padding:96px 0 36px; border-bottom:1px solid var(--rule); }
.page-hero h1{ font-family:var(--font); font-weight:900; letter-spacing:-0.03em; line-height:1.05; font-size:clamp(34px,4.6vw,52px); margin-top:16px; }
.page-body{ padding:48px 0 90px; }

/* ════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════ */
#site-footer{ border-top:1px solid var(--rule); padding:56px 0; }
.footer-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.footer-logo{ font-family:var(--font); font-weight:700; font-size:19px; letter-spacing:-0.02em; }
.footer-logo span{ color:var(--red); }
.footer-nav ul{ list-style:none; display:flex; gap:24px; flex-wrap:wrap; }
.footer-nav a{ font-size:14px; color:var(--ink-soft); transition:color .15s; }
.footer-nav a:hover{ color:var(--ink); }
.footer-copy{ font-family:var(--mono); font-size:12px; color:var(--ink-mute); }

/* ════════════════════════════════════════════════════════════
   MOTION
   ════════════════════════════════════════════════════════════ */
.fade-in{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
.fade-in.visible{ opacity:1; transform:none; }
.rise{ opacity:0; transform:translateY(13px); animation:rise .6s cubic-bezier(.2,.7,.2,1) forwards; }
.rise.d1{animation-delay:.04s;} .rise.d2{animation-delay:.1s;} .rise.d3{animation-delay:.18s;} .rise.d4{animation-delay:.26s;}
@keyframes rise{ to{ opacity:1; transform:none; } }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
  .fc-grid,.intake-grid{ grid-template-columns:1fr; gap:48px; }
  .modes-grid,.packages-grid,.steps,.posts-grid,.post-modes{ grid-template-columns:1fr; }
  .del-grid,.ba-grid{ grid-template-columns:1fr; }
}
@media (max-width:760px){
  :root{ --pad:22px; }
  .nav-toggle{ display:block; }
  #site-navigation{
    display:none; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:22px;
    background:var(--paper); border-bottom:1px solid var(--rule);
    padding:24px var(--pad) 30px; box-shadow:0 26px 44px -30px rgba(27,24,19,0.55);
  }
  #site-header.nav-open #site-navigation{ display:flex; }
  #site-navigation ul{ flex-direction:column; align-items:flex-start; gap:18px; }
  #site-navigation a{ font-size:16px; }
  .lang-switcher{ font-size:14px; gap:8px; }
  .lang-btn{ font-size:14px; }
  .nav-cta{ text-align:center; }
  .section{ padding:68px 0; }
  .hero{ padding:64px 0 70px; }
  .blog-header{ padding:72px 0 44px; }
  .sheet{ padding:28px 26px 30px; border-radius:12px; }
  .sheet-inner{ padding-left:18px; }
  .draft{ font-size:16px; }
  .de{ font-size:14px; }
  .post-cta{ padding:30px; }
  .focus-top,.blog-head-row{ flex-direction:column; align-items:flex-start; }
}
@media (prefers-reduced-motion:reduce){
  .rise,.correction,.fade-in{ animation:none !important; transition:none !important; opacity:1 !important; transform:none !important; }
  .draft::after{ animation:none; transform:scaleX(1); }
  html{ scroll-behavior:auto; }
}
