/* ============================================================
   Leise Weltklasse — Stylesheet (v2: warm-journalistisch, blau)
   Schriften: Lora (Überschriften) + Inter (Text), selbst gehostet.
   Farben & Schriften als Variablen — hier zentral anpassen.
   ============================================================ */

/* ---------- Selbst gehostete Schriften (kein externes Laden) ---------- */
@font-face { font-family:'Lora'; font-style:normal; font-weight:500; font-display:swap;
  src:url('fonts/lora-latin-500-normal.woff2') format('woff2'); }
@font-face { font-family:'Lora'; font-style:normal; font-weight:600; font-display:swap;
  src:url('fonts/lora-latin-600-normal.woff2') format('woff2'); }
@font-face { font-family:'Lora'; font-style:normal; font-weight:700; font-display:swap;
  src:url('fonts/lora-latin-700-normal.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap;
  src:url('fonts/inter-latin-400-normal.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap;
  src:url('fonts/inter-latin-500-normal.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap;
  src:url('fonts/inter-latin-600-normal.woff2') format('woff2'); }

:root {
  /* Blau-Palette — durchgehend, für Blau-Gelb-Wahrnehmung gut lesbar */
  --navy:      #12243B;   /* tiefes Nachtblau: dunkle Flächen, Headlines */
  --navy-2:    #1B3454;   /* etwas heller, für Verläufe                 */
  --blue:      #1F5C99;   /* Primärblau: Buttons, Akzente, Links        */
  --blue-bright:#2E7CC4;  /* helleres Blau: Hover, Linien               */
  --sky:       #E7F0F8;   /* sehr helles Blau: Sektionsflächen          */
  --paper:     #F8FAFC;   /* Seitenhintergrund                          */
  --surface:   #FFFFFF;   /* Karten                                     */
  --line:      #D5DFEA;   /* Trennlinien                                */
  --ink:       #1A2A3D;   /* Haupttext                                  */
  --muted:     #566678;   /* Sekundärtext                               */
  --on-dark:   #EAF2FA;   /* Text auf dunkler Fläche                    */
  --on-dark-muted:#A6BDD6;
  /* Optionaler warmer Sekundärakzent (sparsam, „Gütesiegel“-Gold).
     Liegt auf der Blau-Gelb-Achse, daher gut wahrnehmbar.
     Wird aktuell nur für einen feinen Strich genutzt; bei Bedarf auf --blue stellen. */
  --gold:      #C8A24B;

  --font-head: 'Lora', Georgia, 'Times New Roman', serif;
  --font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

  --maxw: 1140px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body {
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-body); font-size:1.075rem; line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:var(--blue); text-underline-offset:3px; }
a:hover{ color:var(--blue-bright); }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 clamp(1.25rem,5vw,3rem); }

/* Kicker — jetzt in Inter (kein Monospace mehr) */
.kicker{
  font-family:var(--font-body); font-size:.8rem; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin:0 0 1rem;
}
.kicker--ondark{ color:var(--on-dark-muted); }

.skip{ position:absolute; left:-999px; top:0; background:var(--navy); color:#fff; padding:.6rem 1rem; z-index:100; }
.skip:focus{ left:0; }
:where(a,button,input,select,textarea):focus-visible{ outline:2px solid var(--blue-bright); outline-offset:2px; }

/* ============================ HERO ============================ */
.hero{
  position:relative; color:var(--on-dark);
  /* Duotone-Hero: Navy-Verlauf tönt das Foto blau ein und hält links den Textkontrast,
     während rechts der Schweiß-Lichtbogen durchscheint. */
  background-image:
    linear-gradient(102deg, rgba(18,36,59,.93) 0%, rgba(18,36,59,.82) 44%, rgba(18,36,59,.55) 100%),
    url('fotos/hero.jpg');
  background-size:cover; background-position:center right;
}
.hero__inner{ padding:clamp(5rem,13vh,8.5rem) 0 clamp(4rem,10vh,6.5rem); max-width:62ch; }
.hero h1{
  font-family:var(--font-head); font-weight:700;
  font-size:clamp(2.8rem,7.5vw,5.6rem); line-height:1.02; letter-spacing:-0.01em;
  margin:0 0 1.2rem; color:#fff; text-wrap:balance;
}
.hero .thesis{ font-family:var(--font-head); font-style:italic; font-weight:500;
  font-size:clamp(1.3rem,3.2vw,2rem); line-height:1.25; margin:0 0 1.1rem; color:var(--on-dark); }
.hero .lede{ font-size:clamp(1.05rem,1.7vw,1.25rem); color:var(--on-dark-muted); margin:0 0 2.2rem; max-width:48ch; }

/* ===================== SCHMALER HEADER (Rechtsseiten) ===================== */
.legal-hero{
  position:relative; color:var(--on-dark);
  background-size:cover; background-position:center;
}
.legal-hero--impressum{
  background-image:
    linear-gradient(102deg, rgba(18,36,59,.93) 0%, rgba(18,36,59,.78) 55%, rgba(18,36,59,.62) 100%),
    url('fotos/impressum.jpg');
}
.legal-hero--datenschutz{
  background-image:
    linear-gradient(102deg, rgba(18,36,59,.93) 0%, rgba(18,36,59,.78) 55%, rgba(18,36,59,.62) 100%),
    url('fotos/datenschutz.jpg');
}
.legal-hero__inner{ padding:clamp(2.2rem,6vh,3.6rem) 0; }
.legal-hero .back{ display:inline-block; margin:0 0 .9rem; font-size:.85rem; font-weight:600;
  letter-spacing:.04em; text-transform:uppercase; text-decoration:none; color:var(--on-dark); opacity:.85; }
.legal-hero .back:hover{ opacity:1; }
.legal-hero h1{ font-family:var(--font-head); font-weight:700;
  font-size:clamp(1.9rem,4vw,2.7rem); line-height:1.05; margin:0; color:#fff; }

.btn{
  display:inline-block; font-family:var(--font-body); font-weight:600; font-size:1rem;
  padding:.9rem 1.7rem; border:0; border-radius:7px;
  background:var(--blue); color:#fff; text-decoration:none; cursor:pointer;
  transition:background .15s ease, transform .15s ease;
}
.btn:hover{ background:var(--blue-bright); color:#fff; }
.btn--ghost{ background:transparent; color:#fff; box-shadow:inset 0 0 0 1.5px rgba(234,242,250,.55); }
.btn--ghost:hover{ background:rgba(234,242,250,.12); }

/* ============================ Sektionen ============================ */
.section{ padding:clamp(3.5rem,9vh,6.5rem) 0; }
.section--sky{ background:var(--sky); }
.section--navy{ background:var(--navy); color:var(--on-dark); }
.section h2{
  font-family:var(--font-head); font-weight:600;
  font-size:clamp(2rem,4.5vw,3.1rem); line-height:1.1; letter-spacing:-0.01em;
  margin:0 0 1.25rem; color:var(--navy); text-wrap:balance;
}
.section--navy h2{ color:#fff; }

/* Worum es geht */
.intro-grid{ display:grid; gap:clamp(1.5rem,4vw,3.5rem); grid-template-columns:1fr; align-items:start; }
@media (min-width:820px){ .intro-grid{ grid-template-columns:1.05fr .95fr; } }
.intro-statement{
  font-family:var(--font-head); font-weight:600;
  font-size:clamp(1.7rem,3.6vw,2.6rem); line-height:1.18; letter-spacing:-0.01em;
  margin:0; color:var(--navy);
}
.intro-statement .em{ color:var(--blue); font-style:italic; }
.intro-body{ font-size:1.08rem; }
.intro-body p{ margin:0 0 1.15rem; }
.intro-body p:last-child{ margin-bottom:0; }

/* Formate */
.formats{ display:grid; gap:1.25rem; grid-template-columns:1fr; margin-top:2.5rem; }
@media (min-width:620px){ .formats{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:940px){ .formats{ grid-template-columns:repeat(3,1fr); } }
.format{
  background:var(--surface); border:1px solid var(--line); border-radius:12px;
  box-shadow:0 1px 3px rgba(18,36,59,.05);
  padding:clamp(1.5rem,2.5vw,2rem); transition:transform .15s ease, box-shadow .15s ease;
}
.format:hover{ transform:translateY(-3px); box-shadow:0 14px 32px rgba(18,36,59,.13); }
.format .tag{ font-size:.74rem; font-weight:600; letter-spacing:.10em; text-transform:uppercase;
  color:var(--blue); margin:0 0 .85rem; }
.format h3{ font-family:var(--font-head); font-weight:600; font-size:1.3rem; margin:0 0 .55rem; color:var(--navy); }
.format p{ margin:0; color:var(--muted); font-size:1rem; line-height:1.6; }

/* Kontakt */
.contact-grid{ display:grid; gap:clamp(1.5rem,4vw,3.5rem); grid-template-columns:1fr; }
@media (min-width:860px){ .contact-grid{ grid-template-columns:.85fr 1.15fr; } }
.contact-intro p{ color:var(--on-dark-muted); margin:0 0 1.5rem; max-width:42ch; font-size:1.08rem; }
/* freundliche Merkmal-Zeilen statt Terminal-Pfeile */
.feat{ list-style:none; padding:0; margin:0; display:grid; gap:.85rem; }
.feat li{ display:grid; grid-template-columns:auto 1fr; gap:.7rem; align-items:center; color:var(--on-dark); font-size:1rem; }
.feat .ic{ width:1.5rem; height:1.5rem; flex:0 0 auto; color:var(--blue-bright); }

form.lw-form{ display:grid; gap:1.15rem; background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10); border-radius:14px; padding:clamp(1.5rem,3vw,2.25rem); }
.field{ display:grid; gap:.4rem; }
.field label{ font-size:.9rem; font-weight:600; color:var(--on-dark); }
.field .req{ color:var(--blue-bright); }
.field input,.field select,.field textarea{
  font-family:var(--font-body); font-size:1rem; background:#fff; color:var(--ink);
  border:1px solid #cdd9e6; border-radius:7px; padding:.8rem .9rem; width:100%;
}
.field input::placeholder,.field textarea::placeholder{ color:#8a98a8; }
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--blue); outline:none; box-shadow:0 0 0 3px rgba(46,124,196,.18); }
.field textarea{ resize:vertical; min-height:140px; }
.field select{ appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 20px) 1.25rem,calc(100% - 14px) 1.25rem; background-size:6px 6px,6px 6px; background-repeat:no-repeat; }
.checks{ display:grid; gap:.8rem; margin-top:.25rem; }
.check{ display:grid; grid-template-columns:auto 1fr; gap:.65rem; align-items:start; font-size:.92rem; color:var(--on-dark-muted); line-height:1.5; }
.check input{ width:1.1rem; height:1.1rem; margin-top:.15rem; accent-color:var(--blue-bright); }
.check a{ color:var(--on-dark); }
.honey{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-actions{ margin-top:.5rem; }

.notice{ padding:.9rem 1.1rem; border-radius:8px; font-size:.95rem; margin:0 0 1.5rem; }
.notice--err{ background:#3a2230; color:#f3d2dc; border:1px solid #6b3a50; }

/* Footer + Recht */
.site-footer{ background:var(--navy); color:var(--on-dark-muted); padding:3rem 0; font-size:.95rem; }
.site-footer .foot-grid{ display:flex; flex-wrap:wrap; gap:1rem 2rem; align-items:baseline; justify-content:space-between; }
.site-footer a{ color:var(--on-dark); }
.site-footer .brand{ font-family:var(--font-head); font-weight:600; color:#fff; }
.site-footer nav a{ margin-left:1.5rem; }
.site-footer .foot-legal{ display:flex; flex-wrap:wrap; gap:.35rem 1.5rem; justify-content:space-between;
  margin-top:1.6rem; padding-top:1.2rem; border-top:1px solid rgba(255,255,255,.10);
  font-size:.82rem; color:var(--on-dark-muted); }
.site-footer .foot-legal .credit{ color:var(--on-dark); }
@media (max-width:520px){ .site-footer nav a{ margin:0 1.5rem 0 0; } }

.legal{ padding:clamp(3rem,8vh,5rem) 0; max-width:70ch; }
.legal a.back{ font-size:.85rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase; text-decoration:none; color:var(--blue); }
.legal h1{ font-family:var(--font-head); font-weight:700; font-size:clamp(1.9rem,4vw,2.7rem); margin:1.5rem 0 1rem; color:var(--navy); }
.legal h2{ font-family:var(--font-head); font-weight:600; font-size:1.25rem; margin:2rem 0 .5rem; color:var(--navy); }
.legal p,.legal li{ color:#2c3a4b; }
.legal .draft{ background:var(--sky); border-left:4px solid var(--blue); padding:.95rem 1.15rem; font-size:.92rem; color:#33414f; margin:1.5rem 0; border-radius:0 8px 8px 0; }
