:root{
  /* Primärfarben (Brand-Manual) */
  --c-primary:#233C7E;           /* Dark Blue / Petrolblau */
  --c-primary-dark:#152756;
  --c-primary-deep:#0a1633;
  --c-gray:#575757;              /* Cool Gray 11 C */

  /* Sekundärfarben (Brand-Manual) */
  --c-blue-mid:#0069A9;
  --c-accent:#009FE3;            /* CMYK 100/0/0/0 — Hauptakzent */
  --c-accent-dark:#0085c2;
  --c-blue-light:#62B9E9;

  /* Brand-Gradient (aus Manual: dark-blue → cyan → light) */
  --grad-brand:linear-gradient(135deg,#233C7E 0%,#0069A9 40%,#009FE3 70%,#62B9E9 100%);
  --grad-hero:linear-gradient(135deg,#233C7E 0%,#152756 50%,#0a1633 100%);

  --c-text:#575757;
  --c-text-light:#7a7a7a;
  --c-heading:#1a1a1a;
  --c-bg:#ffffff;
  --c-bg-alt:#f5f7fb;
  --c-bg-dark:#0f1d3f;
  --c-border:#e5e8ee;
  --c-success:#1f9d55;
  --c-warning:#e09b00;
  --c-error:#c0392b;
  --r-sm:6px;
  --r-md:10px;
  --r-lg:16px;
  --r-xl:24px;
  --shadow-sm:0 1px 2px rgba(35,60,126,.06);
  --shadow-md:0 6px 24px rgba(35,60,126,.08);
  --shadow-lg:0 12px 40px rgba(35,60,126,.12);
  --shadow-xl:0 24px 60px rgba(35,60,126,.18);
  --maxw:1180px;
  --gap:24px;
  --t-fast:.15s ease;
  --t-base:.25s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.6;
  color:var(--c-text);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  max-width:100vw;
}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--c-accent);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--c-accent-dark)}
h1,h2,h3,h4{
  font-family:'Montserrat',sans-serif;
  color:var(--c-heading);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-.01em;
  hyphens:auto;
  word-wrap:break-word;
  overflow-wrap:break-word;
}
h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;letter-spacing:-.02em;line-height:1.1}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem);margin-bottom:16px;font-weight:700}
h3{font-size:clamp(1.1rem,2vw,1.3rem);margin-bottom:12px;font-weight:700}
/* Brand-Manual: Headlines mit Regular+Bold-Mix */
h1 strong,h2 strong,h3 strong{font-weight:700}
h1 .light,h2 .light,h3 .light{font-weight:400}
p{margin-bottom:14px}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.section{padding:90px 0;overflow-x:hidden}
.section-alt{background:var(--c-bg-alt)}
.section-dark{background:var(--c-bg-dark);color:rgba(255,255,255,.85)}
.section-dark h2,.section-dark h3{color:#fff}
/* Brand-Manual: "//"-Präfix vor Eyebrow */
.eyebrow{
  display:inline-block;font-size:.85rem;font-weight:400;
  text-transform:uppercase;letter-spacing:.12em;
  color:var(--c-primary);margin-bottom:14px;
}
.eyebrow::before{
  content:"// ";
  font-weight:400;color:var(--c-primary);margin-right:2px;
}
.eyebrow strong{font-weight:700;color:var(--c-primary)}
.section-dark .eyebrow,.section-dark .eyebrow::before,.section-dark .eyebrow strong{color:#fff}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-head p{font-size:1.1rem}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--c-border);
  padding:14px 0;
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo-wrap{display:flex;align-items:center;gap:18px;color:var(--c-primary);text-decoration:none}
.logo-wrap img,.logo-wrap svg{display:block;height:42px;width:auto}
.logo-text{
  font-weight:600;font-size:.78rem;letter-spacing:.18em;line-height:1.1;color:var(--c-primary);
  text-transform:uppercase;padding-left:14px;border-left:2px solid var(--c-border);
}
.logo-text small{display:block;font-size:.68rem;font-weight:400;color:var(--c-text);letter-spacing:.14em;margin-top:3px}
@media(max-width:520px){
  .logo-wrap img,.logo-wrap svg{height:34px}
  .logo-text{display:none}
}

/* Hero */
.hero{
  position:relative;
  background-color:#0a1633;
  background-image:linear-gradient(110deg,rgba(10,22,51,.88) 0%,rgba(10,22,51,.6) 55%,rgba(10,22,51,.35) 100%),url("../img/team/halle-uebersicht.jpg");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  color:#fff;
  padding:120px 0;
  overflow:hidden;
}
/* Zusätzlicher Bottom-Fade für CTA-Lesbarkeit */
.hero::before{
  content:"";position:absolute;inset:auto 0 0 0;height:40%;
  background:linear-gradient(180deg,transparent 0%,rgba(10,22,51,.55) 100%);
  pointer-events:none;
}
/* hero-bg-signet: deaktiviert (Hintergrundbild übernimmt das visuell) */
.hero-bg-signet{display:none}

/* Section-Watermark: riesiges R-Signet semi-transparent als Hintergrund */
.section-watermark{position:relative;overflow:hidden}
.section-watermark > .container{position:relative;z-index:1}
.section-watermark::before{
  content:"";position:absolute;
  left:-12%;top:50%;transform:translateY(-50%);
  width:min(680px,68vw);height:min(680px,68vw);
  background-image:url("../img/ritzhaupt-signet.png");
  background-repeat:no-repeat;background-size:contain;
  opacity:.06;
  pointer-events:none;z-index:0;
}
.section-watermark--right::before{left:auto;right:-15%}
.hero-grid{
  position:relative;z-index:1;
  display:block;max-width:780px;
}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:32px}}
.hero-kicker{
  display:inline-block;
  font-size:.9rem;font-weight:400;
  text-transform:uppercase;letter-spacing:.16em;
  color:rgba(255,255,255,.85);margin-bottom:14px;
}
.hero-kicker::before{
  content:"// ";font-weight:400;color:rgba(255,255,255,.55);
}
.hero h1{
  color:#fff;margin-bottom:22px;hyphens:auto;
  font-weight:300;
  font-size:clamp(2.2rem,5.5vw,3.8rem);
  letter-spacing:-.015em;line-height:1.05;
}
.hero h1 strong{font-weight:700}
.hero h1 .accent{
  color:var(--c-accent);
  background:linear-gradient(135deg,#62B9E9 0%,#009FE3 60%,#62B9E9 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  font-weight:700;
}
.hero .lead{
  font-size:clamp(1.05rem,1.8vw,1.2rem);
  max-width:560px;margin-bottom:32px;
  color:rgba(255,255,255,.88);line-height:1.55;
}
.hero .badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.hero .badge{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  padding:7px 14px;border-radius:999px;
  font-size:.85rem;font-weight:400;
  display:inline-flex;align-items:center;gap:6px;
}
.hero .badge::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--c-accent-light);
}
.hero .cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:28px}
.hero .quick-trust{
  display:flex;gap:24px;font-size:.9rem;color:rgba(255,255,255,.75);
  flex-wrap:wrap;
}
.hero .quick-trust span{display:inline-flex;align-items:center;gap:6px}
.hero .quick-trust span::before{content:"✓";color:var(--c-accent-light);font-weight:700}

/* Hero-Visual deaktiviert */
.hero-visual{display:none}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 26px;border-radius:var(--r-md);
  font-weight:600;font-size:1rem;cursor:pointer;border:none;
  text-align:center;transition:all var(--t-base);
  font-family:inherit;text-decoration:none;
  line-height:1;min-height:48px;
}
.btn-primary{background:var(--c-accent);color:#fff;box-shadow:0 4px 14px rgba(0,158,227,.4)}
.btn-primary:hover{background:var(--c-accent-dark);color:#fff;transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,158,227,.5)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4)}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}
.btn-secondary{background:transparent;color:var(--c-primary);border:2px solid var(--c-border)}
.btn-secondary:hover{border-color:var(--c-primary);color:var(--c-primary)}
.btn-block{display:flex;width:100%}
.btn-sm{padding:10px 18px;font-size:.92rem;min-height:40px}

/* Trust-Strip */
.trust{
  background:#fff;
  padding:36px 0;
  border-bottom:1px solid var(--c-border);
}
.trust-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:32px;text-align:center;
}
@media(max-width:768px){.trust-grid{grid-template-columns:repeat(2,1fr);gap:24px}}
.trust-item .num{
  font-size:clamp(1.6rem,3vw,2.1rem);font-weight:700;
  color:var(--c-primary);display:block;line-height:1;
  letter-spacing:-.02em;
}
.trust-item .num span{color:var(--c-primary);font-size:.7em;font-weight:600}
.trust-item .label{
  font-size:.88rem;color:var(--c-text);margin-top:6px;display:block;
  line-height:1.4;
}

/* Job-Grid (Karriere-Hub) */
.job-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
}
@media(max-width:780px){.job-grid{grid-template-columns:1fr}}
.job-card{
  display:flex;flex-direction:column;
  background:#fff;border:1.5px solid var(--c-border);
  border-radius:var(--r-lg);padding:28px;
  text-decoration:none;color:inherit;
  transition:all var(--t-base);
  position:relative;overflow:hidden;
}
.job-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--c-accent) 0%,var(--c-primary) 100%);
  transform:scaleY(0);transform-origin:top;transition:transform var(--t-base);
}
.job-card:hover{
  border-color:var(--c-accent);
  box-shadow:var(--shadow-md);transform:translateY(-2px);
}
.job-card:hover::before{transform:scaleY(1)}
.job-card__badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.job-pill{
  background:rgba(0,158,227,.08);color:var(--c-accent-dark);
  padding:4px 10px;border-radius:999px;font-size:.78rem;
  font-weight:500;letter-spacing:.02em;
}
.job-card__title{
  color:var(--c-primary);font-size:1.2rem;font-weight:600;
  margin-bottom:10px;hyphens:auto;line-height:1.25;
}
.job-card__short{
  color:var(--c-text);font-size:.95rem;line-height:1.5;
  margin:0 0 16px;flex:1;
}
.job-card__foot{display:flex;justify-content:flex-end}
.job-card__cta{
  color:var(--c-primary);font-weight:600;font-size:.95rem;
  display:inline-flex;align-items:center;gap:6px;
}
.job-card:hover .job-card__cta{color:var(--c-primary-dark);transform:translateX(2px)}

/* Karten / Stelle */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cards{grid-template-columns:1fr}}
.card{
  background:#fff;border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:28px;
  box-shadow:var(--shadow-sm);
  transition:all var(--t-base);
  position:relative;overflow:hidden;
}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:#cfd5e0}
.card .icon{
  width:46px;height:46px;border-radius:12px;
  background:linear-gradient(135deg,rgba(0,158,227,.12) 0%,rgba(0,158,227,.04) 100%);
  color:var(--c-accent);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;font-weight:600;font-size:1.3rem;
}
.card .icon svg{width:24px;height:24px;display:block}
.card h3{color:var(--c-primary);margin-bottom:10px}
.card p{font-size:.95rem;margin:0}

/* Liste mit Check */
.list-check{list-style:none;padding:0}
.list-check li{
  padding:12px 0 12px 30px;position:relative;
  border-bottom:1px solid var(--c-border);
  font-size:.96rem;
}
.list-check li:last-child{border-bottom:none}
.list-check li::before{
  content:"";position:absolute;left:0;top:16px;
  width:18px;height:18px;border-radius:50%;
  background:var(--c-accent);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:12px;background-position:center;background-repeat:no-repeat;
}

/* Profil-Sektion */
.split-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:900px){.split-2{grid-template-columns:1fr;gap:32px}}

/* Tagesablauf */
.day-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:40px}
@media(max-width:900px){.day-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.day-grid{grid-template-columns:1fr}}
.day-card{
  background:#fff;border:1px solid var(--c-border);
  border-radius:var(--r-md);padding:22px;
  position:relative;
}
.day-card .time{
  font-size:.78rem;font-weight:700;color:var(--c-primary);
  letter-spacing:.05em;margin-bottom:6px;
}
.day-card h4{color:var(--c-primary);margin-bottom:8px;font-size:1.02rem;font-weight:600}
.day-card p{font-size:.9rem;margin:0;color:var(--c-text)}

/* Quote / GF */
.quote-block{
  background:linear-gradient(135deg,var(--c-bg-alt) 0%,#fff 100%);
  border-left:4px solid var(--c-accent);
  border-radius:var(--r-lg);padding:36px 36px 32px;
  position:relative;overflow-x:hidden;max-width:100%;
}
.quote-block::before{
  content:"„";position:absolute;top:-20px;left:24px;
  font-size:7rem;color:rgba(0,158,227,.18);font-family:serif;
  line-height:1;font-weight:700;
}
.quote-block blockquote{
  font-size:clamp(1.05rem,1.8vw,1.25rem);font-style:normal;
  color:var(--c-heading);line-height:1.55;font-weight:400;
  margin-bottom:20px;position:relative;z-index:1;
  hyphens:auto;word-break:break-word;
}
.quote-author{display:flex;align-items:center;gap:14px}
.quote-avatar{
  width:56px;height:56px;border-radius:50%;
  object-fit:cover;flex-shrink:0;
  border:2px solid #fff;box-shadow:0 2px 6px rgba(10,22,51,.18);
}
.quote-author .name{font-weight:600;color:var(--c-heading);font-size:.96rem}
.quote-author .role{font-size:.85rem;color:var(--c-text)}

/* Vergleich */
.compare-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--c-border);border-radius:var(--r-lg);
  overflow:hidden;
}
@media(max-width:700px){.compare-grid{grid-template-columns:1fr}}
.compare-col{padding:32px}
.compare-col h3{margin-bottom:18px;font-size:1.1rem}
.compare-bad{background:#fafbfc;color:var(--c-text)}
.compare-bad h3{color:#888}
.compare-bad ul{list-style:none;padding:0}
.compare-bad li{padding:8px 0 8px 26px;position:relative;font-size:.94rem}
.compare-bad li::before{content:"✕";position:absolute;left:0;color:#bbb;font-weight:700}
.compare-good{background:#fff;border-left:1px solid var(--c-border)}
@media(max-width:700px){.compare-good{border-left:none;border-top:1px solid var(--c-border)}}
.compare-good h3{color:var(--c-primary)}
.compare-good ul{list-style:none;padding:0}
.compare-good li{padding:8px 0 8px 26px;position:relative;font-size:.94rem;color:var(--c-heading)}
.compare-good li::before{
  content:"";position:absolute;left:0;top:13px;
  width:14px;height:14px;border-radius:50%;background:var(--c-accent);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:9px;background-position:center;background-repeat:no-repeat;
}

/* Form */
.form-section{
  background:linear-gradient(180deg,var(--c-bg-alt) 0%,#fff 100%);
  padding:90px 0;
}
.form-wrap{
  max-width:680px;margin:0 auto;
  background:#fff;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  padding:44px 40px;
  border:1px solid var(--c-border);
  overflow-x:hidden;max-width:min(680px,100vw);
}
@media(max-width:600px){.form-wrap{padding:32px 22px;border-radius:0;border-left:none;border-right:none}}
.form-wrap h2{text-align:center;color:var(--c-primary)}
.form-wrap .sub{text-align:center;margin-bottom:28px;font-size:1rem;color:var(--c-text)}
.progress{
  display:flex;gap:6px;margin-bottom:32px;
}
.progress .step{
  flex:1;height:5px;background:var(--c-border);border-radius:3px;
  transition:background var(--t-base);
}
.progress .step.active,.progress .step.done{background:var(--c-accent)}
.step-panel{display:none}
.step-panel.active{display:block;animation:fadeIn .3s}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.step-title{font-size:.85rem;color:var(--c-accent);font-weight:600;margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}
.field{margin-bottom:20px}
.field label{display:block;font-weight:500;margin-bottom:8px;color:var(--c-heading);font-size:.95rem}
.field input,.field select,.field textarea{
  width:100%;padding:13px 14px;
  border:1.5px solid var(--c-border);
  border-radius:var(--r-sm);
  font-size:16px;font-family:inherit;
  background:#fff;color:var(--c-heading);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--c-accent);
  box-shadow:0 0 0 3px rgba(0,158,227,.15);
}
.field .hint{font-size:.85rem;color:#888;margin-top:6px}
.field .err{font-size:.85rem;color:var(--c-error);margin-top:6px;display:none}
.field.has-error input,.field.has-error select,.field.has-error textarea{border-color:var(--c-error)}
.field.has-error .err{display:block}
.radio-group,.check-group{display:flex;flex-direction:column;gap:8px}
.radio-group label,.check-group label{
  display:flex;align-items:flex-start;gap:10px;
  padding:13px 16px;border:1.5px solid var(--c-border);
  border-radius:var(--r-sm);cursor:pointer;
  font-weight:400;font-size:.95rem;
  transition:all var(--t-fast);
  margin-bottom:0;line-height:1.4;min-height:44px;
}
.radio-group label:hover,.check-group label:hover{border-color:var(--c-accent);background:rgba(0,158,227,.03)}
.radio-group input,.check-group input{margin-top:2px;flex-shrink:0;accent-color:var(--c-accent);width:18px;height:18px}
.radio-group label.selected,.check-group label.selected{
  border-color:var(--c-accent);background:rgba(0,158,227,.06);
}
.consent{
  font-size:.85rem;line-height:1.5;color:#666;
  display:flex;gap:10px;align-items:flex-start;margin-bottom:20px;
}
.consent input{margin-top:3px;accent-color:var(--c-accent);width:18px;height:18px;flex-shrink:0}
.consent a{text-decoration:underline}
.btn-row{display:flex;justify-content:space-between;gap:12px;margin-top:24px}
.btn-row .btn{min-width:120px}
@media(max-width:520px){.btn-row{flex-direction:column-reverse}.btn-row .btn{width:100%}}

/* FAQ */
.faq-wrap{max-width:780px;margin:0 auto}
.faq-item{
  background:#fff;border:1px solid var(--c-border);
  border-radius:var(--r-md);margin-bottom:10px;
  overflow:hidden;transition:border-color var(--t-fast);
}
.faq-item:hover{border-color:#cfd5e0}
.faq-item summary{
  padding:18px 22px;cursor:pointer;font-weight:500;
  color:var(--c-heading);list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-size:.98rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-size:1.5rem;color:var(--c-accent);
  font-weight:300;transition:transform var(--t-base);flex-shrink:0;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .body{padding:0 22px 18px;font-size:.95rem;color:var(--c-text)}

/* Ansprechpartner-Sektion */
.contact-person{
  background:var(--grad-hero);
  color:#fff;padding:80px 0;
  position:relative;overflow:hidden;
}
.contact-person::after{
  content:"";position:absolute;right:-8%;top:50%;
  transform:translateY(-50%);
  width:min(560px,60vw);height:min(560px,60vw);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 600'><g fill='none' stroke='%2362B9E9' stroke-width='9'><circle cx='300' cy='300' r='265'/></g><g fill='%2362B9E9'><path d='M210 150 L210 460 L260 460 L260 360 L320 360 L380 460 L440 460 L385 355 C420 340 437 312 437 275 C437 218 393 178 335 178 L260 178 M260 198 L335 198 C375 198 410 230 410 270 C410 310 375 340 335 340 L260 340 Z'/><path d='M155 200 L185 300 L215 200 Z' opacity='.5'/></g></svg>");
  background-repeat:no-repeat;background-size:contain;
  opacity:.07;pointer-events:none;
}
.contact-person .container{position:relative;z-index:1}
.contact-person h2{color:#fff;text-align:center;margin-bottom:48px}
.cp-card{
  display:grid;grid-template-columns:auto auto 1px 1fr;
  gap:32px;align-items:center;max-width:920px;margin:0 auto;
}
@media(max-width:768px){
  .cp-card{grid-template-columns:1fr;gap:20px;text-align:center;justify-items:center}
}
.cp-photo{
  width:150px;height:150px;border-radius:50%;
  object-fit:cover;border:4px solid rgba(255,255,255,.15);
  flex-shrink:0;
}
.cp-info .cp-name{
  font-size:1.5rem;font-weight:700;line-height:1.15;margin-bottom:14px;color:#fff;
}
.cp-info .cp-contact{font-size:.95rem;line-height:1.7;color:rgba(255,255,255,.85)}
.cp-info .cp-contact a{color:rgba(255,255,255,.85)}
.cp-info .cp-contact a:hover{color:#fff}
.cp-divider{width:1px;align-self:stretch;background:rgba(255,255,255,.25);margin:8px 0}
@media(max-width:768px){.cp-divider{width:60px;height:1px;align-self:auto}}
.cp-quote{
  font-size:1.15rem;line-height:1.55;font-weight:300;
  color:rgba(255,255,255,.92);
}
.cp-quote::before{content:"„";color:var(--c-blue-light);font-weight:700}
.cp-quote::after{content:"“";color:var(--c-blue-light);font-weight:700}

/* Final-CTA */
.final-cta{
  background:linear-gradient(135deg,var(--c-primary) 0%,var(--c-primary-dark) 60%,#0a1633 100%);
  padding:90px 0;text-align:center;color:#fff;
  position:relative;overflow:hidden;
}
.final-cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 50% 30%, rgba(0,159,227,.22) 0%, transparent 55%),
    radial-gradient(circle at 80% 90%, rgba(98,185,233,.10) 0%, transparent 45%);
}
.final-cta::after{
  content:"";position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:min(620px,80vw);height:min(620px,80vw);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 600'><g fill='none' stroke='%2362B9E9' stroke-width='8'><circle cx='300' cy='300' r='265'/></g><g fill='%2362B9E9'><path d='M210 150 L210 460 L260 460 L260 360 L320 360 L380 460 L440 460 L385 355 C420 340 437 312 437 275 C437 218 393 178 335 178 L260 178 M260 198 L335 198 C375 198 410 230 410 270 C410 310 375 340 335 340 L260 340 Z'/><path d='M155 200 L185 300 L215 200 Z' opacity='.5'/></g></svg>");
  background-repeat:no-repeat;background-size:contain;
  opacity:.08;pointer-events:none;
}
.final-cta .container{position:relative;z-index:1}
.final-cta h2{color:#fff;margin-bottom:14px}
.final-cta p{font-size:1.1rem;color:rgba(255,255,255,.85);margin-bottom:28px}

/* Footer */
.footer{
  background:#0c1731;color:rgba(255,255,255,.75);
  padding:48px 0 24px;font-size:.92rem;
}
.footer a{color:rgba(255,255,255,.85)}
.footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:32px}
@media(max-width:680px){.footer-grid{grid-template-columns:1fr}}
.footer h4{color:#fff;margin-bottom:14px;font-size:.95rem;font-weight:600}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:20px;text-align:center;font-size:.82rem;
  color:rgba(255,255,255,.5);
}

/* Sticky Mobile-CTA */
.sticky-mcta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  background:#fff;border-top:1px solid var(--c-border);
  padding:10px 16px calc(10px + env(safe-area-inset-bottom));
  z-index:40;box-shadow:0 -4px 20px rgba(0,0,0,.08);
}
.sticky-mcta .btn{width:100%}
@media(max-width:900px){
  .sticky-mcta{display:block}
  body{padding-bottom:80px}
  .cookie-banner.show ~ .sticky-mcta,
  .sticky-mcta.with-cookie{bottom:auto}
}

/* Cookie-Banner */
.cookie-banner{
  position:fixed;bottom:16px;left:16px;right:auto;max-width:460px;
  background:#fff;
  border:1px solid var(--c-border);border-radius:var(--r-md);
  box-shadow:var(--shadow-xl);padding:18px 20px;
  z-index:60;display:none;font-size:.9rem;line-height:1.5;
}
.cookie-banner.show{display:block;animation:slideUp .3s}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-banner__text strong{display:block;margin-bottom:6px;color:var(--c-primary);font-size:1rem}
.cookie-banner p{margin:0 0 14px}
.cookie-banner a{text-decoration:underline;color:var(--c-primary)}
.cookie-banner .actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.cookie-banner .actions .btn{min-height:38px;padding:8px 14px;font-size:.88rem;flex:0 0 auto}
.cookie-banner .btn-primary{flex:0 1 auto}
.cookie-banner .btn-ghost{
  background:transparent;color:var(--c-text);border:1px solid var(--c-border);
}
.cookie-banner .btn-ghost:hover{background:#f4f6f9}
.cookie-banner .btn-link{
  background:none;border:none;color:var(--c-text);
  text-decoration:underline;padding:8px 10px;font-size:.85rem;
}
.cookie-banner .btn-link:hover{color:var(--c-primary)}
@media(max-width:600px){
  .cookie-banner{left:12px;right:12px;max-width:none;bottom:80px}
}

/* Cookie-Modal */
.cookie-modal{
  position:fixed;inset:0;background:rgba(10,22,51,.55);
  z-index:70;display:flex;align-items:center;justify-content:center;
  padding:20px;
}
.cookie-modal[hidden]{display:none}
.cookie-modal__inner{
  background:#fff;max-width:520px;width:100%;
  border-radius:var(--r-lg);padding:28px;
  box-shadow:var(--shadow-xl);
  max-height:90vh;overflow-y:auto;
}
.cookie-modal h3{color:var(--c-primary);margin:0 0 10px;font-size:1.3rem}
.cookie-modal p{margin:0 0 20px;font-size:.92rem;line-height:1.55}
.cookie-option{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px;margin-bottom:10px;
  border:1px solid var(--c-border);border-radius:var(--r-md);
  cursor:pointer;
}
.cookie-option:has(input:disabled){cursor:default;background:#f8f9fb}
.cookie-option input{margin-top:3px;width:18px;height:18px;accent-color:var(--c-accent)}
.cookie-option span{display:flex;flex-direction:column;gap:3px}
.cookie-option strong{color:var(--c-primary);font-size:.95rem}
.cookie-option small{color:var(--c-text);font-size:.82rem;line-height:1.4}
.cookie-modal__actions{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}

/* Test page */
.test-q{
  background:#fff;border:1px solid var(--c-border);
  border-radius:var(--r-md);padding:24px;margin-bottom:18px;
}
.test-q .qnum{
  display:inline-block;background:var(--c-primary);color:#fff;
  padding:4px 12px;border-radius:999px;font-size:.78rem;
  font-weight:600;margin-bottom:12px;letter-spacing:.04em;
}
.test-q .qtext{font-size:1.02rem;color:var(--c-heading);margin-bottom:16px;font-weight:500;line-height:1.45}
.likert{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.likert label{
  text-align:center;padding:14px 4px;
  border:1.5px solid var(--c-border);border-radius:var(--r-sm);
  cursor:pointer;font-size:.82rem;transition:all var(--t-fast);
  background:#fff;line-height:1.25;min-height:60px;
  display:flex;align-items:center;justify-content:center;
}
.likert label:hover{border-color:var(--c-accent)}
.likert input{display:none}
.likert label:has(input:checked){background:var(--c-accent);border-color:var(--c-accent);color:#fff;font-weight:500}
@media(max-width:520px){.likert label{padding:10px 2px;font-size:.7rem;min-height:54px}}

/* Status / Loader */
.loader{display:none;text-align:center;padding:40px}
.loader.active{display:block}
.spinner{
  width:42px;height:42px;border:4px solid var(--c-border);
  border-top-color:var(--c-accent);border-radius:50%;
  margin:0 auto 16px;animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Mobile */
@media(max-width:640px){
  .section{padding:64px 0}
  .hero{padding:64px 0}
  .form-section{padding:48px 0}
  .compare-col{padding:24px 22px}
}

/* ============================================================
   Funnel-Wizard — eigene Bewerbungs-Unterseite (bewerbung.php)
   ============================================================ */
.funnel-page{
  background:var(--c-bg-alt);
  padding:44px 16px 72px;
  min-height:calc(100vh - 71px);
}
.wizard{max-width:640px;margin:0 auto}
.wizard-head{text-align:center;margin-bottom:18px}
.wizard-kicker{
  font-size:.8rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--c-primary);
}
.w-card{
  background:#fff;border:1px solid var(--c-border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-md);
  overflow:hidden;
}
.w-bar{height:5px;background:var(--c-border)}
.w-bar span{
  display:block;height:100%;width:20%;
  background:var(--c-accent);
  transition:width var(--t-base);
}
.w-steps{
  display:flex;flex-wrap:wrap;gap:6px;list-style:none;
  margin:0;padding:16px 20px;
  border-bottom:1px solid var(--c-border);
}
.w-steps li{
  font-size:.71rem;font-weight:600;letter-spacing:.03em;
  text-transform:uppercase;white-space:nowrap;
  padding:6px 11px;border-radius:999px;
  background:var(--c-bg-alt);color:var(--c-text-light);
  transition:all var(--t-fast);
}
.w-steps li.done{background:rgba(0,159,227,.1);color:var(--c-accent-dark)}
.w-steps li.active{background:var(--c-primary);color:#fff}
@media(max-width:560px){.w-steps li{font-size:.64rem;padding:5px 8px}}

.w-body{padding:32px 30px}
@media(max-width:560px){.w-body{padding:24px 18px}}
.w-panel{display:none}
.w-panel.active{display:block;animation:fadeIn .3s}
.w-title{font-size:clamp(1.3rem,3vw,1.7rem);color:var(--c-heading);margin-bottom:8px;line-height:1.2}
.w-sub{color:var(--c-text);font-size:.97rem;margin-bottom:22px}
.w-field{margin-bottom:18px}
.w-label{display:block;font-weight:600;color:var(--c-heading);font-size:.95rem;margin-bottom:8px}
.w-opt{font-weight:400;color:var(--c-text-light);font-size:.85rem}

/* Option-Karten */
.opt-list{display:flex;flex-direction:column;gap:10px}
.opt-list.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.opt-list.cols-2{grid-template-columns:1fr}}
.opt{
  display:flex;align-items:flex-start;gap:13px;
  padding:15px 16px;background:#fff;
  border:1.5px solid var(--c-border);border-radius:var(--r-md);
  cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);
}
.opt:hover{border-color:var(--c-accent)}
.opt input{display:none}
.opt-mark{
  width:22px;height:22px;border-radius:50%;flex-shrink:0;margin-top:1px;
  border:2px solid var(--c-border);
  transition:all var(--t-fast);
}
.opt-body{display:flex;flex-direction:column;gap:2px}
.opt-title{font-weight:600;color:var(--c-heading);font-size:.97rem;line-height:1.3}
.opt-sub{font-size:.85rem;color:var(--c-text-light);line-height:1.4}
.opt.selected{border-color:var(--c-accent);background:rgba(0,159,227,.05)}
.opt.selected .opt-mark{
  border-color:var(--c-accent);background-color:var(--c-accent);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:13px;background-position:center;background-repeat:no-repeat;
}

/* Inputs */
.w-input{
  width:100%;padding:13px 14px;
  border:1.5px solid var(--c-border);border-radius:var(--r-sm);
  font-size:16px;font-family:inherit;
  background:#fff;color:var(--c-heading);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.w-input:focus{outline:none;border-color:var(--c-accent);box-shadow:0 0 0 3px rgba(0,159,227,.15)}
textarea.w-input{resize:vertical;min-height:88px}

/* Upload-Zone */
.w-upload{
  position:relative;display:flex;flex-direction:column;
  align-items:center;gap:5px;text-align:center;
  padding:26px 18px;cursor:pointer;
  border:2px dashed var(--c-border);border-radius:var(--r-md);
  transition:border-color var(--t-fast),background var(--t-fast);
}
.w-upload:hover{border-color:var(--c-accent);background:rgba(0,159,227,.03)}
.w-upload input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.w-upload-icon{
  width:30px;height:30px;opacity:.45;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23233C7E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' y1='3' x2='12' y2='15'/%3E%3C/svg%3E") center/contain no-repeat;
}
.w-upload-text{font-weight:600;color:var(--c-heading);font-size:.94rem;word-break:break-word}
.w-upload-hint{font-size:.81rem;color:var(--c-text-light)}
.w-upload.has-file{border-style:solid;border-color:var(--c-accent);background:rgba(0,159,227,.05)}
.w-upload.has-file .w-upload-icon{opacity:.7}

/* Consent */
.w-consent{
  display:flex;gap:10px;align-items:flex-start;
  font-size:.85rem;line-height:1.5;color:var(--c-text);
}
.w-consent input{margin-top:2px;width:18px;height:18px;flex-shrink:0;accent-color:var(--c-accent)}
.w-consent a{text-decoration:underline}

/* Fehler */
.w-err{display:none;font-size:.85rem;color:var(--c-error);margin-top:8px}
.w-field.has-error .w-err{display:block}
.w-field.has-error .opt{border-color:var(--c-error)}
.w-field.has-error .w-input{border-color:var(--c-error)}
.w-field.has-error .w-consent{color:var(--c-error)}

/* Navigation */
.w-nav{display:flex;justify-content:space-between;gap:12px;margin-top:26px}
.w-nav .btn{min-width:132px}
@media(max-width:480px){
  .w-nav{flex-direction:column-reverse}
  .w-nav .btn{width:100%}
}
.w-loader{display:none;text-align:center;padding:48px 20px}
.w-loader.active{display:block}

.funnel-foot{
  text-align:center;padding:22px 14px 4px;
  font-size:.82rem;color:var(--c-text-light);
}
.funnel-foot a{color:var(--c-text-light);text-decoration:underline}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}


/* Foto-Galerie "Einblicke" */
.gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin-top:32px;
}
.gallery-grid figure{
  margin:0;border-radius:var(--r-lg);overflow:hidden;
  background:#0a1633;box-shadow:var(--shadow-sm);
  aspect-ratio:4/3;position:relative;
}
.gallery-grid img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform var(--t-base);
}
.gallery-grid figure:hover img{transform:scale(1.03)}
@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gallery-grid{grid-template-columns:1fr}}
