/* =====================================================================
   Johannes-Verlag Liebenzell — global.css
   Refined editorial: papierhaft, ruhig, klassisch-mediterran-christlich.
   Tokens & Komponenten gemäß Vibe-Coding-Briefing (24.05.2026).
   Dependency-frei (kein Tailwind/Alpine) — statisches Hosting, kein Build.
   ===================================================================== */
@import url('./fonts.css');

:root {
  /* === Farbpalette (Visitenkarte) === */
  --cream-50:  #FBF7EA;
  --cream-100: #F4ECD8;   /* primärer Hintergrund */
  --cream-200: #EAE0C2;   /* Hover, Trennlinien */
  --olive-300: #A8B286;
  --olive-500: #6B7F4F;   /* Sage */
  --olive-700: #3D4F2E;   /* Logo, Headlines */
  --olive-900: #1E2A14;   /* Footer */
  --gold:      #D4A93B;
  --ink:       #2A2A1F;
  --ink-soft:  #5C5C4A;
  --line: rgba(47, 64, 34, 0.15);
  --err:  #9B3B2E;

  /* === Typografie === */
  --font-display: 'Bevan', 'Roboto Slab', Georgia, serif;
  --font-serif:   'Cormorant Garamond', 'EB Garamond', Georgia, serif;
  --font-sans:    'Source Sans 3', system-ui, -apple-system, sans-serif;

  /* === Spacing (4er) === */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-6:24px; --space-8:32px; --space-12:48px; --space-16:64px;
  --space-24:96px; --space-32:128px;

  /* === Schatten === */
  --shadow-sm: 0 1px 2px rgba(30,42,20,.08);
  --shadow-md: 0 4px 12px rgba(30,42,20,.10);
  --shadow-lg: 0 12px 32px rgba(30,42,20,.15);
  --shadow-book: 0 24px 48px rgba(30,42,20,.25), 0 8px 16px rgba(30,42,20,.12);

  /* === Radien === */
  --radius-sm:4px; --radius-md:8px; --radius-lg:16px; --radius-pill:999px;

  /* === Motion === */
  --ease-out: cubic-bezier(0.16,1,0.3,1);
  --t-fast:180ms; --t-mid:320ms; --t-slow:600ms;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-sans);
  background:var(--cream-100);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--olive-700);text-decoration:none}

/* === Container === */
.container{max-width:1240px;margin:0 auto;padding:0 var(--space-6)}
@media(min-width:768px){.container{padding:0 var(--space-12)}}
@media(min-width:1280px){.container{padding:0 var(--space-16)}}

/* === Skip-Link === */
.skip-link{
  position:absolute;left:-999px;top:0;z-index:100;
  background:var(--olive-700);color:var(--cream-50);
  padding:var(--space-3) var(--space-6);border-radius:0 0 var(--radius-sm) 0;
  font-family:var(--font-sans);font-size:14px;
}
.skip-link:focus{left:0}

/* === Überschriften === */
h1{
  font-family:var(--font-display);
  font-size:clamp(40px,5.5vw,76px);line-height:.95;
  color:var(--olive-900);letter-spacing:-.01em;
}
h2{
  font-family:var(--font-display);
  font-size:clamp(30px,4vw,52px);line-height:1.05;
  color:var(--olive-900);letter-spacing:-.01em;margin-bottom:var(--space-6);
}
h3{font-family:var(--font-serif);font-size:26px;font-weight:600;color:var(--olive-700)}
.eyebrow{
  font-family:var(--font-sans);font-size:12px;text-transform:uppercase;
  letter-spacing:.2em;color:var(--olive-500);margin-bottom:var(--space-4);
}
.lead{
  font-family:var(--font-serif);font-size:22px;line-height:1.5;
  color:var(--ink-soft);max-width:720px;
}

/* === Header === */
header.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(244,236,216,.88);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:80px}
@media(max-width:767px){.nav-inner{height:64px}}
.logo-mark{
  font-family:var(--font-display);font-size:24px;
  color:var(--olive-700);letter-spacing:.04em;line-height:1;
}
.logo-mark span{display:block;font-family:var(--font-sans);font-size:9px;
  letter-spacing:.22em;color:var(--olive-500);margin-top:2px;text-transform:uppercase}
nav.primary ul{display:flex;gap:var(--space-8);list-style:none}
nav.primary a{
  font-family:var(--font-sans);font-size:14px;color:var(--olive-700);
  text-transform:uppercase;letter-spacing:.12em;padding:var(--space-2) 0;
  position:relative;transition:color var(--t-fast) var(--ease-out);
}
nav.primary a::after{
  content:'';position:absolute;bottom:0;left:0;width:100%;height:1px;
  background:var(--olive-700);transform:scaleX(0);transform-origin:right;
  transition:transform var(--t-mid) var(--ease-out);
}
nav.primary a:hover{color:var(--olive-900)}
nav.primary a:hover::after,nav.primary a[aria-current="page"]::after{transform:scaleX(1);transform-origin:left}
nav.primary a[aria-current="page"]{color:var(--olive-900)}

/* Burger */
.burger{display:none;background:none;border:none;cursor:pointer;padding:var(--space-2);
  flex-direction:column;gap:5px}
.burger span{display:block;width:24px;height:2px;background:var(--olive-700);
  transition:transform var(--t-mid) var(--ease-out),opacity var(--t-mid) var(--ease-out)}
@media(max-width:767px){
  nav.primary{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);
    background:var(--cream-50);box-shadow:var(--shadow-lg);
    transform:translateX(100%);transition:transform var(--t-mid) var(--ease-out);
    padding:var(--space-24) var(--space-8);z-index:60}
  nav.primary.open{transform:translateX(0)}
  nav.primary ul{flex-direction:column;gap:var(--space-6)}
  nav.primary a{font-size:18px}
  .burger{display:flex;z-index:70}
  body.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.nav-open .burger span:nth-child(2){opacity:0}
  body.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-backdrop{position:fixed;inset:0;background:rgba(30,42,20,.4);
    opacity:0;pointer-events:none;transition:opacity var(--t-mid);z-index:55}
  body.nav-open .nav-backdrop{opacity:1;pointer-events:auto}
}

/* === Buttons === */
.btn{display:inline-flex;align-items:center;gap:var(--space-3);
  font-family:var(--font-sans);font-size:15px;font-weight:500;
  text-transform:uppercase;letter-spacing:.1em;cursor:pointer;
  border:none;transition:all var(--t-mid) var(--ease-out);text-align:center}
.btn .arrow{transition:transform var(--t-mid) var(--ease-out)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--olive-700);color:var(--cream-50);
  padding:var(--space-4) var(--space-8);border-radius:var(--radius-pill)}
.btn-primary:hover{background:var(--olive-900);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;color:var(--olive-700);
  padding:var(--space-4) var(--space-6);border:1px solid var(--olive-700);
  border-radius:var(--radius-pill)}
.btn-ghost:hover{background:var(--olive-700);color:var(--cream-50)}
.btn-link{color:var(--olive-700);border-bottom:1px solid var(--olive-700);
  padding:var(--space-1) 0;text-transform:uppercase;letter-spacing:.1em;font-size:14px;font-weight:500}
:focus-visible{outline:2px solid var(--olive-700);outline-offset:3px;border-radius:2px}

/* === Sections === */
section{padding:var(--space-24) 0}
@media(max-width:767px){section{padding:var(--space-16) 0}}
.section-cream-50{background:var(--cream-50)}
.section-dark{background:var(--olive-700);color:var(--cream-50)}
.section-dark h2,.section-dark h3{color:var(--cream-50)}
.section-dark .eyebrow{color:var(--olive-300)}

/* === Hero (Home) === */
.hero{position:relative;overflow:hidden;padding:var(--space-24) 0 var(--space-32)}
@media(max-width:767px){.hero{padding:var(--space-16) 0 var(--space-24)}}
.hero-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-16);align-items:center}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:var(--space-12)}}
.hero h1 em{font-family:var(--font-serif);font-style:italic;font-weight:500;color:var(--olive-700)}
.hero-lede{font-family:var(--font-serif);font-size:22px;line-height:1.5;color:var(--ink-soft);
  margin:var(--space-6) 0 var(--space-8)}
.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-4)}

/* === Buchcover-Mockup === */
.book-mock{
  width:100%;max-width:340px;margin:0 auto;position:relative;
  border-radius:2px 6px 6px 2px;box-shadow:var(--shadow-book);overflow:hidden}
.book-mock img{display:block;width:100%;height:auto;border-radius:inherit}
/* angedeutete Bindung / Buchruecken links */
.book-mock::after{content:"";position:absolute;top:0;left:0;bottom:0;width:15px;pointer-events:none;
  background:linear-gradient(to right,rgba(0,0,0,.30),rgba(0,0,0,.08) 55%,rgba(255,255,255,.12) 78%,rgba(0,0,0,0))}
.hero-book{transform:rotate(-4deg);transition:transform var(--t-slow) var(--ease-out)}
.hero-book:hover{transform:rotate(-2deg) translateY(-8px)}
.book-mock .author-top{font-family:var(--font-serif);font-style:italic;align-self:flex-end;font-size:15px}
.book-star{width:88px;height:88px;align-self:center;
  background:radial-gradient(circle,#D4A93B 0%,#B8902B 100%);
  clip-path:polygon(50% 0%,63% 38%,100% 38%,69% 59%,82% 100%,50% 73%,18% 100%,31% 59%,0 38%,37% 38%)}
.book-mock .titlearea{text-align:center;font-family:var(--font-serif)}
.book-mock .titlearea .small{font-size:15px;font-style:italic;color:#3D2D1A}
.book-mock .titlearea .big{font-size:21px;font-weight:600;margin-top:var(--space-2);line-height:1.2}

/* === Philosophie-Block === */
.philo{max-width:760px;margin:0 auto;text-align:center}
.philo p{font-family:var(--font-serif);font-style:italic;font-size:23px;line-height:1.6;color:var(--ink)}
.olive-divider{display:flex;align-items:center;justify-content:center;gap:var(--space-3);
  margin:var(--space-12) auto;color:var(--olive-500)}
.olive-divider::before,.olive-divider::after{content:'';height:1px;width:80px;background:var(--line)}

/* === Bibelzitat === */
.bible-quote{font-family:var(--font-serif);font-style:italic;
  font-size:clamp(26px,3.5vw,42px);line-height:1.35;color:var(--cream-50);
  text-align:center;max-width:880px;margin:0 auto;position:relative}
.bible-quote .cite{display:block;font-family:var(--font-sans);font-style:normal;
  font-size:14px;text-transform:uppercase;letter-spacing:.2em;color:var(--olive-300);margin-top:var(--space-8)}

/* === Sektionskopf zentriert === */
.section-head{text-align:center;max-width:680px;margin:0 auto var(--space-16)}
.section-head .lead{margin:0 auto}

/* === Buch-Karten-Raster === */
.book-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:var(--space-8);max-width:1000px;margin:0 auto}
.book-grid.single{grid-template-columns:minmax(0,360px);justify-content:center}
.book-card{background:var(--cream-50);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:var(--space-8);text-align:center;cursor:pointer;
  transition:transform var(--t-mid) var(--ease-out),box-shadow var(--t-mid) var(--ease-out);
  font:inherit;color:inherit;width:100%}
.book-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.book-card .mini-book{aspect-ratio:3/4.4;max-width:200px;margin:0 auto var(--space-6)}
.book-card h3{font-family:var(--font-serif);font-size:20px;color:var(--olive-700);margin-bottom:var(--space-1)}
.book-card .author{font-family:var(--font-sans);font-size:14px;color:var(--ink-soft);font-style:italic}
.book-card .price{margin-top:var(--space-3);font-family:var(--font-sans);font-size:15px;color:var(--olive-500);font-weight:600}

/* mini-book reuse of mock styling */
.mini-book{background:linear-gradient(135deg,#C5A968,#A78845);border-radius:2px;
  box-shadow:var(--shadow-md);display:flex;flex-direction:column;justify-content:space-between;
  padding:var(--space-4) var(--space-3);color:#2A1F0E;overflow:hidden}
.mini-book .mb-star{width:42px;height:42px;align-self:center;
  background:radial-gradient(circle,#D4A93B,#B8902B);
  clip-path:polygon(50% 0%,63% 38%,100% 38%,69% 59%,82% 100%,50% 73%,18% 100%,31% 59%,0 38%,37% 38%)}
.mini-book .mb-title{font-family:var(--font-serif);font-size:12px;font-weight:600;text-align:center;line-height:1.15}

/* === Echtes Buchcover (Bild) === */
.book-cover{display:block;width:100%;height:auto;border-radius:4px;box-shadow:var(--shadow-md)}
.book-card .book-cover{max-width:200px;margin:0 auto var(--space-6)}
.order-summary .book-cover{max-width:200px;margin:0 auto var(--space-6)}
.cover-gallery{display:flex;flex-direction:column;gap:var(--space-5);max-width:320px;margin:0 auto}
.cover-gallery figure{margin:0}
.cover-gallery figcaption{font-family:var(--font-sans);font-size:12.5px;color:var(--ink-soft);
  text-align:center;margin-top:var(--space-2)}

/* === Modal === */
.modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:var(--space-6)}
.modal.open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(30,42,20,.7);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  opacity:0;transition:opacity 220ms var(--ease-out)}
.modal.open .modal-backdrop{opacity:1}
.modal-card{position:relative;background:var(--cream-50);max-width:820px;width:100%;
  max-height:90vh;overflow-y:auto;border-radius:var(--radius-lg);padding:var(--space-12);
  box-shadow:var(--shadow-lg);transform:scale(.95);opacity:0;
  transition:transform var(--t-mid) var(--ease-out),opacity var(--t-mid) var(--ease-out)}
.modal.open .modal-card{transform:scale(1);opacity:1}
.modal-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:var(--space-12);align-items:start}
@media(max-width:680px){.modal-grid{grid-template-columns:1fr}.modal-card{padding:var(--space-8)}}
.modal-close{position:absolute;top:var(--space-4);right:var(--space-4);
  background:none;border:none;cursor:pointer;color:var(--olive-700);font-size:28px;line-height:1;
  width:40px;height:40px;border-radius:var(--radius-pill);transition:background var(--t-fast)}
.modal-close:hover{background:var(--cream-200)}
.modal .meta-list{list-style:none;font-family:var(--font-sans);font-size:15px;color:var(--ink-soft);
  margin:var(--space-4) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:var(--space-4) 0}
.modal .meta-list li{display:flex;justify-content:space-between;padding:var(--space-1) 0;gap:var(--space-4)}
.modal .meta-list dt{color:var(--olive-700)}
.modal .price-big{font-family:var(--font-serif);font-size:30px;color:var(--olive-700);margin:var(--space-4) 0 var(--space-2)}
.modal .ship-note{font-size:14px;color:var(--ink-soft);margin-bottom:var(--space-6)}

/* === Formulare === */
.form-card{background:var(--cream-50);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:var(--space-12)}
@media(max-width:767px){.form-card{padding:var(--space-8)}}
.form-field{margin-bottom:var(--space-6)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.form-field label{display:block;font-family:var(--font-sans);font-size:13px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--olive-700);margin-bottom:var(--space-2)}
.form-field label .req{color:var(--err)}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:var(--space-3) var(--space-4);background:var(--cream-100);
  border:1px solid var(--line);border-radius:var(--radius-sm);
  font-family:var(--font-serif);font-size:18px;color:var(--ink);
  transition:border-color var(--t-fast) var(--ease-out),background var(--t-fast)}
.form-field textarea{min-height:120px;resize:vertical}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{
  outline:none;border-color:var(--olive-700);background:var(--cream-50)}
.form-field.invalid input,.form-field.invalid textarea,.form-field.invalid select{border-color:var(--err)}
.field-error{display:none;color:var(--err);font-family:var(--font-sans);font-size:13px;margin-top:var(--space-2)}
.form-field.invalid .field-error{display:block}
.checkbox-field{display:flex;gap:var(--space-3);align-items:flex-start;margin-bottom:var(--space-6)}
.checkbox-field input{width:20px;height:20px;flex:none;margin-top:3px;accent-color:var(--olive-700)}
.checkbox-field label{font-family:var(--font-sans);font-size:15px;color:var(--ink-soft);text-transform:none;letter-spacing:0}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.radio-group{display:flex;flex-direction:column;gap:var(--space-3)}
.radio-group label{display:flex;gap:var(--space-3);align-items:center;font-family:var(--font-sans);
  font-size:16px;color:var(--ink);text-transform:none;letter-spacing:0}
.radio-group input{width:18px;height:18px;accent-color:var(--olive-700)}
/* Stepper */
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;background:var(--cream-100)}
.qty button{width:44px;height:46px;border:none;background:none;cursor:pointer;
  font-size:22px;color:var(--olive-700);font-family:var(--font-serif)}
.qty button:hover{background:var(--cream-200)}
.qty input{width:56px;text-align:center;border:none;border-left:1px solid var(--line);
  border-right:1px solid var(--line);border-radius:0;background:var(--cream-50)}

/* === Bestell-/Kontakt-Layout 2-spaltig === */
.split{display:grid;grid-template-columns:0.85fr 1.15fr;gap:var(--space-16);align-items:start}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:var(--space-12)}}
.order-summary{background:var(--cream-50);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:var(--space-8);text-align:center}
.order-summary .mini-book{max-width:180px;margin:0 auto var(--space-6)}
.order-summary h3{margin-bottom:var(--space-1)}
.order-summary .author{font-style:italic;color:var(--ink-soft);font-size:15px}
.order-summary .price{font-family:var(--font-serif);font-size:28px;color:var(--olive-700);margin:var(--space-4) 0 var(--space-2)}
.ship-table{font-family:var(--font-sans);font-size:14px;color:var(--ink-soft);text-align:left;
  margin-top:var(--space-6);border-top:1px solid var(--line);padding-top:var(--space-4);line-height:1.7}
.ship-table strong{color:var(--olive-700)}

.contact-info{font-family:var(--font-serif);font-size:20px;line-height:1.8;color:var(--ink)}
.contact-info .label{font-family:var(--font-sans);font-size:12px;text-transform:uppercase;
  letter-spacing:.15em;color:var(--olive-500);display:block;margin-top:var(--space-6)}
.contact-info a{color:var(--olive-700)}

/* === Prose / Rechtsseiten === */
.prose{max-width:760px;margin:0 auto}
.prose h1{font-size:clamp(34px,4.5vw,52px);margin-bottom:var(--space-8)}
.prose h2{font-size:26px;margin-top:var(--space-12);margin-bottom:var(--space-4);color:var(--olive-700)}
.prose h3{font-size:20px;margin-top:var(--space-8);margin-bottom:var(--space-2)}
.prose p,.prose li{font-family:var(--font-serif);font-size:19px;line-height:1.7;color:var(--ink);margin-bottom:var(--space-4)}
.prose ul,.prose ol{padding-left:var(--space-6);margin-bottom:var(--space-4)}
.prose a{border-bottom:1px solid var(--line)}
.placeholder-note{font-family:var(--font-sans);font-size:15px;color:var(--ink-soft);font-style:italic;
  background:rgba(212,169,59,.10);border-left:3px solid var(--gold);padding:var(--space-4) var(--space-6);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:var(--space-6) 0}

/* === FAQ === */
.faq{max-width:780px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:var(--space-4) 0}
.faq summary{cursor:pointer;font-family:var(--font-serif);font-size:21px;color:var(--olive-700);
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-family:var(--font-display);color:var(--olive-500);transition:transform var(--t-fast)}
.faq details[open] summary::after{content:'–'}
.faq details p{margin-top:var(--space-3);color:var(--ink-soft);font-family:var(--font-sans);font-size:16px}

/* === Leere Aktuelles-Seite === */
.empty-state{text-align:center;max-width:620px;margin:0 auto;padding:var(--space-16) 0}
.empty-state .lead{margin:var(--space-6) auto 0}

/* === Footer === */
footer.site-footer{background:var(--olive-900);color:var(--cream-200);padding:var(--space-16) 0 var(--space-8)}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-12)}
@media(max-width:767px){.footer-grid{grid-template-columns:1fr;gap:var(--space-8)}}
footer.site-footer h4{font-family:var(--font-display);font-size:14px;text-transform:uppercase;
  letter-spacing:.12em;color:var(--cream-50);margin-bottom:var(--space-4)}
footer.site-footer p,footer.site-footer a{font-size:15px;line-height:1.8;color:var(--cream-200)}
footer.site-footer a:hover{color:var(--gold)}
footer.site-footer ul{list-style:none}
.footer-bottom{border-top:1px solid rgba(244,236,216,.15);margin-top:var(--space-12);
  padding-top:var(--space-6);text-align:center;font-size:13px;color:var(--cream-200)}
.footer-credit{margin-top:var(--space-2);opacity:.6;font-size:12px}

/* === Olivenzweig-Dekoration === */
.branch-deco{position:absolute;pointer-events:none;opacity:.18;z-index:0}
.section-dark .branch-deco{opacity:.30}
.branch-deco.top-left{top:-40px;left:-60px;transform:rotate(-15deg)}
.branch-deco.bottom-right{bottom:-50px;right:-40px;transform:rotate(165deg)}
.hero .container,.philo,.bible-quote{position:relative;z-index:1}

/* === Coming-Soon === */
.soon{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:var(--space-12);position:relative;overflow:hidden;background:var(--cream-100)}
.soon .jvl{font-family:var(--font-display);font-size:clamp(64px,12vw,120px);color:var(--olive-700);line-height:1;letter-spacing:.04em}
.soon h1{font-size:clamp(26px,4vw,40px);margin:var(--space-8) 0 var(--space-4)}
.soon .tag{font-family:var(--font-serif);font-size:22px;color:var(--ink-soft);font-style:italic;margin-bottom:var(--space-12)}
.soon .contact{font-family:var(--font-serif);font-size:19px;line-height:1.9;color:var(--ink)}
.soon .contact a{color:var(--olive-700)}

/* === Reveal-Animationen === */
.reveal{opacity:0;transform:translateY(16px);transition:opacity var(--t-slow) var(--ease-out),transform var(--t-slow) var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.hero .anim{opacity:0;transform:translateY(8px);animation:rise var(--t-slow) var(--ease-out) forwards}
.hero .anim.d1{animation-delay:.10s}.hero .anim.d2{animation-delay:.20s}
.hero .anim.d3{animation-delay:.30s}.hero .anim.d4{animation-delay:.40s}
.hero-book.anim{animation:bookrise .8s var(--ease-out) .4s forwards;opacity:0}
@keyframes rise{to{opacity:1;transform:none}}
@keyframes bookrise{from{opacity:0;transform:rotate(0) translateY(20px)}to{opacity:1;transform:rotate(-4deg)}}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-delay:0ms!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero .anim,.hero-book.anim{opacity:1;transform:none;animation:none}
  .hero-book.anim{transform:rotate(-4deg)}
}

/* === Bildungspartner-Streifen (Tür zu EduAssets) === */
.partner-strip{background:linear-gradient(135deg,#E2E8D4 0%,#C7D3AC 100%);
  border-top:3px solid #B8742A;border-bottom:3px solid #B8742A}
.partner-strip .eyebrow{color:#5B7043}
.partner-strip .partner-inner p,.partner-strip .partner-inner p strong{color:var(--olive-900)}
.partner-strip .btn-primary{background:linear-gradient(135deg,#E0A24A 0%,#B8742A 100%);color:#FFFFFF;box-shadow:0 4px 16px rgba(184,116,42,.35)}
.partner-strip .btn-primary:hover{background:linear-gradient(135deg,#EAAE58 0%,#A85F1E 100%);transform:translateY(-2px);box-shadow:0 8px 22px rgba(184,116,42,.5)}
.partner-strip .container{padding-top:var(--space-12);padding-bottom:var(--space-12)}
.partner-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-8)}
.partner-inner .eyebrow{margin-bottom:var(--space-2)}
.partner-inner p{font-family:var(--font-serif);font-size:21px;line-height:1.45;color:var(--ink);max-width:600px}
.partner-inner p strong{color:var(--olive-700)}
.partner-inner .btn{flex:none}
@media(max-width:700px){.partner-inner{flex-direction:column;align-items:flex-start;gap:var(--space-6)}}
