/* ============================================
   mahnbescheid — Bestellformular
   Farb-/Layout-Tokens kommen zentral aus css/tokens.css
   (dieselben Farben wie die Landingpage). Hier nur das
   Seiten-Gerüst (header, nav, stepper, layout shell, aside,
   summary, footer) + seiten-spezifische Hex-Fallbacks.
   The order form itself is a React/Vite app that ships
   its own scoped CSS modules (and stable `mahnbescheid-*`
   class hooks) — no form-field styling lives here.
   ============================================ */


*{ box-sizing: border-box; }
html, body{ margin: 0; padding: 0; overflow-x: clip; }
body{ font-size: 16px; line-height: 1.55; }

a{ color: var(--c-primary); text-underline-offset: 2px; text-decoration-thickness: 1px; }
a:hover{ color: var(--c-primary-700); text-decoration: underline; }
/* Buttons & Logo nie unterstreichen — auch nicht beim Hover */
.btn:hover, .brand:hover{ text-decoration: none; }

h1, h2, h3, h4{ font-family: "IBM Plex Sans", sans-serif; color: var(--c-ink); margin: 0; font-weight: 600; letter-spacing: -0.005em; }
p{ margin: 0; }

.wrap{ max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }

/* ============ UTILITY / HEADER / NAV (shared) ============ */
.utility{ background: var(--c-dark); color: oklch(0.85 0.008 252); font-size: 13px; border-bottom: 1px solid var(--c-dark-border); }
.utility .wrap{ display: flex; justify-content: space-between; align-items: center; height: 36px; }
.utility a{ color: oklch(0.9 0.008 252); text-decoration: none; }
.utility a:hover{ color: #fff; text-decoration: underline; }
.util-lang-current{ color: oklch(0.6 0.008 252); cursor: default; }
.utility-right{ display: flex; gap: 18px; align-items: center; }
.util-sep{ width: 1px; height: 14px; background: var(--c-dark-border); display: inline-block; }

.header{ background: var(--c-surface); border-bottom: 1px solid var(--c-line); }
.header .wrap{ display: flex; align-items: center; justify-content: space-between; padding-top: 22px; padding-bottom: 22px; }
.brand{ display: flex; align-items: center; gap: 14px; text-decoration: none; color: var(--c-ink); }
.brand-mark{
  width: 40px; height: 40px;
  flex-shrink: 0;
  box-sizing: border-box;
}
.brand-mark svg{ width: 100%; height: 100%; display: block; }
.brand-text{ display: flex; flex-direction: column; line-height: 1.15; }
.brand-name{ font-size: 22px; font-weight: 600; letter-spacing: -0.01em; }
.brand-name .tld{ color: var(--c-muted); font-weight: 500; }
.brand-tag{ font-size: 12.5px; color: var(--c-muted); letter-spacing: 0.02em; font-weight: 500; }

.btn{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px;
  border-radius: var(--r-md);
  font: inherit; font-weight: 500;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  line-height: 1.2;
  transition: background .12s ease;
}
.btn-primary{ background: var(--c-primary); color: #fff; }
.btn-primary:hover{ background: var(--c-primary-700); color: #fff; }
.btn-ghost{ background: transparent; color: var(--c-primary-700); border-color: var(--c-line); }
.btn-ghost:hover{ background: var(--c-primary-050); }
.btn-lg{ padding: 14px 22px; font-size: 16px; }
.btn-arrow::after{ content: "→"; font-weight: 400; margin-left: 2px; }

.mainnav{ background: var(--c-primary); color: #fff; }
.mainnav .wrap{ display: flex; }
.mainnav a{
  color: #fff; text-decoration: none;
  padding: 14px 18px;
  font-size: 15px; font-weight: 500;
  border-bottom: 3px solid transparent;
}
.mainnav a:hover{ background: var(--c-primary-700); }
.mainnav a.active{ background: var(--c-primary-700); }

/* ============ STEP PROGRESS (horizontal, top) ============ */
.step-progress{
  background: var(--c-surface-2);
  border-bottom: 1px solid var(--c-line-soft);
  padding: 32px 0 28px;
}
.step-progress-list{
  list-style: none; padding: 0; margin: 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  --progress-fraction: 0;
}
.step-progress-list::before,
.step-progress-list::after{
  content: "";
  position: absolute;
  top: 17px;
  left: 18px;
  height: 2px;
  z-index: 0;
}
.step-progress-list::before{
  right: 18px;
  background: var(--c-line);
}
.step-progress-list::after{
  width: calc(var(--progress-fraction) * (100% - 36px));
  background: var(--c-primary);
  transition: width .35s cubic-bezier(.22,.61,.36,1);
}
.step-progress-list li{
  display: flex; flex-direction: column; align-items: center;
  gap: 12px;
  text-align: center;
  position: relative;
  z-index: 1;
  color: var(--c-ink-soft);
  max-width: 200px;
}
.step-progress-list li:first-child{ align-items: flex-start; text-align: left; }
.step-progress-list li:last-child{ align-items: flex-end; text-align: right; }

.step-progress-list .step-pill{
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid var(--c-line);
  background: var(--c-surface-2);
  color: var(--c-ink-soft);
  display: grid; place-items: center;
  font-size: 14px; font-weight: 600;
  flex-shrink: 0;
  transition: background .15s, border-color .15s, color .15s;
}
.step-progress-list li.is-active .step-pill,
.step-progress-list li.is-done .step-pill{
  background: var(--c-primary); color: #fff; border-color: var(--c-primary);
}
.step-progress-list li.is-done .step-pill > span{ display: none; }
.step-progress-list li.is-done .step-pill::before{ content: "✓"; font-size: 16px; }
.step-progress-list li.is-active{ color: var(--c-ink); }
.step-info{ display: flex; flex-direction: column; line-height: 1.25; min-width: 0; gap: 2px; }
.step-label{ font-size: 14px; font-weight: 600; color: inherit; }
.step-progress-list li.is-active .step-label{ color: var(--c-primary-700); }

/* ============ FORM LAYOUT ============ */
.form-main{ padding: 40px 0; }
.form-layout{
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 40px;
  align-items: start;
}

/* React/Vite form mounts here; it brings its own styles.
   Container-Optik an der .step-Klasse der index.html orientiert
   (weiße Karte, 1px-Rahmen, gleiches Padding) — Breite bleibt jedoch
   die volle Spaltenbreite (kein Breiten-Constraint von .step). */
.form-content{
  min-width: 0;
  background: #fff;
  border: 1px solid var(--c-line);
  padding: 26px;
  position: relative;
}

/* ============ ASIDE (right column, contextual help) ============ */
.form-aside{
  display: flex; flex-direction: column;
  gap: 20px;
}
.aside-card{
  background: #fff;
  border: 1px solid var(--c-line);
  border-top: 4px solid var(--c-primary);
  padding: 28px 28px 26px;
  position: relative;
  transition: transform .35s cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}
.form-help-card{
  background: var(--c-surface-2);
  border: 1px solid var(--c-line);
  padding: 22px 24px 20px;
  position: sticky;
  top: 24px;
  z-index: 2;
  order: -1;
}
.form-help-card h4{
  font-size: 15px;
  margin-bottom: 6px;
  color: var(--c-ink);
  font-weight: 600;
}
.form-help-card p{
  font-size: 13.5px;
  color: var(--c-ink-soft);
  line-height: 1.55;
  margin-bottom: 14px;
}
.form-help-contact{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.form-help-contact li{
  display: flex; align-items: center; gap: 10px;
  font-size: 14px;
  color: var(--c-ink);
}
.form-help-contact a{
  color: var(--c-primary-700);
  text-decoration: none;
  font-weight: 500;
}
.form-help-contact a:hover{
  color: var(--c-primary);
  text-decoration: underline;
}
.form-help-icon{
  width: 28px; height: 28px;
  color: var(--c-primary-700);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.aside-arrow{
  position: absolute;
  left: -9px;
  top: 50px;
  width: 16px; height: 16px;
  background: #fff;
  border-left: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  transform: rotate(45deg);
  transition: top .25s cubic-bezier(.22,.61,.36,1);
  pointer-events: none;
  z-index: 2;
}

.aside-content{ }
.aside-content[hidden]{ display: none; }
.aside-eyebrow{
  font-size: 12.5px; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--c-primary-700); font-weight: 600;
  margin-bottom: 12px;
}
.aside-content h3{
  font-size: 19px; margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.aside-content > p{
  font-size: 14px; line-height: 1.6; color: var(--c-ink-soft);
  margin-bottom: 16px;
}
.aside-content > p:last-of-type{ margin-bottom: 22px; }
.aside-content > p strong{ color: var(--c-ink); }

/* ============ SUMMARY (Übersicht) ============ */
.summary{
  border: 1px solid var(--c-line);
  border-radius: var(--r-md);
  overflow: hidden;
  background: #fff;
}
.summary-row{
  display: grid;
  grid-template-columns: 180px 1fr auto;
  gap: 20px;
  align-items: start;
  padding: 18px 22px;
  border-bottom: 1px solid var(--c-line-soft);
}
.summary-row:last-child{ border-bottom: 0; }
.summary-label{
  font-size: 13px; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--c-primary-700); font-weight: 600;
}
.summary-value{
  font-size: 14px; color: var(--c-ink-soft);
  line-height: 1.6;
}
.summary-value strong{ color: var(--c-ink); font-weight: 600; }
.summary-edit{
  background: transparent; border: 1px solid var(--c-line);
  color: var(--c-primary-700);
  font: inherit; font-size: 13px; font-weight: 500;
  padding: 7px 12px;
  border-radius: var(--r-sm);
  cursor: pointer;
}
.summary-edit:hover{ background: var(--c-primary-050); border-color: var(--c-primary); }


/* ============ FOOTER ============ */
footer{
  background: var(--c-dark);
  color: oklch(0.78 0.008 252);
  font-size: 14px;
  padding: 28px 0;
}
footer a{ color: oklch(0.86 0.008 252); text-decoration: none; }
footer a:hover{ color: #fff; text-decoration: underline; }
.foot-bottom{
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px;
  color: oklch(0.65 0.008 252); font-size: 13px;
}
.foot-bottom-left{ display: flex; flex-direction: column; gap: 5px; }
.foot-legal{ display: flex; gap: 20px; }
.foot-pay{ flex-shrink: 0; }
.foot-pay-badge{
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--c-dark-border);
  border-radius: 5px;
  padding: 6px 11px;
  color: oklch(0.8 0.008 252);
  font-size: 12.5px; font-weight: 500;
}
.foot-pay-badge svg{ width: 22px; height: 22px; }

/* ============ HAMBURGER ============ */
.hamburger{
  display: none;
  width: 44px; height: 44px;
  background: transparent;
  border: 1px solid var(--c-line);
  cursor: pointer;
  padding: 0;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  border-radius: var(--r-sm);
}
.hamburger span{
  display: block;
  width: 18px; height: 2px;
  background: var(--c-ink);
  transition: transform .2s, opacity .2s;
}
body.nav-open .hamburger span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
body.nav-open .hamburger span:nth-child(2){ opacity: 0; }
body.nav-open .hamburger span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* ============ HELP POPOVER (mobile) ============ */
.help-popover{
  position: absolute;
  z-index: 100;
  width: min(320px, calc(100vw - 32px));
  background: #fff;
  border: 1px solid var(--c-line);
  border-top: 4px solid var(--c-primary);
  padding: 22px 22px 20px;
  box-shadow: 0 18px 40px -10px rgba(15,31,61,.3);
}
.help-popover[hidden]{ display: none; }
.help-popover-close{
  position: absolute; top: 8px; right: 10px;
  background: transparent; border: 0;
  font-size: 22px; line-height: 1;
  color: var(--c-muted);
  cursor: pointer; padding: 4px 8px;
}
.help-popover-close:hover{ color: var(--c-ink); }

/* ============ RESPONSIVE ============ */
@media (max-width: 1024px){
  .form-layout{ grid-template-columns: 1fr; gap: 28px; }
  .form-aside{ order: 2; }
  .form-help-card{ position: static; max-width: 480px; }
  .aside-card{ display: none; } /* contextual help is popover on tablet/mobile */
  .summary-row{ grid-template-columns: 160px 1fr auto; }
}

@media (max-width: 768px){
  .wrap{ padding: 0 20px; }

  /* Formular-Container kompakter (wie .step mobil auf der index.html) */
  .form-content{ padding: 20px; }

  /* utility bar */
  .utility{ font-size: 12px; }
  .utility .wrap{ height: 32px; }
  .utility-right{ gap: 12px; }

  /* header */
  .header .wrap{ padding-top: 12px; padding-bottom: 12px; } /* an index.html angeglichen (war 14px) */
  .hamburger{ display: flex; }
  /* Logo mobil identisch zu Desktop: Mark 40px, Name 22px, Tagline sichtbar
     (keine Mobile-Overrides) */

  /* nav drawer */
  .mainnav{ display: none; }
  body.nav-open .mainnav{ display: block; }
  .mainnav .wrap{ flex-direction: column; padding: 0; }
  .mainnav a{ padding: 14px 20px; border-bottom: 1px solid rgba(255,255,255,0.12); width: 100%; }
  
  .form-main {padding: 25px 0;}

  /* compact stepper: "Schritt X von 4: Label" */
  .step-progress{ padding: 18px 0 18px; }
  .step-progress .wrap{ display: block; }
  .step-progress-list{ display: block; padding: 0; margin: 0; }
  .step-progress-list::before, .step-progress-list::after{ display: none; }
  .step-progress-list li{ display: none; max-width: none; padding: 0; }
  .step-progress-list li.is-active{
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    text-align: left;
    align-items: center;
  }
  .step-progress-list li:first-child,
  .step-progress-list li:last-child{ align-items: center; text-align: left; }
  .step-progress-list .step-pill{ grid-row: 1 / 3; }
  .step-progress-list .step-info{ display: flex; flex-direction: column; gap: 2px; }
  .step-progress-list .step-info::before{
    content: "Schritt " attr(data-step) " von 4";
    font-size: 12px; color: var(--c-muted);
    text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500;
  }

  /* summary on Übersicht */
  .summary-row{
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 16px 18px;
  }
  .summary-edit{ justify-self: start; }

  /* footer */
  footer{ padding: 20px 0; }
  .foot-bottom{ flex-direction: column; gap: 10px; align-items: flex-start; }
  .foot-legal{ flex-wrap: wrap; gap: 10px 16px; }
}

/* ============================================================
   LEGACY-FALLBACK — sRGB-Hex für Browser ohne OKLCH-Support
   (vor 2023). Moderne Browser ignorieren diesen Block und
   verwenden die OKLCH-Werte oben. Siehe TOKENS.md.
   ============================================================ */
@supports not (color: oklch(0 0 0)){
  .utility{ color: #CACED3; }
  .utility a{ color: #DADEE3; }
  .util-lang-current{ color: #7D8185; }
  footer{ color: #B4B8BC; }
  footer a{ color: #CDD1D6; }
  .foot-bottom{ color: #8C9094; }
}

/* ============ MODAL (Übersetzungs-Hinweis) ============ */
/* Identisch zu landing.css, damit der "Leichte Sprache"-Dialog auch
   auf der Formularseite korrekt dargestellt wird. */
.modal{
  position: fixed; inset: 0;
  z-index: 10000;
  display: grid; place-items: center;
  padding: 24px;
}
.modal[hidden]{ display: none; }
.modal-backdrop{
  position: absolute; inset: 0;
  background: rgba(15, 31, 61, .55);
  backdrop-filter: blur(2px);
  cursor: pointer;
}
.modal-panel{
  position: relative;
  background: #fff;
  border-top: 4px solid var(--c-primary);
  width: 100%; max-width: 520px;
  padding: 36px 40px 32px;
  box-shadow: 0 30px 80px -20px rgba(15,31,61,.4);
  border-radius: 2px;
}
.modal-close{
  position: absolute; top: 14px; right: 18px;
  background: transparent; border: 0;
  font-size: 26px; line-height: 1; color: var(--c-muted);
  cursor: pointer; padding: 4px 8px;
}
.modal-close:hover{ color: var(--c-ink); }
.modal-eyebrow{
  font-size: 12.5px; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--c-primary-700); font-weight: 600;
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 10px;
}
.modal-eyebrow::before{
  content: ""; width: 22px; height: 2px; background: var(--c-primary);
}
.modal-title{ font-size: 22px; line-height: 1.25; margin-bottom: 14px; }
.modal-body{ font-size: 15px; line-height: 1.6; color: var(--c-ink-soft); margin-bottom: 24px; }
.modal-actions{ display: flex; justify-content: flex-end; }

@media (max-width: 768px){
  .modal-panel{ padding: 28px 22px 24px; }
  .modal-title{ font-size: 19px; }
  .modal-body{ font-size: 14px; }
}
