/* ═══════════════════════════════════════════════════════════
   MARIA LIPPOLD — THE REGULATED WOMAN
   Shared styles across all pages
   GDPR-friendly: all fonts loaded locally, no external connections
═══════════════════════════════════════════════════════════ */

/* ── LOCAL FONT FACES ── */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-400-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/jost-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/jost-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/jost-600.woff2') format('woff2');
}

:root {
  --sand:   #e2d6ae;
  --sage:   #b7c798;
  --peach:  #f6ba96;
  --cream:  #eaede4;
  --gold:   #b59f78;
  --dark:   #502525;
  --warm:   #816a60;
  --white:  #faf9f6;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Jost', -apple-system, system-ui, sans-serif;
  background:var(--white);
  color:var(--dark);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

a { color:inherit; }
img { max-width:100%; display:block; }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  padding:22px 64px;
  display:flex; justify-content:space-between; align-items:center;
  background:rgba(250,249,246,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(80,37,37,0.07);
}
.nav-logo {
  font-family:'Cormorant Garamond',serif; font-size:1rem;
  letter-spacing:0.14em; text-transform:uppercase;
  color:var(--dark); text-decoration:none;
}
.nav-right { display:flex; gap:36px; align-items:center; }
.nav-links { display:flex; gap:36px; align-items:center; }
.nav-links a {
  font-size:0.7rem; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--warm); text-decoration:none; transition:color 0.3s;
}
.nav-links a:hover,
.nav-links a.active { color:var(--dark); }

/* Language switch */
.lang-switch {
  display:flex; align-items:center; gap:6px;
  font-size:0.7rem; letter-spacing:0.16em; text-transform:uppercase;
  border-left:1px solid rgba(80,37,37,0.15);
  padding-left:24px;
}
.lang-switch a {
  color:var(--warm); text-decoration:none; transition:color 0.3s;
  padding:2px 4px;
}
.lang-switch a.active { color:var(--dark); font-weight:500; }
.lang-switch a:hover { color:var(--dark); }
.lang-switch span { color:rgba(80,37,37,0.3); }

.nav-cta {
  font-size:0.7rem; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--white) !important; background:var(--dark);
  padding:10px 24px; text-decoration:none; transition:background 0.3s;
}
.nav-cta:hover { background:var(--warm) !important; }

/* ── BUTTONS ── */
.btn-primary {
  display:inline-block; background:var(--dark); color:var(--cream);
  padding:16px 44px; font-size:0.72rem; letter-spacing:0.2em;
  text-transform:uppercase; text-decoration:none; transition:background 0.3s;
}
.btn-primary:hover { background:var(--warm); }
.btn-light {
  display:inline-block; background:var(--cream); color:var(--dark);
  padding:18px 52px; font-size:0.72rem; letter-spacing:0.2em;
  text-transform:uppercase; text-decoration:none; transition:background 0.3s;
}
.btn-light:hover { background:var(--sand); }
.btn-link {
  font-size:0.78rem; color:var(--dark); text-decoration:none;
  border-bottom:1px solid var(--dark); padding-bottom:2px;
  transition:opacity 0.3s;
}
.btn-link:hover { opacity:0.6; }

/* ── TICKER ── */
.ticker { background:var(--dark); padding:18px 0; overflow:hidden; white-space:nowrap; }
.ticker-track { display:inline-flex; animation:ticker 32s linear infinite; }
.ticker-item {
  font-family:'Cormorant Garamond',serif; font-style:italic;
  font-size:1.15rem; color:var(--sand); padding:0 44px; letter-spacing:0.05em;
}
.ticker-sep { color:var(--peach); font-style:normal; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── SECTION BASICS ── */
.section { padding:120px 64px; }
.label {
  display:block; font-size:0.62rem; letter-spacing:0.28em;
  text-transform:uppercase; color:var(--warm); margin-bottom:18px;
}
.h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.8vw,3.4rem); font-weight:300; line-height:1.18;
  color:var(--dark); margin-bottom:24px;
}
.h2 em { font-style:italic; }
.body-text {
  font-size:0.98rem; font-weight:300; line-height:1.85; color:var(--warm);
}

/* ── PAGE HERO ── */
.page-hero {
  padding:160px 64px 100px;
  background:var(--cream);
  position:relative;
}
.page-hero-inner {
  max-width:1180px; margin:0 auto;
  display:grid; grid-template-columns:1.1fr 1fr; gap:80px;
  align-items:center;
}
.page-hero-text { z-index:2; }
.page-hero-eyebrow {
  font-size:0.65rem; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--dark); opacity:0.65; margin-bottom:24px;
}
.page-hero-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,4.8vw,4.8rem); font-weight:300; line-height:1.08;
  color:var(--dark); margin-bottom:28px;
}
.page-hero-title em { font-style:italic; }
.page-hero-sub {
  font-size:1rem; font-weight:300; line-height:1.85;
  color:var(--dark); max-width:480px; margin-bottom:36px;
}
.page-hero-img {
  width:100%; aspect-ratio:3/4; max-height:600px;
  overflow:hidden; box-shadow:0 30px 80px -30px rgba(80,37,37,0.25);
}
.page-hero-img img { width:100%; height:100%; object-fit:cover; }

/* ── QUOTE BAND ── */
.quote-band {
  padding:100px 64px;
  display:flex; justify-content:center; align-items:center;
}
.quote-inner { max-width:820px; text-align:center; }
.quote-text {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.55rem,3.2vw,2.7rem); font-weight:300; font-style:italic;
  line-height:1.45; color:var(--dark); margin-bottom:24px;
}
.quote-attr {
  font-size:0.65rem; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--dark); opacity:0.7;
}

/* ── FINAL CTA ── */
.cta-final {
  background:var(--dark); padding:140px 64px; text-align:center;
  position:relative; overflow:hidden;
}
.cta-final::before {
  content:''; position:absolute; top:-50%; left:-20%;
  width:60%; height:200%;
  background:radial-gradient(circle, rgba(246,186,150,0.08) 0%, transparent 70%);
  pointer-events:none;
}
.cta-eyebrow {
  display:block; font-size:0.62rem; letter-spacing:0.28em;
  text-transform:uppercase; color:var(--gold); margin-bottom:22px;
  position:relative;
}
.cta-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.4rem,4.5vw,4.2rem); font-weight:300; line-height:1.15;
  color:var(--cream); margin-bottom:28px;
  max-width:760px; margin-left:auto; margin-right:auto;
  position:relative;
}
.cta-title em { font-style:italic; }
.cta-sub {
  font-size:0.97rem; font-weight:300; line-height:1.8;
  color:rgba(234,237,228,0.65); max-width:480px;
  margin:0 auto 52px;
  position:relative;
}

/* ── FOOTER ── */
footer {
  background:var(--dark); border-top:1px solid rgba(234,237,228,0.1);
  padding:52px 64px;
  display:grid; grid-template-columns:1fr 1fr 1fr; gap:48px;
  align-items:start;
}
.foot-col h4 {
  font-family:'Cormorant Garamond',serif; font-size:0.95rem;
  letter-spacing:0.14em; text-transform:uppercase; font-weight:400;
  color:var(--sand); margin-bottom:18px;
}
.foot-col a {
  display:block; font-size:0.82rem; font-weight:300;
  color:rgba(234,237,228,0.55); text-decoration:none;
  margin-bottom:8px; transition:color 0.3s;
}
.foot-col a:hover { color:var(--sand); }
.foot-claim {
  font-family:'Cormorant Garamond',serif; font-style:italic;
  font-size:0.95rem; color:var(--gold); opacity:0.7; margin-top:10px;
}

/* ── ANIMATIONS ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(26px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }

.reveal {
  opacity:0; transform:translateY(22px);
  transition:opacity 0.6s ease, transform 0.6s ease;
}
.reveal.vis { opacity:1; transform:translateY(0); }

/* ── DISCLAIMER BAND (gold band at bottom of services) ── */
.disclaimer-band {
  background:var(--gold);
  padding:40px 64px;
  color:var(--white);
}
.disclaimer-inner {
  max-width:1180px; margin:0 auto;
}
.disclaimer-inner strong {
  font-weight:600;
  display:inline-block;
  margin-right:6px;
}
.disclaimer-inner p {
  font-size:0.92rem; font-weight:300; line-height:1.7;
  color:var(--white);
}

/* ── SOCIAL ICONS (footer + contact) ── */
.social-icons { display:flex; gap:16px; margin-top:8px; }
.social-icons a {
  display:inline-flex; align-items:center; justify-content:center;
  width:38px; height:38px;
  border:1px solid rgba(234,237,228,0.25);
  border-radius:50%;
  color:var(--sand);
  transition:background 0.3s, border-color 0.3s;
  text-decoration:none;
}
.social-icons a:hover {
  background:var(--gold);
  border-color:var(--gold);
  color:var(--dark);
}
.social-icons svg { width:16px; height:16px; fill:currentColor; }
.social-icons-light a {
  border-color:rgba(80,37,37,0.2);
  color:var(--warm);
}
.social-icons-light a:hover {
  background:var(--dark);
  border-color:var(--dark);
  color:var(--cream);
}

/* ── NEWSLETTER (under contact form) ── */
.newsletter-section {
  background:var(--cream);
  padding:80px 64px;
}
.newsletter-inner {
  max-width:680px; margin:0 auto; text-align:center;
}
.newsletter-eyebrow {
  display:block; font-size:0.62rem; letter-spacing:0.28em;
  text-transform:uppercase; color:var(--warm); margin-bottom:18px;
}
.newsletter-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.8rem,3.2vw,2.6rem); font-weight:300;
  font-style:italic; line-height:1.25; color:var(--dark);
  margin-bottom:18px;
}
.newsletter-sub {
  font-size:0.95rem; font-weight:300; line-height:1.7;
  color:var(--warm); max-width:520px; margin:0 auto 32px;
}
.newsletter-form {
  display:flex; gap:0; max-width:520px; margin:0 auto;
  border:1px solid rgba(80,37,37,0.2);
  background:var(--white);
}
.newsletter-form input[type="email"] {
  flex:1;
  padding:16px 20px;
  border:none; background:transparent;
  font-family:'Jost',sans-serif; font-size:0.95rem;
  color:var(--dark);
}
.newsletter-form input[type="email"]:focus {
  outline:none; background:var(--cream);
}
.newsletter-form button {
  padding:16px 32px;
  background:var(--dark); color:var(--cream);
  border:none;
  font-family:'Jost',sans-serif;
  font-size:0.7rem; letter-spacing:0.2em; text-transform:uppercase;
  cursor:pointer; transition:background 0.3s;
}
.newsletter-form button:hover { background:var(--warm); }
.newsletter-consent {
  font-size:0.78rem; color:var(--warm); margin-top:14px; line-height:1.6;
}
.newsletter-consent a { color:var(--dark); text-decoration:underline; }

/* ── HERO CTA ROW (button + secondary link side-by-side) ── */
.hero-cta-row {
  display:flex; gap:32px; align-items:center; flex-wrap:wrap;
}
.hero-cta-row .btn-link {
  font-size:0.72rem; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--dark);
}

/* ── HONEYPOT (anti-spam, hidden field) ── */
.hp-field {
  position:absolute; left:-9999px; top:-9999px;
  width:1px; height:1px; overflow:hidden;
  visibility:hidden;
}

/* ── LEGAL PAGES (privacy + impressum) ── */
.legal-page {
  padding:140px 64px 100px;
  max-width:880px; margin:0 auto;
}
.legal-page h1 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.5vw,3rem); font-weight:300;
  color:var(--dark); margin-bottom:16px;
}
.legal-page h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:1.4rem; font-weight:400;
  color:var(--dark); margin:48px 0 14px;
}
.legal-page h3 {
  font-family:'Jost',sans-serif;
  font-size:0.85rem; font-weight:600; letter-spacing:0.05em;
  color:var(--dark); margin:28px 0 10px;
}
.legal-page p, .legal-page li {
  font-size:0.95rem; font-weight:300; line-height:1.85;
  color:var(--warm); margin-bottom:14px;
}
.legal-page ul { padding-left:24px; margin-bottom:14px; }
.legal-page a { color:var(--dark); }

/* ── COMPACT TRAINING GRID (More subtle than before) ── */
.training-compact {
  background:var(--cream);
  padding:80px 64px;
}
.training-compact-inner {
  max-width:1100px; margin:0 auto;
}
.training-compact-head {
  display:grid; grid-template-columns:1fr 1.4fr; gap:64px;
  align-items:start; margin-bottom:48px;
}
.training-compact-eyebrow {
  font-size:0.62rem; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--warm); margin-bottom:14px;
}
.training-compact-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.6rem,2.6vw,2.2rem); font-weight:300;
  font-style:italic; line-height:1.3; color:var(--dark);
}
.training-compact-text {
  font-size:0.95rem; font-weight:300; line-height:1.85; color:var(--warm);
}
.training-compact-list {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:rgba(80,37,37,0.1);
  border:1px solid rgba(80,37,37,0.1);
}
.training-compact-list > div {
  background:var(--white); padding:22px 24px;
}
.training-compact-list h4 {
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem; font-weight:400;
  color:var(--dark); margin-bottom:6px;
}
.training-compact-list p {
  font-size:0.82rem; font-weight:300; line-height:1.6;
  color:var(--warm);
}

/* ── GOOGLE REVIEWS LINK ── */
.google-reviews-link {
  text-align:center; margin-top:48px;
}
.google-reviews-link a {
  font-size:0.78rem; letter-spacing:0.06em;
  color:var(--warm); text-decoration:none;
  border-bottom:1px solid rgba(129,106,96,0.3);
  padding-bottom:2px; transition:color 0.3s, border-color 0.3s;
}
.google-reviews-link a:hover { color:var(--dark); border-color:var(--dark); }
.google-reviews-link .stars {
  color:var(--gold); margin-right:6px; font-size:0.85rem;
}

/* ── HAMBURGER NAV (mobile) ── */
.nav-hamburger {
  display:none;
  flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.nav-hamburger span {
  display:block; width:22px; height:1.5px;
  background:var(--dark); transition:all 0.3s;
}
.nav-mobile-menu {
  display:none;
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:var(--white); z-index:300;
  flex-direction:column; align-items:center; justify-content:center; gap:36px;
}
.nav-mobile-menu.open { display:flex; }
.nav-mobile-menu a {
  font-size:1.6rem; font-family:'Cormorant Garamond',serif;
  font-weight:300; color:var(--dark); text-decoration:none;
  letter-spacing:0.06em;
}
.nav-mobile-menu .mobile-lang {
  display:flex; gap:12px; align-items:center;
  font-size:0.72rem; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--warm); margin-top:16px;
}
.nav-mobile-menu .mobile-lang a { font-family:'Jost',sans-serif; font-size:0.72rem; color:var(--warm); }
.nav-mobile-menu .mobile-lang a.active { color:var(--dark); font-weight:500; }
.nav-mobile-close {
  position:absolute; top:24px; right:24px;
  font-size:1.6rem; background:none; border:none;
  cursor:pointer; color:var(--dark); line-height:1;
}

/* ── RESPONSIVE ── */
@media(max-width:960px) {
  nav { padding:16px 20px; }
  .nav-links { display:none; }
  .nav-hamburger { display:flex; }
  .nav-right { gap:16px; }
  .lang-switch { padding-left:16px; }
  .section, .quote-band, .cta-final, .page-hero { padding-left:24px; padding-right:24px; }
  .page-hero { padding-top:120px; padding-bottom:60px; }
  .page-hero-inner { grid-template-columns:1fr; gap:48px; }
  .page-hero-img { max-height:480px; aspect-ratio:4/5; }
  footer { grid-template-columns:1fr; gap:32px; padding:40px 24px; }
  .training-compact { padding:60px 24px; }
  .training-compact-head { grid-template-columns:1fr; gap:24px; margin-bottom:32px; }
  .training-compact-list { grid-template-columns:1fr; }
  .disclaimer-band { padding:32px 24px; }
  .legal-page { padding:120px 24px 80px; }
  .hero-cta-row { gap:20px; }

  /* Approach section: stack cards vertically */
  .approach-grid {
    grid-template-columns:1fr !important;
    gap:2px;
  }
  /* Approach cards readable on mobile */
  .approach-grid > div {
    padding:36px 24px !important;
  }
  /* Behind the work section */
  .behind-work-inner {
    grid-template-columns:1fr !important;
    gap:40px !important;
    padding:0 24px;
  }
  /* Behind the work: image not too tall on mobile */
  .behind-work-inner > div[style*="aspect-ratio"] {
    aspect-ratio:4/3 !important;
    max-height:320px;
  }

  /* Behind the work: stack image and text */
  .behind-work-inner {
    grid-template-columns:1fr !important;
    gap:40px !important;
  }

  /* Values grid mobile */
  .values-new-grid { grid-template-columns:1fr !important; }

  /* Offer inner sections */
  .offer-inner, .offer-inner.reverse {
    grid-template-columns:1fr !important;
    gap:40px !important;
  }
  .offer-img-wrap { position:static !important; }
  .keynote-list { grid-template-columns:1fr !important; gap:16px !important; }
  .tracks-grid { grid-template-columns:1fr !important; gap:24px !important; }

  /* Story sections on about page */
  .story-inner, .story-inner.reverse {
    grid-template-columns:1fr !important;
    gap:40px !important;
  }
}
