/* =========================================================
   HARZJOBS – Design-System
   Adaptiert vom optimierten Harzspots-Layout, Akzentfarbe Blau.
   Eine zentrale CSS-Datei für alle Seitentypen.
   ========================================================= */

:root{
  /* Markenfarben (am Logo orientiert, etwas wärmer/dezenter als Default-Blau) */
  --blue:#2b5fc4;
  --blue-deep:#214a9e;
  --blue-dark:#17357a;
  --blue-soft:#e9f0fb;
  --blue-tint:#f3f6fc;

  /* Neutrale Töne */
  --ink:#1c1f26;
  --ink-2:#444b57;
  --ink-3:#717784;
  --paper:#f5f6f8;
  --card:#ffffff;
  --line:#e6e8ec;

  /* Dunkle Flächen (Header/Footer) – neutral, ohne Blaustich */
  --dark:#191a1e;
  --dark-line:rgba(255,255,255,.09);

  /* Akzente */
  --amber:#e8821e;
  --gold:#f5b301;
  --green:#16a34a;
  --red:#e23b3b;

  --radius:18px;
  --radius-sm:13px;
  --shadow-sm:0 1px 2px rgba(17,24,39,.06), 0 2px 8px rgba(17,24,39,.05);
  --shadow-md:0 8px 30px rgba(17,24,39,.10);
  --shadow-lg:0 18px 50px rgba(17,24,39,.16);
  --maxw:1240px;
  --font-display:'Bricolage Grotesque', sans-serif;
  --font-body:'Hanken Grotesk', sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---------- BUTTONS ---------- */
.btn-primary{background:var(--blue);color:#fff;border:none;font-family:var(--font-body);font-weight:700;font-size:16px;padding:14px 28px;border-radius:var(--radius-sm);cursor:pointer;transition:.15s;box-shadow:0 4px 14px rgba(43,95,196,.28);display:inline-flex;align-items:center;gap:9px}
.btn-primary:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn-ghost{background:var(--card);color:var(--ink);border:1px solid var(--line);font-family:var(--font-body);font-weight:700;font-size:15px;padding:13px 24px;border-radius:var(--radius-sm);cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:8px}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue-deep)}
.btn-white{background:#fff;color:var(--blue-deep);border:none;font-family:var(--font-body);font-weight:700;font-size:16px;padding:14px 26px;border-radius:var(--radius-sm);cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:9px}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* ---------- HEADER ---------- */
header.site{
  position:sticky;top:0;z-index:60;
  background:rgba(25,26,30,.97);
  backdrop-filter:saturate(120%) blur(10px);
  color:#fff;border-bottom:1px solid var(--dark-line);
}
.nav{position:relative;display:flex;align-items:center;gap:28px;height:68px}
.logo{font-family:var(--font-display);font-weight:800;font-size:25px;letter-spacing:-.5px;display:flex;align-items:center;gap:2px;color:#fff}
.logo .jobs{color:var(--blue);}
.logo .dot{width:9px;height:9px;border-radius:50%;background:var(--blue);display:inline-block;margin-left:3px}
/* Navigation füllt den Raum zwischen Logo und Tools und zentriert sich darin */
nav.main{flex:1;display:flex;justify-content:center;align-items:center;gap:26px;font-weight:500;font-size:15px}
nav.main a{color:rgba(255,255,255,.82);transition:color .15s;position:relative;padding:4px 0}
nav.main a:hover{color:#fff}
nav.main a.active{color:#fff}
nav.main a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--blue);border-radius:2px}
.nav .tools{margin-left:auto;display:flex;gap:12px;align-items:center}
.icon-btn{height:38px;min-width:38px;padding:0 10px;border-radius:11px;display:inline-grid;place-items:center;color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);cursor:pointer;transition:.15s;font-family:var(--font-body);font-weight:600;font-size:14px}
.icon-btn:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-post{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:700;padding:0 16px}
.btn-post:hover{background:var(--blue-deep);border-color:var(--blue-deep);color:#fff}
.burger{display:none}

/* language dropdown */
.lang-wrap{position:relative}
.lang-menu{position:absolute;right:0;top:46px;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow-md);padding:6px;min-width:170px;display:none;flex-direction:column;gap:2px;z-index:80}
.lang-menu.open{display:flex}
.lang-menu a{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:9px;font-size:14px;font-weight:600;color:var(--ink-2)}
.lang-menu a:hover{background:var(--blue-soft);color:var(--blue-deep)}
.lang-menu a .flag{font-size:16px}

/* mobile nav drawer */
.mobile-nav{display:none;position:fixed;inset:68px 0 0;background:rgba(25,26,30,.99);z-index:55;padding:24px;flex-direction:column;gap:4px}
.mobile-nav.open{display:flex}
.mobile-nav a{color:#fff;font-size:19px;font-weight:600;padding:14px 6px;border-bottom:1px solid rgba(255,255,255,.08)}
@media(max-width:980px){
  nav.main{display:none}
  .burger{display:inline-grid}
  .hide-mobile{display:none}
}

/* ---------- HERO (Kategorie / Job / Unternehmen) ---------- */
.hero{position:relative;min-height:360px;overflow:hidden;display:flex;align-items:flex-end}
.hero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,21,26,.5) 0%,rgba(20,21,26,.42) 35%,rgba(20,21,26,.9) 100%)}
.hero-content{position:relative;z-index:2;width:100%}
.hero-content .wrap{padding-bottom:32px;padding-top:40px}
.breadcrumb{color:rgba(255,255,255,.85);font-size:14px;font-weight:500;display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.breadcrumb a:hover{color:#fff;text-decoration:underline}
.breadcrumb .sep{opacity:.6}
.hero h1{font-family:var(--font-display);color:#fff;font-size:clamp(30px,5vw,52px);line-height:1.03;font-weight:800;letter-spacing:-1px;text-shadow:0 2px 24px rgba(0,0,0,.3);max-width:880px}
.hero .lead{color:rgba(255,255,255,.92);font-size:18px;font-weight:500;margin-top:12px;max-width:680px}
.hero-stats{display:flex;gap:26px;margin-top:20px;flex-wrap:wrap}
.hero-stats .stat{color:#fff}
.hero-stats .stat b{font-family:var(--font-display);font-size:24px;font-weight:800;display:block;line-height:1}
.hero-stats .stat span{font-size:13.5px;color:rgba(255,255,255,.8);font-weight:500}
@media(max-width:640px){.hero{min-height:300px}}

/* ---------- HOME HERO (Startseite mit Suchmaske) ---------- */
.home-hero{position:relative;overflow:hidden;color:#fff;background:var(--ink)}
.home-hero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.55}
.home-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,21,26,.66),rgba(20,34,72,.84))}
.home-hero .wrap{position:relative;z-index:2;padding-top:64px;padding-bottom:72px;text-align:center}
.home-hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;font-weight:600;font-size:13.5px;padding:7px 15px;border-radius:99px;margin-bottom:20px}
.home-hero h1{font-family:var(--font-display);font-size:clamp(34px,6vw,62px);font-weight:800;letter-spacing:-1.5px;line-height:1.02;max-width:920px;margin:0 auto;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.home-hero h1 .accent{color:#fff}
.home-hero .lead{font-size:19px;color:rgba(255,255,255,.92);max-width:620px;margin:16px auto 0;font-weight:500}

/* Suchmaske */
.searchmask{background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);max-width:980px;margin:34px auto 0;padding:14px;display:flex;gap:10px;align-items:stretch}
.searchmask .sm-field{flex:1;position:relative;display:flex;align-items:center}
.searchmask .sm-field svg{position:absolute;left:16px;color:var(--ink-3);pointer-events:none}
.searchmask .sm-field input,.searchmask .sm-field select{width:100%;height:58px;border:none;border-radius:13px;background:var(--paper);padding:0 16px 0 46px;font-family:var(--font-body);font-size:16px;color:var(--ink);font-weight:500;appearance:none;cursor:pointer}
.searchmask .sm-field input{cursor:text}
.searchmask .sm-field input:focus,.searchmask .sm-field select:focus{outline:2px solid var(--blue);background:#fff}
.searchmask .sm-field.with-sep::after{content:"";position:absolute;right:0;top:12px;bottom:12px;width:1px;background:var(--line)}
.searchmask .btn-primary{height:58px;padding:0 30px;font-size:17px}
@media(max-width:760px){
  .searchmask{flex-direction:column;padding:12px}
  .searchmask .sm-field.with-sep::after{display:none}
  .searchmask .btn-primary{justify-content:center}
}
.home-hero .quicklinks{margin-top:22px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.home-hero .quicklinks span{color:rgba(255,255,255,.75);font-size:14px;font-weight:600;align-self:center}
.home-hero .quicklinks a{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:14px;font-weight:600;padding:7px 14px;border-radius:99px;transition:.15s}
.home-hero .quicklinks a:hover{background:#fff;color:var(--blue-deep)}

/* ---------- TRUST / LOGOS ---------- */
.trust{background:var(--card);border-bottom:1px solid var(--line);padding:22px 0}
.trust .wrap{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center}
.trust .tlabel{font-size:13.5px;font-weight:600;color:var(--ink-3)}
.trust .tlogos{display:flex;gap:30px;flex-wrap:wrap;align-items:center}
.trust .tlogos span{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--ink-3);opacity:.7}
.trust .marquee{margin-top:30px}

/* ---------- SECTION HEADERS ---------- */
.section{padding:54px 0}
.section.tint{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px;flex-wrap:wrap}
.section-head h2{font-family:var(--font-display);font-size:clamp(24px,3.4vw,34px);font-weight:800;letter-spacing:-.6px;line-height:1.08}
.section-head p{color:var(--ink-3);font-size:16px;margin-top:6px;max-width:620px}
.section-head .link-more{font-weight:700;color:var(--blue-deep);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.section-head .link-more svg{transition:transform .15s}
.section-head .link-more:hover svg{transform:translateX(3px)}

/* ---------- FILTER BAR ---------- */
.filterbar{position:sticky;top:68px;z-index:50;background:var(--paper);border-bottom:1px solid var(--line);padding:16px 0}
.filter-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.search-field{flex:1;min-width:200px;position:relative}
.search-field input{width:100%;height:46px;border:1px solid var(--line);border-radius:13px;padding:0 16px 0 44px;font-family:var(--font-body);font-size:15px;background:var(--card);color:var(--ink);transition:.15s}
.search-field input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,95,196,.14)}
.search-field .si{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--ink-3)}
.selectbox{position:relative}
select.f{height:46px;border:1px solid var(--line);border-radius:13px;padding:0 38px 0 16px;font-family:var(--font-body);font-size:15px;background:var(--card);color:var(--ink);cursor:pointer;appearance:none;font-weight:500;transition:.15s}
select.f:hover{border-color:var(--blue)}
select.f:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,95,196,.14)}
.selectbox::after{content:"";position:absolute;right:15px;top:50%;width:8px;height:8px;border-right:2px solid var(--ink-3);border-bottom:2px solid var(--ink-3);transform:translateY(-70%) rotate(45deg);pointer-events:none}
.view-toggle{display:flex;border:1px solid var(--line);border-radius:13px;overflow:hidden;background:var(--card);height:46px}
.view-toggle button{border:none;background:none;padding:0 14px;font-family:var(--font-body);font-weight:600;font-size:14px;color:var(--ink-3);cursor:pointer;display:flex;align-items:center;gap:7px}
.view-toggle button.on{background:var(--blue);color:#fff}

.chip-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:12px;min-height:8px}
.feature-chip{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 15px;border:1px solid var(--line);border-radius:99px;background:var(--card);font-size:14px;font-weight:600;color:var(--ink-2);cursor:pointer;transition:.15s;user-select:none}
.feature-chip:hover{border-color:var(--blue);color:var(--blue-deep)}
.feature-chip.on{background:var(--blue);border-color:var(--blue);color:#fff}
.feature-chip svg{width:16px;height:16px}
.chip-divider{width:1px;height:24px;background:var(--line);margin:0 4px}

.active-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:14px}
.result-count{font-weight:700;font-size:15px;color:var(--ink)}
.result-count b{color:var(--blue-deep)}
.active-chip{display:inline-flex;align-items:center;gap:6px;background:var(--blue-soft);color:var(--blue-deep);border:1px solid #cfe0fd;padding:5px 8px 5px 12px;border-radius:99px;font-size:13px;font-weight:600}
.active-chip button{border:none;background:rgba(29,78,216,.14);color:var(--blue-deep);width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:13px;line-height:1;display:grid;place-items:center}
.active-chip button:hover{background:rgba(29,78,216,.28)}
.clear-all{font-size:13px;font-weight:600;color:var(--ink-3);cursor:pointer;border:none;background:none;text-decoration:underline}
.clear-all:hover{color:var(--ink)}

/* ---------- GRID ---------- */
main{display:block}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid{grid-template-columns:1fr}}

/* =========================================================
   JOB-KARTE (ohne Bild – Fokus auf Titel + Key Facts)
   ========================================================= */
.job-list{display:flex;flex-direction:column;gap:14px}
.job-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 22px;display:flex;gap:18px;transition:transform .18s,box-shadow .18s,border-color .18s;cursor:pointer;position:relative}
.job-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#cfe0fd}
.job-card.featured{border-color:#cfe0fd;background:linear-gradient(180deg,var(--blue-tint),#fff 60%)}
.job-logo{width:64px;height:64px;min-width:64px;border-radius:14px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;overflow:hidden;font-family:var(--font-display);font-weight:800;font-size:22px;color:var(--blue-deep)}
.job-logo img{width:100%;height:100%;object-fit:contain;padding:6px}
.job-main{flex:1;min-width:0}
.job-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-right:42px}
.job-card h3{font-family:var(--font-display);font-size:19px;font-weight:700;line-height:1.18;letter-spacing:-.3px;margin-bottom:3px}
.job-card .company{font-size:14.5px;font-weight:600;color:var(--ink-2)}
.job-card .company a:hover{color:var(--blue-deep);text-decoration:underline}
.job-badges{display:flex;gap:6px;flex-wrap:wrap}
.badge{font-size:11px;font-weight:700;letter-spacing:.3px;padding:4px 9px;border-radius:8px;text-transform:uppercase;white-space:nowrap}
.badge.premium{background:linear-gradient(135deg,#f5b301,#e8821e);color:#fff}
.badge.new{background:var(--blue);color:#fff}
.badge.soft{background:var(--blue-soft);color:var(--blue-deep)}
.badge.green{background:#e7f6ec;color:var(--green)}
.job-facts{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.fact{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;color:var(--ink-2);background:var(--paper);border:1px solid var(--line);padding:5px 11px;border-radius:9px}
.fact svg{width:15px;height:15px;color:var(--blue-deep)}
.job-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;flex-wrap:wrap}
.job-foot .salary{font-family:var(--font-display);font-weight:800;font-size:17px;color:var(--ink)}
.job-foot .salary small{font-weight:500;font-size:12.5px;color:var(--ink-3);font-family:var(--font-body)}
.job-foot .posted{font-size:13px;color:var(--ink-3);font-weight:500}
.job-cta{font-weight:700;font-size:14px;color:var(--blue-deep);display:inline-flex;align-items:center;gap:5px}
.job-cta svg{width:15px;height:15px;transition:transform .15s}
.job-card:hover .job-cta svg{transform:translateX(3px)}
.fav-btn{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;background:var(--paper);border:1px solid var(--line);display:grid;place-items:center;cursor:pointer;color:var(--ink-3);transition:.15s}
.fav-btn:hover{color:var(--red);border-color:#f3c2c2}
.fav-btn.on{color:var(--red)}
.fav-btn.on svg{fill:var(--red)}
@media(max-width:560px){.job-logo{width:50px;height:50px;min-width:50px;font-size:18px}.job-card{padding:18px}}

/* =========================================================
   UNTERNEHMENS-KARTE (mit Bild – wie Harzspots)
   ========================================================= */
.company-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;cursor:pointer}
.company-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.company-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:linear-gradient(135deg,#c7d8f7,#9bb6e8)}
.company-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.company-card:hover .company-media img{transform:scale(1.05)}
.company-media .clogo{position:absolute;left:16px;bottom:-26px;width:62px;height:62px;border-radius:14px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);display:grid;place-items:center;overflow:hidden;font-family:var(--font-display);font-weight:800;color:var(--blue-deep);font-size:20px}
.company-media .clogo img{width:100%;height:100%;object-fit:contain;padding:7px}
.company-media .badges{position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap}
.company-body{padding:34px 18px 18px;display:flex;flex-direction:column;flex:1}
.company-body h3{font-family:var(--font-display);font-size:19px;font-weight:700;line-height:1.15;letter-spacing:-.3px;margin-bottom:3px}
.company-body .claim{color:var(--ink-3);font-size:14px;font-weight:500;margin-bottom:12px}
.company-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.company-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:14px;border-top:1px solid var(--line)}
.kununu{display:flex;align-items:center;gap:8px}
.kununu .score{background:#16a34a;color:#fff;font-weight:700;font-size:14px;padding:3px 8px;border-radius:8px}
.kununu .ktxt{font-size:12.5px;font-weight:600;color:var(--ink-2)}
.kununu .ktxt small{display:block;color:var(--ink-3);font-weight:500;font-size:11.5px}
.openjobs{font-weight:700;font-size:13.5px;color:var(--blue-deep)}

/* ---------- CATEGORY CARDS (Startseite) ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:980px){.cat-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
.cat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;transition:.18s;cursor:pointer;display:flex;flex-direction:column;gap:10px}
.cat-card:hover{border-color:var(--blue);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.cat-icon{width:46px;height:46px;border-radius:12px;background:var(--blue-soft);color:var(--blue-deep);display:grid;place-items:center}
.cat-icon svg{width:24px;height:24px}
.cat-card h3{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:-.3px}
.cat-card .cat-count{font-size:13px;color:var(--ink-3);font-weight:600;margin-top:auto}
.cat-card .cat-count b{color:var(--blue-deep)}

/* big category block (Startseite – Hauptkategorien mit interner Verlinkung) */
.catblock{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:820px){.catblock{grid-template-columns:1fr}}
.catblock-item{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.catblock-item .cb-media{height:160px;position:relative;overflow:hidden;background:#c7d8f7}
.catblock-item .cb-media img{width:100%;height:100%;object-fit:cover}
.catblock-item .cb-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(17,24,39,.7))}
.catblock-item .cb-media h3{position:absolute;left:18px;bottom:14px;color:#fff;font-family:var(--font-display);font-size:22px;font-weight:800;z-index:2;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.catblock-item .cb-body{padding:18px 20px 20px}
.catblock-item .cb-body p{color:var(--ink-2);font-size:15px;margin-bottom:12px}
.catblock-item .cb-links{display:flex;gap:8px;flex-wrap:wrap}
.catblock-item .cb-links a{font-size:13.5px;font-weight:600;color:var(--blue-deep);background:var(--blue-soft);padding:6px 12px;border-radius:99px;transition:.15s}
.catblock-item .cb-links a:hover{background:var(--blue);color:#fff}

/* ---------- STEPS (für Arbeitgeber) ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:780px){.steps{grid-template-columns:1fr}}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.step .num{width:40px;height:40px;border-radius:12px;background:var(--blue);color:#fff;font-family:var(--font-display);font-weight:800;font-size:18px;display:grid;place-items:center;margin-bottom:14px}
.step h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin-bottom:6px}
.step p{color:var(--ink-2);font-size:14.5px}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--blue-dark),var(--blue));color:#fff;border-radius:24px;padding:46px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cta-band h2{font-family:var(--font-display);font-size:clamp(24px,3vw,32px);font-weight:800;letter-spacing:-.6px}
.cta-band p{color:rgba(255,255,255,.9);font-size:16px;margin-top:6px;max-width:520px}

/* =========================================================
   DETAILSEITEN (Job / Unternehmen / Blog)
   ========================================================= */
.detail-wrap{display:grid;grid-template-columns:1fr 340px;gap:34px;padding:38px 0}
@media(max-width:920px){.detail-wrap{grid-template-columns:1fr}}
.prose h2{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:-.5px;margin:30px 0 12px}
.prose h3{font-family:var(--font-display);font-size:20px;font-weight:700;margin:24px 0 10px}
.prose p{color:var(--ink-2);font-size:16px;margin-bottom:14px}
.prose ul{margin:0 0 16px 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:9px}
.prose ul li{position:relative;padding-left:30px;color:var(--ink-2);font-size:16px}
.prose ul li::before{content:"";position:absolute;left:0;top:3px;width:20px;height:20px;border-radius:50%;background:var(--blue-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231d4ed8' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.prose a{color:var(--blue-deep);font-weight:600;text-decoration:underline}

/* Key facts panel */
.factgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:8px 0 6px}
@media(max-width:560px){.factgrid{grid-template-columns:1fr}}
.factgrid .fg{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:13px 15px;display:flex;gap:11px;align-items:center}
.factgrid .fg .ic{width:38px;height:38px;border-radius:10px;background:var(--blue-soft);color:var(--blue-deep);display:grid;place-items:center;min-width:38px}
.factgrid .fg .ic svg{width:19px;height:19px}
.factgrid .fg .lbl{font-size:12px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.factgrid .fg .val{font-size:15px;font-weight:700;color:var(--ink)}

/* sticky apply card */
.aside-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px;position:sticky;top:90px}
.aside-card h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin-bottom:14px}
.aside-card .apply-row{display:flex;gap:10px;margin-bottom:14px}
.aside-card .full{width:100%;justify-content:center}
.aside-card .comp-mini{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:14px}
.aside-card .comp-mini .clogo{width:48px;height:48px;border-radius:11px;border:1px solid var(--line);display:grid;place-items:center;font-family:var(--font-display);font-weight:800;color:var(--blue-deep);overflow:hidden}
.aside-card .comp-mini .clogo img{width:100%;height:100%;object-fit:contain;padding:5px}
.aside-card .comp-mini b{font-size:15px;display:block}
.aside-card .comp-mini a{font-size:13px;color:var(--blue-deep);font-weight:600}
.aside-card .small-meta{font-size:13px;color:var(--ink-3);display:flex;flex-direction:column;gap:7px}
.aside-card .small-meta div{display:flex;align-items:center;gap:8px}
.aside-card .small-meta svg{width:15px;height:15px;color:var(--blue-deep)}

/* benefits chips */
.benefits{display:flex;gap:10px;flex-wrap:wrap;margin:6px 0 8px}
.benefit{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-size:14.5px;font-weight:600;color:var(--ink-2)}
.benefit svg{width:18px;height:18px;color:var(--blue-deep)}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0}
@media(max-width:680px){.gallery{grid-template-columns:repeat(2,1fr)}}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:13px;border:1px solid var(--line)}

/* ---------- FAQ (Akkordeon) ---------- */
.faq{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:13px;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:16px 18px;font-family:var(--font-display);font-weight:700;font-size:16.5px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";width:11px;height:11px;border-right:2.4px solid var(--ink-3);border-bottom:2.4px solid var(--ink-3);transform:rotate(45deg);transition:transform .2s;flex-shrink:0}
.faq details[open] summary::after{transform:rotate(-135deg)}
.faq .faq-body{padding:0 18px 16px;color:var(--ink-2);font-size:15.5px}

/* ---------- SEO TEXT ---------- */
.seo{background:var(--card);border-top:1px solid var(--line);padding:56px 0}
.seo .wrap{max-width:840px}
.seo h2{font-family:var(--font-display);font-size:30px;font-weight:700;letter-spacing:-.5px;margin-bottom:6px}
.seo .sub{color:var(--blue-deep);font-weight:600;font-size:17px;margin-bottom:22px}
.seo-body{color:var(--ink-2);font-size:16px;position:relative}
.seo-body p{margin-bottom:16px}
.seo-body a{color:var(--blue-deep);font-weight:600;text-decoration:underline}
.seo-body.collapsed{max-height:230px;overflow:hidden}
.seo-body.collapsed::after{content:"";position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(180deg,transparent,var(--card))}
.seo-toggle{margin-top:8px;background:none;border:none;color:var(--blue-deep);font-family:var(--font-body);font-weight:700;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.seo-toggle svg{width:16px;height:16px;transition:transform .2s}
.seo-toggle.open svg{transform:rotate(180deg)}

/* ---------- BLOG ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:920px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
.blog-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.18s;cursor:pointer}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.blog-card .bmedia{aspect-ratio:16/9;overflow:hidden;background:#c7d8f7}
.blog-card .bmedia img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .bmedia img{transform:scale(1.05)}
.blog-card .bbody{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.blog-card .btag{font-size:12px;font-weight:700;color:var(--blue-deep);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.blog-card h3{font-family:var(--font-display);font-size:19px;font-weight:700;line-height:1.2;letter-spacing:-.3px;margin-bottom:8px}
.blog-card p{color:var(--ink-2);font-size:14.5px;margin-bottom:14px}
.blog-card .bmeta{margin-top:auto;font-size:13px;color:var(--ink-3);font-weight:500;display:flex;gap:8px;align-items:center}

/* article */
.article-hero{max-width:820px;margin:0 auto;padding:40px 24px 0}
.article-hero .atag{color:var(--blue-deep);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.6px}
.article-hero h1{font-family:var(--font-display);font-size:clamp(30px,5vw,46px);font-weight:800;letter-spacing:-1px;line-height:1.08;margin:12px 0}
.article-meta{display:flex;align-items:center;gap:12px;color:var(--ink-3);font-size:14px;font-weight:500;margin-bottom:22px}
.article-meta .avatar{position:relative;width:38px;height:38px;border-radius:50%;background:var(--blue-soft);color:var(--blue-deep);display:grid;place-items:center;font-weight:800;font-family:var(--font-display);overflow:hidden}
.article-meta .avatar img,.author-box .avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
.article-cover{max-width:1000px;margin:0 auto 10px;padding:0 24px}
.article-cover img{width:100%;aspect-ratio:16/8;object-fit:cover;border-radius:20px}
.article-body{max-width:760px;margin:0 auto;padding:28px 24px 10px}
.author-box{max-width:760px;margin:30px auto;padding:0 24px}
.author-box .inner{background:var(--blue-tint);border:1px solid #d9e6ff;border-radius:var(--radius);padding:22px;display:flex;gap:16px;align-items:center}
.author-box .avatar{position:relative;width:64px;height:64px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:800;font-family:var(--font-display);font-size:24px;min-width:64px;overflow:hidden}
.author-box h4{font-family:var(--font-display);font-size:17px;font-weight:700}
.author-box p{font-size:14px;color:var(--ink-2);margin-top:3px}

/* ---------- FOOTER ---------- */
footer.site{background:var(--dark);color:rgba(255,255,255,.7);padding:54px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:28px}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr 1fr}}
footer h4{color:#fff;font-family:var(--font-display);font-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:8px}
footer ul a{color:rgba(255,255,255,.62);font-size:14px;transition:.15s}
footer ul a:hover{color:var(--blue)}
.foot-brand .logo{font-size:23px;margin-bottom:12px}
.foot-brand p{font-size:14px;max-width:280px;line-height:1.6;margin-bottom:14px}
.foot-social{display:flex;gap:10px}
.foot-social a{width:38px;height:38px;border-radius:11px;border:1px solid rgba(255,255,255,.14);display:grid;place-items:center;color:rgba(255,255,255,.7);transition:.15s}
.foot-social a:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:38px;padding-top:20px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.foot-bottom a:hover{color:#fff}

/* ---------- DEMO NOTE ---------- */
.note{background:#fff7e6;border:1px solid #f3e0a8;color:#7a5d0a;font-size:13.5px;padding:11px 18px;border-radius:12px;margin:0 auto;max-width:var(--maxw);display:flex;gap:10px;align-items:center}
.note-wrap{padding:14px 24px 0}

/* ---------- LOAD MORE / PAGINATION ---------- */
.loadmore{text-align:center;padding:34px 0 10px}
.no-results{text-align:center;padding:60px 20px;color:var(--ink-3)}
.no-results svg{width:48px;height:48px;margin-bottom:14px;color:var(--line)}
.no-results h3{font-family:var(--font-display);color:var(--ink);font-size:22px;margin-bottom:6px}

/* utility */
.fade-in{animation:fade .4s ease both}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.mt-0{margin-top:0}
.tag-pill{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--blue-deep);background:var(--blue-soft);padding:5px 11px;border-radius:99px}

/* =========================================================
   MARKEN-LOGOS (generierte Branchen-Badges)
   ========================================================= */
.brandlogo{color:#fff !important;border:none !important}
.brandlogo svg{width:56%;height:56%}
.job-logo.brandlogo{padding:0}
.clogo.brandlogo{padding:0}

/* current language flag in header button – Flagge sauber DANEBEN, nicht darüber */
#langBtn{display:inline-flex !important;align-items:center;gap:6px}
#langBtn .cur-flag{font-size:15px;line-height:1}

/* =========================================================
   LOGO-MARQUEE (Startseite – durchlaufende Partner-Logos)
   ========================================================= */
.marquee{position:relative;overflow:hidden;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.marquee-track{display:flex;width:max-content;gap:54px;animation:marquee 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:flex;align-items:center;gap:12px;flex-shrink:0}
.marquee-item .ml{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff}
.marquee-item .ml svg{width:55%;height:55%}
.marquee-item span{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--ink-2);white-space:nowrap}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =========================================================
   DETAILSEITEN – einheitliche vertikale Abstände
   ========================================================= */
.detail-main > h2{font-family:var(--font-display);font-size:25px;font-weight:800;letter-spacing:-.5px;margin:40px 0 18px}
.detail-main > h2:first-child{margin-top:0}
.detail-main .benefits{margin:0 0 6px}
.detail-main .gallery{margin:0 0 6px}
.detail-main .job-list{margin-top:4px}

/* =========================================================
   LOGIN-SEITE
   ========================================================= */
.auth{min-height:calc(100vh - 68px);display:grid;grid-template-columns:1.05fr .95fr}
@media(max-width:860px){.auth{grid-template-columns:1fr}}
.auth-visual{position:relative;overflow:hidden;color:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:48px;background:var(--dark)}
.auth-visual>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.4;z-index:0}
.auth-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(20,34,72,.7),rgba(20,21,26,.85));z-index:1}
.auth-visual>*{position:relative;z-index:2}
.auth-visual .logo{font-size:26px}
.auth-visual h2{font-family:var(--font-display);font-size:34px;font-weight:800;letter-spacing:-.8px;line-height:1.1;max-width:420px}
.auth-visual p{color:rgba(255,255,255,.85);font-size:16px;margin-top:12px;max-width:400px}
.auth-points{display:flex;flex-direction:column;gap:12px;margin-top:22px}
.auth-points div{display:flex;align-items:center;gap:11px;font-weight:600;font-size:15px}
.auth-points .ck{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.16);display:grid;place-items:center}
.auth-points .ck svg{width:15px;height:15px}
@media(max-width:860px){.auth-visual{display:none}}

.auth-form{display:flex;align-items:center;justify-content:center;padding:48px 24px;background:var(--paper)}
.auth-card{width:100%;max-width:420px}
.auth-card h1{font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.5px}
.auth-card .sub{color:var(--ink-3);font-size:15px;margin:6px 0 22px}
.auth-tabs{display:flex;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:5px;margin-bottom:22px}
.auth-tabs button{flex:1;border:none;background:none;font-family:var(--font-body);font-weight:700;font-size:14.5px;color:var(--ink-3);padding:10px;border-radius:9px;cursor:pointer;transition:.15s}
.auth-tabs button.on{background:var(--blue);color:#fff}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;font-weight:700;color:var(--ink-2);margin-bottom:7px}
.field input{width:100%;height:50px;border:1px solid var(--line);border-radius:12px;padding:0 14px;font-family:var(--font-body);font-size:15px;background:var(--card);transition:.15s}
.field input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,95,196,.14)}
.field .pw-wrap{position:relative}
.field .pw-wrap button{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:none;color:var(--ink-3);cursor:pointer;font-size:13px;font-weight:600}
.auth-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;font-size:13.5px}
.auth-row label{display:flex;align-items:center;gap:7px;color:var(--ink-2);font-weight:600;cursor:pointer}
.auth-row a{color:var(--blue-deep);font-weight:600}
.auth-sep{display:flex;align-items:center;gap:12px;color:var(--ink-3);font-size:13px;font-weight:600;margin:18px 0}
.auth-sep::before,.auth-sep::after{content:"";flex:1;height:1px;background:var(--line)}
.social-row{display:flex;gap:10px}
.social-btn{flex:1;height:48px;border:1px solid var(--line);border-radius:12px;background:var(--card);display:flex;align-items:center;justify-content:center;gap:9px;font-weight:700;font-size:14px;color:var(--ink-2);cursor:pointer;transition:.15s}
.social-btn:hover{border-color:var(--ink-3)}
.auth-bottom{text-align:center;margin-top:22px;font-size:14px;color:var(--ink-3)}
.auth-bottom a{color:var(--blue-deep);font-weight:700}

/* =========================================================
   KONTAKTFORMULAR (überarbeitet)
   ========================================================= */
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:28px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.contact-grid{grid-template-columns:1fr}}
.contact-card .field textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:13px 14px;font-family:var(--font-body);font-size:15px;background:var(--card);resize:vertical;min-height:140px;transition:.15s}
.contact-card .field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,95,196,.14)}
.contact-info{display:flex;flex-direction:column;gap:16px}
.contact-info .ci{display:flex;gap:14px;align-items:flex-start}
.contact-info .ci .ic{width:44px;height:44px;min-width:44px;border-radius:12px;background:var(--blue-soft);color:var(--blue-deep);display:grid;place-items:center}
.contact-info .ci .ic svg{width:20px;height:20px}
.contact-info .ci .lbl{font-size:13px;color:var(--ink-3);font-weight:600}
.contact-info .ci .val{font-size:15.5px;font-weight:700;color:var(--ink)}
