/* FireAID — STOP · FRAG · CHEF · v2.1 — Stylesheet
   Ruhig, schweizerisch präzise, ingenieursnah. */

:root{
  --paper:#F7F5F1;
  --paper-2:#EFEBE3;
  --line:#D8D2C6;
  --ink:#101418;
  --ink-2:#3E4751;
  --ink-3:#6C7480;
  --accent:#C8341C;
  --accent-2:#A02414;
  --signal:#E0A024;
  --ok:#3E7B4F;
  --radius:4px;
  --f-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --f-display: "Fraunces", Georgia, "Times New Roman", serif;
  --container: 1180px;
  --gutter: clamp(20px, 4vw, 48px);
}

*,*::before,*::after{box-sizing:border-box}
html{ -webkit-text-size-adjust:100%; }
html,body{margin:0;padding:0}
body{
  font-family:var(--f-sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--ink);text-underline-offset:3px}
a:hover{color:var(--accent)}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
hr{border:0;border-top:1px solid var(--line);margin:48px 0}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 14px;z-index:9999}
.skip-link:focus{left:8px;top:8px}

.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}

/* Typography */
h1,h2,h3,h4,h5{font-family:var(--f-display);font-weight:500;letter-spacing:-0.01em;color:var(--ink);margin:0 0 .4em}
h1{font-size:clamp(40px, 6vw, 76px);line-height:1.05}
h2{font-size:clamp(28px, 3.6vw, 44px);line-height:1.1}
h3{font-size:clamp(22px, 2.4vw, 28px);line-height:1.2}
h4{font-size:18px;line-height:1.3}
h5{font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-family:var(--f-sans);font-weight:600;color:var(--ink-2);margin-bottom:12px}
em{font-style:italic;color:var(--accent)}
p{margin:0 0 1em}
.lede{font-size:clamp(17px,1.6vw,21px);color:var(--ink-2);line-height:1.5;max-width:60ch}
.eyebrow{display:inline-block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--accent);padding:6px 10px;border:1px solid var(--accent);border-radius:999px}
.muted{color:var(--ink-3);font-size:14px}
.small{font-size:13px;color:var(--ink-3)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(247,245,241,.92);backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:64px;gap:16px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;font-weight:700;letter-spacing:.02em}
.brand-text{font-family:var(--f-display);font-size:22px;font-weight:600}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{text-decoration:none;font-size:14px;color:var(--ink-2);font-weight:500}
.nav-links a:hover{color:var(--ink)}
.nav-links a.btn-primary{color:#fff}

/* Desktop dropdowns */
.has-sub{position:relative}
.sub-trigger{display:inline-flex;align-items:center;gap:6px;padding:0;font-size:14px;color:var(--ink-2);font-weight:500;cursor:pointer}
.sub-trigger:hover,.sub-trigger[aria-expanded="true"]{color:var(--ink)}
.caret{width:8px;height:8px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translate(-2px,-2px);transition:transform .2s;display:inline-block}
.sub-trigger[aria-expanded="true"] .caret{transform:rotate(-135deg) translate(-2px,-2px)}
.submenu{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-4px);
  min-width:300px;padding:10px;
  background:var(--paper);border:1px solid var(--line);border-radius:8px;
  box-shadow:0 12px 32px rgba(16,20,24,.08);
  display:none;flex-direction:column;gap:2px;z-index:60;
}
.submenu[data-open="true"]{display:flex;animation:subFade .18s ease}
@keyframes subFade{from{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(-4px)}}
.submenu::before{
  content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:12px;height:12px;background:var(--paper);border-left:1px solid var(--line);border-top:1px solid var(--line);
}
.submenu a{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 12px;border-radius:6px;text-decoration:none;color:var(--ink);
  font-size:14px;line-height:1.3;transition:background .15s;
}
.submenu a:hover{background:var(--paper-2);color:var(--ink)}
.submenu a b{display:block;font-weight:600;font-family:var(--f-sans);font-size:14px}
.submenu a small{display:block;color:var(--ink-3);font-size:12px;margin-top:2px}
.submenu .sub-num{
  font-family:"JetBrains Mono",ui-monospace,monospace;font-size:11px;
  color:var(--accent);padding:3px 6px;background:var(--paper-2);border-radius:3px;
  flex-shrink:0;margin-top:1px;letter-spacing:.05em;
}
.submenu-all{font-weight:600;font-size:13px;color:var(--accent) !important;padding:8px 12px !important}
.submenu-all:hover{background:transparent !important;color:var(--accent-2) !important;text-decoration:underline}
.submenu-divider{height:1px;background:var(--line);margin:4px 0}

/* Mobile collapsible groups */
.m-group{border-bottom:1px solid var(--line)}
.m-group summary{
  padding:18px 4px;font-size:19px;font-family:var(--f-display);color:var(--ink);
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;
}
.m-group summary::-webkit-details-marker{display:none}
.m-group summary::after{content:"+";font-family:var(--f-sans);font-size:24px;font-weight:300;color:var(--ink-3);transition:transform .2s}
.m-group[open] summary::after{transform:rotate(45deg)}
.m-group a{display:block !important;padding:12px 16px !important;font-size:15px !important;font-family:var(--f-sans) !important;color:var(--ink-2) !important;border:0 !important;border-bottom:1px solid var(--line) !important;background:transparent !important;border-radius:0 !important}
.m-group a:last-child{border-bottom:0 !important}
.m-group a:last-child{padding-bottom:18px !important}
.menu-toggle{display:none;width:40px;height:40px;flex-direction:column;justify-content:center;gap:5px;align-items:center}
.menu-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);transition:transform .25s, opacity .25s}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-menu{display:flex;flex-direction:column;padding:8px var(--gutter) 20px;border-top:1px solid var(--line);background:var(--paper)}
[hidden]{display:none !important}
.mobile-menu a{padding:12px 0;border-bottom:1px solid var(--line);text-decoration:none;font-size:16px;color:var(--ink)}
@media (max-width:860px){.nav-links{display:none}.menu-toggle{display:flex}}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:.01em;text-decoration:none;border:1px solid var(--ink);background:transparent;color:var(--ink);transition:background .2s, color .2s, border-color .2s, transform .15s;white-space:nowrap}
.btn:hover{background:var(--ink);color:var(--paper);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-2);color:#fff;border-color:var(--accent-2)}
.btn-ghost{border-color:var(--line);color:var(--ink-2)}
.btn-ghost:hover{background:var(--paper-2);color:var(--ink)}
.btn .arrow{display:inline-block}
.btn .arrow::after{content:"→"}

/* Sections */
section{padding:clamp(60px,9vw,120px) 0}
section.tight{padding:clamp(40px,6vw,72px) 0}
.section-head{max-width:62ch;margin-bottom:48px}
.section-head .eyebrow{margin-bottom:18px}

/* Layout helpers (replace former inline styles) */
.band{background:var(--paper-2);border-top:1px solid var(--line)}
.split{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
.cta-band{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:center}
@media (max-width:860px){
  .split{grid-template-columns:1fr;gap:32px}
  .cta-grid{grid-template-columns:1fr;gap:24px}
}

/* Hero */
.hero{padding-top:clamp(60px,9vw,120px);padding-bottom:clamp(40px,6vw,80px);position:relative;overflow:hidden}
.hero.hero-bg::before{
  content:"";position:absolute;inset:0;
  background-image:url("../imgs/Hintergrund.webp");
  background-size:cover;background-position:center right;
  opacity:.55;z-index:0;pointer-events:none;
  mask-image:linear-gradient(to bottom, #000 50%, transparent 100%);
  -webkit-mask-image:linear-gradient(to bottom, #000 50%, transparent 100%);
}
.hero.hero-bg > *{position:relative;z-index:1}

/* Editorial figure block */
.figure{margin:0;display:block}
.figure img{width:100%;height:auto;border-radius:var(--radius);display:block;border:1px solid var(--line)}
.figure figcaption{font-size:13px;color:var(--ink-3);margin-top:10px;font-family:var(--f-sans)}
.media-split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.media-split.reverse{direction:rtl}
.media-split.reverse > *{direction:ltr}
@media (max-width:860px){.media-split{grid-template-columns:1fr;gap:24px}.media-split.reverse{direction:ltr}}

.media-band{
  position:relative;padding:0;margin:0;
}
.media-band img{width:100%;height:clamp(220px,40vw,420px);object-fit:cover;display:block}

/* System diagram (STOP·FRAG·CHEF·PUMA flow) */
.diagram{
  background:linear-gradient(180deg,var(--paper) 0%, var(--paper-2) 100%);
  border:1px solid var(--line);border-radius:8px;
  padding:clamp(20px,3vw,40px);
  text-align:center;
}
.diagram img{
  max-width:100%;height:auto;margin:0 auto;display:block;
  filter:saturate(.95);
}
.diagram-caption{
  margin-top:18px;font-size:14px;color:var(--ink-3);
  display:flex;justify-content:center;gap:24px;flex-wrap:wrap;
}
.diagram-caption b{color:var(--accent);font-weight:600;font-family:var(--f-sans)}
@media (max-width:640px){
  .diagram-caption{gap:12px;font-size:13px}
}

.hero h1{margin-top:24px}
.hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:end}
.hero-meta p{font-size:18px;color:var(--ink-2);max-width:46ch}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
@media (max-width:860px){.hero-grid{grid-template-columns:1fr;gap:32px}}

/* Strip */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;background:var(--paper-2);font-family:var(--f-display);font-style:italic;font-size:18px;color:var(--ink-2);text-align:center}
.strip b{color:var(--accent);font-style:normal;margin:0 14px}

/* Grids */
.grid{display:grid;gap:32px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Cards */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:border-color .2s, transform .2s, box-shadow .2s;display:flex;flex-direction:column;gap:14px;text-decoration:none;color:inherit}
.card:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:0 10px 28px rgba(16,20,24,.07)}
.card .num{font-family:"JetBrains Mono",ui-monospace,monospace;font-size:12px;color:var(--ink-3);letter-spacing:.1em}
.card h3{margin:0}
.card .meta{font-size:13px;color:var(--ink-3);display:flex;gap:14px;flex-wrap:wrap}
.card .price{margin-top:auto;font-family:var(--f-display);font-size:24px;color:var(--ink)}
.card .price small{display:block;font-family:var(--f-sans);font-size:12px;color:var(--ink-3);margin-top:4px}

/* Stufen */
.stufen{border-top:1px solid var(--ink)}
.stufen .row{display:grid;grid-template-columns:80px 1.4fr 1.2fr .8fr 180px;gap:24px;padding:28px 0;border-bottom:1px solid var(--line);align-items:start;text-decoration:none;color:inherit;transition:padding-left .2s}
.stufen .row:hover{padding-left:8px}
.stufen .row .n{font-family:"JetBrains Mono",ui-monospace,monospace;font-size:13px;color:var(--accent)}
.stufen .row .t{font-family:var(--f-display);font-size:26px;line-height:1.15}
.stufen .row .d{color:var(--ink-2);font-size:15px}
.stufen .row .m{font-size:13px;color:var(--ink-3)}
.stufen .row .p{font-family:var(--f-display);font-size:20px;text-align:right}
.stufen .row .p small{display:block;font-family:var(--f-sans);font-size:12px;color:var(--ink-3);margin-top:4px}
@media (max-width:860px){.stufen .row{grid-template-columns:1fr;gap:8px}.stufen .row .p{text-align:left}}

/* CHEF cycle */
.cycle-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
@media (max-width:860px){.cycle-wrap{grid-template-columns:1fr}}
.cycle-svg{aspect-ratio:1/1;max-width:420px;margin:0 auto;width:100%}
.cycle-ring{fill:none;stroke:var(--line);stroke-width:1}
.cycle-letter{font-family:var(--f-display);font-size:48px;fill:var(--ink-3);cursor:pointer;transition:fill .2s}
.cycle-letter.active,.cycle-letter:hover{fill:var(--accent)}
.cycle-word{font-family:var(--f-sans);font-size:11px;letter-spacing:.12em;text-transform:uppercase;fill:var(--ink-3)}
.cycle-steps{display:flex;flex-direction:column;gap:14px}
.cycle-step{display:flex;gap:18px;padding:18px;border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;transition:border-color .2s, background .2s;background:transparent;text-align:left;width:100%}
.cycle-step:hover,.cycle-step.active{border-color:var(--accent);background:var(--paper-2)}
.cycle-step .letter{font-family:var(--f-display);font-size:32px;color:var(--accent);width:40px;flex-shrink:0;line-height:1}
.cycle-step h4{margin:0 0 4px}
.cycle-step p{margin:0;color:var(--ink-2);font-size:14px}

/* Tables */
.puma-table,.kompetenz-table,.std-table{width:100%;border-collapse:collapse;font-size:14px;border-top:1px solid var(--ink)}
.puma-table th,.kompetenz-table th,.std-table th{text-align:left;padding:12px 14px;font-family:var(--f-sans);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);border-bottom:1px solid var(--line);background:var(--paper-2)}
.puma-table td,.kompetenz-table td,.std-table td{padding:14px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--ink)}
.puma-table tr:hover,.kompetenz-table tr:hover{background:var(--paper-2)}
.kompetenz-table .kstep{font-family:"JetBrains Mono",ui-monospace,monospace;font-weight:600;color:var(--accent)}

/* Stepper K0-K4 */
.stepper{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:32px 0}
.stepper .step{padding:18px 14px;background:var(--paper-2);border-radius:var(--radius);border:1px solid var(--line);position:relative}
.stepper .step h5{color:var(--accent);margin-bottom:6px}
.stepper .step p{font-size:13px;color:var(--ink-2);margin:0}
@media (max-width:860px){.stepper{grid-template-columns:1fr}}

/* Roles */
.roles{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.role{padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper)}
.role h4{margin-bottom:4px}
.role p{margin:0;font-size:14px;color:var(--ink-2)}
@media (max-width:640px){.roles{grid-template-columns:1fr}}

/* Forms */
.form{display:grid;gap:18px;max-width:760px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:640px){.form-row{grid-template-columns:1fr}}
.field label{display:block;font-size:13px;color:var(--ink-2);font-weight:600;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;color:var(--ink);font:inherit;font-size:15px;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);outline:none}
.field textarea{resize:vertical;min-height:140px}
.field .req{color:var(--accent)}
.honeypot{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}
.checkbox{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--ink-2)}
.checkbox input{margin-top:4px}
.form-notice{padding:14px 16px;border-radius:var(--radius);font-size:14px;border:1px solid}
.form-notice.ok{background:#EAF3EC;border-color:#B4D3BA;color:#274E32}
.form-notice.err{background:#FBECE9;border-color:#E9B5AD;color:#7E2718}

/* Prose */
.prose{max-width:68ch}
.prose ul,.prose ol{padding-left:20px}
.prose li{margin:6px 0;color:var(--ink-2)}
.prose h3{margin-top:32px}
.prose p{color:var(--ink-2)}
.prose strong{color:var(--ink)}

/* Audience tiles */
.audience-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.audience-tiles a{background:var(--paper);padding:32px 24px;text-decoration:none;color:var(--ink);transition:background .2s;display:block}
.audience-tiles a:hover{background:var(--paper-2)}
.audience-tiles h4{margin-bottom:6px;color:var(--accent)}
.audience-tiles p{font-size:14px;color:var(--ink-2);margin:0}
@media (max-width:860px){.audience-tiles{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.audience-tiles{grid-template-columns:1fr}}

/* Footer */
.site-footer{background:var(--paper-2);border-top:1px solid var(--line);padding:64px 0 32px;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-claim{font-family:var(--f-display);font-size:24px;line-height:1.2;color:var(--ink);margin:0 0 8px}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.site-footer a{font-size:14px;color:var(--ink-2);text-decoration:none}
.site-footer a:hover{color:var(--accent)}
.footer-base{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-3);margin-top:48px;padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap;gap:12px}

/* View transitions */
@media (prefers-reduced-motion: no-preference){
  main{animation:fade .25s ease}
  @keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
}

/* ============================================================
   RESPONSIVE — bewusste Breakpoints
   sm: ≤ 480  (Phone hochkant)
   md: ≤ 640  (Phone quer / kleines Tablet)
   lg: ≤ 860  (Tablet)
   xl: ≤ 1024 (kleines Laptop)
   Mobile ist NICHT gestauchter Desktop — eigene Hierarchie,
   eigene Komponenten-Form, eigene Touch-Targets.
   ============================================================ */

/* ---- Tablet ≤ 860 ---- */
@media (max-width:860px){
  :root{ --gutter: 24px; }
  section{ padding: 56px 0; }
  .section-head{ margin-bottom: 32px; }

  /* Header wird kompakter, Brand-Text leicht reduziert */
  .nav{ min-height: 56px; }
  .brand-text{ font-size: 19px; }

  /* Mobile-Menu als Vollflächen-Overlay statt Drop-Panel */
  .mobile-menu{
    position: fixed; inset: 56px 0 0 0;
    padding: 24px var(--gutter) 32px;
    overflow-y: auto;
    gap: 0;
    background: var(--paper);
    z-index: 49;
  }
  .mobile-menu a{
    padding: 18px 4px;
    font-size: 19px;
    font-family: var(--f-display);
    border-bottom: 1px solid var(--line);
    color: var(--ink);
  }
  .mobile-menu > a:last-child{
    margin-top: 16px;
    padding: 16px 22px;
    border: 1px solid var(--accent);
    background: var(--accent);
    color: #fff;
    border-radius: 999px;
    text-align: center;
    font-size: 15px;
    font-family: var(--f-sans);
    font-weight: 600;
  }

  /* Hero: weniger Padding-oben, Lede unter H1 statt daneben (bereits) */
  .hero{ padding-top: 40px; padding-bottom: 32px; }
  .hero-meta p.lede{ font-size: 17px; }

  /* Stufen-Zeilen → echte Karten statt zusammengestauchtes Tabellenraster */
  .stufen{ border-top: 0; }
  .stufen .row{
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 24px;
    margin-bottom: 12px;
    border: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--paper);
  }
  .stufen .row:hover{ padding-left: 24px; border-color: var(--ink); }
  .stufen .row .n{ font-size: 11px; }
  .stufen .row .t{ font-size: 22px; }
  .stufen .row .p{ text-align: left; font-size: 18px; }

  /* CHEF-Cycle: SVG zentriert, Steps darunter mit kompakterem Padding */
  .cycle-svg{ max-width: 320px; }
  .cycle-step{ padding: 14px; }
  .cycle-step .letter{ font-size: 26px; width: 30px; }

  /* Tabellen: horizontaler Scroll-Container statt Stauchen */
  .puma-table,.kompetenz-table,.std-table{
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
  .puma-table td,.std-table td{ white-space: normal; min-width: 200px; }
  .puma-table th,.std-table th{ white-space: nowrap; }

  /* Detail-Seiten: Sidebar wandert unter Hauptinhalt */
  section .wrap[style*="grid-template-columns:1.4fr 1fr"]{
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }

  /* CTA-Block: Stack statt zwei Spalten */
  section[style*="background:var(--paper-2)"] .wrap[style*="grid-template-columns:1.4fr 1fr"]{
    gap: 24px !important;
  }

  /* Footer: ruhigere Hierarchie auf Tablet */
  .footer-grid{ gap: 28px; }
}

/* ---- Mobile ≤ 640 ---- */
@media (max-width:640px){
  :root{ --gutter: 20px; }
  body{ font-size: 15px; }

  h1{ font-size: 36px; line-height: 1.08; }
  h2{ font-size: 26px; }
  h3{ font-size: 20px; }
  .lede{ font-size: 16px; }
  .eyebrow{ font-size: 11px; padding: 5px 9px; }

  section{ padding: 44px 0; }
  .section-head{ margin-bottom: 24px; }

  /* Hero: Eyebrow + H1 + Lede klar gestapelt, mehr Atem */
  .hero{ padding-top: 32px; padding-bottom: 24px; }
  .hero h1{ margin-top: 16px; }
  .hero-ctas{ flex-direction: column; align-items: stretch; gap: 10px; }
  .hero-ctas .btn{ justify-content: center; width: 100%; }

  /* Strip ist auf Mobile zu lang — Schriftgrösse runter, Padding runter */
  .strip{ padding: 14px 0; font-size: 14px; line-height: 1.5; }
  .strip b{ margin: 0 8px; }

  /* Buttons: Touch-Target ≥ 44px, kein Wrapping */
  .btn{ padding: 14px 20px; font-size: 14px; min-height: 46px; }
  .btn-primary, .form .btn{ width: 100%; justify-content: center; }

  /* Karten: weniger Padding, weniger Gap */
  .card{ padding: 22px; gap: 12px; }
  .grid{ gap: 16px; }

  /* Stufen-Karten: kompakter */
  .stufen .row{ padding: 20px; }
  .stufen .row .t{ font-size: 20px; }
  .stufen .row .d{ font-size: 14px; }

  /* CHEF-Cycle: SVG kleiner, eindeutige Reihenfolge */
  .cycle-wrap{ gap: 24px; }
  .cycle-svg{ max-width: 260px; }
  .cycle-letter{ font-size: 38px; }
  .cycle-word{ font-size: 10px; }
  .cycle-step{ padding: 12px 14px; gap: 12px; }
  .cycle-step .letter{ font-size: 22px; width: 26px; }
  .cycle-step h4{ font-size: 16px; }
  .cycle-step p{ font-size: 13px; }

  /* Stepper K0–K4: vertikale Liste mit Trennlinien statt 5 leerer Karten */
  .stepper{ gap: 0; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
  .stepper .step{ border: 0; border-bottom: 1px solid var(--line); border-radius: 0; padding: 14px 16px; }
  .stepper .step:last-child{ border-bottom: 0; }
  .stepper .step h5{ margin-bottom: 2px; }

  /* Audience-Kacheln: vertikale Liste mit klarer Trennung */
  .audience-tiles{ border-radius: var(--radius); }
  .audience-tiles a{ padding: 20px 18px; }
  .audience-tiles h4{ font-size: 17px; }

  /* Formular: alle Felder einspaltig, grössere Touch-Targets */
  .form-row{ grid-template-columns: 1fr; gap: 14px; }
  .field input,.field select,.field textarea{
    padding: 14px; font-size: 16px; /* 16px verhindert iOS-Zoom */
  }
  .field textarea{ min-height: 120px; }
  .checkbox{ font-size: 13px; }

  /* Detail-Sidebar wird gewöhnliche Karte unten */
  aside .card{ margin-top: 0; }

  /* Footer: alle Spalten einspaltig, kompaktere Liste */
  .footer-grid{ grid-template-columns: 1fr; gap: 32px; }
  .site-footer{ padding: 48px 0 24px; margin-top: 56px; }
  .footer-claim{ font-size: 22px; }
  .footer-base{ flex-direction: column; align-items: flex-start; gap: 8px; margin-top: 32px; }
}

/* ---- Small phone ≤ 480 ---- */
@media (max-width:480px){
  :root{ --gutter: 16px; }
  h1{ font-size: 32px; }
  h2{ font-size: 24px; }

  section{ padding: 36px 0; }
  .hero{ padding-top: 24px; }

  /* Stufen-Karten extra-kompakt, Preis sichtbar als kleines Footer-Label */
  .stufen .row{ padding: 18px; gap: 8px; }
  .stufen .row .t{ font-size: 19px; }
  .stufen .row .m{ font-size: 12px; }
  .stufen .row .p{ font-size: 16px; padding-top: 8px; border-top: 1px solid var(--line); margin-top: 4px; }
  .stufen .row .p small{ font-size: 11px; }

  /* CHEF-Cycle noch kleiner, Steps mit kleinerem Letter-Badge */
  .cycle-svg{ max-width: 220px; }
  .cycle-letter{ font-size: 32px; }

  /* Tabellen: Header etwas kleiner */
  .puma-table th,.kompetenz-table th,.std-table th{ font-size: 11px; padding: 10px 12px; }
  .puma-table td,.kompetenz-table td,.std-table td{ padding: 12px; font-size: 13px; }
}

/* ---- Landscape Phone: Hero-Padding nicht doppelt zählen ---- */
@media (max-width:860px) and (orientation:landscape) and (max-height:500px){
  .hero{ padding-top: 24px; padding-bottom: 16px; }
  section{ padding: 32px 0; }
}

/* Print */
@media print{
  .site-header,.site-footer,.menu-toggle,.btn{display:none !important}
  body{background:#fff;color:#000}
  section{padding:16px 0;page-break-inside:avoid}
  a{color:#000;text-decoration:none}
}
