/* ============================================================
   EXPATS LP — page-specific overrides
   Layered on top of neocore.css. Keep this small; prefer the
   shared tokens/classes from neocore.css wherever possible.
   ============================================================ */

/* ---------- Section helper: subtle bordered band ---------- */
.nc-section--band {
  background: var(--nc-bg-2);
  border-top: 1px solid var(--nc-line);
  border-bottom: 1px solid var(--nc-line);
}

/* ---------- All section headlines centered (hero keeps its left split) ---------- */
.nc-section:not(.exp-hero) .nc-eyebrow { display: block; text-align: center; }
.nc-section:not(.exp-hero) h2 { text-align: center; }
.nc-section:not(.exp-hero) > .nc-container > .nc-lead,
.nc-section:not(.exp-hero) > .nc-container--narrow > .nc-lead {
  text-align: center; margin-left: auto; margin-right: auto;
}

/* ---------- Hero ---------- */
.exp-hero { text-align: center; }
.exp-hero .nc-lead { margin-left: auto; margin-right: auto; }

/* ---------- Split 2-col (text + media) ---------- */
.exp-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.exp-split__media {
  background: var(--nc-card);
  border: 1px solid var(--nc-line);
  border-radius: var(--nc-radius-lg);
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--nc-muted);
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-align: center;
  padding: 24px;
}
@media (max-width: 860px) {
  .exp-split { grid-template-columns: 1fr; gap: 28px; }
}

/* ---------- Hero: 2-col split with building visual (main-site style) ---------- */
.exp-hero__split { align-items: center; }
.exp-hero .exp-hero__copy { text-align: left; }
.exp-hero__split .nc-lead { margin-left: 0; margin-right: 0; }
.exp-hero__split .nc-hero__actions { justify-content: flex-start; }
.exp-hero__media {
  border-radius: var(--nc-radius-lg);
  overflow: hidden;
  border: 1px solid var(--nc-line);
  box-shadow: var(--nc-shadow);
}
.exp-hero__media img {
  width: 100%; height: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}
/* Bare variant: transparent PNG floats on the navy canvas (main-site style) */
.exp-hero__media--bare {
  border: none;
  border-radius: 0;
  overflow: visible;
  box-shadow: none;
}
.exp-hero__media--bare img {
  aspect-ratio: auto;
  object-fit: contain;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,0.45));
}
@media (max-width: 860px) {
  .exp-hero .exp-hero__copy { text-align: center; }
  .exp-hero__split .nc-lead { margin-left: auto; margin-right: auto; }
  .exp-hero__split .nc-hero__actions { justify-content: center; }
  .exp-hero__media { order: -1; }
  .exp-hero__media img { aspect-ratio: 16 / 10; }
}

/* ---------- Figures / charts (SVG schaubilder) ---------- */
.exp-figure { max-width: 760px; margin: 0 auto; }
.exp-figure--wide { max-width: 900px; }
.exp-figure img, .exp-figure svg { width: 100%; height: auto; display: block; }
.exp-figure__note {
  text-align: center;
  font-size: 12px;
  color: var(--nc-muted);
  margin-top: 10px;
  font-style: italic;
}

/* ---------- Premium hero (refined split) ---------- */
.exp-hero { padding-top: 92px; padding-bottom: 64px; }
.exp-hero__split { gap: 56px; min-height: 600px; }

/* Eyebrow with fine rule (faulstich pattern) */
.exp-eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  font-size: 12px; font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--nc-accent); margin-bottom: 24px;
}
.exp-eyebrow::before { content: ""; width: 34px; height: 2px; background: var(--nc-accent); }

/* Refined display headline */
.exp-hero__copy h1 {
  font-size: clamp(40px, 5.2vw, 62px);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.06;
  margin-bottom: 22px;
}
.exp-hero__copy h1 .nc-hl {
  font-weight: 600;
  color: var(--nc-accent);
  -webkit-text-fill-color: var(--nc-accent);
}
.exp-hero__copy .nc-lead { font-weight: 400; font-size: 18px; max-width: 32em; }
.exp-hero__split .nc-hero__actions { margin-top: 30px; }

/* KPI row */
.exp-kpis {
  display: flex; gap: 36px; margin-top: 36px; padding-top: 24px;
  border-top: 1px solid var(--nc-line);
}
.exp-kpi__value { font-size: 30px; font-weight: 500; letter-spacing: -0.01em; color: var(--nc-accent); line-height: 1; }
.exp-kpi__label { font-size: 11px; font-weight: 600; letter-spacing: 1.4px; text-transform: uppercase; color: var(--nc-muted); margin-top: 7px; }

/* Full-bleed hero media: fills the column height, soft frame, no small box */
.exp-hero__media--bleed {
  border: 1px solid var(--nc-line);
  border-radius: var(--nc-radius-lg);
  box-shadow: var(--nc-shadow);
  overflow: hidden;
  align-self: stretch;
}
.exp-hero__media--bleed img { width: 100%; height: 100%; aspect-ratio: auto; object-fit: cover; object-position: center 20%; }

@media (max-width: 860px) {
  .exp-hero { padding-top: 28px; }
  .exp-eyebrow { justify-content: center; }
  .exp-kpis { justify-content: center; flex-wrap: wrap; gap: 28px; }
  .exp-hero__split { min-height: 0; }
  .exp-hero__media--bleed { aspect-ratio: 4 / 3; align-self: auto; }
  .exp-hero__media--bleed img { aspect-ratio: 4 / 3; }
}

/* ---------- Full-width photo band ---------- */
.exp-photo {
  border-radius: var(--nc-radius-lg);
  overflow: hidden;
  border: 1px solid var(--nc-line);
  box-shadow: var(--nc-shadow);
  margin: 0;
}
.exp-photo img { width: 100%; height: auto; display: block; }

/* ---------- Numbered process steps ---------- */
.exp-steps { counter-reset: step; }
.exp-step { position: relative; padding-top: 8px; }
.exp-step__num {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(88, 166, 255, 0.12);
  border: 1px solid var(--nc-line-strong);
  color: var(--nc-accent);
  font-weight: 800;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}

/* ---------- Icon + heading row in cards ---------- */
.exp-pillar__head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

/* ---------- Video testimonials (from Objekt-LP pattern) ---------- */
.video-testimonials { gap: 28px; }
.video-testimonial {
  margin: 0;
  background: var(--nc-card);
  border: 1px solid var(--nc-line);
  border-radius: var(--nc-radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--nc-shadow);
}
.video-testimonial__player {
  position: relative;
  background: #16204a;
  aspect-ratio: 16 / 9;
}
.video-testimonial__player video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-bottom: 1px solid var(--nc-line);
}
.testimonial-video { cursor: pointer; }
.video-testimonial__caption {
  padding: 22px 24px 26px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.video-testimonial__quote {
  font-size: 17px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--nc-text);
  margin-bottom: 8px;
}
.video-testimonial__name { font-size: 15px; font-weight: 600; color: var(--nc-text); }
.video-testimonial__role {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--nc-muted);
}
/* Placeholder marker badge on testimonial videos (remove once real clips land) */
.video-testimonial__player[data-placeholder="true"]::after {
  content: "PLACEHOLDER";
  position: absolute;
  top: 10px; left: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  padding: 4px 8px;
  border-radius: 6px;
  background: rgba(255, 195, 112, 0.18);
  color: var(--nc-warn);
  border: 1px solid rgba(255, 195, 112, 0.4);
  pointer-events: none;
}

/* ---------- Expert cards (the highlighted experts) ---------- */
.exp-expert__photo {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: var(--nc-radius);
  background: var(--nc-bg-2);
  border: 1px solid var(--nc-line);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--nc-muted);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 18px;
  overflow: hidden;
}
.exp-expert__photo img { width: 100%; height: 100%; object-fit: cover; }
.exp-expert__photo[data-placeholder="true"]::after {
  content: "PHOTO";
  position: absolute;
  top: 10px; left: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  padding: 4px 8px;
  border-radius: 6px;
  background: rgba(31, 39, 62, 0.1);
  color: var(--nc-accent);
  border: 1px solid var(--nc-line-strong);
}
.exp-expert__cred {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--nc-accent);
  font-weight: 700;
  margin-bottom: 4px;
}

/* ---------- Avatar trust strip ---------- */
.exp-avatars {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: var(--nc-bg-2);
  border: 1px solid var(--nc-line);
  border-radius: 999px;
  padding: 10px 22px 10px 14px;
  text-decoration: none;
}
.exp-avatars__imgs { display: inline-flex; }
.exp-avatars__imgs img {
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 2px solid var(--nc-bg);
  object-fit: cover;
  margin-left: -10px;
}
.exp-avatars__imgs img:first-child { margin-left: 0; }
.exp-avatars__more {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--nc-accent);
  color: var(--nc-bg);
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: -10px;
  border: 2px solid var(--nc-bg);
}
.exp-avatars__copy { text-align: left; line-height: 1.3; }
.exp-avatars__copy strong { display: block; color: var(--nc-text); font-size: 14px; }
.exp-avatars__copy span { color: var(--nc-muted); font-size: 12px; }

/* ---------- Team / experts cards (richer, premium) ---------- */
.exp-team { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; max-width: 860px; margin: 0 auto; }
@media (max-width: 680px) { .exp-team { grid-template-columns: 1fr; } }
.exp-teamcard {
  background: var(--nc-card);
  border: 1px solid var(--nc-line);
  border-radius: var(--nc-radius-lg);
  overflow: hidden;
  box-shadow: var(--nc-shadow);
  display: flex;
  flex-direction: column;
  transition: transform 0.2s, border-color 0.2s;
}
.exp-teamcard:hover { transform: translateY(-3px); border-color: var(--nc-line-strong); }
.exp-teamcard__photo { position: relative; background: #141a2c; aspect-ratio: 1 / 1; }
.exp-teamcard__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.exp-teamcard__photo::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 42%;
  background: linear-gradient(transparent, rgba(10, 12, 22, 0.6));
}
.exp-teamcard__badge {
  position: absolute; left: 16px; bottom: 16px; z-index: 1;
  background: rgba(245, 237, 225, 0.95); color: var(--nc-accent);
  font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  padding: 6px 12px; border-radius: 999px;
}
.exp-teamcard__body { padding: 20px 24px 26px; }
.exp-teamcard__name { font-size: 20px; font-weight: 700; color: var(--nc-text); margin-bottom: 6px; }
.exp-teamcard__bio { color: var(--nc-muted); font-size: 14px; line-height: 1.6; }

/* ---------- Interactive cost calculator ---------- */
.exp-calc {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: stretch;
  background: var(--nc-card); border: 1px solid var(--nc-line);
  border-radius: var(--nc-radius-lg); padding: 32px; box-shadow: var(--nc-shadow);
}
@media (max-width: 820px) { .exp-calc { grid-template-columns: 1fr; gap: 26px; padding: 22px; } }
.exp-calc__controls { display: flex; flex-direction: column; gap: 28px; }
.exp-calc__field label {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 13px; font-weight: 600; color: var(--nc-muted); margin-bottom: 12px; letter-spacing: 0.3px;
}
.exp-calc__field label b { font-size: 19px; color: var(--nc-text); font-weight: 800; }
.exp-calc input[type="range"] {
  -webkit-appearance: none; appearance: none; width: 100%; height: 6px;
  border-radius: 999px; background: var(--nc-bg-2); outline: none;
}
.exp-calc input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; width: 22px; height: 22px; border-radius: 50%;
  background: var(--nc-accent); cursor: pointer; border: 3px solid #fff; box-shadow: 0 2px 8px rgba(28, 31, 42, 0.3);
}
.exp-calc input[type="range"]::-moz-range-thumb {
  width: 22px; height: 22px; border-radius: 50%; background: var(--nc-accent); cursor: pointer; border: 3px solid #fff;
}
.exp-calc__seg { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.exp-calc__seg button {
  padding: 13px 8px; border-radius: var(--nc-radius-sm); border: 1px solid var(--nc-line);
  background: var(--nc-bg-2); color: var(--nc-text); font: inherit; font-weight: 700; font-size: 14px;
  cursor: pointer; transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.exp-calc__seg button:hover { border-color: var(--nc-accent); }
.exp-calc__seg button.is-active { background: var(--nc-accent); color: #fff; border-color: var(--nc-accent); }
.exp-calc__result { background: var(--nc-bg-2); border-radius: var(--nc-radius); padding: 24px; display: flex; flex-direction: column; }
.exp-calc__line { display: flex; justify-content: space-between; align-items: center; padding: 11px 0; border-bottom: 1px solid var(--nc-line); font-size: 14px; }
.exp-calc__line span:first-child { color: var(--nc-muted); display: flex; align-items: center; gap: 9px; }
.exp-calc__line .v { font-weight: 700; font-variant-numeric: tabular-nums; color: var(--nc-text); }
.exp-calc__line .v.pos { color: #1f8a55; }
.exp-calc__dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.exp-calc__total { display: flex; justify-content: space-between; align-items: baseline; margin-top: 14px; padding-top: 16px; border-top: 2px solid var(--nc-line-strong); }
.exp-calc__total .lbl { font-weight: 700; font-size: 15px; color: var(--nc-text); }
.exp-calc__total .amt { font-size: 30px; font-weight: 800; color: var(--nc-accent); font-variant-numeric: tabular-nums; white-space: nowrap; flex: 0 0 auto; padding-left: 12px; }
.exp-calc__note { font-size: 11px; color: var(--nc-muted); line-height: 1.5; margin-top: 12px; }

/* ---------- 60-second eligibility check ---------- */
.exp-quiz {
  background: var(--nc-card); border: 1px solid var(--nc-line);
  border-radius: var(--nc-radius-lg); padding: 32px; box-shadow: var(--nc-shadow);
  max-width: 640px; margin: 0 auto; min-height: 320px;
}
@media (max-width: 560px) { .exp-quiz { padding: 22px; } }
.exp-quiz__bar { height: 6px; border-radius: 999px; background: var(--nc-bg-2); overflow: hidden; margin-bottom: 26px; }
.exp-quiz__bar i { display: block; height: 100%; background: var(--nc-accent); width: 0; transition: width 0.3s ease; }
.exp-quiz__count { font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--nc-muted); font-weight: 700; margin-bottom: 16px; display: block; }
.exp-quiz__q { font-size: 21px; font-weight: 700; color: var(--nc-text); line-height: 1.25; margin-bottom: 18px; }
.exp-quiz__opts { display: grid; gap: 10px; }
.exp-quiz__opt {
  text-align: left; width: 100%; padding: 16px 18px; border-radius: var(--nc-radius);
  border: 1px solid var(--nc-line); background: var(--nc-bg-2); color: var(--nc-text);
  font: inherit; font-weight: 600; cursor: pointer; transition: border-color 0.15s, background 0.15s, transform 0.15s;
}
.exp-quiz__opt:hover { border-color: var(--nc-accent); background: #fff; transform: translateY(-1px); }
.exp-quiz__result { text-align: center; }
.exp-quiz__badge {
  display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--nc-accent); background: rgba(31, 39, 62, 0.08); border: 1px solid var(--nc-line);
  padding: 5px 12px; border-radius: 999px;
}
.exp-quiz__restart { background: none; border: none; color: var(--nc-muted); cursor: pointer; font: inherit; font-size: 13px; text-decoration: underline; margin-top: 16px; }

/* ===== Nav brand: icon + wordmark lockup =====
   Icon is masked so it follows the brand colour (navy on the creme nav). */
.nc-nav__brand { display: inline-flex; align-items: center; gap: 9px; margin-right: auto; }
.nc-nav__logo {
  width: 26px; height: 28px; flex: 0 0 auto;
  background-color: currentColor;
  -webkit-mask: url("assets/neocore-icon.svg") center / contain no-repeat;
          mask: url("assets/neocore-icon.svg") center / contain no-repeat;
}
@media (max-width: 900px) {
  .nc-nav__logo { width: 22px; height: 24px; }
}


/* ===== Calculator: collapsible assumptions (declutter) ===== */
.exp-calc__assum { margin-top: 16px; }
.exp-calc__assum > summary {
  cursor: pointer; list-style: none; user-select: none;
  font-size: 12px; font-weight: 600; color: var(--nc-muted);
  display: inline-flex; align-items: center; gap: 6px;
}
.exp-calc__assum > summary::-webkit-details-marker { display: none; }
.exp-calc__assum > summary::after { content: "+"; font-weight: 700; }
.exp-calc__assum[open] > summary::after { content: "\2013"; }
.exp-calc__assum .exp-calc__note { margin-top: 8px; }
