:root {
  --bg: #10163a;
  --surface: #0d142e;
  --line: rgba(255, 255, 255, 0.14);
  --text: #f8fbfb;
  --muted: #c7d0da;
  --cyan: #4ad5dc;
  --blue: #78bfef;
  --violet: #8566f5;
  --gradient-main: linear-gradient(90deg, var(--cyan), var(--blue) 48%, var(--violet));
  --gradient-panel: linear-gradient(145deg, rgba(74, 213, 220, 0.16), rgba(255, 255, 255, 0.04) 42%, rgba(133, 102, 245, 0.18));
  --shadow: 0 26px 90px rgba(0, 0, 0, 0.42);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
section { scroll-margin-top: 92px; }
body {
  margin: 0;
  background: linear-gradient(135deg, rgba(74, 213, 220, 0.42), rgba(120, 191, 239, 0.28) 42%, rgba(133, 102, 245, 0.46)), var(--bg);
  color: var(--text);
  font-family: Inter, system-ui, sans-serif;
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 76px;
  padding: 18px clamp(18px, 4vw, 58px);
  background: linear-gradient(90deg, rgba(74, 213, 220, 0.38), rgba(120, 191, 239, 0.24), rgba(133, 102, 245, 0.38)), rgba(10, 17, 35, 0.86);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}
.brand { display: inline-flex; align-items: center; font-weight: 900; text-transform: uppercase; }
.brand img { display: block; width: clamp(190px, 18vw, 260px); height: auto; }
.brand strong, .eyebrow, .service-card svg, .step-tab span, .step-count, .story-points svg, .stars { color: var(--cyan); }
.nav-links { display: flex; align-items: center; gap: 24px; color: #eef4f7; font-size: 0.94rem; font-weight: 800; }
.nav-cta, .button.primary, .story-tag { background: var(--gradient-main); color: #071010; }
.nav-cta { padding: 11px 16px; border-radius: 6px; }
.menu-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--line); border-radius: 6px; background: var(--gradient-panel); color: white; }

.hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 430px);
  gap: clamp(24px, 6vw, 76px);
  align-items: center;
  min-height: calc(100vh - 76px);
  padding: clamp(56px, 9vw, 120px) clamp(18px, 6vw, 86px) clamp(56px, 7vw, 86px);
  overflow: hidden;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(74, 213, 220, 0.58), rgba(16, 22, 58, 0.72) 45%, rgba(133, 102, 245, 0.62)), linear-gradient(90deg, rgba(5, 9, 24, 0.72), rgba(18, 38, 65, 0.52), rgba(33, 24, 76, 0.68)), url("assets/passport-paperwork.jpg") center / cover;
  opacity: 0.92;
}
.hero-copy, .case-panel { position: relative; z-index: 1; }
.eyebrow { margin: 0 0 14px; font-size: 0.82rem; font-weight: 900; letter-spacing: 0.26em; text-transform: uppercase; }
h1, h2, h3 { margin: 0; line-height: 0.95; }
h1, h2 { font-family: "Barlow Condensed", Impact, sans-serif; text-transform: uppercase; }
h1 { max-width: 920px; font-size: clamp(4rem, 11vw, 9rem); text-shadow: 0 18px 50px rgba(0, 0, 0, 0.45); }
.hero-lede { max-width: 760px; margin: 28px 0 0; color: #edf3f7; font-size: clamp(1.12rem, 2.4vw, 1.52rem); font-weight: 700; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 50px; padding: 14px 18px; border: 0; border-radius: 6px; cursor: pointer; font-weight: 900; }
.button.secondary { background: var(--gradient-panel); border: 1px solid var(--line); color: #fff; }
.button svg, .service-card svg, .trust-strip svg, .contact-methods svg { width: 20px; height: 20px; }

.case-panel, .service-card, .step-detail, .story-copy, .success-image, .approval-card, .review-card, .lead-form {
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  background: var(--gradient-panel), rgba(7, 9, 24, 0.64);
  box-shadow: var(--shadow);
}
.case-panel { padding: 22px; }
.panel-top, .route-card, .mini-grid div { border: 1px solid var(--line); background: var(--gradient-panel); border-radius: 6px; }
.panel-top { display: flex; align-items: center; gap: 10px; padding: 12px; font-weight: 800; }
.status-dot { width: 11px; height: 11px; border-radius: 999px; background: var(--gradient-main); box-shadow: 0 0 20px rgba(120, 191, 239, 0.72); }
.route-card { margin: 18px 0; padding: 22px; }
.route-card span, .mini-grid span { color: var(--muted); font-size: 0.76rem; font-weight: 800; text-transform: uppercase; }
.route-card strong { display: block; margin: 8px 0; font-family: "Barlow Condensed", sans-serif; font-size: 3.2rem; line-height: 1; }
.mini-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.mini-grid div { min-height: 100px; padding: 16px; }
.mini-grid strong { display: block; margin-top: 10px; font-size: 1.35rem; }

.trust-strip, .proof-band, .site-footer { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; padding: 0 clamp(18px, 6vw, 86px); }
.trust-strip span, .proof-band div { display: flex; align-items: center; justify-content: center; min-height: 92px; padding: 20px; background: var(--gradient-panel), linear-gradient(135deg, rgba(74, 213, 220, 0.18), rgba(133, 102, 245, 0.2)); color: #eff7fa; font-weight: 800; text-align: center; gap: 10px; }

.section, .process-section, .countries, .success-section, .reviews-section, .contact-section { padding: clamp(70px, 9vw, 118px) clamp(18px, 6vw, 86px); background: linear-gradient(135deg, rgba(74, 213, 220, 0.3), rgba(120, 191, 239, 0.16) 44%, rgba(133, 102, 245, 0.32)), #11184a; }
.process-section { background: linear-gradient(135deg, rgba(74, 213, 220, 0.34), rgba(120, 191, 239, 0.18) 45%, rgba(133, 102, 245, 0.34)), #111a49; }
.success-section { background: linear-gradient(135deg, rgba(74, 213, 220, 0.36), rgba(120, 191, 239, 0.2) 42%, rgba(133, 102, 245, 0.38)), #12184a; }
.reviews-section { background: linear-gradient(135deg, rgba(133, 102, 245, 0.36), rgba(120, 191, 239, 0.2) 48%, rgba(74, 213, 220, 0.32)), #12184a; }
.section-heading { max-width: 850px; margin-bottom: 38px; }
.section-heading.compact { max-width: 760px; }
.section-heading h2, .process-section h2, .contact-copy h2, .country-card h2 { font-size: clamp(3.1rem, 7vw, 6.4rem); }
.section-heading p:not(.eyebrow), .contact-copy > p:not(.eyebrow), .country-card p { color: var(--muted); font-size: 1.05rem; font-weight: 700; }
.service-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.service-card { min-height: 250px; padding: 26px; }
.service-card h3 { margin-top: 24px; font-size: 1.25rem; }
.service-card p { color: var(--muted); font-weight: 700; }

.process-shell { display: grid; grid-template-columns: 330px minmax(0, 1fr); gap: 18px; }
.steps-list { display: grid; gap: 10px; }
.step-tab { display: flex; align-items: center; gap: 14px; min-height: 70px; padding: 16px; border: 1px solid var(--line); border-radius: 6px; background: var(--gradient-panel); color: #fff; cursor: pointer; text-align: left; font-weight: 900; }
.step-tab span { font-family: "Barlow Condensed", sans-serif; font-size: 1.7rem; }
.step-tab.active { border-color: rgba(133, 102, 245, 0.72); background: linear-gradient(135deg, rgba(74, 213, 220, 0.18), rgba(133, 102, 245, 0.22)); }
.step-detail { min-height: 430px; padding: clamp(24px, 5vw, 52px); }
.progress-track { height: 7px; margin-bottom: 32px; overflow: hidden; border-radius: 999px; background: rgba(133, 102, 245, 0.12); }
.progress-track span { display: block; width: 20%; height: 100%; border-radius: inherit; background: var(--gradient-main); transition: width 260ms ease; }
.step-detail h3 { font-family: "Barlow Condensed", sans-serif; font-size: clamp(3rem, 7vw, 5.8rem); text-transform: uppercase; }
.step-detail p { max-width: 760px; color: #e2ecf1; font-size: 1.08rem; font-weight: 700; }
.step-detail ul, .country-card ul { display: grid; gap: 10px; margin: 24px 0 0; padding: 0; list-style: none; }
.step-detail li, .country-card li { position: relative; padding-left: 26px; color: #f2f8fa; font-weight: 800; }
.step-detail li::before, .country-card li::before { content: ""; position: absolute; left: 0; top: 0.7em; width: 10px; height: 10px; border-radius: 999px; background: var(--gradient-main); }

.countries, .success-feature { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.country-card { min-height: 590px; display: flex; flex-direction: column; justify-content: space-between; padding: clamp(28px, 5vw, 48px); border: 1px solid var(--line); border-radius: 8px; background: var(--gradient-panel), rgba(7, 9, 24, 0.68); }
.story-copy { display: flex; min-height: 520px; flex-direction: column; justify-content: space-between; padding: clamp(26px, 5vw, 48px); }
.story-tag { width: fit-content; padding: 9px 12px; border-radius: 999px; font-size: 0.78rem; font-weight: 900; text-transform: uppercase; }
.story-copy h3 { margin-top: 26px; font-family: "Barlow Condensed", sans-serif; font-size: clamp(3rem, 6vw, 5.4rem); text-transform: uppercase; }
.story-copy p { color: #e2ecf1; font-size: 1.08rem; font-weight: 700; }
.story-points { display: grid; gap: 12px; }
.story-points span { display: flex; align-items: center; gap: 10px; font-weight: 900; }
.success-image, .approval-card { position: relative; overflow: hidden; margin: 0; }
.success-image img, .approval-card img { display: block; width: 100%; height: 100%; min-height: 360px; object-fit: cover; filter: saturate(0.94) contrast(1.03); }
.success-image.featured { display: flex; align-items: center; justify-content: center; min-height: 460px; padding: 42px; background: linear-gradient(135deg, rgba(74, 213, 220, 0.14), rgba(133, 102, 245, 0.18)), #090e25; }
.success-image.featured img { width: min(82%, 920px); height: auto; max-height: 430px; min-height: 0; object-fit: contain; }
.success-image figcaption, .approval-card figcaption { position: absolute; left: 0; right: 0; bottom: 0; z-index: 1; padding: 54px 18px 18px; background: linear-gradient(180deg, transparent, rgba(18, 19, 37, 0.9)); color: #fff; font-size: 0.9rem; font-weight: 800; }
.approval-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.approval-card { min-height: 330px; }
.approval-card img { min-height: 330px; }
.approval-card figcaption { display: grid; gap: 3px; }
.success-note { max-width: 980px; margin: 22px 0 0; color: var(--muted); font-size: 0.9rem; font-weight: 700; }

.reviews-grid { display: grid; grid-template-columns: 1.2fr repeat(3, minmax(0, 1fr)); gap: 14px; }
.review-card { display: flex; min-height: 310px; flex-direction: column; justify-content: space-between; padding: 24px; }
.review-card p { color: #f0f7fa; font-size: 1.02rem; font-weight: 700; }
.review-card footer { display: grid; gap: 2px; }
.review-card span, .form-note, .disclaimer { color: var(--muted); font-size: 0.9rem; font-weight: 800; }
.proof-band div { min-height: 150px; flex-direction: column; }
.metric { font-family: "Barlow Condensed", sans-serif; font-size: clamp(3.6rem, 7vw, 6.4rem); line-height: 0.9; }
.proof-band p { margin: 8px 0 0; color: var(--muted); font-weight: 900; text-transform: uppercase; }

.contact-section { display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(320px, 560px); gap: clamp(24px, 6vw, 70px); align-items: start; }
.contact-methods { display: grid; gap: 12px; margin-top: 26px; }
.contact-methods a { display: inline-flex; align-items: center; gap: 10px; font-weight: 900; }
.lead-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; padding: 22px; }
.lead-form label { display: grid; gap: 8px; color: #fff; font-size: 0.9rem; font-weight: 900; }
.lead-form input, .lead-form select, .lead-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 6px; background: #0b1030; color: #fff; padding: 13px 14px; outline: none; }
.lead-form textarea { resize: vertical; }
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus { border-color: var(--violet); box-shadow: 0 0 0 3px rgba(133, 102, 245, 0.16); }
.wide, .form-note { grid-column: 1 / -1; }
.site-footer { display: flex; justify-content: space-between; padding-top: 28px; padding-bottom: 28px; border-top: 1px solid var(--line); background: linear-gradient(90deg, rgba(74, 213, 220, 0.28), rgba(133, 102, 245, 0.32)); color: var(--muted); font-weight: 800; }

@media (max-width: 980px) {
  .menu-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .nav-links { position: absolute; top: 76px; left: 0; right: 0; display: none; flex-direction: column; align-items: stretch; gap: 0; padding: 18px; background: linear-gradient(135deg, rgba(74, 213, 220, 0.28), rgba(133, 102, 245, 0.36)), rgba(10, 17, 35, 0.98); border-bottom: 1px solid var(--line); }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 14px; }
  .hero, .process-shell, .success-feature, .contact-section { grid-template-columns: 1fr; }
  .trust-strip, .proof-band, .service-grid, .countries, .approval-grid, .reviews-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .site-header { min-height: 68px; }
  .nav-links { top: 68px; }
  .hero { min-height: auto; padding-top: 52px; }
  h1 { font-size: clamp(3.6rem, 17vw, 5.3rem); }
  .hero-actions, .button { width: 100%; }
  .trust-strip, .proof-band, .service-grid, .countries, .approval-grid, .reviews-grid, .mini-grid, .lead-form { grid-template-columns: 1fr; }
  .story-copy, .approval-card, .approval-card img { min-height: 300px; }
  .success-image.featured { min-height: 300px; padding: 22px; }
  .success-image.featured img { width: 100%; max-height: 340px; }
  .country-card { min-height: 0; }
  .site-footer { flex-direction: column; gap: 8px; }
}
