/* Relocation cost estimator — public page styles. Design tokens only. */

/* Immersive hero: cancel the inner-page top offset on .site-main so the
   full-screen hero sits behind the transparent navbar (like the homepage). */
body.relocation-page .site-main { padding-top: 0 !important; }

/* ── Full-screen photo hero ── */
.relocation-hero {
  position: relative; min-height: 100svh; min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center; overflow: hidden;
}
.relocation-hero .pub-hero__bg {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
}
.relocation-hero .pub-hero__overlay { background: transparent; } /* clean image, no overlay */
.relocation-hero .pub-hero__inner { position: relative; z-index: 2; max-width: 840px; padding: var(--space-8, 3rem) var(--space-5, 1.25rem); }
.relocation-hero .pub-hero__eyebrow { color: var(--color-accent, #d4af37); letter-spacing: .12em; }
.relocation-hero .pub-hero__title { color: #fff; font-size: clamp(2.2rem, 5vw, 3.6rem); text-shadow: 0 1px 6px rgba(8, 22, 40, .45); }
.relocation-hero .pub-hero__subtitle { color: #fff; opacity: .95; max-width: 640px; margin-inline: auto; text-shadow: 0 1px 6px rgba(8, 22, 40, .45); }
.relocation-hero .pub-hero__actions { margin-top: var(--space-5, 1.25rem); justify-content: center; }
.relocation-hero__trust { list-style: none; display: flex; gap: var(--space-5, 1.25rem); justify-content: center; flex-wrap: wrap; margin: var(--space-6, 1.5rem) 0 0; padding: 0; }
.relocation-hero__trust li { display: flex; align-items: center; gap: .4rem; color: #fff; opacity: .9; font-size: var(--font-size-sm, .9rem); }
.relocation-hero__trust i { color: var(--color-accent, #d4af37); }
.relocation-hero__scroll {
  position: absolute; bottom: var(--space-5, 1.25rem); left: 50%; transform: translateX(-50%);
  z-index: 2; color: #fff; opacity: .8; font-size: 1.4rem; text-decoration: none;
  animation: relocBounce 2s ease-in-out infinite;
}
@keyframes relocBounce { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(8px); } }

/* ── Two-column layout: form | result ── */
.reloc-layout { display: grid; grid-template-columns: minmax(0, 1fr); gap: var(--space-6, 1.5rem); }
@media (min-width: 900px) {
  /* Stretch so the form column is as tall as the (longer) result column —
     that gives the sticky form room to pin while the result scrolls past it. */
  .reloc-layout--has-result,
  .reloc-layout { grid-template-columns: minmax(320px, 400px) minmax(0, 1fr); align-items: stretch; }
}

/* ── Form (fixed/sticky, never internally scrollable) ── */
.reloc-form {
  display: flex; flex-direction: column; gap: var(--space-4, 1rem);
  background: var(--surface-raised, #fff);
  border: 1px solid var(--color-border, #e6e8ec);
  border-radius: var(--radius-lg, 18px);
  padding: var(--space-5, 1.25rem);
  position: sticky; top: var(--space-4, 1rem); align-self: start;
  /* Fallback only: if the window is shorter than the form, scroll internally
     so the Calculate button stays reachable. Invisible on normal/large windows. */
  max-height: calc(100vh - var(--space-6, 1.5rem)); overflow-y: auto; overflow-x: hidden;
}
.reloc-form__group { border: 0; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2, .5rem); }
.reloc-form__legend { font-weight: 600; color: var(--text-primary, #0c2340); padding: 0; margin-bottom: var(--space-1, .25rem); }
.reloc-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3, .75rem); }
.reloc-form__submit { width: 100%; justify-content: center; }

/* segmented (nationality) */
.reloc-seg { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2, .5rem); }
.reloc-seg__opt input, .reloc-tier input { position: absolute; opacity: 0; pointer-events: none; }
.reloc-seg__opt span {
  display: flex; align-items: center; justify-content: center; gap: .4rem;
  text-align: center; padding: var(--space-3, .75rem); cursor: pointer;
  border: 1px solid var(--color-border, #e6e8ec); border-radius: var(--radius-md, 12px);
  font-size: var(--font-size-sm, .9rem); color: var(--text-secondary, #4a5568); transition: all .15s ease;
}
.reloc-seg__opt input:checked + span,
.reloc-tier input:checked + .reloc-tier__card {
  border-color: var(--color-accent, #d4af37);
  box-shadow: 0 0 0 2px var(--color-accent, #d4af37) inset;
  color: var(--text-primary, #0c2340);
}

/* tiers (compact 3-up grid) */
.reloc-tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-2, .5rem); }
.reloc-tier__card {
  display: flex; flex-direction: column; gap: .1rem; cursor: pointer; height: 100%;
  align-items: center; text-align: center; justify-content: center;
  padding: var(--space-3, .75rem) var(--space-1, .25rem); border: 1px solid var(--color-border, #e6e8ec);
  border-radius: var(--radius-md, 12px); transition: all .15s ease;
}
.reloc-tier__name { font-weight: 600; color: var(--text-primary, #0c2340); font-size: var(--font-size-sm, .9rem); }
.reloc-tier__desc { font-size: var(--font-size-xs, .72rem); color: var(--text-tertiary, #718096); line-height: 1.25; }

/* optional-extras toggles (compact) */
.reloc-toggles { display: flex; flex-direction: column; gap: var(--space-2, .5rem); }
.reloc-toggle {
  display: flex; align-items: center; gap: var(--space-3, .75rem); position: relative;
  padding: var(--space-2, .5rem) var(--space-3, .75rem); cursor: pointer;
  border: 1px solid var(--color-border, #e6e8ec); border-radius: var(--radius-md, 12px); transition: all .15s ease;
}
.reloc-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.reloc-toggle__icon {
  width: 2rem; height: 2rem; flex: 0 0 auto; display: flex; align-items: center; justify-content: center;
  border-radius: 9px; background: #f3f4f6; color: var(--text-secondary, #4a5568); font-size: .9rem; transition: all .15s ease;
}
.reloc-toggle__text { flex: 1; min-width: 0; line-height: 1.2; }
.reloc-toggle__text strong { display: block; color: var(--text-primary, #0c2340); font-size: var(--font-size-sm, .9rem); }
.reloc-toggle__text small { color: var(--text-tertiary, #718096); font-size: var(--font-size-xs, .75rem); }
.reloc-toggle__check {
  width: 1.3rem; height: 1.3rem; flex: 0 0 auto; border-radius: 50%;
  border: 1.5px solid var(--color-border, #cdd2da); display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: .65rem; transition: all .15s ease;
}
.reloc-toggle__check i { opacity: 0; transition: opacity .15s ease; }
.reloc-toggle input:checked ~ .reloc-toggle__icon { background: var(--color-accent, #d4af37); color: var(--color-primary, #0c2340); }
.reloc-toggle input:checked ~ .reloc-toggle__check { background: var(--color-accent, #d4af37); border-color: var(--color-accent, #d4af37); }
.reloc-toggle input:checked ~ .reloc-toggle__check i { opacity: 1; }
.reloc-toggle:has(input:checked) { border-color: var(--color-accent, #d4af37); box-shadow: 0 0 0 1px var(--color-accent, #d4af37) inset; }

/* ── Empty state (no-JS fallback) ── */
.reloc-empty {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: var(--space-3, .75rem); padding: var(--space-8, 3rem) var(--space-5, 1.25rem);
  border: 1px dashed var(--color-border, #e6e8ec); border-radius: var(--radius-lg, 18px); color: var(--text-tertiary, #718096);
}
.reloc-empty i { font-size: 2.5rem; color: var(--color-accent, #d4af37); opacity: .7; }
.reloc-empty h2 { color: var(--text-primary, #0c2340); margin: 0; }

/* ── Result ── */
.reloc-result { display: flex; flex-direction: column; gap: var(--space-5, 1.25rem); }
.reloc-headline {
  background: linear-gradient(135deg, var(--color-primary, #0c2340), #143257);
  color: #fff; border-radius: var(--radius-lg, 18px); padding: var(--space-6, 1.5rem); text-align: center;
}
.reloc-headline__label { display: block; font-size: var(--font-size-sm, .9rem); opacity: .8; }
.reloc-headline__range { display: block; font-size: clamp(1.9rem, 4vw, 2.8rem); font-weight: 700; color: var(--color-accent, #d4af37); }
.reloc-headline__annual { display: inline-block; margin-top: .25rem; font-size: var(--font-size-sm, .9rem); opacity: .9; }
.reloc-headline__note { margin: var(--space-2, .5rem) 0 0; font-size: var(--font-size-xs, .78rem); opacity: .7; }

/* explainer + legend */
.reloc-explain { background: var(--surface-raised, #fff); border: 1px solid var(--color-border, #e6e8ec); border-radius: var(--radius-lg, 16px); padding: var(--space-4, 1rem) var(--space-5, 1.25rem); }
.reloc-explain p { margin: 0 0 var(--space-3, .75rem); color: var(--text-secondary, #4a5568); font-size: var(--font-size-sm, .9rem); line-height: 1.55; }
.reloc-legend { display: flex; gap: var(--space-2, .5rem); flex-wrap: wrap; }
.reloc-legend__item { display: inline-flex; align-items: center; gap: .35rem; font-size: var(--font-size-xs, .75rem); font-weight: 600; padding: .2rem .6rem; border-radius: 999px; }
.reloc-legend__item i { font-size: .7rem; }
.reloc-legend__item--twins { background: #fbf3da; color: #8a6d12; }
.reloc-legend__item--gov { background: #eef2f7; color: #3a4d63; }
.reloc-legend__item--third { background: #eef7f1; color: #2f6b46; }

.reloc-group { background: var(--surface-raised, #fff); border: 1px solid var(--color-border, #e6e8ec); border-radius: var(--radius-lg, 16px); padding: var(--space-5, 1.25rem); }
.reloc-group--twins { border-left: 3px solid #d4af37; }
.reloc-group--government { border-left: 3px solid #6b86a8; }
.reloc-group--thirdparty { border-left: 3px solid #5aa178; }
.reloc-group__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-3, .75rem); margin-bottom: var(--space-1, .25rem); }
.reloc-group__title { display: flex; align-items: center; gap: .5rem; margin: 0; font-size: var(--font-size-lg, 1.1rem); color: var(--text-primary, #0c2340); }
.reloc-group__title i { color: var(--color-accent, #d4af37); }
.reloc-group__subtotal { font-weight: 700; color: var(--text-primary, #0c2340); white-space: nowrap; }
.reloc-group__desc { margin: 0 0 var(--space-3, .75rem); color: var(--text-tertiary, #718096); font-size: var(--font-size-xs, .8rem); line-height: 1.5; }

.reloc-lines { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.reloc-line { display: flex; justify-content: space-between; gap: var(--space-3, .75rem); padding: var(--space-2, .5rem) 0; border-top: 1px solid var(--color-border, #eef0f3); }
.reloc-line:first-child { border-top: 0; }
.reloc-line__label { color: var(--text-secondary, #4a5568); }
.reloc-line__note { display: block; font-size: var(--font-size-xs, .78rem); color: var(--text-tertiary, #718096); }
.reloc-line__amt { white-space: nowrap; font-weight: 600; color: var(--text-primary, #0c2340); }

.reloc-tag { display: inline-block; font-size: var(--font-size-xs, .7rem); padding: .05rem .4rem; border-radius: 999px; margin-left: .3rem; vertical-align: middle; }
.reloc-tag--opt { background: #eef2f7; color: #5a6b80; }
.reloc-tag--rec { background: #fbf3da; color: #8a6d12; }

.reloc-elig {
  display: flex; gap: var(--space-2, .5rem); align-items: flex-start;
  background: #f3f7fc; border: 1px solid #dbe7f4; color: #2c5282;
  border-radius: var(--radius-md, 12px); padding: var(--space-3, .75rem) var(--space-4, 1rem); font-size: var(--font-size-sm, .9rem);
}
.reloc-elig i { margin-top: .15rem; }

/* ── Documents checklist (icon-rich, grouped by stage) ── */
.reloc-docs { background: var(--surface-raised, #fff); border: 1px solid var(--color-border, #e6e8ec); border-radius: var(--radius-lg, 16px); overflow: hidden; }
.reloc-docs__head { display: flex; align-items: center; gap: .5rem; padding: var(--space-4, 1rem); cursor: pointer; font-weight: 600; color: var(--text-primary, #0c2340); list-style: none; }
.reloc-docs__head::-webkit-details-marker { display: none; }
.reloc-docs__head > i:first-child { color: var(--color-accent, #d4af37); }
.reloc-docs__count { background: var(--color-primary, #0c2340); color: #fff; font-size: var(--font-size-xs, .75rem); border-radius: 999px; padding: .05rem .5rem; }
.reloc-docs__chev { margin-left: auto; color: var(--text-tertiary, #718096); transition: transform .2s ease; }
.reloc-docs[open] .reloc-docs__chev { transform: rotate(180deg); }
.reloc-docs__body { padding: 0 var(--space-4, 1rem) var(--space-4, 1rem); display: flex; flex-direction: column; gap: var(--space-4, 1rem); }
.reloc-docstage__title { margin: var(--space-2, .5rem) 0; font-size: var(--font-size-xs, .72rem); text-transform: uppercase; letter-spacing: .06em; color: var(--text-tertiary, #718096); font-weight: 700; }
.reloc-docs__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-2, .5rem); }
.reloc-doc { display: flex; gap: var(--space-3, .75rem); align-items: center; padding: var(--space-3, .75rem); border: 1px solid var(--color-border, #eef0f3); border-radius: var(--radius-md, 12px); transition: border-color .15s ease; }
.reloc-doc:hover { border-color: var(--color-accent, #d4af37); }
.reloc-doc__icon {
  width: 2.4rem; height: 2.4rem; flex: 0 0 auto; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: rgba(212, 175, 55, .14); color: #b8941f; font-size: 1rem;
}
.reloc-doc__body strong { display: block; color: var(--text-primary, #0c2340); font-size: var(--font-size-sm, .9rem); }
.reloc-doc__body small { display: block; color: var(--text-tertiary, #718096); font-size: var(--font-size-xs, .8rem); margin-top: .1rem; line-height: 1.45; }

/* lead form */
.reloc-lead { background: var(--surface-raised, #fff); border: 1px solid var(--color-accent, #d4af37); border-radius: var(--radius-lg, 18px); padding: var(--space-6, 1.5rem); }
.reloc-lead__title { margin: 0 0 .25rem; color: var(--text-primary, #0c2340); }
.reloc-lead__sub { margin: 0 0 var(--space-4, 1rem); color: var(--text-secondary, #4a5568); font-size: var(--font-size-sm, .9rem); }
.reloc-lead__form { display: flex; flex-direction: column; gap: var(--space-3, .75rem); }

@media (max-width: 560px) {
  .reloc-form__row { grid-template-columns: 1fr; }
  .reloc-form { position: static; }
}
