/* Self-hosted fonts (WOFF2) with subsets to reduce payload */
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-Regular-latin.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-Regular-cyr.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-Regular.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+02C7,U+02D8-U+02DD,U+0300-036F,U+1D00-1DBF,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-SemiBold-latin.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-SemiBold-cyr.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-SemiBold.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+02C7,U+02D8-U+02DD,U+0300-036F,U+1D00-1DBF,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-Bold-latin.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-Bold-cyr.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/Inter-Bold.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+02C7,U+02D8-U+02DD,U+0300-036F,U+1D00-1DBF,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-Regular-latin.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-Regular-cyr.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-Regular.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+02C7,U+02D8-U+02DD,U+0300-036F,U+1D00-1DBF,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-SemiBold-latin.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-SemiBold-cyr.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-SemiBold.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+02C7,U+02D8-U+02DD,U+0300-036F,U+1D00-1DBF,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-Bold-latin.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-Bold-cyr.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;
}
@font-face{
  font-family:"Montserrat";
  src:url("/assets/fonts/Montserrat-Bold.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:optional;
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+02C7,U+02D8-U+02DD,U+0300-036F,U+1D00-1DBF,U+2C60-2C7F,U+A720-A7FF;
}

/* 360bewerben – Design Refresh (clean, responsive, 3-col grids)
   - Fixes grid--2/grid--3 (desktop)
   - Better spacing/typography/buttons
   - Contact split: image left / form right
*/

:root{
  --bg:#ffffff;
  --text:#2b2b2b;
  --muted:#6b7280;
  --brand:#0b6dbf;
  --accent:#b35700;
  --line:#e7e7e7;
  --card:#ffffff;
  --soft:#f6f7f9;
  --radius:12px;
  --shadow:0 14px 36px rgba(0,0,0,.10);
  --max:1080px;

  --font-body: Inter, "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-head: Montserrat, Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
img{max-width:100%;height:auto}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.8;
  color:var(--text);
  background:var(--bg);
}

a{color:inherit;text-decoration:none}
.container{width:min(var(--max), 92vw); margin:0 auto}

h1,h2,h3,h4{
  font-family:var(--font-head);
  line-height:1.25;
  color:#333;
  letter-spacing:-0.01em;
}
h1{font-size:clamp(30px, 4vw, 52px); margin:10px 0 12px}
h2{font-size:clamp(22px, 2.5vw, 34px); margin:0 0 12px}
h3{font-size:18px; margin:0 0 8px}


p{margin:0 0 1em}
.small{font-size:13px}
.muted{color:var(--muted)}

.muted ul{margin:10px 0 0 18px;padding:0}
.muted li{margin:6px 0}
.muted p{margin:10px 0 0}
.muted p:first-child{margin-top:0}

.note ul{margin:10px 0 0 18px;padding:0}
.note li{margin:6px 0}
.note p{margin:10px 0 0}
.note p:first-child{margin-top:0}

/* Topbar */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  background:#fff;
  border-bottom:1px solid var(--line);
}
.topbar__inner{
  display:flex;
  align-items:center;
  gap:18px;
  padding:14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  letter-spacing:.2px;
}
.brand__logo{
  width:34px;height:34px;
  object-fit:contain;
  display:block;
}
.brand__dot{
  width:10px;height:10px;
  border-radius:999px;
  background:var(--brand);
  display:none; /* logo is enough */
}
.nav{
  display:flex;
  gap:18px;
  margin-left:auto;
  flex-wrap:wrap;
}
.nav a{
  color:#666;
  font-weight:600;
  padding:6px 2px;
}
.nav a:hover{color:#222}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:800;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn--primary{
  border:0;
  background:var(--brand);
  color:#fff;
  box-shadow:0 10px 24px rgba(11,109,191,.30);
}
.btn--primary:hover{filter:brightness(1.03)}
.btn--accent{
  border:0;
  background:var(--accent);
  color:#fff;
  border-radius:6px;
  box-shadow:0 10px 26px rgba(0,0,0,.18);
}
.btn--accent:hover{filter:brightness(1.03)}
.btn--ghost{
  background:var(--soft);
}

/* Hamburger */
.burger{
  display:none;
  margin-left:12px;
  width:44px;height:40px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
}
.burger span{display:block;height:2px;margin:7px 10px;background:#333;opacity:.9}
.mobileNav{
  display:none;
  border-top:1px solid var(--line);
  background:#fff;
}
.mobileNav__inner{padding:8px 0 12px}
.mobileNav a{
  display:block;
  padding:10px 0;
  color:#666;
  font-weight:700;
}
.mobileNav a:hover{color:#222}
.mobileNav.is-open{display:block}

/* Sections */
.section{padding:54px 0}
.section--alt{
  background:var(--soft);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

/* Grid (FIX) */
.grid{display:grid; gap:26px}
.grid--2{grid-template-columns:repeat(2, minmax(0, 1fr))}
.grid--3{grid-template-columns:repeat(3, minmax(0, 1fr))}

/* Cards */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.card__pad{padding:20px}
.item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.thumb{
  width:100%;
  height:190px;
  object-fit:cover;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  display:block;
  margin-bottom:14px;
}

/* Hero (slim) */
.hero{
  padding:22px 0 18px;
  color:#fff;
  background:
    linear-gradient(90deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.55) 55%, rgba(0,0,0,.22) 100%),
    image-set(
      url("/assets/img/career-coach-2.avif") type("image/avif"),
      url("/assets/img/career-coach-2.webp") type("image/webp")
    );
  background-size:cover;
  background-position:center;
}
.hero__grid{
  display:grid;
  grid-template-columns: 1.20fr .80fr;
  gap:26px;
  align-items:stretch;
  min-height:260px;
}
.pill{
  display:inline-block;
  font-family:var(--font-head);
  font-size:13px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:rgba(255,255,255,.75);
  margin-bottom:6px;
}
.hero h1{color:#fff}
.hero .lead{color:rgba(255,255,255,.78); max-width:64ch}
.heroCardImg{
  width:100%;
  max-height:200px;
  object-fit:contain;
  background:#fff;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  margin-bottom:14px;
}

/* Home: gleicher "Clean Card" Stil wie die Ziel-Karten */
.page-home .hero{
  background:var(--soft);
  background-image:none;
  background-blend-mode:normal;
  color:var(--text);
}
.page-home .hero:before{display:none;}
.page-home .hero__grid{align-items:start;min-height:auto;}
.page-home .hero__bullets{color:var(--muted);}
.page-home .heroCard{background:var(--card);border-color:var(--line);backdrop-filter:none;box-shadow:var(--shadow);}
.page-home .hero .pill{color:var(--muted);border-color:var(--line);background:#fff;}
.page-home .hero h1{color:var(--text)}
.page-home .hero .lead{color:var(--muted)}
.page-home .heroLeftCard .card__pad,
.page-home .heroRight .card__pad{padding:22px;}
.page-home .heroCardImg{
  border:1px solid var(--line);
  background:#fff;
}
.page-home .heroRight .heroCardImg{object-fit:cover;}
.page-home .heroLeftCard .heroCardImg{
  /*
    Home: "blauer Mann" soll nicht am Kopf abgeschnitten werden.
    Wir füllen die Breite (cover), aber pinnen das Bild nach oben.
    => falls gecroppt wird, dann eher unten – der Kopf bleibt sichtbar.
  */
  max-height:none;
  height:clamp(180px,28vh,280px);
  object-fit:cover;
  object-position:left top;
  border-radius:14px;
}

@media (max-width:980px){
  .page-home .hero{padding:32px 0 22px;}
  /* auf Mobile etwas weniger hoch, Kopf bleibt dank object-position sichtbar */
  .page-home .heroLeftCard .heroCardImg{height:210px;}
}

/* 4 reasons icons (simple) */
.iconRow{
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.etIcon{
  width:38px;height:38px;
  border-radius:999px;
  background:#e9f6fe;
  border:1px solid #cfe9fb;
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}
.etIcon svg{width:18px;height:18px;fill:var(--brand)}
.listIcon{display:grid; gap:14px}

/* Notes / form */
.note{
  padding:12px 14px;
  border-radius:12px;
  border:1px dashed var(--line);
  background:#fff;
}
.note a{color:var(--primary);font-weight:900;text-decoration:underline;}
.note a:hover{text-decoration:none;}
.divider{border:0;border-top:1px solid var(--line);margin:16px 0;}

.contactForm{display:grid; gap:14px}
/* label meta (Pflichtfeld/optional smaller) */
.req{
  font-size:12px;
  font-weight:800;
  color:var(--muted);
  margin-left:6px;
  letter-spacing:0;
  text-transform:none;
}

/* consent box (move to bottom) */
.consentBox{
  padding:14px 14px;
  border-radius:12px;
  border:1px dashed var(--line);
  background:#fff;
}
.consentTitle{
  font-weight:900;
  margin:0 0 8px;
  font-family:var(--font-head);
  color:#333;
}
.consentRow{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.consentRow input[type="checkbox"]{
  width:18px;
  height:18px;
  margin-top:3px;
  flex:0 0 auto;
}
.consentRow a{ text-decoration: underline; }

label{
  font-weight:800;
  font-size:13px;
  color:#444;
  display:block;
  margin-bottom:6px;
}
input,textarea,select{
  width:100%;
  padding:12px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  outline:none;
  font-family:var(--font-body);
  font-size:15px;
}
input:focus,textarea:focus,select:focus{
  border-color:rgba(46,163,242,.8);
  box-shadow:0 0 0 4px rgba(46,163,242,.14);
}
textarea{resize:vertical}

/* Honeypot hidden */
.hp-field{
  position:absolute;
  left:-10000px;
  top:auto;
  width:1px;height:1px;
  overflow:hidden;
}

/* Contact split */
.contactSplit{
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap:26px;
  align-items:start;
  margin-top:10px;
}
.contactSplit__media{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px;
  box-shadow:var(--shadow);

  display:flex;
  align-items:center;
  justify-content:center;
}
.contactSplit__img{
  width:min(320px, 100%);
  aspect-ratio: 1 / 1;
  height:auto;
  object-fit:cover;
  object-position:center;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  display:block;
}
.contactSplit__form .card{box-shadow:var(--shadow)}

/* CTA Blue (time section) */
/* CTA Blue (time section) – balanced layout */
.ctaBlue{
  background:#1c2240;
  color:#fff;
  padding:70px 0;
}
.ctaBlue__grid{
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap:56px;
  align-items:center;
}
.ctaBlue__img{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 18px 50px rgba(0,0,0,.25);
  background: rgba(255,255,255,.04);
}
.ctaBlue__img picture,
.ctaBlue__img img{
  display:block;
  width:100%;
}
.ctaBlue__content{
  max-width:520px;
}
.ctaBlue__content h2{
  color:#fff;
  margin:0 0 14px;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height:1.12;
  letter-spacing:-0.02em;
}
.ctaBlue__content p{
  color:rgba(255,255,255,.78);
  margin:0 0 18px;
  font-size:16px;
  line-height:1.7;
}
@media (max-width: 980px){
  .ctaBlue{padding:54px 0}
  .ctaBlue__grid{grid-template-columns:1fr; gap:22px}
  .ctaBlue__content{max-width:none}
}

/* CTA Brush (tips section) */
.ctaBrush{
  position:relative;
  padding:70px 0;
  background:#fff;
  border-top:8px solid #1c2240;
  border-bottom:8px solid #1c2240;
  box-shadow:0 10px 26px rgba(0,0,0,.08) inset;
}
.ctaBrush::before{
  content:"";
  position:absolute;
  left:0; top:50%;
  width:260px; height:260px;
  transform:translateY(-50%);
  background:url("/assets/img/brush-left.png") no-repeat left center / contain;
  opacity:.95;
}
.ctaBrush::after{
  content:"";
  position:absolute;
  right:0; top:50%;
  width:260px; height:260px;
  transform:translateY(-50%);
  background:url("/assets/img/brush-right.png") no-repeat right center / contain;
  opacity:.95;
}
.ctaBrush__inner{
  position:relative;
  text-align:center;
}
.ctaBrush__inner .pill{
  color:#1c2240;
  margin-bottom:10px;
}
.ctaBrush__inner h2{margin:0 0 10px}
.ctaBrush__inner p{max-width:70ch;margin:0 auto 16px}

/* Accordion */
.accordion{display:grid;gap:10px}
.acc__item{
  border:1px solid var(--line);
  border-radius:12px;
  overflow:hidden;
  background:#fff;
}
.acc__btn{
  width:100%;
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border:0;
  background:#fff;
  font-weight:900;
  cursor:pointer;
  text-align:left;
}
.acc__panel{padding:14px 16px; border-top:1px solid var(--line)}
.hide{display:none}

/* Footer */
footer{padding:30px 0 40px;border-top:1px solid var(--line)}
.footer__grid,.footer__inner{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer__links{display:flex;flex-direction:column;gap:6px;text-align:right;align-items:flex-end}
.footer__links a{display:block}
@media (max-width:900px){.footer__links{align-items:flex-start;text-align:left}}

/* Responsive */
@media (max-width: 980px){
  .nav{display:none}
  .burger{display:inline-block}
  .hero__grid{grid-template-columns:1fr; min-height:200px}
  .grid--3{grid-template-columns:repeat(2, minmax(0,1fr))}
  .contactSplit{grid-template-columns:1fr}
  .ctaBlue__grid{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .contactSplit__img{width:min(260px, 100%)}

  .grid--3,.grid--2{grid-template-columns:1fr}
  .contactSplit__img{
  width:min(320px, 100%);
  aspect-ratio: 1 / 1;
  height:auto;
  object-fit:cover;
  object-position:center;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  display:block;
}
  .ctaBrush::before,.ctaBrush::after{width:160px;height:160px;opacity:.9}
}


/* Inner page hero images (small banners) */
.hero__img{width:100%;height:140px;object-fit:cover;border-radius:14px;border:1px solid var(--line);background:#fff;display:block;margin:10px 0 18px}
.hero__img picture, .hero__img img{display:block;width:100%;height:100%}
.hero__img img{object-fit:cover;border-radius:inherit}
@media (max-width: 680px){
  .hero__img{height:110px; margin:8px 0 14px}
  .grid--3,.grid--2{grid-template-columns:1fr}
  .contactSplit__img{
  width:min(320px, 100%);
  aspect-ratio: 1 / 1;
  height:auto;
  object-fit:cover;
  object-position:center;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  display:block;
}
  .ctaBrush::before,.ctaBrush::after{width:160px;height:160px;opacity:.9}
}

.pageHead{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  margin-bottom:8px;
}
.pageHead p{margin:0}
@media (max-width: 680px){
  .pageHead{flex-direction:column;align-items:flex-start}
}

/* Hero: make ghost button readable on dark hero */
.hero .btn--ghost{
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.28);
  color:#fff;
}
.hero .btn--ghost:hover{
  background: rgba(255,255,255,.20);
  border-color: rgba(255,255,255,.34);
}

/* Image overlay: 4 points in 4 columns (inside image) */
.thumbWrap{
  position:relative;
  border-radius:12px;
  overflow:hidden;
}
.thumbWrap picture, .thumbWrap img{display:block}
.thumbWrap .thumb{
  margin:0;
  border:0;
  border-radius:0;
  height:240px;
  object-fit:cover;
}
.imgPoints{
  list-style:none;
  margin:0;
  padding:0;
  position:absolute;
  left:14px;
  right:14px;
  bottom:14px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:10px;
}
.imgPoints li{
  margin:0;
  padding:10px 10px;
  border-radius:10px;
  background: rgba(0,0,0,.46);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(6px);
  color:#fff;
  font-weight:900;
  font-size:13px;
  text-align:center;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.thumbFade{
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.55) 100%);
  pointer-events:none;
}
@media (max-width: 980px){
  .thumbWrap .thumb{height:200px}
  .imgPoints{grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media (max-width: 680px){
  .thumbWrap .thumb{height:170px}
  .imgPoints{left:10px;right:10px;bottom:10px;gap:8px}
  .imgPoints li{padding:9px 8px;font-size:12px}
}

/* Equal height benefit cards (3 columns) */
.benefitGrid{
  align-items: stretch;
}
.benefitGrid > .item{
  height:100%;
  display:flex;
  flex-direction:column;
}
.benefitGrid > .item h3{
  min-height:2.6em; /* keeps headings aligned (2 lines) */
  margin-bottom:12px;
}
.benefitGrid > .item picture,
.benefitGrid > .item .thumbWrap{
  flex:0 0 auto;
}
.benefitGrid > .item .thumb{
  height:220px;       /* uniform media height */
  object-fit:cover;
}
.benefitGrid > .item p{
  margin-top:14px;
  flex:1 1 auto;      /* fills remaining space so cards align */
  padding-right:8px;
}

@media (max-width: 680px){
  .benefitGrid > .item .thumb{height:200px}
}


/* Mobile header fixes */
body{overflow-x:hidden}
@media (max-width: 980px){
  .topbar__inner{gap:12px}
  .topbar__inner > a.btn--primary{display:none}
  .burger{margin-left:auto}
}
@media (max-width: 420px){
  .brand > span:last-child{display:none}
}


/* CV Wizard */
.wizard{padding:22px}
.wizardTop{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}
.wizardProgress{height:10px;background:var(--soft);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.wizardProgress__bar{height:100%;width:0;background:var(--brand);transition:width .2s ease}
.wizardDots{display:grid;grid-template-columns:repeat(5, minmax(0,1fr));gap:10px}
.wizardDot{border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px 10px;text-align:left;cursor:pointer;display:flex;gap:10px;align-items:center}
.wizardDot span{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--soft);font-weight:900}
.wizardDot small{display:block;color:var(--muted);font-weight:700}
.wizardDot strong{display:block;font-weight:900}
.wizardDot.is-active{border-color:rgba(46,163,242,.55);box-shadow:0 10px 22px rgba(46,163,242,.15)}
.wizardDot.is-active span{background:var(--brand);color:#fff}

.wizardPanel{display:none}
.wizardPanel.is-active{display:block}
.wizardGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.wizardGrid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width: 980px){
  .wizardDots{grid-template-columns:repeat(2, minmax(0,1fr))}
  .wizardGrid,.wizardGrid--3{grid-template-columns:1fr}
}
.wizardActions{display:flex;justify-content:space-between;gap:10px;margin-top:18px;flex-wrap:wrap}
.wizardActions .btn{min-width:150px}
.cvApp .wizardActions--start{justify-content:center}
.cvApp .wizardActions--start > span{display:none}
.cvApp .cvHint{
  margin:14px auto 0;
  max-width:68ch;
  text-align:center;
}
.cvApp .wizardStart{
  margin-bottom:18px;
  padding:18px;
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.94));
}
.cvApp .wizardStart .pill{margin-bottom:10px}
.cvApp .wizardLangChoices{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;
  margin:16px 0 12px;
}
.cvApp .wizardLangCard{
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  color:var(--text);
  padding:14px 16px;
  font-weight:800;
  text-align:left;
  cursor:pointer;
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.cvApp .wizardLangCard:hover{transform:translateY(-1px)}
.cvApp .wizardLangCard.is-active{
  border-color:rgba(46,163,242,.55);
  box-shadow:0 10px 22px rgba(46,163,242,.15);
}

.repeatList{display:grid;gap:12px}
.repeatItem{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff}
.repeatItem__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.repeatItem__title{font-weight:900}
.templateGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
@media (max-width: 980px){.templateGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 520px){.templateGrid{grid-template-columns:1fr}}
.templateCard{border:1px solid var(--line);border-radius:14px;background:#fff;padding:12px;cursor:pointer}
.templateCard.is-active{border-color:rgba(46,163,242,.55);box-shadow:0 10px 22px rgba(46,163,242,.15)}
.templateThumb{height:84px;border-radius:10px;border:1px solid var(--line);overflow:hidden;background:var(--soft);display:flex}
.templateThumb__side{width:26%;background:#e9f6fe}
.templateThumb__main{flex:1;padding:10px}
.templateThumb__bar{height:10px;border-radius:999px;background:var(--brand);margin-bottom:8px;width:72%}
.templateThumb__line{height:8px;border-radius:999px;background:#dfe5eb;margin-bottom:6px}
.templateThumb__line.s{width:56%}
.templateThumb__line.m{width:78%}
.templateThumb__line.l{width:92%}

/* Optional: real template thumbnail (generated in Admin via PDF upload) */
.templateThumbImg{height:84px;border-radius:10px;border:1px solid var(--line);overflow:hidden;background:var(--soft);display:block;width:100%;object-fit:cover}
.templateLabel{margin:10px 0 0}

/* CV Wizard: Step 5 must be mobile friendly (templates stacked + no horizontal clipping) */
@media (max-width: 820px){
  .cvApp .cvBuilder.is-preview .templateGrid{display:flex !important;flex-direction:column;gap:12px;grid-template-columns:none !important}
  .cvApp .cvBuilder.is-preview .templateCard{display:flex;align-items:center;gap:12px}
  .cvApp .cvBuilder.is-preview .templateThumb,
  .cvApp .cvBuilder.is-preview .templateThumbImg{width:120px;flex:0 0 120px;height:84px}
  .cvApp .cvBuilder.is-preview .templateLabel{margin:0 !important}
}

/* CV Generator: language row + live preview */
.langRow{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.langRow__ctl{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:180px;
}
.langSelect{
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  color:var(--text);
}

.cvBuilder{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
  align-items:start;
}
.cvPreviewCard{
  position:sticky;
  top:86px;
  padding:14px;
}
.cvPreviewCard.is-collapsed .cvPreviewViewport{
  display:none;
}
.cvPreviewTop{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.cvPreviewViewport{
  background:linear-gradient(180deg,#f8fafc,#ffffff);
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px;
  overflow:auto;
  max-height:75vh;
}
.cvPreviewScaler{transform-origin:top left;}

.cvPage{
  width:794px;
  min-height:1123px;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:10px;
  box-shadow:0 8px 30px rgba(0,0,0,.08);
  padding:34px;
  box-sizing:border-box;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:#111;
}
.cvPage h1{font-size:28px;margin:0 0 6px;}
.cvPage h2{
  font-size:14px;
  margin:20px 0 8px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#111;
}
.cvPage .cvMut{color:#6b7280;font-size:12px;}
.cvPage .cvTop{display:flex;gap:18px;align-items:center;justify-content:space-between;}
.cvPage .cvPhoto{width:92px;height:92px;border-radius:18px;object-fit:cover;border:1px solid #e5e7eb;}
.cvPage .cvName{font-weight:800;font-size:30px;line-height:1.05;}
.cvPage .cvHeadline{font-weight:600;color:#2563eb;margin-top:6px;}
.cvPage .cvContact{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;font-size:12px;color:#374151;}
.cvPage .cvContact span{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:999px;padding:4px 10px;}
.cvPage .cvSection{margin-top:18px;}
.cvPage .cvItem{margin:0 0 12px;}
.cvPage .cvItem__top{display:flex;justify-content:space-between;gap:10px;font-size:12px;}
.cvPage .cvItem__title{font-weight:700;}
.cvPage .cvItem__meta{color:#6b7280;}
.cvPage .cvBullets{margin:6px 0 0 18px;color:#374151;font-size:12px;}
.cvPage .cvChips{display:flex;flex-wrap:wrap;gap:8px;}
.cvPage .cvChip{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;border-radius:999px;padding:4px 10px;font-size:12px;}

.cvTpl--modern{padding-top:22px;}
.cvTpl--modern .cvHeaderBar{height:10px;border-radius:999px;background:var(--accent);margin-bottom:18px;}
.cvTpl--minimal{padding:34px;}
.cvTpl--minimal .cvHeaderBar{display:none;}
.cvTpl--sidebar{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:22px;
  padding:0;
}
.cvTpl--sidebar .cvSide{
  background:#0f172a;
  color:#fff;
  border-radius:10px;
  padding:26px;
}
.cvTpl--sidebar .cvMain{padding:26px;}
.cvTpl--sidebar .cvSide .cvMut{color:rgba(255,255,255,.75);}
.cvTpl--sidebar .cvSide .cvContact span{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:#fff;}
.cvTpl--sidebar .cvSide h2{color:#fff;}

@media (max-width: 980px){
  .cvBuilder{grid-template-columns:1fr;}
  .cvPreviewCard{position:relative;top:auto;}
  .cvPreviewViewport{max-height:65vh;}
}


/* =========================================================
   CV Generator UI v2 (preview only on last step)
   ========================================================= */
.cvApp .cvHero{
  padding:28px 0 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border-bottom:1px solid var(--line);
}
.cvApp .cvHero__top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.cvApp .cvHero__title{
  font-size: clamp(30px, 3.4vw, 46px);
  letter-spacing:-0.02em;
  line-height:1.05;
}
.cvApp .cvHero__sub{
  margin:8px 0 0;
  color:var(--muted);
  max-width:76ch;
  line-height:1.6;
}
.cvApp .cvHero__lang{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:220px;
}
.cvApp .cvHero__note{
  margin-top:14px;
  border:1px dashed var(--line);
  border-radius:14px;
  padding:12px 14px;
  background:#fff;
  color:var(--muted);
}

.cvApp .cvBuilder{
  display:grid;
  grid-template-columns: 1fr;
  gap:22px;
  align-items:start;
}
.cvApp .cvBuilder__preview{display:none;}
.cvApp .cvBuilder.is-preview{
  grid-template-columns: minmax(360px, 520px) minmax(0, 1fr);
  gap:22px;
}

.cvApp .cvBuilder.is-preview .templateGrid{grid-template-columns:repeat(2,minmax(0,1fr));}
.cvApp .cvBuilder.is-preview .cvBuilder__preview{display:block;}

/* Step 5 (Template): ensure the template grid becomes 1-column on very small
   screens even when preview mode is active (mobile / narrow embeds). */
@media (max-width: 520px){
  .cvApp .cvBuilder.is-preview .templateGrid{grid-template-columns:1fr;}
}

/* Step 5 (Template): make download buttons easier to tap on mobile */
@media (max-width: 520px){
  .cvApp .wizardPanel[data-step="4"] .wizardActions{align-items:stretch;}
  .cvApp .wizardPanel[data-step="4"] .wizardActions > span{width:100%;}
  .cvApp .wizardPanel[data-step="4"] .wizardActions > span .btn{width:100%;}
}

/* Make the wizard feel like an iOS stepper (cleaner + less bulky) */
.cvApp .wizard{padding:18px;}
.cvApp .wizardTop{gap:12px;}
.cvApp .wizardProgress{height:8px;}
.cvApp .wizardDots{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:stretch;
}
.cvApp .wizardDot{
  border-radius:999px;
  padding:10px 12px;
  gap:10px;
  align-items:center;
  flex:1 1 160px;
  min-width:160px;
}
.cvApp .wizardDot span{
  width:30px;height:30px;
  font-size:13px;
}
.cvApp .wizardDot strong{font-size:13px;}
.cvApp .wizardDot small{font-size:11px;}

@media (max-width: 980px){
  .cvApp .cvBuilder.is-preview{grid-template-columns:1fr;}
  .cvApp .wizardDot{min-width:140px;}
}
@media (max-width: 520px){
  .cvApp .wizardLangChoices{grid-template-columns:1fr;}
  .cvApp .cvHero__lang{min-width:100%;}
  .cvApp .wizardDot small{display:none;}
  .cvApp .wizardActions .btn{min-width:unset;}
}

/* Preview: no horizontal scrollbar + better sizing */
.cvApp .cvPreviewCard{padding:16px;}
.cvApp .cvPreviewViewport{
  overflow-x:hidden;
  overflow-y:auto;
  max-height:78vh;
  padding:12px;
}
.cvApp .cvPreviewScaler{
  position:relative;
  width:100%;
}
.cvApp #cvPreview{
  transform-origin: top left;
  will-change: transform;
}


/* Home hero right column: stack cards to fill height */
.heroRight{
  display:flex;
  flex-direction:column;
  gap:18px;
  align-items:stretch;
  height:100%;
}
.heroMiniCta .card__pad{padding:18px;height:100%;display:flex;flex-direction:column}

/* Bewerbungstipps: Generator card */
.genCard{border-radius:16px}
.genCard .card__pad{padding:22px}
.genCard .note{background:var(--soft)}
.genCard .cvEmbed{box-shadow:none}

/* CV generator embed */
.cvEmbed{
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow);
}
.cvEmbed iframe{
  min-height:320px;
  width:100%;
  height:520px; /* will be resized via JS to match the embedded CV app */
  border:0;
  display:block;
  background:#fff;
}

/* CV generator embedded mode (inside iframe) */
.cvApp.is-embed main{padding:0}
.cvApp.is-embed .section{padding:0}
.cvApp.is-embed .container{width:100%;max-width:none}
.cvApp.is-embed .cvBuilder{margin-top:0}

/* Bewerbungstipps header layout */
.tipsHead{align-items:flex-start; margin-bottom:10px}
.tipsHead__text p{margin:0}
.tipsHead .tipsNav{display:flex; gap:10px; flex-wrap:wrap; align-items:flex-start}
@media (max-width: 680px){
  .tipsHead{flex-direction:column; align-items:flex-start}
}

.heroMiniCta{flex:1}

.heroMiniCta .card__pad > p:last-child{margin-top:auto}

/* Bewerbungstipps: Tip cards */
.tipsCards{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
  margin-top:16px;
}
.tipCard{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:18px;
  height:100%;
}
.tipCard--wide{grid-column:1 / -1}
.tipCard__head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
}
.tipCard__head h3{
  margin:0;
  font-size:18px;
}
.tipIcon{
  width:34px;height:34px;
  border-radius:12px;
  background:rgba(46,163,242,.12);
  border:1px solid rgba(46,163,242,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  color:var(--brand);
}
.tipIcon svg{width:18px;height:18px}
.tipList{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
}
.tipList li{
  position:relative;
  padding-left:22px;
}
.tipList li:before{
  content:"";
  position:absolute;
  left:0; top:6px;
  width:14px;height:14px;
  border-radius:5px;
  background:rgba(46,163,242,.16);
}
.tipList li:after{
  content:"";
  position:absolute;
  left:4px; top:10px;
  width:6px;height:3px;
  border-left:2px solid var(--brand);
  border-bottom:2px solid var(--brand);
  transform:rotate(-45deg);
}
.tipList--two{
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px 16px;
}
@media (max-width: 680px){
  .tipsCards{grid-template-columns:1fr}
  .tipCard--wide{grid-column:auto}
  .tipList--two{grid-template-columns:1fr}
}

/* Bewerbungstipps + CV Generator: 2-spaltig auf Desktop */
.tipsTwoCol{
  display:grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 32px;
  align-items:start;
  margin-top:18px;
}
.tipsCol{min-width:0}
.genCol{min-width:0}
@media (max-width: 980px){
  .tipsTwoCol{grid-template-columns:1fr}
}


/* Contact page – make media image fill the left box */
.contactSplit{align-items:stretch}
.contactSplit__media{
  padding:0;
  display:block;
  overflow:hidden;
}
.contactSplit__media picture{
  display:block;
  width:100%;
  height:100%;
}
.contactSplit__img{
  width:100%;
  max-width:none;
  height:100%;
  aspect-ratio:auto;
  object-fit:cover;
  object-position:center;
  border:0;
  border-radius:0;
}
@media (max-width: 980px){
  .contactSplit__media{height:240px}
}
@media (max-width: 680px){
  .contactSplit__media{height:210px}
}


/* Bewerbungstipps layout: tips in 2 columns on top, generator full width below */
.tipsTopGrid{
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap:26px;
  align-items:start;
  margin-top:14px;
}
.tipsLeft .tipsCards{margin-top:0}
.tipsRight .accordion{margin-top:0}
.genFull{margin-top:26px}
.genFull .genCard{box-shadow:var(--shadow)}
.genFull .cvEmbed iframe{height:520px; min-height:320px}/* auto-sized via JS */
@media (max-width: 980px){
  .tipsTopGrid{grid-template-columns:1fr}
  .genFull{margin-top:18px}
  .genFull .cvEmbed iframe{height:520px; min-height:320px}/* auto-sized via JS */
}


.contactSplit__media{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:0;
  overflow:hidden;

  /* Match phone image ratio (2560×1707 ≈ 3:2) so the full image is visible */
  aspect-ratio: 3 / 2;
}
.contactSplit__media picture{
  width:100%;
  height:100%;
  display:block;
}
.contactSplit__img{
  width:100%;
  height:100%;
  object-fit:contain;          /* show the whole image */
  object-position:center;
  display:block;
  background:#0aa0b0;          /* fallback to match image tone */
  border:0;
  border-radius:0;
}
.contactSplit__form .card{box-shadow:var(--shadow);}


/* Language switch */
.langSwitch{display:flex;align-items:center}
.langSwitch select{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-weight:700;
  max-width: 200px;
}
@media (max-width: 820px){
  .langSwitch select{padding:8px 10px;max-width: 160px}
}
.mobileNav .langSwitch--mobile{margin-top:12px}
.mobileNav .langSwitch--mobile select{width:100%}


/* Admin: aligned toggles (label left, checkbox right) */
.adminToggleGroup{display:grid;gap:8px}
.adminToggleRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  user-select:none;
}
.adminToggleRow span{
  font-weight:700;
  color:var(--text);
}
.adminToggleRow input{
  width:18px;
  height:18px;
  flex:0 0 auto;
  accent-color:var(--brand);
}

/* --- Fine tuning: Buttons & home hero image placement --- */
.btnRow{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.reasonHero{margin:10px 0 14px}
.reasonHeroImg{width:100%;height:auto;display:block;border-radius:12px;border:1px solid var(--line)}
.shortContact h4{margin:14px 0 6px;font-size:16px}
.shortContact p{margin:0 0 12px}

@media (max-width:520px){
  .btnRow .btn{width:100%;justify-content:center}
}

/* --- Home: Hero bullets (services list) --- */
.hero__bullets{
  margin: 14px 0 16px 18px;
  padding: 0;
  color: #e5e7eb;
  font-size: 15px;
  line-height: 1.6;
}
.hero__bullets li{ margin: 4px 0; }
@media (max-width: 900px){
  .hero__bullets{ color: #f3f4f6; }
}

/* --- Simple 2-column grid helper (used on prices) --- */
.grid-2{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 900px){
  .grid-2{ grid-template-columns: 1fr; }
}

/* --- Prose spacing (used on text-heavy pages) --- */
.prose h2{ margin-top: 1.2rem; }
.prose h3{ margin-top: 1rem; }
.prose hr{ margin: 1.25rem 0; border: 0; border-top: 1px solid var(--border); }
.prose ul{ margin: .6rem 0 0 1.2rem; padding: 0; }
.prose li{ margin: .25rem 0; }

/* --- Bewerbungstipps: Clean-Style wie Home --- */
.page-tips .hero{
  background: var(--soft);
  background-image: none;
  color: var(--text);
  /* oben war zu viel Abstand – kompakter wie auf der Startseite */
  padding: 28px 0 26px;
}
.page-tips .hero:before{ display:none; }
.page-tips .hero .pill{
  background: rgba(11,109,191,.10);
  border-color: rgba(11,109,191,.18);
  color: var(--primary);
}
.page-tips .hero__grid{ align-items: end; }
.page-tips .hero h1{
  color: var(--text);
  /* etwas kleiner als Default-H1, damit der Textblock sauber zum Hero-Bild passt */
  font-size: clamp(26px, 2.8vw, 40px);
  line-height: 1.12;
  margin: 0 0 12px;
}
.page-tips .hero .lead{ color: var(--muted); max-width: 70ch; margin: 0; }
.page-tips .hero__actions{ margin-top: 18px; }
.page-tips .section{ padding-top: 22px; }
.page-tips .card.prose{ padding: 28px; }

@media (max-width: 900px){
  /* Mobile: ebenfalls kompakter, ohne den Inhalt zu quetschen */
  .page-tips .hero{ padding: 22px 0 18px; }
  .page-tips .card.prose{ padding: 18px; }
}


/* --- Bewerbungstipps: Kachelsystem --- */
.page-tips .tipsGrid{gap:10px;}
.tipsGrid--spaced{margin-top:10px;}
.page-tips .bullets{
  margin:10px 0 0 18px;
  padding:0;
}
.page-tips .bullets li{
  margin:6px 0;
  color:var(--muted);
  line-height:1.45;
}
.page-tips .bullets li::marker{
  color:var(--accent);
}
.page-tips .tipTile .note{margin-top:10px;}


/* =========================================================
   Consolidated final overrides
   ========================================================= */

/* Accessibility */
.srOnly{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* Header unified */
.topbar__right{
  display:flex;
  align-items:center;
  gap:12px;
  flex:0 0 auto;
  white-space:nowrap;
}
.topbar__right .langSwitch{margin:0}
.topbar__right .btn{margin:0}
.nav{flex-wrap:nowrap}
.nav a{white-space:nowrap}
.nav a.is-active,
.mobileNav a.is-active{
  color:var(--accent) !important;
  font-weight:600;
}
.topbar .container{width:min(1240px,96vw)}
@media (max-width:980px){
  .topbar__right{display:none}
}

/* Smaller titles globally */
h1{font-size:clamp(28px,3.4vw,46px); margin:6px 0 10px; line-height:1.12;}
h2{font-size:clamp(20px,2.1vw,30px); margin:0 0 10px; line-height:1.2;}
h3{font-size:17px; margin:0 0 8px;}
.hero--slim{padding:24px 0 18px; background:var(--soft); background-image:none; color:var(--text);}
.hero--slim h1{color:var(--text);}
.hero--slim .lead{color:var(--muted);}
.page-flow .flowStepTitle,
.page-flow .flowCardTitle,
.page-flow .h3,
.page-flow h2.h3{font-size:15px !important; line-height:1.3; margin-bottom:8px;}
.page-prices .h3,
.page-prices h2.h3{font-size:17px !important; line-height:1.3;}
.page-generator h2{font-size:clamp(19px,2vw,28px);}
.page-contact h1,
.page-tips h1,
.page-prices h1,
.page-generator h1,
.page-flow h1{font-size:clamp(26px,3.1vw,40px);}

/* Home hero clean + video */
.page-home .hero{background:var(--soft); background-image:none; color:var(--text); padding:28px 0 24px;}
.page-home .hero:before{display:none;}
.page-home .hero h1{color:var(--text);}
.page-home .hero .lead{color:var(--muted);}
.page-home .hero .pill{
  color:var(--muted);
  background:#fff;
  border:1px solid var(--line);
  padding:8px 10px;
  border-radius:999px;
}
.page-home .hero__grid{align-items:start; min-height:0;}
.heroLeftCard .card__pad,
.heroRight .card__pad{padding:22px;}
.hero__bullets{margin:10px 0 0 18px; padding:0; color:var(--muted); line-height:1.55;}
.hero__bullets li{margin:5px 0;}
.reasonHero{
  margin:14px 0 16px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
}
.reasonHero picture,
.reasonHero img{display:block; width:100%;}
.reasonHero img{height:clamp(180px,22vw,240px); object-fit:cover;}
.shortContact{margin-top:14px; padding-top:14px; border-top:1px solid var(--line);}

.heroVideoWrap{
  position:relative;
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow);
  aspect-ratio: 16 / 9;
  margin:14px 0;
}
.heroCardPoster,
.heroCardVideo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  margin:0;
  border:0;
  border-radius:0;
  background:#fff;
}
.heroCardPoster{z-index:1; transition:opacity .45s ease;}
.heroCardVideo{z-index:2; opacity:0; transition:opacity .55s ease;}
.heroVideoWrap.is-playing .heroCardVideo{opacity:1;}
.heroVideoWrap.is-playing .heroCardPoster{opacity:0;}
@media (max-width:820px){
  .heroVideoWrap{aspect-ratio:16/9;}
  .heroCardVideo{display:none !important;}
  .heroCardPoster{position:absolute; inset:0;}
}

/* Tips hero like home */
.page-tips .hero{
  background:var(--soft);
  background-image:none;
  color:var(--text);
  padding:20px 0 18px;
}
.page-tips .hero h1{color:var(--text); font-size:clamp(24px,2.9vw,36px); margin-bottom:8px;}
.page-tips .hero .lead{color:var(--muted); max-width:68ch; margin:0;}
.page-tips .hero__grid{align-items:end; min-height:0; gap:18px;}
.page-tips .hero__img{margin:0;}
.page-tips .tipsGrid{gap:10px; margin-top:10px;}
.page-tips .tipsGrid--spaced{margin-top:10px;}
.page-tips .tipTile{height:100%;}
.page-tips .bullets{margin:8px 0 0 18px; padding:0;}
.page-tips .bullets li{margin:6px 0; color:var(--muted); line-height:1.45;}
.page-tips .bullets li::marker{color:var(--accent);}
@media (max-width:900px){
  .page-tips .hero{padding:18px 0 16px;}
}

/* Generator */
.page-generator .hero{background:var(--soft); background-image:none; color:var(--text);}
.page-generator .hero h1{color:var(--text);}
.page-generator .hero .lead{color:var(--muted);}
.genCard{border-radius:16px;}
.genCard .card__pad{padding:22px;}
.cvEmbed{border:1px solid var(--line); border-radius:16px; overflow:hidden; background:#fff; box-shadow:var(--shadow);}
.cvEmbed iframe{display:block; width:100%; min-height:520px; height:620px; border:0; background:#fff;}
@media (max-width:900px){
  .cvEmbed iframe{min-height:640px;}
}

/* Ablauf steps */
.flowGrid{gap:20px;}
.flowStepCard .thumb{margin-bottom:0; height:210px;}
.stepBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;height:34px;
  border-radius:999px;
  background:rgba(11,109,191,.10);
  border:1px solid rgba(11,109,191,.20);
  color:var(--brand);
  font-weight:900;
  margin:0 0 10px;
}
.flowEndGrid{align-items:stretch;}
.card--dashed{border-style:dashed;}
.flowCardTitle{margin-top:0;}
.flowCtaButtons{display:flex; gap:10px; flex-wrap:wrap;}
@media (max-width:700px){
  .flowStepCard .thumb{height:180px;}
}

/* Prices */
.price{
  margin-top:12px;
  font-weight:900;
  font-family:var(--font-head);
  color:#111827;
  font-size:24px;
}
.noteCard__grid{align-items:center;}
.noteCard__thumb{height:220px; object-fit:cover; margin:0;}
@media (max-width:900px){
  .noteCard__thumb{height:180px;}
}

/* Footer links right aligned under each other */
.footer__links{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  text-align:right;
  gap:8px;
}
@media (max-width:900px){
  .footer__links{align-items:flex-start; text-align:left;}
}

/* Generic reveal */
.reveal{
  opacity:0;
  transform:translate3d(-42px,0,0);
  transition:transform .85s cubic-bezier(.22,.61,.36,1), opacity .85s ease;
  will-change:transform,opacity;
}
.reveal--from-right{transform:translate3d(110px,0,0);}
.reveal--from-left{transform:translate3d(-110px,0,0);}
.reveal--from-up{transform:translate3d(0,34px,0);}
.reveal.is-visible{
  opacity:1;
  transform:none;
}
.reveal-grid > *{
  opacity:0;
  transform:translate3d(-46px,0,0);
  transition:transform .8s cubic-bezier(.22,.61,.36,1), opacity .8s ease;
  will-change:transform,opacity;
}
.reveal-grid > *.is-visible{opacity:1; transform:none;}

/* Home hero intro animation */
.heroSlide{
  opacity:0;
  animation-duration:1.05s;
  animation-fill-mode:forwards;
  animation-timing-function:cubic-bezier(.22,.61,.36,1);
}
.heroSlide--from-right{animation-name:heroSlideFromRight;}
.heroSlide--from-left{animation-name:heroSlideFromLeft; animation-delay:.14s;}
@keyframes heroSlideFromRight{
  from{opacity:0; transform:translate3d(110px,0,0);}
  to{opacity:1; transform:none;}
}
@keyframes heroSlideFromLeft{
  from{opacity:0; transform:translate3d(-110px,0,0);}
  to{opacity:1; transform:none;}
}
@media (max-width: 820px){
  .page-home .heroSlide{
    animation:none !important;
    opacity:1 !important;
    transform:none !important;
  }
}

/* Hover micro-interactions */
@media (hover:hover) and (pointer:fine){
  .card,
  .item{
    transition:transform .18s ease, box-shadow .18s ease;
  }
  .card:hover,
  .item:hover{
    transform:translateY(-4px);
    box-shadow:0 20px 46px rgba(0,0,0,.12);
  }
  .card:hover .thumb{
    transform:scale(1.02);
  }
  .thumb{
    transition:transform .35s ease;
  }
}

@media (prefers-reduced-motion: reduce){
  .reveal,
  .reveal-grid > *,
  .heroSlide,
  .card, .item, .thumb, .btn{
    transition:none !important;
    animation:none !important;
    transform:none !important;
    opacity:1 !important;
  }
}


/* Hotfix: Home hero media + generator iframe exact heights */
.page-home .heroVideoWrap{
  min-height:0 !important;
  height:auto !important;
}
.page-home .heroVideoWrap .heroCardPoster,
.page-home .heroVideoWrap .heroCardVideo,
.page-home .heroLeftCard .heroCardImg{
  max-height:none !important;
  margin:0 !important;
}
.page-home .heroVideoWrap .heroCardPoster,
.page-home .heroVideoWrap .heroCardVideo{
  display:block;
}
.page-generator .cvEmbed,
.page-tips .cvEmbed,
.genFull .cvEmbed{min-height:0 !important;}
.page-generator .cvEmbed iframe,
.page-tips .cvEmbed iframe,
.genFull .cvEmbed iframe{
  min-height:0 !important;
}


/* Final hotfix: home hero media fill wrapper exactly */
.page-home .heroVideoWrap .heroCardPoster,
.page-home .heroVideoWrap .heroCardVideo{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
  display:block !important;
  margin:0 !important;
  max-height:none !important;
}
.page-home .heroVideoWrap{
  aspect-ratio:16 / 9;
  overflow:hidden;
}
.page-generator .cvEmbed iframe{
  min-height:320px !important;
}


/* Performance overrides: desktop video, mobile image, stable hero box */
.heroVideoWrap{
  display:block;
  line-height:0;
  contain:layout paint;
}
.heroCardPosterWrap,
.heroCardMobileWrap{
  position:absolute;
  inset:0;
  display:block;
}
.heroCardPoster,
.heroCardVideo,
.heroCardMobileImg{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
  margin:0 !important;
  max-height:none !important;
  display:block !important;
}
.heroCardMobileWrap{display:none;}
@media (max-width:820px){
  .heroVideoWrap{aspect-ratio:2 / 1;}
  .heroCardPosterWrap,
  .heroCardVideo{display:none !important;}
  .heroCardMobileWrap{display:block !important;}
  .heroCardMobileImg{object-fit:cover !important;}
}
@media (min-width:821px){
  .heroCardMobileWrap{display:none !important;}
}
