/* ============================================================
   VILLA ROSA – Design Tokens
   ============================================================ */
:root{
  /* Brand palette */
  --charcoal:#3c3c3b;
  --rose:#EBABBE;
  --rose-deep:#c76a86;      /* darkened rose – meets large-text AA on light bg */
  --soft-pink:#FFD9E4;
  --blush:#FDEEF5;
  --petrol:#15768f;         /* teal – AA (>=4.5) as text on white/blush and as button bg */
  --petrol-deep:#13657d;    /* darker petrol for hover/contrast */
  --white:#FFFFFF;
  --cream:#fffaf6;          /* warm near-white for alternating sections */

  /* Type */
  --serif:"Vollkorn", Georgia, "Times New Roman", serif;
  --sans:"Mulish", system-ui, -apple-system, sans-serif;

  /* Fluid type scale */
  --fs-hero:clamp(2.6rem, 1.4rem + 5.4vw, 5.6rem);
  --fs-h2:clamp(1.9rem, 1.2rem + 2.6vw, 3.1rem);
  --fs-h3:clamp(1.25rem, 1rem + 0.9vw, 1.6rem);
  --fs-quote:clamp(1.4rem, 1rem + 1.8vw, 2.4rem);
  --fs-body:clamp(1rem, 0.96rem + 0.2vw, 1.12rem);
  --fs-small:0.9rem;

  /* Spacing */
  --space-section:clamp(2.25rem, 1.5rem + 3.5vw, 4.5rem);
  --maxw:1180px;
  --radius:20px;
  --radius-section:clamp(28px, 4.5vw, 56px);  /* weiche „Sheet"-Rundung ganzer Sektionen */
  --gutter:clamp(.5rem, 1.25vw, 1.25rem);     /* seitlicher Versatz der Sheet-Sektionen */

  --rose-line:rgba(235,171,190,.38);
  --shadow-soft:0 18px 50px -28px rgba(60,60,59,0.35);
  --ease:cubic-bezier(.22,.61,.36,1);

  /* Konfetti-Punkte (greift das Herz-Konfetti des Hero-Fotos auf) */
  --dots-rose:radial-gradient(rgba(235,171,190,.25) 1.1px, transparent 1.7px);
  --dots-white:radial-gradient(rgba(255,255,255,.6) 1.2px, transparent 1.8px);

  /* kleines Herz als Ornament (Eyebrow) */
  --heart:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 21s-7-4.35-9.5-8.5C1 9.5 2.5 6 6 6c2 0 3.2 1.2 4 2.3C10.8 7.2 12 6 14 6c3.5 0 5 3.5 3.5 6.5C19 16.65 12 21 12 21z'/%3E%3C/svg%3E");
}

/* ============================================================
   Base / Reset
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--sans);
  font-size:var(--fs-body);
  line-height:1.7;
  color:var(--charcoal);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--petrol);text-decoration:none}
a:hover{color:var(--petrol-deep)}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:-0.01em;color:var(--charcoal);margin:0}
p{margin:0 0 1.1em}
ul{margin:0;padding:0}

:focus-visible{outline:3px solid var(--petrol);outline-offset:3px;border-radius:4px}
::selection{background:var(--soft-pink);color:var(--charcoal)}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,2.5rem)}
.eyebrow{
  font-family:var(--sans);font-weight:700;text-transform:uppercase;
  letter-spacing:.22em;font-size:.74rem;color:var(--petrol);
  margin:0 0 1rem;display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{
  content:"";width:14px;height:14px;flex:0 0 auto;background:var(--rose);
  -webkit-mask:var(--heart) center/contain no-repeat;mask:var(--heart) center/contain no-repeat;
}

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--sans);font-weight:700;font-size:.96rem;
  padding:.85em 1.5em;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .3s var(--ease),background .3s,color .3s,border-color .3s;
  text-decoration:none;line-height:1;
}
.btn-primary{background:var(--petrol);color:var(--white);box-shadow:0 12px 26px -14px rgba(21,118,143,.55)}
.btn-primary:hover{background:var(--petrol-deep);color:var(--white);transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(19,101,125,.6)}
.btn-ghost{background:transparent;color:var(--charcoal);border-color:var(--rose)}
.btn-ghost:hover{background:var(--blush);color:var(--charcoal);transform:translateY(-2px)}
.link-arrow{
  font-weight:700;color:var(--petrol);display:inline-flex;align-items:center;gap:.4rem;
}
.link-arrow svg{transition:transform .3s var(--ease)}
.link-arrow:hover svg{transform:translateX(4px)}

/* ============================================================
   Header
   ============================================================ */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  padding-block:1.1rem;
  background:rgba(255,255,255,0.9);
  backdrop-filter:blur(10px);
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
}
.site-header.scrolled{
  background:rgba(255,255,255,0.96);
  box-shadow:0 1px 0 rgba(60,60,59,0.08);
  padding-block:.65rem;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;line-height:1;text-decoration:none}
.brand-logo{height:62px;width:auto;display:block;transition:height .4s var(--ease)}
.site-header.scrolled .brand-logo{height:48px}

.nav{display:flex;align-items:center;gap:2rem}
.nav ul{display:flex;gap:1.7rem;list-style:none}
.nav a{color:var(--charcoal);font-weight:600;font-size:.95rem;position:relative;padding-block:.2rem}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--rose);transition:width .3s var(--ease)}
.nav a:hover{color:var(--charcoal)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.header-cta{white-space:nowrap}
/* Header-Button: weiße Schrift erzwingen (sonst überschreibt .nav a den Wert) */
.nav a.header-cta,.nav a.header-cta:hover{color:var(--white)}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.5rem;color:var(--charcoal)}
.nav-toggle svg{width:30px;height:30px}

/* ============================================================
   Hero (home)
   ============================================================ */
.hero{
  position:relative;padding-top:clamp(8rem, 7rem + 6vw, 11rem);padding-bottom:var(--space-section);
  background:var(--blush);overflow:hidden;
  background-image:var(--dots-rose);background-size:26px 26px;
  margin-inline:var(--gutter);
  border-radius:0 0 var(--radius-section) var(--radius-section);
}
.hero::before{
  content:"";position:absolute;top:-12%;right:-8%;width:46vw;height:46vw;max-width:640px;max-height:640px;
  background:radial-gradient(circle at 30% 30%,var(--soft-pink),transparent 70%);
  opacity:.7;border-radius:50%;z-index:0;
}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero h1{font-size:var(--fs-hero);font-weight:400}
.hero h1 em{font-style:italic;color:var(--rose-deep)}
.hero-lead{font-size:clamp(1.05rem, 1rem + .5vw, 1.3rem);max-width:34ch;margin-top:1.4rem;color:#55504e}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem;align-items:center}

.hero-figure{position:relative}
/* Foto mit weicher Eckenrundung + leicht gedrehter Rosé-Rahmen dahinter
   (einheitlich auf Start- und Team-Seite — Jens bevorzugt die rechteckige Form) */
.hero-figure img{
  position:relative;z-index:1;
  width:100%;height:auto;display:block;
  border-radius:clamp(28px,4vw,44px);
  box-shadow:var(--shadow-soft);
}
.hero-figure::before{
  content:"";position:absolute;inset:-3.5% -3% -2.5% -3.5%;z-index:0;
  border:2px solid var(--rose);opacity:.55;transform:rotate(2deg);
  border-radius:clamp(32px,4.5vw,50px);
}
.hero-figure::after{
  content:"";position:absolute;left:-7%;bottom:-9%;width:42%;aspect-ratio:1;z-index:0;
  background:var(--soft-pink);opacity:.6;
  border-radius:60% 40% 55% 45% / 50% 55% 45% 50%;
}
.hero-figure .badge{
  position:absolute;bottom:6%;left:0;transform:translateX(-34%);background:var(--white);
  border-radius:var(--radius);padding:1rem 1.3rem;box-shadow:var(--shadow-soft);
  display:flex;align-items:center;gap:.85rem;max-width:230px;z-index:2;
  border:1px solid var(--rose-line);
}
.hero-figure .badge .num{font-family:var(--serif);font-size:2.1rem;color:var(--rose-deep);line-height:1}
.hero-figure .badge .txt{font-size:.85rem;line-height:1.35;color:#55504e}


/* ============================================================
   Page hero (inner pages)
   ============================================================ */
.page-hero{
  position:relative;background:var(--blush);overflow:hidden;
  padding-top:clamp(9rem, 7rem + 6vw, 11rem);padding-bottom:var(--space-section);
  background-image:var(--dots-rose);background-size:26px 26px;
  margin-inline:var(--gutter);
  border-radius:0 0 var(--radius-section) var(--radius-section);
}
.page-hero::before{
  content:"";position:absolute;top:-20%;right:-6%;width:38vw;height:38vw;max-width:520px;max-height:520px;
  background:radial-gradient(circle at 30% 30%,var(--soft-pink),transparent 70%);
  opacity:.6;border-radius:50%;z-index:0;
}
.page-hero .wrap{position:relative;z-index:1}
/* Team-Hero: Hochformat-Foto, Ausschnitt oben ausgerichtet (Köpfe sichtbar);
   Rundung/Rahmen kommen aus der .hero-figure-Basis */
.team-hero-figure{max-width:420px;justify-self:center;width:100%}
.team-hero-figure img{aspect-ratio:4/5;object-fit:cover;object-position:50% 8%;width:100%}
.page-hero h1{font-size:var(--fs-h2);font-weight:400;max-width:18ch}
.page-hero h1 em{font-style:italic;color:var(--rose-deep)}
.page-hero .lead{font-size:clamp(1.05rem, 1rem + .4vw, 1.25rem);max-width:52ch;margin-top:1.2rem;color:#55504e}

/* ============================================================
   Philosophy
   ============================================================ */
.philosophy{padding-block:var(--space-section)}
.phil-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.pull-quote{
  font-family:var(--serif);font-size:var(--fs-quote);font-style:italic;font-weight:400;
  line-height:1.25;color:var(--charcoal);position:relative;margin:0;
  padding-top:2.6rem;
}
/* großes Zier-Anführungszeichen statt harter Linie */
.pull-quote::before{
  content:"“";position:absolute;top:-1rem;left:-.35rem;
  font-family:var(--serif);font-style:normal;font-size:6.2rem;line-height:1;
  color:var(--rose);opacity:.55;pointer-events:none;
}
.pull-quote span{color:var(--rose-deep)}
.phil-body p{color:#55504e}
.phil-body .signature{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:var(--charcoal);margin-top:1.5rem}

/* ============================================================
   Leistungen (editorial alternating rows)
   ============================================================ */
.services{
  padding-block:var(--space-section);background:var(--blush);
  margin-inline:var(--gutter);border-radius:var(--radius-section);
}
.services-head{max-width:46ch;margin-bottom:clamp(2.5rem,5vw,4rem)}
.service-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:clamp(1.2rem,3vw,2.6rem);
  align-items:baseline;padding:clamp(1.6rem,3vw,2.4rem) clamp(.9rem,2vw,1.5rem);
  border-top:1px solid rgba(60,60,59,0.14);
  border-radius:16px;transition:background .35s var(--ease);
}
.service-row:hover{background:rgba(255,255,255,.7)}
.service-row:last-of-type{border-bottom:1px solid rgba(60,60,59,0.14)}
.service-row .idx{font-family:var(--serif);font-size:1.1rem;color:var(--rose-deep);font-variant-numeric:tabular-nums}
.service-row h3{font-size:var(--fs-h3);font-weight:500;transition:color .3s}
.service-row .desc{color:#5d5755;max-width:60ch;margin-top:.5rem;margin-bottom:0}
.service-row .meta{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--petrol);white-space:nowrap}
.service-row:hover h3{color:var(--rose-deep)}

/* ============================================================
   Team
   ============================================================ */
.team{padding-block:var(--space-section)}
.team-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.5rem;margin-bottom:clamp(2.5rem,5vw,3.5rem)}
.team-head .intro{max-width:42ch;color:#55504e;margin:0}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:clamp(1.5rem,3vw,2.5rem)}
.member figure{margin:0}
.member img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--radius) var(--radius) 60px var(--radius)}
.member h3{font-size:1.3rem;font-weight:600;margin-top:1rem}
.member .role{color:var(--petrol);font-weight:700;font-size:.86rem;letter-spacing:.04em;margin:.25rem 0 .55rem}
.member .bio{font-size:.95rem;color:#5d5755;margin:0}

/* Team-Kacheln (Flip-Karten im Kurs-Design, 2 pro Zeile) */
.team-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.5rem,3vw,2.2rem);
  margin-top:clamp(2rem,4vw,3rem);align-items:start}
.team-card .flip-face{text-align:center}
/* Runde Portraits mit weißem Ring – Gesicht mittig im Kreis
   (object-position leicht nach oben, da Gesichter im oberen Bilddrittel liegen) */
.team-card-img{display:block;width:100%;max-width:220px;aspect-ratio:1/1;object-fit:cover;
  object-position:50% 22%;
  margin:0 auto .8rem;border-radius:50%;
  border:5px solid var(--white);box-shadow:0 16px 36px -24px rgba(60,60,59,.45)}
.team-card-img.is-placeholder{display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blush),var(--soft-pink))}
.team-card-img.is-placeholder svg{width:64px;height:64px;color:var(--rose);opacity:.55}
.team-card h3{font-size:1.3rem;font-weight:600;margin:.2rem 0 0}
.team-card .role{color:var(--petrol);font-weight:700;font-size:.86rem;letter-spacing:.04em;margin:.3rem 0 .55rem}
.team-card .team-bio{font-size:.95rem;color:#5d5755;line-height:1.55;margin:0}
.team-card .flip-face .course-details{text-align:left}
/* Umgekehrtes Schema zu den Kursen mit DENSELBEN Farbcodes:
   Kurse = weiße Kacheln auf Blush · Team = Blush-Kacheln auf Weiß */
.team-cards-section{background:var(--white);padding-top:0}
.team-card .flip-face{background:var(--blush)}

/* ============================================================
   Kurse
   ============================================================ */
.courses{
  padding-block:var(--space-section);background:var(--blush);position:relative;
  margin-inline:var(--gutter);border-radius:var(--radius-section);
}
/* Feste 3-Spalten-Darstellung: Kacheln behalten ihre Breite, auch wenn nur
   1–2 Kurse angezeigt werden (linksbündig, keine Streckung). Schmale Screens: 2 → 1. */
.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,2rem);margin-top:clamp(2.5rem,5vw,3.5rem);align-items:start}
.course-card{
  background:var(--white);border-radius:var(--radius);padding:clamp(1.4rem,2.6vw,1.9rem);
  display:flex;flex-direction:column;gap:.45rem;box-shadow:0 14px 40px -30px rgba(60,60,59,.4);
  border:1px solid rgba(235,171,190,.35);transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.course-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.course-card-img{display:block;width:100%;height:160px;object-fit:cover;
  margin:0 0 .3rem;border-radius:12px}

/* ===== Flip-Karte ===== */
.flip-card{display:block;background:transparent;border:none;box-shadow:none;padding:0;perspective:1600px}
.flip-card:hover{transform:none}
.flip-card-inner{position:relative;width:100%;min-height:360px;transition:transform .6s var(--ease);
  transform-style:preserve-3d}
.flip-face{
  position:absolute;inset:0;overflow:hidden;
  background:var(--white);border-radius:var(--radius);padding:clamp(1.4rem,2.6vw,1.9rem);
  display:flex;flex-direction:column;gap:.45rem;box-shadow:0 14px 40px -30px rgba(60,60,59,.4);
  border:1px solid rgba(235,171,190,.35);
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
}
.face-a{transform:rotateY(0deg)}
.face-b{transform:rotateY(180deg)}
.flip-card:hover .flip-face{box-shadow:var(--shadow-soft)}
.panel-store{display:none}
.course-details{flex-grow:1;color:#5d5755;font-size:.95rem;line-height:1.55}
/* paginierte Detail-Blöcke */
.course-details .db-line{margin:0 0 .55rem}
.course-details .db-li{margin:.12rem 0;padding-left:1.15rem;position:relative}
.course-details .db-li::before{content:"•";position:absolute;left:.15rem;color:var(--rose);font-weight:700}
.course-details .db-gap{height:.55rem}
.course-details>*:last-child{margin-bottom:0}
/* Aktionen: Abbrechen + Weiter/Anfrage nebeneinander, gleiche Breite, unten fixiert */
.flip-actions{display:flex;gap:.7rem;flex-wrap:nowrap;margin-top:auto;padding-top:.6rem}
.flip-actions>.btn{flex:1 1 0;justify-content:center;padding-left:1em;padding-right:1em;white-space:nowrap}
.flip-nav{margin-top:.4rem}
.course-sessions-title{font-weight:600;color:var(--petrol);margin:.2rem 0 .3rem}
.course-sessions{list-style:none;margin:0 0 .4rem;padding:0;display:flex;flex-direction:column;gap:.35rem;flex-grow:1}
.course-sessions li{padding:.45rem .7rem;background:var(--blush);border-radius:8px;font-size:.92rem;color:var(--charcoal)}
.course-card-img.is-placeholder{display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blush),var(--soft-pink))}
.course-card-img.is-placeholder svg{width:52px;height:52px;color:var(--rose);opacity:.5}
.course-leader{display:flex;flex-direction:column;justify-content:center;gap:.12rem;background:var(--blush);
  border-radius:10px;padding:.55rem .85rem;margin:.1rem 0;min-height:3.4rem;flex:0 0 auto}
.course-leader span{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--rose)}
.course-leader strong{font-size:1rem;font-weight:600;color:var(--charcoal)}
.course-leader .leader-link{color:var(--petrol);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.course-leader .leader-link:hover{color:var(--petrol-deep)}
/* Tag-Chip schwebt halb über dem Kursbild */
.course-card .tag{
  align-self:flex-start;background:var(--soft-pink);color:var(--charcoal);
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  padding:.35em .8em;border-radius:999px;
  position:relative;z-index:1;margin-top:-1.5rem;margin-left:.5rem;
  border:3px solid var(--white);box-shadow:0 8px 18px -10px rgba(60,60,59,.45);
}
.course-card h3{font-size:1.35rem;font-weight:600;margin-top:.4rem}
.course-card p{color:#5d5755;font-size:.97rem;flex-grow:1}
/* Vorderseite: Titel + Beschreibung auf EXAKT gleiche Höhe bringen (feste Höhe,
   nicht nur min-height), damit die „Wer den Kurs durchführt?"-Box und die
   Angaben darunter bei allen Kacheln bündig auf gleicher Höhe stehen.
   Titel = 2 Zeilen, Beschreibung = 4 Zeilen (überzählige Zeilen werden mit „…"
   abgeschnitten – aktuell passt überall der volle Text). */
.course-card .face-a>h3{margin:.3rem 0 0;line-height:1.2;height:2.4em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.course-card .face-a>p:not(.course-leader){flex:0 0 auto;margin:.15rem 0 0;line-height:1.5;height:6em;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.course-card .face-a>.course-meta{flex:0 0 auto}
/* „Mehr/Weiter"-Button auf der Vorderseite unten fixieren (Kurs- & Team-Kacheln) */
.face-a>.flip-nav{margin-top:auto}
.course-card .link-arrow{margin-top:.4rem}
.courses-note{text-align:center;margin-top:2.4rem;font-size:.92rem;color:#6a6360;font-style:italic;font-family:var(--serif)}

/* editable course meta (dates / price — easy for the owner to edit) */
.course-meta{
  list-style:none;margin:.45rem 0 .4rem;padding:.6rem 0 0;display:flex;flex-direction:column;gap:.3rem;
  border-top:1px dashed var(--rose-line);
}
.course-meta li{display:flex;flex-wrap:wrap;align-items:baseline;gap:.05rem .5rem;font-size:.9rem;color:var(--charcoal)}
.course-meta .label{font-weight:700;color:var(--petrol);min-width:6.4rem;flex:0 0 auto;display:inline-flex;align-items:center;gap:.45rem}
.course-meta .label svg{width:15px;height:15px;flex:0 0 auto;color:var(--rose-deep)}
.course-meta .val{flex:1 1 auto}
.course-meta .nw{white-space:nowrap}  /* Datum/Uhrzeit nie mittendrin umbrechen */
.edit-hint{background:var(--cream);border:1px dashed var(--rose);border-radius:12px;padding:1rem 1.2rem;font-size:.88rem;color:#6a6360;margin-bottom:clamp(2rem,4vw,3rem)}
.edit-hint strong{color:var(--charcoal)}

/* ============================================================
   Betreuung / Forms
   ============================================================ */
.betreuung{
  padding-block:var(--space-section);
  background-image:var(--dots-white),linear-gradient(180deg,var(--soft-pink),var(--blush));
  background-size:24px 24px,auto;
  margin-inline:var(--gutter);border-radius:var(--radius-section);
}
/* Abstand zwischen direkt aufeinanderfolgenden „Sheet"-Sektionen */
.page-hero + .courses,.page-hero + .services,.page-hero + .betreuung,
.services + .betreuung,.courses + .betreuung{margin-top:var(--gutter)}
.betreuung-cta{max-width:640px;margin-inline:auto;text-align:center}
.betreuung-cta p{color:#55504e;margin-top:1rem}
.betreuung-cta .btn{margin-top:1.8rem}

.contact{padding-block:var(--space-section)}
.contact-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:clamp(2rem,5vw,4rem);align-items:start}

/* form styling shared */
.form-card{background:var(--white);border-radius:var(--radius);padding:clamp(1.6rem,3.5vw,2.6rem);box-shadow:var(--shadow-soft);border:1px solid rgba(235,171,190,.3)}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.2rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field.full{grid-column:1 / -1}
.field label{font-weight:700;font-size:.85rem;color:var(--charcoal)}
.field label .req{color:var(--rose-deep)}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:1rem;color:var(--charcoal);
  padding:.75rem .9rem;border:1.5px solid #e3d6dc;border-radius:12px;background:var(--cream);
  transition:border-color .25s,box-shadow .25s;width:100%;
}
.field input:hover,.field select:hover,.field textarea:hover{border-color:var(--rose)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--petrol);box-shadow:0 0 0 3px rgba(27,133,163,.15);background:var(--white);
}
.field textarea{resize:vertical;min-height:120px}
.consent{
  display:flex;gap:.7rem;align-items:flex-start;margin-top:1.2rem;font-size:.88rem;color:#5d5755;
  background:var(--cream);border:1px solid var(--rose-line);border-radius:12px;padding:.9rem 1rem;
}
.consent input{margin-top:.25rem;width:18px;height:18px;accent-color:var(--petrol);flex:0 0 auto}
.form-card .btn{margin-top:1.4rem}
.form-success{
  display:none;background:var(--soft-pink);border-radius:12px;padding:1.1rem 1.3rem;
  margin-top:1.3rem;font-weight:600;color:var(--charcoal);border:1px solid var(--rose);
}
.form-success.show{display:block;animation:fadeUp .5s var(--ease)}

/* contact info block */
.contact-info{display:flex;flex-direction:column;gap:1.6rem}
.info-item{display:flex;gap:.95rem;align-items:flex-start}
.info-item .ic{flex:0 0 auto;width:42px;height:42px;border-radius:50%;background:var(--blush);display:grid;place-items:center;color:var(--petrol)}
.info-item .ic svg{width:20px;height:20px}
.info-item h3{font-size:1rem;font-weight:700;font-family:var(--sans);margin-bottom:.15rem}
.info-item p,.info-item a{font-size:.96rem;color:#55504e;margin:0}
.info-item a{color:var(--petrol);font-weight:600}
.socials{display:flex;gap:.8rem;margin-top:.9rem}
.socials a{width:44px;height:44px;border-radius:50%;background:var(--petrol);color:var(--white);display:grid;place-items:center;transition:background .3s,transform .3s var(--ease)}
.socials a:hover{background:var(--petrol-deep);color:var(--white);transform:translateY(-2px)}
.socials a svg{width:20px;height:20px}

/* ============================================================
   Legal pages
   ============================================================ */
.legal{padding-block:var(--space-section)}
.legal .wrap{max-width:820px}
.legal h2{font-size:var(--fs-h3);font-weight:600;margin-top:2.4rem;margin-bottom:.6rem}
.legal h2:first-of-type{margin-top:0}
.legal p,.legal li{color:#55504e}
.legal ul{padding-left:1.3rem;margin-bottom:1.1rem}
.legal a{color:var(--petrol);font-weight:600;word-break:break-word}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{
  background:var(--petrol);color:#ffffff;padding-block:clamp(3.5rem,5vw,5rem) 2rem;
  margin-inline:var(--gutter);margin-top:var(--gutter);
  border-radius:var(--radius-section) var(--radius-section) 0 0;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(2rem,5vw,3.5rem)}
.footer-logo{height:54px;width:auto;display:block;margin-bottom:.9rem;background:var(--white);padding:.7rem 1rem;border-radius:var(--radius);box-sizing:content-box}
.site-footer p{color:#eef5f6;font-size:.95rem;max-width:34ch;margin-top:1rem}
.site-footer h4{font-family:var(--sans);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:#ffffff;margin:0 0 1rem}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.site-footer li{font-size:.95rem}            /* auch reine Text-Einträge (Adresse, Zeiten) gleich groß */
.site-footer a{color:#ffffff;font-size:.95rem}
.site-footer a:hover{color:#ffffff;text-decoration:underline}
.footer-bottom{margin-top:clamp(2.5rem,5vw,3.5rem);padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.28);display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center}
.footer-bottom .legal-links{display:flex;flex-wrap:wrap;gap:1.3rem}
.footer-bottom .legal-links a{font-size:.95rem;color:#eef5f6}
.footer-bottom small{color:#eef5f6;font-size:.95rem}

/* ============================================================
   Reveal animation
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.visible{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.course-card,.socials a{transition:none}
  .flip-card-inner{transition:none}
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:900px){
  .hero-grid,.phil-grid,.contact-grid{grid-template-columns:1fr}
  .hero-figure{max-width:480px;margin-inline:auto}
  .footer-grid{grid-template-columns:1fr 1fr}
  .courses-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .nav ul{display:none}
  .header-cta{display:none}
  .nav-toggle{display:inline-flex}
  .nav.open{
    position:absolute;top:100%;left:0;right:0;background:var(--white);
    box-shadow:var(--shadow-soft);padding:1.4rem clamp(1.25rem,5vw,2.5rem) 1.8rem;
    flex-direction:column;align-items:stretch;gap:1.2rem;
  }
  .nav.open ul{display:flex;flex-direction:column;gap:1.1rem}
  .nav.open .header-cta{display:inline-flex;align-self:flex-start}
  .nav.open a{font-size:1.05rem}
}
@media (max-width:560px){
  .service-row{grid-template-columns:auto 1fr;gap:1rem}
  .service-row .meta{grid-column:2;margin-top:.4rem}
  .field-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .courses-grid{grid-template-columns:1fr}
  .hero-figure .badge{left:0;transform:none}
  .team-cards-grid{grid-template-columns:1fr}
}
