/* Вакансии Рядом — Clean SaaS HR theme: white + soft blue, mobile-first. */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
  font-size:16px;line-height:1.55;color:#0f172a;background:#ffffff;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
img,svg{max-width:100%;display:block}
a{color:#2563eb;text-decoration:none;transition:color .15s ease}
a:hover{color:#1d4ed8}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
ul{list-style:none}

:root{
  --bg:#ffffff;
  --surface:#f8fafc;
  --surface-2:#f1f5f9;
  --tint:#eff6ff;
  --line:#e2e8f0;
  --text:#0f172a;
  --muted:#475569;
  --muted-2:#64748b;
  --blue-50:#eff6ff;
  --blue-500:#3b82f6;
  --blue-600:#2563eb;
  --blue-700:#1d4ed8;
  --shadow-sm:0 1px 2px rgba(15,23,42,.04);
  --shadow:0 4px 12px rgba(15,23,42,.06);
  --shadow-lg:0 12px 32px rgba(15,23,42,.08);
  --radius:14px;
  --radius-lg:20px;
  --grad:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);
}

.wrap{max-width:1180px;margin:0 auto;padding:0 20px}

/* ---------- Header ---------- */
.hdr{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line)}
.hdr__wrap{display:flex;align-items:center;gap:24px;padding:14px 20px;min-height:64px}
.brand{display:inline-flex;align-items:center;gap:10px;color:#0f172a;font-weight:700;font-size:18px;letter-spacing:-.01em}
.brand__mark{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:var(--grad);color:#fff;box-shadow:var(--shadow)}
.brand__name{font-weight:700}
.brand--ft{color:#0f172a}
.nav{display:none;gap:24px;margin-left:24px}
.nav a{color:#475569;font-size:14.5px;font-weight:500;padding:8px 0}
.nav a:hover{color:#0f172a}
.hdr__cta{margin-left:auto;display:none}
.hdr__burger{display:inline-flex;flex-direction:column;gap:4px;margin-left:auto;width:40px;height:40px;align-items:center;justify-content:center;border-radius:10px}
.hdr__burger span{display:block;width:18px;height:2px;background:#0f172a;border-radius:2px;transition:transform .2s}
.mobnav{display:flex;flex-direction:column;gap:6px;padding:12px 20px 18px;border-bottom:1px solid var(--line);background:#fff}
.mobnav a{color:#0f172a;padding:10px 4px;border-radius:8px;font-size:15px}
.mobnav a:hover{background:var(--surface)}
.mobnav .btn{margin-top:8px;text-align:center}

@media (min-width:840px){
  .nav{display:inline-flex}
  .hdr__cta{display:inline-flex}
  .hdr__burger{display:none}
  .mobnav{display:none !important}
}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:12px;font-weight:600;font-size:14.5px;letter-spacing:-.01em;line-height:1;transition:transform .12s ease, box-shadow .15s ease, background .15s ease, color .15s ease;cursor:pointer;text-align:center;white-space:nowrap;border:1px solid transparent}
.btn--primary{background:var(--grad);color:#fff;box-shadow:0 6px 16px rgba(37,99,235,.25)}
.btn--primary:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(37,99,235,.35);color:#fff}
.btn--ghost{background:#fff;color:#0f172a;border-color:var(--line)}
.btn--ghost:hover{background:var(--tint);border-color:#bfdbfe;color:#1d4ed8}
.btn--block{display:flex;width:100%}

/* ---------- Hero ---------- */
.hero{padding:48px 0 60px;background:linear-gradient(180deg,#f8fbff 0%,#ffffff 60%)}
.hero__grid{display:grid;gap:32px;grid-template-columns:1fr}
@media (min-width:960px){.hero__grid{grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding:24px 20px}}
.hero h1{font-size:clamp(32px,4.5vw,48px);line-height:1.08;letter-spacing:-.02em;font-weight:700;color:#0f172a}
.hero .lead{margin-top:14px;font-size:clamp(16px,1.6vw,18px);color:var(--muted);max-width:600px}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.badges li{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border:1px solid var(--line);border-radius:999px;font-size:14px;color:#1e293b;box-shadow:var(--shadow-sm)}
.badges .dot{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--blue-50);color:var(--blue-600);font-size:11px;font-weight:700}

.hero__card{padding:24px;border-radius:var(--radius-lg);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-lg)}
.card__h{font-size:18px;font-weight:700;letter-spacing:-.01em;margin-bottom:16px}
.form{display:flex;flex-direction:column;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field>span{font-size:13px;font-weight:500;color:var(--muted)}
.field select,.field input,.field textarea{
  appearance:none;-webkit-appearance:none;
  border:1px solid var(--line);border-radius:10px;padding:11px 14px;font:inherit;background:#fff;color:#0f172a;
  transition:border-color .15s, box-shadow .15s;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;
}
.field input,.field textarea{background-image:none;padding-right:14px}
.field select:focus,.field input:focus,.field textarea:focus{outline:0;border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.15)}

/* ---------- Sections ---------- */
.sec{padding:64px 0}
.sec--soft{background:var(--surface)}
.sec__head{margin:0 auto 36px;max-width:720px;text-align:center}
.sec__head h2{font-size:clamp(24px,2.8vw,32px);font-weight:700;letter-spacing:-.02em;color:#0f172a}
.sec__head p{margin-top:10px;color:var(--muted)}

/* Vacancies */
.vacgrid{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.vac{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:12px;transition:transform .15s, box-shadow .2s, border-color .15s;box-shadow:var(--shadow-sm)}
.vac:hover{transform:translateY(-2px);border-color:#bfdbfe;box-shadow:var(--shadow-lg)}
.vac__top{display:flex;justify-content:space-between;align-items:center;gap:12px}
.tag{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.01em}
.tag--blue{background:var(--blue-50);color:var(--blue-700)}
.vac__sal{font-weight:700;color:#0f172a}
.vac h3{font-size:18px;font-weight:600;letter-spacing:-.01em;color:#0f172a}
.vac p{color:var(--muted);font-size:14.5px}
.vac__meta{color:var(--muted-2);font-size:13px}
.vac .btn{margin-top:auto;align-self:flex-start}

/* Steps */
.steps{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));counter-reset:n;list-style:none}
.steps li{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.steps li::before{counter-increment:n;content:counter(n);position:absolute;top:18px;right:18px;font-size:48px;font-weight:700;line-height:1;color:#dbeafe;letter-spacing:-.02em}
.step__icn{width:40px;height:40px;border-radius:10px;background:var(--blue-50);color:var(--blue-600);display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px}
.steps h3{font-size:17px;font-weight:600;color:#0f172a;letter-spacing:-.01em;margin-bottom:6px}
.steps p{color:var(--muted);font-size:14.5px}

/* Advantages */
.advgrid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.adv{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:border-color .15s, transform .15s}
.adv:hover{border-color:#bfdbfe;transform:translateY(-2px)}
.adv h3{font-size:16px;font-weight:600;color:#0f172a;letter-spacing:-.01em;margin-bottom:6px}
.adv p{color:var(--muted);font-size:14px}

/* FAQ */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;transition:border-color .15s}
.faq details[open]{border-color:#bfdbfe;box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-weight:600;color:#0f172a;display:flex;align-items:center;justify-content:space-between;list-style:none;padding-right:8px;font-size:15px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;font-weight:300;color:var(--muted)}
.faq details[open] summary::after{content:"–"}
.faq p{margin-top:10px;color:var(--muted);font-size:14.5px}

/* Footer */
.ft{background:#0f172a;color:#cbd5e1;padding:48px 0 24px;margin-top:24px}
.ft a{color:#cbd5e1}
.ft a:hover{color:#fff}
.ft .brand{color:#fff}
.ft .brand__mark{background:var(--grad);color:#fff}
.ft__grid{display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.ft__col h4{color:#fff;font-size:14px;font-weight:600;letter-spacing:.01em;margin-bottom:14px;text-transform:uppercase}
.ft__col ul{display:flex;flex-direction:column;gap:8px;font-size:14px}
.ft__col p{font-size:13.5px;color:#94a3b8;line-height:1.6;max-width:300px;margin-top:14px}
.ft__bot{margin-top:32px;padding-top:18px;border-top:1px solid #1e293b;display:flex;justify-content:space-between;color:#64748b;font-size:13px}

/* Utilities */
.muted{color:var(--muted)}
.small{font-size:13px}

/* Static info pages */
.page{padding:48px 0 40px;max-width:760px;margin:0 auto}
.page h1{font-size:clamp(26px,3vw,34px);font-weight:700;letter-spacing:-.02em;margin-bottom:18px}
.page h2{font-size:20px;font-weight:600;margin:28px 0 10px;color:#0f172a}
.page p,.page li{color:#334155;font-size:15px;margin-bottom:8px}
.page ul,.page ol{padding-left:22px;margin:8px 0}
.page a{color:var(--blue-600)}
.page .meta{color:var(--muted);font-size:13.5px;margin-bottom:18px}
.contacts__grid{display:grid;grid-template-columns:1fr;gap:22px;margin-top:18px}
@media (min-width:720px){.contacts__grid{grid-template-columns:1fr 1fr}}
.contacts__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.contacts__card h3{font-size:16px;font-weight:600;margin-bottom:8px;color:#0f172a}
.contacts__card p{font-size:14.5px;color:#475569}


/* contacts page extra */
.contacts__form{margin-top:14px;max-width:560px}
.contacts__form textarea{width:100%;font:inherit;border:1px solid var(--line);border-radius:10px;padding:11px 14px;background:#fff;color:#0f172a;transition:border-color .15s, box-shadow .15s;resize:vertical}
.contacts__form textarea:focus{outline:0;border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.15)}

/* hero form: 2-column row for City + Type */
.field__row{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width:560px){
  .field__row{grid-template-columns:1fr 1fr}
}


/* ============ Vacancy detail page ============ */
.vacpage{padding:36px 0 48px}
.vacpage .crumbs{font-size:13.5px;color:var(--muted);margin-bottom:18px}
.vacpage .crumbs a{color:var(--muted)}
.vacpage .crumbs a:hover{color:var(--blue-600)}
.vacpage h1{font-size:clamp(26px,3vw,34px);font-weight:700;letter-spacing:-.02em;margin-bottom:6px}
.vacpage .vacpage__meta{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 24px}
.vacpage .vacpage__meta .tag{font-size:13px;padding:5px 12px}
.vacpage .vacpage__sal{display:inline-block;font-size:18px;font-weight:700;color:#0f172a;margin-bottom:18px}
.vacpage__grid{display:grid;gap:32px;grid-template-columns:1fr}
@media (min-width:980px){.vacpage__grid{grid-template-columns:1.4fr .9fr;align-items:start}}
.vacpage__main h2{font-size:18px;font-weight:600;margin:24px 0 8px;color:#0f172a;letter-spacing:-.01em}
.vacpage__main p,.vacpage__main li{color:#334155;font-size:15px;line-height:1.65}
.vacpage__main ul{padding-left:22px;margin:6px 0 14px}
.vacpage__main ul li{margin-bottom:4px}
.vacpage__sidecard{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);position:sticky;top:84px}
.vacpage__sidecard h2{font-size:16px;font-weight:600;margin-bottom:14px;color:#0f172a}
.vacpage__similar{margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}
.vacpage__similar h2{font-size:22px;font-weight:600;margin-bottom:18px;color:#0f172a;letter-spacing:-.01em}
.vacpage__back{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:14px;margin-top:6px}
.vacpage__back:hover{color:var(--blue-600)}


/* ============ Chat widget ============ */
.wh-chat{position:fixed;right:20px;bottom:20px;z-index:1000;font-family:inherit}
.wh-chat__toggle{
  display:inline-flex;align-items:center;gap:10px;padding:13px 18px 13px 14px;
  background:var(--grad);color:#fff;border:0;border-radius:999px;cursor:pointer;
  box-shadow:0 10px 28px rgba(37,99,235,.32),0 4px 10px rgba(15,23,42,.12);
  font:inherit;font-weight:600;font-size:14.5px;letter-spacing:-.005em;
  transition:transform .15s ease, box-shadow .2s ease;
}
.wh-chat__toggle:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(37,99,235,.4)}
.wh-chat__btn-icn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.18)}
.wh-chat--open .wh-chat__toggle{display:none}

.wh-chat__panel{
  position:fixed;right:20px;bottom:20px;width:340px;max-width:calc(100vw - 32px);
  height:480px;max-height:calc(100vh - 100px);
  background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:0 24px 60px rgba(15,23,42,.18);
  display:flex;flex-direction:column;overflow:hidden;
}
@media (max-width:520px){
  .wh-chat__panel{right:8px;bottom:8px;width:calc(100vw - 16px);height:calc(100vh - 16px);max-height:none;border-radius:14px}
}
.wh-chat__hdr{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 14px;background:var(--grad);color:#fff;
}
.wh-chat__hdr-l{display:flex;align-items:center;gap:10px}
.wh-chat__avatar{
  display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;
  border-radius:50%;background:rgba(255,255,255,.2);color:#fff;font-weight:700;font-size:12px;letter-spacing:.02em;
}
.wh-chat__hdr strong{font-size:14.5px;font-weight:600;display:block}
.wh-chat__status{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,.85);margin-top:2px}
.wh-chat__dot{display:inline-block;width:8px;height:8px;border-radius:50%}
.wh-chat__dot--busy{background:#fbbf24;box-shadow:0 0 0 3px rgba(251,191,36,.25)}
.wh-chat__close{
  width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.18);color:#fff;border:0;border-radius:50%;cursor:pointer;
  transition:background .15s;
}
.wh-chat__close:hover{background:rgba(255,255,255,.32)}

.wh-chat__body{
  flex:1;overflow-y:auto;padding:16px 14px;background:#f8fafc;display:flex;flex-direction:column;gap:10px;
}
.wh-msg{display:flex;align-items:flex-end;gap:8px;max-width:85%}
.wh-msg--bot{align-self:flex-start}
.wh-msg--user{align-self:flex-end;flex-direction:row-reverse}
.wh-msg__avatar{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:var(--grad);color:#fff;font-size:10px;font-weight:700;letter-spacing:.02em;
  flex-shrink:0;
}
.wh-msg__bubble{
  padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.45;
  background:#fff;border:1px solid var(--line);color:#0f172a;
}
.wh-msg--user .wh-msg__bubble{background:var(--blue-50);border-color:#bfdbfe;color:#0f172a}
.wh-msg--bot .wh-msg__bubble{border-top-left-radius:4px}
.wh-msg--user .wh-msg__bubble{border-top-right-radius:4px}

.wh-typing{display:inline-flex;gap:4px;align-items:center;padding:2px 0}
.wh-typing i{
  width:6px;height:6px;border-radius:50%;background:#94a3b8;display:inline-block;
  animation:wh-blink 1.2s infinite ease-in-out both;
}
.wh-typing i:nth-child(2){animation-delay:.15s}
.wh-typing i:nth-child(3){animation-delay:.3s}
@keyframes wh-blink{0%,80%,100%{opacity:.25}40%{opacity:1}}

.wh-chat__form{
  display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--line);background:#fff;
}
.wh-chat__form input{
  flex:1;padding:10px 12px;border:1px solid var(--line);border-radius:10px;font:inherit;
  background:#fff;color:#0f172a;
}
.wh-chat__form input:focus{outline:0;border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.15)}
.wh-chat__send{
  width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;
  background:var(--grad);color:#fff;border:0;border-radius:10px;cursor:pointer;
  transition:transform .12s, box-shadow .15s;
}
.wh-chat__send:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,.3)}

/* Footer chat link styled like a regular footer link (since it's a button) */
.ft__chatlink{
  background:transparent;border:0;padding:0;margin:0;color:#cbd5e1;font:inherit;cursor:pointer;text-align:left;
}
.ft__chatlink:hover{color:#fff}

/* "Open chat" CTA on contacts page */
.contacts__chatcta{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 18px;border-radius:12px;font:inherit;font-weight:600;font-size:14.5px;
  background:var(--blue-50);color:var(--blue-700);border:1px solid #bfdbfe;cursor:pointer;
  transition:background .15s, border-color .15s;
}
.contacts__chatcta:hover{background:#dbeafe;border-color:var(--blue-500)}


/* ============ Vacancy card enrichment ============ */
.vac__age{display:inline;color:var(--muted-2);font-size:13px;margin-left:6px}
.vac__age span{margin:0 4px;color:#cbd5e1}

/* ============ Stats / Numbers ============ */
.stats{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:18px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center}
.stat__num{font-size:28px;font-weight:700;color:var(--blue-600);letter-spacing:-.02em;line-height:1}
.stat__label{margin-top:6px;font-size:14px;color:var(--muted)}

/* ============ Categories grid ============ */
.cats{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.cat{display:flex;align-items:center;gap:12px;padding:18px 16px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);transition:border-color .15s, transform .15s;color:#0f172a}
.cat:hover{border-color:#bfdbfe;transform:translateY(-2px);color:#0f172a}
.cat__icn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:var(--blue-50);color:var(--blue-600);flex-shrink:0}
.cat__name{font-weight:600;font-size:14.5px}
.cat__meta{display:block;font-size:12px;color:var(--muted-2);font-weight:400;margin-top:2px}

/* ============ Reviews ============ */
.reviews{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.review__text{color:#334155;font-size:14.5px;line-height:1.55}
.review__author{margin-top:14px;display:flex;align-items:center;gap:10px}
.review__avatar{width:34px;height:34px;border-radius:50%;background:var(--blue-50);color:var(--blue-700);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.review__name{font-weight:600;font-size:14px;color:#0f172a}
.review__role{font-size:12.5px;color:var(--muted-2)}

/* ============ Team grid ============ */
.team{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:14px}
.team__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.team__avatar{width:48px;height:48px;border-radius:50%;background:var(--grad);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;margin-bottom:12px}
.team__name{font-weight:600;font-size:15px;color:#0f172a}
.team__role{font-size:13px;color:var(--muted);margin-top:2px}

/* ============ Cities tags ============ */
.cities{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.city{display:inline-block;padding:6px 12px;background:#fff;border:1px solid var(--line);border-radius:999px;font-size:13px;color:#475569}

/* ============ 404 page ============ */
.err404{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:48px 20px}
.err404 .num{font-size:96px;font-weight:700;color:var(--blue-600);letter-spacing:-.03em;line-height:1}
.err404 h1{font-size:24px;font-weight:600;margin-top:8px;color:#0f172a}
.err404 p{margin-top:10px;color:var(--muted);max-width:480px}
.err404 .actions{margin-top:22px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}


/* ============ Hero CTAs row ============ */
.hero__ctas{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.hero__ctas .btn{flex:0 0 auto}
.cta-row{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:32px}
.cta-row--center{justify-content:center}
.checklist{list-style:none;margin:14px 0;padding:0;display:flex;flex-direction:column;gap:8px}
.checklist li{padding-left:24px;position:relative;color:#334155;font-size:14.5px}
.checklist li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border-radius:50%;background:var(--blue-50);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232563eb' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 12 10 17 19 7'/></svg>");background-size:12px 12px;background-repeat:no-repeat;background-position:center}

/* Categories: 6-column grid with bigger cards */
.cats--6{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.cats--6 .cat{padding:22px 20px}
.cats--6 .cat__icn{width:44px;height:44px}
.cats--6 .cat__icn svg{width:22px;height:22px}
.cats--6 .cat__name{font-size:15.5px}

/* Hero numbers (stats) inside hero__card a tighter grid */
.hero__card .stats{grid-template-columns:1fr 1fr;gap:14px;margin-top:0}
.hero__card .stat{padding:18px 14px}
.hero__card .stat__num{font-size:24px}
.hero__card .stat__label{font-size:13px;line-height:1.35}

/* Vacancy filter buttons row */
.filter-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:22px}
.filter-row .btn{padding:9px 16px;font-size:14px}


/* ---------- Consent checkbox ---------- */
.check{display:flex;gap:10px;align-items:flex-start;margin-top:12px;font-size:13px;color:#475569;line-height:1.45;cursor:pointer}
.check input[type=checkbox]{flex:0 0 auto;margin-top:2px;width:16px;height:16px;accent-color:#2563eb;cursor:pointer}
.check span{flex:1}
.check a{color:#1d4ed8;text-decoration:underline}
.check a:hover{color:#1e40af}

/* ---------- Disclaimer / 18+ note ---------- */
.disclaimer{padding:14px 16px;background:#f8fafc;border:1px solid var(--line);border-radius:10px;color:#475569;font-size:13px;line-height:1.5;margin-top:16px}
.disclaimer strong{color:#0f172a}
