/* ==========================================================================
   Wortbühne Akademie – Elegant Classic UI
   style.css (mobile-first, flexbox-only)
   ========================================================================== */

/* ------------------------------
   CSS RESET / NORMALIZE
   ------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
html { line-height: 1.5; -webkit-text-size-adjust: 100%; }
body { margin: 0; }
h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd { margin: 0; }
ul[role='list'], ol[role='list'] { list-style: none; }
img { max-width: 100%; display: block; height: auto; }
a { text-decoration: none; color: inherit; }
button, input, select, textarea { font: inherit; color: inherit; }
button { background: none; border: 0; padding: 0; cursor: pointer; }
:focus { outline: none; }
:focus-visible { outline: 2px solid #7A1E21; outline-offset: 2px; }
html { scroll-behavior: smooth; }

/* ------------------------------
   THEME TOKENS
   ------------------------------ */
:root {
  --color-primary: #0A2342;
  --color-secondary: #7A1E21;
  --color-accent: #F5F0E6;
  --color-ink: #1F2A37;
  --color-ink-soft: #3D4A59;
  --color-muted: #8A8F98;
  --color-border: #E1DACE;
  --color-surface: #FFFFFF;
  --shadow-soft: 0 2px 10px rgba(10, 35, 66, 0.06);
  --shadow-med: 0 8px 24px rgba(10, 35, 66, 0.10);
  --radius-s: 6px;
  --radius-m: 10px;
  --radius-l: 14px;
  --space-4: 4px;  --space-8: 8px;  --space-10: 10px;  --space-12: 12px;  --space-16: 16px;  --space-20: 20px;  --space-24: 24px;  --space-30: 30px;  --space-32: 32px;  --space-40: 40px;  --space-48: 48px;  --space-60: 60px;  --space-72: 72px;
  --font-display: Georgia, 'Times New Roman', serif;
  --font-body: Verdana, Geneva, sans-serif;
}

/* ------------------------------
   BASE TYPOGRAPHY
   ------------------------------ */
body {
  font-family: var(--font-body);
  color: var(--color-ink);
  background: var(--color-surface);
  font-size: 16px;
  line-height: 1.7;
  letter-spacing: 0.1px;
}

h1, h2, h3, h4 { font-family: var(--font-display); color: var(--color-primary); font-weight: 700; }

h1 { font-size: 36px; line-height: 1.2; margin-bottom: var(--space-16); }
h2 { font-size: 28px; line-height: 1.3; margin-bottom: var(--space-16); }
h3 { font-size: 20px; line-height: 1.35; margin-top: var(--space-20); margin-bottom: var(--space-8); }

p { margin-bottom: var(--space-12); }
strong { color: var(--color-ink); font-weight: 700; }
em { font-style: italic; }

.eyebrow { font-family: var(--font-display); color: var(--color-secondary); font-size: 14px; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--space-8); }
.microcopy { color: var(--color-muted); font-size: 14px; }

/* Links */
a { color: var(--color-primary); text-underline-offset: 3px; }
a:hover { color: var(--color-secondary); text-decoration: underline; }

/* Lists (classic tidy bullets with optional icons) */
ul, ol { padding-left: 0; margin-left: 0; }
ul li, ol li { display: flex; align-items: flex-start; gap: var(--space-10); margin-bottom: var(--space-8); }
ul li::before { content: '\2022'; color: var(--color-secondary); margin-top: 2px; margin-right: 4px; font-size: 18px; font-family: var(--font-display); }
ul li img, ol li img { flex: 0 0 auto; width: 18px; height: 18px; margin-right: 2px; }
/* If an icon image exists, hide the pseudo bullet */
ul li:has(img)::before { content: ''; }

/* ------------------------------
   LAYOUT PRIMITIVES (FLEX-ONLY)
   ------------------------------ */
.container {
  max-width: 1160px;
  margin-left: auto; margin-right: auto;
  padding-left: 16px; padding-right: 16px;
  display: flex; flex-direction: column; gap: var(--space-20);
}

.content-wrapper { display: flex; flex-direction: column; gap: var(--space-16); }

section { margin-bottom: 60px; padding: 40px 0; }

/* MANDATORY SPACING AND ALIGNMENT PATTERNS */
.section { margin-bottom: 60px; padding: 40px 20px; }
.card-container { display: flex; flex-wrap: wrap; gap: 24px; }
.card { margin-bottom: 20px; position: relative; display: flex; flex-direction: column; gap: var(--space-12); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-m); padding: var(--space-20); box-shadow: var(--shadow-soft); }
.content-grid { display: flex; flex-wrap: wrap; gap: 20px; justify-content: space-between; }
.text-image-section { display: flex; align-items: center; gap: 30px; flex-wrap: wrap; }
.testimonial-card { display: flex; align-items: center; gap: 20px; padding: 20px; }
.feature-item { display: flex; flex-direction: column; align-items: flex-start; gap: 15px; }

/* ------------------------------
   HEADER & NAVIGATION
   ------------------------------ */
header { position: sticky; top: 0; background: var(--color-surface); border-bottom: 1px solid var(--color-border); z-index: 1000; }
header .container { flex-direction: row; align-items: center; justify-content: space-between; gap: var(--space-16); padding-top: 12px; padding-bottom: 12px; }
.logo img { height: 40px; width: auto; }

.main-nav { display: none; align-items: center; gap: var(--space-16); }
.main-nav a { padding: 8px 10px; border-radius: var(--radius-s); color: var(--color-ink-soft); font-family: var(--font-display); font-size: 15px; }
.main-nav a:hover { color: var(--color-primary); background: var(--color-accent); }

.header-ctas { display: none; align-items: center; gap: var(--space-12); }

/* Mobile menu button */
.mobile-menu-toggle { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border: 1px solid var(--color-border); border-radius: var(--radius-s); background: var(--color-surface); color: var(--color-primary); transition: background 200ms ease, transform 200ms ease; }
.mobile-menu-toggle:hover { background: var(--color-accent); transform: translateY(-1px); }

/* Mobile menu overlay */
.mobile-menu { position: fixed; inset: 0; background: rgba(10,35,66,0.08); display: flex; flex-direction: row; justify-content: flex-end; align-items: stretch; opacity: 0; pointer-events: none; transform: translateX(0); transition: opacity 250ms ease; z-index: 1200; }
.mobile-menu::before { content: ''; flex: 1 1 auto; }
.mobile-menu .mobile-nav { background: var(--color-surface); width: 82%; max-width: 340px; display: flex; flex-direction: column; gap: 0; transform: translateX(100%); transition: transform 300ms ease; border-left: 1px solid var(--color-border); box-shadow: var(--shadow-med); }
.mobile-menu .mobile-nav a { padding: 14px 18px; border-bottom: 1px solid var(--color-border); font-family: var(--font-display); color: var(--color-ink); }
.mobile-menu .mobile-nav a:hover { background: var(--color-accent); color: var(--color-primary); }
.mobile-menu-close { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border: 1px solid var(--color-border); border-radius: var(--radius-s); background: var(--color-surface); color: var(--color-primary); }

/* Open states (compat with multiple toggling strategies) */
.mobile-menu.open, .mobile-menu.active, body.menu-open .mobile-menu { opacity: 1; pointer-events: auto; }
.mobile-menu.open .mobile-nav, .mobile-menu.active .mobile-nav, body.menu-open .mobile-menu .mobile-nav { transform: translateX(0); }
body.menu-open { overflow: hidden; }

/* ------------------------------
   HERO
   ------------------------------ */
.hero { background: var(--color-accent); border-bottom: 1px solid var(--color-border); }
.hero .container { gap: 0; }
.hero .content-wrapper { padding-top: var(--space-32); padding-bottom: var(--space-24); align-items: flex-start; gap: var(--space-16); }
.hero h1 { color: var(--color-primary); }
.hero p { max-width: 70ch; }

.cta-row { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-12); margin-top: var(--space-8); }

.trust-badges ul { display: flex; flex-wrap: wrap; gap: var(--space-12); padding: 0; }
.trust-badges li { display: flex; align-items: center; gap: var(--space-8); color: var(--color-ink-soft); font-size: 14px; padding: 6px 10px; border: 1px solid var(--color-border); border-radius: 999px; background: #FFF; }
.trust-badges img { width: 16px; height: 16px; }

/* ------------------------------
   TEXT SECTIONS & UTILITIES
   ------------------------------ */
.text-section { display: flex; flex-direction: column; gap: var(--space-12); }
.text-section p { max-width: 75ch; }
.text-section a { font-weight: 600; }

/* ------------------------------
   BUTTONS
   ------------------------------ */
.button { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 10px 18px; border-radius: var(--radius-s); border: 1px solid var(--color-primary); color: var(--color-primary); background: #FFFFFF; transition: background 200ms ease, color 200ms ease, transform 150ms ease, box-shadow 200ms ease; text-decoration: none; min-height: 44px; font-family: var(--font-display); letter-spacing: 0.02em; }
.button:hover { transform: translateY(-1px); box-shadow: var(--shadow-soft); background: var(--color-accent); }
.button:active { transform: translateY(0); }

.button.primary { background: var(--color-primary); color: #FFFFFF; border-color: var(--color-primary); }
.button.primary:hover { background: #0C2A50; }

.button.secondary { background: #FFFFFF; color: var(--color-secondary); border-color: var(--color-secondary); }
.button.secondary:hover { background: #F9F4EC; }

/* ------------------------------
   TESTIMONIALS (high contrast on light bg)
   ------------------------------ */
.testimonial-card { background: #FFF; border: 1px solid var(--color-border); border-left: 4px solid var(--color-secondary); border-radius: var(--radius-m); box-shadow: var(--shadow-soft); color: var(--color-ink); }
.testimonial-card p { margin: 0; }
.testimonial-card p + p { color: var(--color-ink-soft); }

/* ------------------------------
   FOOTER
   ------------------------------ */
footer { background: var(--color-primary); color: var(--color-accent); padding-top: var(--space-40); }
footer .container { padding-bottom: var(--space-32); }
footer .content-wrapper { display: flex; flex-wrap: wrap; gap: var(--space-24); align-items: flex-start; flex-direction: row; }
.footer-brand, .footer-nav-main, .footer-nav-legal, .footer-contact { display: flex; flex-direction: column; gap: var(--space-12); flex: 1 1 240px; }
footer h3 { color: #FFFFFF; font-size: 16px; letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: var(--space-8); }
footer nav { display: flex; flex-direction: column; gap: 8px; }
footer nav a { color: var(--color-accent); opacity: 0.9; }
footer nav a:hover { color: #FFFFFF; text-decoration: underline; }
.footer-brand img { width: 40px; height: 40px; }
.footer-contact p, .footer-brand p { color: #E9E4DA; }
.social-links { display: flex; gap: var(--space-12); }
.social-links a { display: inline-flex; width: 34px; height: 34px; align-items: center; justify-content: center; border: 1px solid rgba(245,240,230,0.3); border-radius: 999px; transition: background 200ms ease, transform 150ms ease; }
.social-links a:hover { background: rgba(245,240,230,0.1); transform: translateY(-1px); }
.newsletter p a { color: #FFFFFF; text-decoration: underline; }

/* ------------------------------
   GENERIC CARDS (not strictly used but styled per requirements)
   ------------------------------ */
.card h3 { margin-bottom: 4px; }
.card p:last-child { margin-bottom: 0; }

/* ------------------------------
   COOKIE CONSENT BANNER & MODAL
   ------------------------------ */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; background: #FFFFFF; border-top: 1px solid var(--color-border); box-shadow: 0 -6px 24px rgba(10,35,66,0.08); padding: 14px 16px; display: flex; flex-direction: column; gap: var(--space-12); z-index: 1400; transform: translateY(100%); opacity: 0; transition: transform 300ms ease, opacity 300ms ease; }
.cookie-banner.show, body.cookie-open .cookie-banner { transform: translateY(0); opacity: 1; }
.cookie-banner .cookie-content { display: flex; flex-direction: column; gap: var(--space-8); }
.cookie-banner .cookie-buttons { display: flex; flex-wrap: wrap; gap: var(--space-12); }
.cookie-banner .button { min-width: 140px; }
.cookie-banner .button.accept { background: var(--color-secondary); border-color: var(--color-secondary); color: #FFF; }
.cookie-banner .button.reject { background: #FFFFFF; border-color: var(--color-ink-soft); color: var(--color-ink); }
.cookie-banner .button.settings { background: var(--color-accent); border-color: var(--color-primary); color: var(--color-primary); }

.cookie-modal { position: fixed; inset: 0; background: rgba(10,35,66,0.5); display: flex; align-items: center; justify-content: center; padding: 20px; opacity: 0; pointer-events: none; transition: opacity 250ms ease; z-index: 1500; }
.cookie-modal.open, .cookie-modal.active, body.cookie-open .cookie-modal { opacity: 1; pointer-events: auto; }
.cookie-modal-content { background: #FFFFFF; border: 1px solid var(--color-border); border-radius: var(--radius-l); box-shadow: var(--shadow-med); width: 100%; max-width: 720px; display: flex; flex-direction: column; gap: var(--space-16); padding: var(--space-24); }
.cookie-modal-header { display: flex; align-items: center; justify-content: space-between; gap: var(--space-12); }
.cookie-modal-body { display: flex; flex-direction: column; gap: var(--space-16); }
.cookie-category { display: flex; align-items: center; justify-content: space-between; gap: var(--space-16); padding: 12px 14px; border: 1px solid var(--color-border); border-radius: var(--radius-s); }
.cookie-switch { position: relative; width: 46px; height: 26px; border: 1px solid var(--color-border); border-radius: 20px; background: #EEE; display: inline-flex; align-items: center; padding: 2px; transition: background 200ms ease, border-color 200ms ease; }
.cookie-switch::after { content: ''; width: 20px; height: 20px; background: #FFF; border-radius: 50%; box-shadow: var(--shadow-soft); transform: translateX(0); transition: transform 200ms ease; }
.cookie-switch.on { background: var(--color-primary); border-color: var(--color-primary); }
.cookie-switch.on::after { transform: translateX(20px); }
.cookie-modal-footer { display: flex; flex-wrap: wrap; gap: var(--space-12); justify-content: flex-end; }

/* ------------------------------
   RESPONSIVE MEDIA QUERIES
   ------------------------------ */
@media (min-width: 600px) {
  h1 { font-size: 40px; }
  h2 { font-size: 30px; }
}

@media (min-width: 768px) {
  header .container { padding-top: 14px; padding-bottom: 14px; }
  .main-nav { display: flex; }
  .header-ctas { display: flex; }
  .mobile-menu-toggle { display: none; }
  .hero .content-wrapper { padding-top: var(--space-48); padding-bottom: var(--space-40); }
  h1 { font-size: 44px; }
  h2 { font-size: 32px; }
  h3 { font-size: 22px; }
  .cookie-banner { flex-direction: row; align-items: center; justify-content: space-between; }
  .cookie-banner .cookie-content { flex-direction: row; align-items: center; justify-content: space-between; gap: var(--space-16); }
}

@media (min-width: 1024px) {
  h1 { font-size: 52px; }
  h2 { font-size: 36px; }
  .content-wrapper { gap: var(--space-20); }
  .text-image-section { flex-direction: row; }
}

/* ------------------------------
   PAGE-SPECIFIC TOUCHES
   ------------------------------ */
/* Index highlights already covered by hero, testimonials, cta-row */

/* Termine list accents */
.text-section strong { color: var(--color-primary); }

/* Contact icon rows */
.text-section li img { filter: none; opacity: 0.9; }

/* ------------------------------
   EXTRA FLEX LAYOUT HELPERS (no grid)
   ------------------------------ */
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.flex-row { display: flex; flex-direction: row; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.justify-between { justify-content: space-between; }
.gap-12 { gap: var(--space-12); }
.gap-20 { gap: var(--space-20); }

/* ------------------------------
   ACCESSIBILITY & MISC
   ------------------------------ */
hr { border: 0; border-top: 1px solid var(--color-border); margin: var(--space-24) 0; }
blockquote { margin: 0; padding-left: var(--space-16); border-left: 4px solid var(--color-secondary); color: var(--color-ink-soft); font-style: italic; }

/* Ensure minimum spacing between adjacent sections/cards */
section + section { margin-top: 0; }
.card + .card, .testimonial-card + .testimonial-card { margin-top: var(--space-20); }

/* Prevent overlaps with adequate spacing */
main { display: flex; flex-direction: column; gap: var(--space-24); }

/* ------------------------------
   PRINT (optional refinement)
   ------------------------------ */
@media print {
  header, .mobile-menu, .cookie-banner, .cookie-modal, .cta-row, footer { display: none !important; }
  section { padding: 0; margin: 16px 0; }
}
