:root{
  /* CI Hostel Round Table — Petrol/Türkis */
  --petrol:#0f7d8c;
  --petrol-dark:#0a5d69;
  --petrol-deep:#063f47;
  --petrol-light:#e6f4f5;
  --petrol-tint:#f4fafb;
  --accent:#ff7a4d;        /* warmer Kontrast für CTAs */
  --accent-dark:#ed5f30;
  --ink:#11272b;
  --body:#41575b;
  --muted:#7d9398;
  --line:#e2eaeb;
  --paper:#ffffff;
  --paper-2:#f7fafa;
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 4px 22px rgba(15,125,140,.08);
  --shadow-lg:0 14px 44px rgba(15,125,140,.16);
  --font-display:"Plus Jakarta Sans",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}

/* ---------- Header ---------- */
.site-head{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:800;font-size:1.18rem;letter-spacing:-.02em;color:var(--ink)}
.brand .mark{
  width:34px;height:34px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,var(--petrol),var(--petrol-dark));
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:1rem;
  box-shadow:0 4px 12px rgba(15,125,140,.3);
}
.brand small{display:block;font-size:.66rem;font-weight:600;color:var(--petrol);letter-spacing:.06em;text-transform:uppercase;margin-top:1px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{padding:9px 15px;border-radius:var(--radius-sm);font-weight:600;font-size:.93rem;color:var(--body);transition:all .15s}
.nav a:hover{color:var(--petrol);background:var(--petrol-tint)}
.nav a.cta{background:var(--petrol);color:#fff;box-shadow:0 4px 12px rgba(15,125,140,.25)}
.nav a.cta:hover{background:var(--petrol-dark);color:#fff;transform:translateY(-1px)}
.langsw{display:flex;gap:2px;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;margin-left:6px}
.langsw a{padding:7px 11px;font-size:.78rem;font-weight:700;color:var(--muted)}
.langsw a:hover{background:var(--petrol-tint);color:var(--petrol)}
.langsw a.active{background:var(--petrol);color:#fff}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,var(--petrol-deep) 0%,var(--petrol-dark) 45%,var(--petrol) 100%);
  color:#fff;padding:90px 0 130px;
}
.hero::before{
  content:"";position:absolute;top:-120px;right:-80px;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,122,77,.22),transparent 65%);
}
.hero::after{
  content:"";position:absolute;bottom:-2px;left:0;right:0;height:80px;
  background:var(--paper);
  clip-path:polygon(0 100%,100% 100%,100% 35%,0 100%);
}
.hero .wrap{position:relative;z-index:2}
.hero .eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);
  padding:7px 16px;border-radius:50px;font-size:.82rem;font-weight:600;letter-spacing:.02em;margin-bottom:26px;
}
.hero .eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(255,122,77,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,122,77,.6)}70%{box-shadow:0 0 0 10px rgba(255,122,77,0)}100%{box-shadow:0 0 0 0 rgba(255,122,77,0)}}
.hero h1{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.3rem,5.4vw,4rem);line-height:1.04;letter-spacing:-.03em;max-width:16ch;
}
.hero h1 .hl{color:var(--accent)}
.hero p{margin-top:20px;font-size:1.22rem;color:rgba(255,255,255,.86);max-width:46ch;font-weight:400}

/* ---------- Searchbar (im Hero, überlappt) ---------- */
.searchbar{
  margin-top:38px;display:flex;gap:10px;flex-wrap:wrap;
  background:#fff;padding:11px;border-radius:18px;box-shadow:var(--shadow-lg);max-width:880px;
}
.searchbar .ico-field{flex:1;min-width:200px;position:relative;display:flex;align-items:center}
.searchbar .ico-field svg{position:absolute;left:15px;width:19px;height:19px;color:var(--muted);pointer-events:none}
.searchbar input[type=text]{
  width:100%;background:var(--paper-2);border:1.5px solid transparent;color:var(--ink);
  padding:15px 16px 15px 44px;border-radius:11px;font-size:.97rem;font-family:inherit;
}
.searchbar input[type=text]:focus{outline:none;border-color:var(--petrol);background:#fff}
.searchbar select{
  background:var(--paper-2);border:1.5px solid transparent;color:var(--ink);
  padding:15px 14px;border-radius:11px;font-size:.95rem;font-family:inherit;cursor:pointer;min-width:155px;
}
.searchbar select:focus{outline:none;border-color:var(--petrol);background:#fff}
.searchbar button{
  background:var(--accent);color:#fff;border:none;font-family:var(--font-display);font-weight:700;
  padding:15px 30px;border-radius:11px;cursor:pointer;font-size:.97rem;transition:all .15s;white-space:nowrap;
}
.searchbar button:hover{background:var(--accent-dark);transform:translateY(-1px)}

/* ---------- Stats band ---------- */
.stats{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.stats .stat{display:flex;flex-direction:column}
.stats .stat b{font-family:var(--font-display);font-size:1.7rem;font-weight:800;color:#fff;line-height:1}
.stats .stat span{font-size:.82rem;color:rgba(255,255,255,.7);margin-top:3px;text-transform:uppercase;letter-spacing:.05em}
.stats .sep{width:1px;background:rgba(255,255,255,.2)}

/* ---------- Section heads ---------- */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin:14px 0 26px;gap:16px;flex-wrap:wrap}
.section-head .left .kicker{color:var(--petrol);font-weight:700;font-size:.84rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.section-head h2{font-family:var(--font-display);font-weight:800;font-size:1.9rem;letter-spacing:-.02em;color:var(--ink)}
.count{color:var(--muted);font-size:.95rem}
.reset{color:var(--accent);font-weight:600}
.reset:hover{text-decoration:underline}

main{padding-bottom:30px}
.section{padding:48px 0}
.section.tint{background:var(--paper-2)}

/* ---------- Job grid ---------- */
.jobs{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:22px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:all .2s;position:relative;
}
.card:hover{border-color:transparent;box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.card .cover{
  height:120px;position:relative;display:flex;align-items:flex-end;padding:16px;
  background:linear-gradient(135deg,var(--petrol) 0%,var(--petrol-dark) 100%);
}
.card .cover.c1{background:linear-gradient(135deg,#0f7d8c,#0a5d69)}
.card .cover.c2{background:linear-gradient(135deg,#1a9aa8,#0f7d8c)}
.card .cover.c3{background:linear-gradient(135deg,#13868f,#0a5d69)}
.card .cover .pattern{position:absolute;inset:0;opacity:.16;background-image:radial-gradient(circle at 20% 30%,#fff 1.5px,transparent 1.5px),radial-gradient(circle at 70% 60%,#fff 1.5px,transparent 1.5px);background-size:38px 38px}
.card .badge{
  position:absolute;top:14px;right:14px;background:var(--accent);color:#fff;
  font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:5px 11px;border-radius:50px;text-transform:uppercase;z-index:2;
}
.card .logo{
  width:54px;height:54px;border-radius:12px;background:#fff;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;
  color:var(--petrol);font-size:1.3rem;position:relative;z-index:2;box-shadow:0 4px 12px rgba(0,0,0,.12);overflow:hidden;
}
.card .logo img{width:100%;height:100%;object-fit:cover}
.card .pad{padding:18px 20px 20px;display:flex;flex-direction:column;gap:12px;flex:1}
.card .company{font-size:.85rem;color:var(--petrol);font-weight:600}
.card h3{font-family:var(--font-display);font-weight:700;font-size:1.2rem;line-height:1.25;letter-spacing:-.01em;color:var(--ink)}
.card h3 a:hover{color:var(--petrol)}
.tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:auto}
.tag{font-size:.78rem;font-weight:500;background:var(--petrol-tint);color:var(--petrol-dark);padding:5px 11px;border-radius:50px}
.tag.salary{background:#fff4ef;color:var(--accent-dark)}
.tag.type{background:#eef3f3;color:var(--body)}
.card .foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:14px}
.card .date{font-size:.78rem;color:var(--muted)}
.card .go{font-size:.88rem;font-weight:700;color:var(--petrol);display:inline-flex;align-items:center;gap:5px;transition:gap .15s}
.card:hover .go{gap:9px}

.empty{padding:70px 24px;text-align:center;color:var(--muted);background:#fff;border:2px dashed var(--line);border-radius:var(--radius)}
.empty svg{width:46px;height:46px;color:var(--line);margin:0 auto 14px}

/* ---------- "So funktioniert's" Band ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;position:relative}
.step .num{
  width:42px;height:42px;border-radius:12px;background:var(--petrol-tint);color:var(--petrol);
  font-family:var(--font-display);font-weight:800;font-size:1.2rem;display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.step h4{font-family:var(--font-display);font-weight:700;font-size:1.12rem;color:var(--ink);margin-bottom:8px}
.step p{font-size:.95rem;color:var(--body)}

/* ---------- Job detail ---------- */
.detail-hero{background:var(--paper-2);border-bottom:1px solid var(--line);padding:40px 0 36px}
.detail-hero .back{color:var(--muted);font-size:.9rem;display:inline-flex;align-items:center;gap:6px;margin-bottom:22px}
.detail-hero .back:hover{color:var(--petrol)}
.detail-hero .top{display:flex;gap:20px;align-items:flex-start}
.detail-hero .logo{width:72px;height:72px;border-radius:16px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;color:var(--petrol);font-size:1.8rem;flex-shrink:0;box-shadow:var(--shadow);overflow:hidden}
.detail-hero .logo img{width:100%;height:100%;object-fit:cover}
.detail-hero .company{color:var(--petrol);font-weight:600;font-size:.98rem;margin-bottom:4px}
.detail-hero h1{font-family:var(--font-display);font-weight:800;font-size:clamp(1.7rem,3.6vw,2.5rem);line-height:1.1;letter-spacing:-.02em;color:var(--ink)}
.detail-hero .quick{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px}
.detail-hero .quick span{display:inline-flex;align-items:center;gap:7px;font-size:.92rem;color:var(--body)}
.detail-hero .quick svg{width:17px;height:17px;color:var(--petrol)}

.detail{display:grid;grid-template-columns:1fr 340px;gap:44px;padding:46px 0 80px}
@media(max-width:880px){.detail{grid-template-columns:1fr}}
.detail .body{font-size:1.04rem;color:var(--body);white-space:pre-line;line-height:1.75}
.aside{position:sticky;top:96px;align-self:start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.aside .apply{display:block;background:var(--accent);color:#fff;text-align:center;font-family:var(--font-display);font-weight:700;padding:16px;border-radius:11px;transition:all .15s;margin-bottom:22px}
.aside .apply:hover{background:var(--accent-dark);transform:translateY(-1px)}
.aside .row{display:flex;flex-direction:column;gap:3px;padding:13px 0;border-bottom:1px solid var(--line)}
.aside .row:last-child{border-bottom:none}
.aside .row .k{font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}
.aside .row .v{font-weight:600;color:var(--ink)}
.aside .row .v a{color:var(--petrol)}

/* ---------- Prose / About / Post ---------- */
.prose{max-width:760px;padding:60px 0 80px}
.prose h1{font-family:var(--font-display);font-weight:800;font-size:2.6rem;letter-spacing:-.02em;color:var(--ink);margin-bottom:20px}
.prose .kicker{color:var(--petrol);font-weight:700;font-size:.86rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.prose p{font-size:1.1rem;color:var(--body);margin-bottom:16px}
.btn-primary{display:inline-block;background:var(--petrol);color:#fff;font-family:var(--font-display);font-weight:700;padding:14px 30px;border-radius:11px;margin-top:10px;transition:all .15s}
.btn-primary:hover{background:var(--petrol-dark);transform:translateY(-1px)}

.form-grid{display:grid;gap:16px;margin-top:24px}
.form-grid .fld{display:grid;gap:7px}
.form-grid label{font-weight:600;font-size:.9rem;color:var(--ink)}
.form-grid input,.form-grid select,.form-grid textarea{
  padding:13px 14px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:.97rem;background:#fff;color:var(--ink);
}
.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{outline:none;border-color:var(--petrol)}
.form-grid .two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.form-grid .two{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.site-foot{background:var(--petrol-deep);color:rgba(255,255,255,.78);padding:54px 0 30px;margin-top:20px}
.site-foot .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;margin-bottom:36px}
@media(max-width:680px){.site-foot .cols{grid-template-columns:1fr}}
.site-foot .brand{color:#fff;margin-bottom:14px}
.site-foot .brand small{color:var(--accent)}
.site-foot p{font-size:.92rem;line-height:1.7;max-width:34ch}
.site-foot h5{font-family:var(--font-display);color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.site-foot ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.site-foot a:hover{color:#fff}
.site-foot .bottom{border-top:1px solid rgba(255,255,255,.13);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.86rem}
.site-foot .bottom a{color:var(--accent)}

/* ---------- Admin (Petrol-Akzent) ---------- */
.admin-body{background:var(--paper-2);color:var(--ink);font-family:var(--font-body)}
.admin-head{background:var(--petrol-deep);color:#fff;padding:16px 0}
.admin-head .wrap{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.admin-head .brand{color:#fff}
.admin-wrap{max-width:960px;margin:32px auto;padding:0 24px}
.admin-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;margin-bottom:20px;box-shadow:var(--shadow)}
.admin-card h2{font-family:var(--font-display);margin-bottom:18px;color:var(--ink)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.86rem;margin-bottom:6px;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;padding:12px 13px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--petrol)}
.field textarea{min-height:120px;resize:vertical}
.field.half{display:inline-block;width:calc(50% - 8px)}
.field.half:nth-child(odd){margin-right:14px}
.btn{background:var(--petrol);color:#fff;border:none;padding:12px 24px;border-radius:10px;font-family:var(--font-display);font-weight:700;cursor:pointer;transition:all .15s;text-decoration:none;display:inline-block}
.btn:hover{background:var(--petrol-dark)}
.btn.alt{background:#fff;color:var(--petrol);border:1.5px solid var(--line)}
.btn.alt:hover{border-color:var(--petrol);background:var(--petrol-tint)}
.btn.danger{background:var(--accent)}
.btn.danger:hover{background:var(--accent-dark)}
.tbl{width:100%;border-collapse:collapse}
.tbl th,.tbl td{text-align:left;padding:13px 11px;border-bottom:1px solid var(--line);font-size:.93rem}
.tbl th{font-family:var(--font-display);text-transform:uppercase;font-size:.76rem;color:var(--muted);letter-spacing:.04em}
.pill{font-size:.74rem;padding:4px 11px;border-radius:50px;font-weight:600}
.pill.published{background:#dcf3ee;color:#0a7d5e}
.pill.draft{background:#fdf0d6;color:#9a6b00}
.pill.closed{background:#eceff0;color:var(--muted)}
.flash{padding:14px 16px;border-radius:11px;margin-bottom:18px;font-weight:600}
.flash.ok{background:#dcf3ee;color:#0a7d5e}
.flash.err{background:#fde4dc;color:#c23b1a}
.login-box{max-width:400px;margin:80px auto;background:#fff;padding:40px;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.login-box .mark{width:48px;height:48px;border-radius:13px;background:linear-gradient(135deg,var(--petrol),var(--petrol-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-weight:900;font-size:1.3rem;margin-bottom:18px}
.admin-stat{display:flex;gap:44px;flex-wrap:wrap}
.admin-stat .s b{font-size:2.1rem;font-family:var(--font-display);font-weight:800;color:var(--petrol);display:block;line-height:1}
.admin-stat .s span{color:var(--muted);font-size:.88rem}

@media(max-width:600px){
  .nav a:not(.cta):not(.langsw a){display:none}
  .field.half{width:100%;margin-right:0}
  .steps{grid-template-columns:1fr}
}

/* ---------- Talent-Pool: Visa-Badge auf Karten ---------- */
.visa-badge{
  position:absolute;top:14px;right:14px;background:rgba(255,255,255,.92);color:var(--petrol-dark);
  font-size:.68rem;font-weight:700;letter-spacing:.02em;padding:5px 11px;border-radius:50px;z-index:2;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.hero-talent{background:linear-gradient(160deg,#0a5d69 0%,#0f7d8c 55%,#13868f 100%)}

/* ---------- Chip-Mehrfachauswahl (Checkboxen) ---------- */
.chip-group{display:flex;flex-wrap:wrap;gap:9px}
.chip{position:relative;cursor:pointer;user-select:none}
.chip input{position:absolute;opacity:0;width:0;height:0}
.chip span{
  display:inline-block;padding:9px 16px;border-radius:50px;font-size:.92rem;font-weight:500;
  background:#fff;border:1.5px solid var(--line);color:var(--body);transition:all .15s;
}
.chip:hover span{border-color:var(--petrol);color:var(--petrol)}
.chip input:checked + span{background:var(--petrol);border-color:var(--petrol);color:#fff;font-weight:600}
.chip input:focus-visible + span{outline:2px solid var(--petrol);outline-offset:2px}

/* ---------- Radio-Cards (Visum, Pflicht-Einzelauswahl) ---------- */
.radio-group{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:560px){.radio-group{grid-template-columns:1fr}}
.radio-card{position:relative;cursor:pointer}
.radio-card input{position:absolute;opacity:0;width:0;height:0}
.radio-card span{
  display:flex;align-items:center;gap:10px;padding:15px 16px;border-radius:11px;font-weight:600;font-size:.96rem;
  background:#fff;border:1.5px solid var(--line);color:var(--ink);transition:all .15s;
}
.radio-card span::before{
  content:"";width:18px;height:18px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;transition:all .15s;
}
.radio-card:hover span{border-color:var(--petrol)}
.radio-card input:checked + span{border-color:var(--petrol);background:var(--petrol-tint)}
.radio-card input:checked + span::before{border-color:var(--petrol);background:radial-gradient(circle,var(--petrol) 0 5px,#fff 6px)}
.radio-card input:focus-visible + span{outline:2px solid var(--petrol);outline-offset:2px}

/* ---------- Sekundärer Ghost-CTA (Jobs suchen) ---------- */
.nav a.cta-ghost{
  background:#fff;color:var(--petrol);border:1.5px solid var(--petrol);
  box-shadow:none;
}
.nav a.cta-ghost:hover{background:var(--petrol-tint);color:var(--petrol-dark);transform:translateY(-1px)}
/* Auf Mobile beide CTAs sichtbar lassen */
@media(max-width:600px){
  .nav a.cta,.nav a.cta-ghost{display:inline-block}
}

/* ---------- Talent-CTA-Band (Startseite) ---------- */
.seek-band{
  display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;
  background:linear-gradient(135deg,var(--petrol-deep),var(--petrol));color:#fff;
  border-radius:var(--radius);padding:34px 38px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.seek-band::before{content:"";position:absolute;top:-60px;right:-40px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(255,122,77,.25),transparent 65%)}
.seek-band>div{position:relative;z-index:2;max-width:62ch}
.seek-band h3{font-family:var(--font-display);font-weight:800;font-size:1.5rem;letter-spacing:-.01em;margin-bottom:6px}
.seek-band p{color:rgba(255,255,255,.85);font-size:1.02rem}
.seek-band-cta{
  position:relative;z-index:2;background:var(--accent);color:#fff;font-family:var(--font-display);font-weight:700;
  padding:15px 28px;border-radius:11px;white-space:nowrap;transition:all .15s;flex-shrink:0;
}
.seek-band-cta:hover{background:var(--accent-dark);transform:translateY(-1px)}

/* ---------- Kontaktdaten-Gate ---------- */
.apply.apply-locked{
  background:var(--petrol-tint);color:var(--petrol-dark);border:1.5px dashed var(--petrol);
  font-size:.92rem;line-height:1.4;
}
.apply.apply-locked:hover{background:var(--petrol-light);transform:none}
.locked-note{color:var(--muted);font-style:italic;font-weight:500;font-size:.9rem}

/* ---------- Bewerberkarten: großes Foto in der Übersicht ---------- */
.applicant-card .cover{height:200px;padding:0;align-items:stretch}
.applicant-card .logo{
  width:100%;height:100%;border-radius:0;border:none;box-shadow:none;background:transparent;
  font-size:3.4rem;color:#fff;
}
.applicant-card .logo img{width:100%;height:100%;object-fit:cover}
/* Platzhalter-Initiale ohne Foto: zentriert auf Cover-Verlauf */
.applicant-card .cover:has(.logo:not(:has(img))){align-items:center;justify-content:center}

/* ---------- Profil: größeres Foto im Detail-Hero ---------- */
.detail-hero .logo{width:104px;height:104px;border-radius:18px;font-size:2.4rem}
@media(max-width:560px){
  .detail-hero .logo{width:84px;height:84px}
  .applicant-card .cover{height:170px}
}

/* ---------- CV-Download-Button ---------- */
.apply.apply-cv{
  background:#fff;color:var(--petrol);border:1.5px solid var(--petrol);margin-top:-8px;
}
.apply.apply-cv:hover{background:var(--petrol-tint);color:var(--petrol-dark)}
