/* ============================================================
   HOME PAGE — vizasupport
   ============================================================ */

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  background: var(--surface-dark);
  color: #ffffff;
  overflow: hidden;
  min-height: 460px;
  display: flex;
  align-items: center;
}

@media (min-width: 768px)  { .hero { min-height: 500px; } }
@media (min-width: 1024px) { .hero { min-height: 540px; } }

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  will-change: transform; /* smooth parallax */
}

.hero__bg-fallback {
  width: 100%;
  height: 100%;
  background: linear-gradient(
    135deg,
    var(--primary-darker) 0%,
    var(--primary) 60%,
    var(--primary-dark) 100%
  );
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      to right,
      rgba(13,13,13,0.94) 0%,
      rgba(13,13,13,0.72) 42%,
      rgba(13,13,13,0.18) 100%
    ),
    linear-gradient(
      to top,
      rgba(13,13,13,0.65) 0%,
      transparent 55%
    );
  z-index: 1;
}

/* Subtle mesh grid overlay */
.hero__overlay::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
}

.hero__overlay::after {
  content: '';
  position: absolute;
  bottom: -10%;
  left: -5%;
  width: 55%;
  height: 80%;
  background: radial-gradient(ellipse at center, rgba(29,122,74,0.18) 0%, transparent 65%);
  pointer-events: none;
}

.hero__inner {
  position: relative;
  z-index: 2;
  padding-block: var(--space-3xl);
  max-width: 660px;
}

@media (min-width: 1024px) {
  .hero__inner { padding-block: var(--space-4xl); }
}

.hero__label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  background: rgba(232,168,0,0.12);
  border: 1px solid rgba(232,168,0,0.40);
  color: var(--secondary);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-lg);
  /* entrance animation */
  animation: fadeInDown 0.60s var(--ease-out) 0.1s both;
}

.hero__title {
  font-size: var(--text-2xl);
  font-weight: var(--font-black);
  line-height: var(--leading-tight);
  color: #ffffff;
  margin-bottom: var(--space-lg);
  letter-spacing: -0.02em;
  animation: fadeInUp 0.70s var(--ease-out) 0.22s both;
}

.hero__title em {
  font-style: normal;
  color: var(--secondary);
}

@media (min-width: 640px)  { .hero__title { font-size: var(--text-2xl); } }
@media (min-width: 1024px) { .hero__title { font-size: var(--text-3xl); } }

.hero__desc {
  font-size: var(--text-base);
  color: rgba(255,255,255,0.75);
  line-height: var(--leading-loose);
  margin-bottom: var(--space-xl);
  max-width: 500px;
  animation: fadeInUp 0.70s var(--ease-out) 0.35s both;
}

@media (min-width: 768px) { .hero__desc { font-size: var(--text-md); } }

.hero__actions {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  align-items: center;
  animation: fadeInUp 0.70s var(--ease-out) 0.46s both;
}

/* ── Hero Search ────────────────────────────────────────── */
.hero__search {
  margin-top: var(--space-xl);
  max-width: 580px;
  animation: fadeInUp 0.70s var(--ease-out) 0.55s both;
}

.search-form {
  display: flex;
  align-items: center;
  background: rgba(255,255,255,0.96);
  border-radius: var(--radius-full);
  overflow: hidden;
  box-shadow: 0 4px 32px rgba(0,0,0,0.25);
  border: 2px solid rgba(255,255,255,0.15);
  transition: box-shadow var(--transition);
}

.search-form:focus-within {
  box-shadow: 0 4px 32px rgba(0,0,0,0.30), 0 0 0 3px rgba(29,122,74,0.25);
}

/* Country select wrapper */
.search-form__select-wrap {
  position: relative;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  border-right: 1px solid var(--color-border);
}

.search-form__select {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: none;
  padding: var(--space-md) var(--space-2xl) var(--space-md) var(--space-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--gray-700);
  font-family: var(--font-body);
  cursor: pointer;
  outline: none;
  white-space: nowrap;
  min-width: 120px;
  max-width: 160px;
}

@media (min-width: 640px) {
  .search-form__select { min-width: 140px; }
}

.search-form__select-wrap span {
  position: absolute;
  right: var(--space-sm);
  pointer-events: none;
  color: var(--gray-400);
  display: flex;
  align-items: center;
}

.search-form__select-wrap span svg {
  width: 12px;
  height: 12px;
}

.search-form__sep {
  width: 1px;
  height: 24px;
  background: var(--color-border);
  flex-shrink: 0;
  display: none;
}

/* Text input */
.search-form__input {
  flex: 1;
  border: none;
  padding: var(--space-md) var(--space-lg);
  font-size: var(--text-sm);
  color: var(--gray-800);
  font-family: var(--font-body);
  background: transparent;
  outline: none;
  min-width: 0;
}

.search-form__input::placeholder {
  color: var(--gray-400);
}

/* Submit button */
.search-form__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  min-width: 48px;
  background: var(--primary);
  color: #ffffff;
  border: none;
  cursor: pointer;
  border-radius: 0 var(--radius-full) var(--radius-full) 0;
  transition: background var(--transition-fast);
  flex-shrink: 0;
}

.search-form__btn:hover {
  background: var(--primary-dark);
}

.search-form__btn svg {
  width: 16px;
  height: 16px;
}

/* ── Hero Stats ─────────────────────────────────────────── */
.hero__stats {
  display: flex;
  gap: var(--space-2xl);
  margin-top: var(--space-2xl);
  flex-wrap: wrap;
  padding-top: var(--space-xl);
  border-top: 1px solid rgba(255,255,255,0.12);
  animation: fadeInUp 0.70s var(--ease-out) 0.65s both;
}

.hero__stat { display: flex; flex-direction: column; }

.hero__stat-value {
  font-size: var(--text-xl);
  font-weight: var(--font-black);
  color: var(--secondary);
  line-height: 1;
  letter-spacing: -0.02em;
}

.hero__stat-label {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.50);
  margin-top: 5px;
  letter-spacing: 0.03em;
}

/* Scroll indicator */
.hero__scroll {
  position: absolute;
  bottom: var(--space-xl);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: rgba(255,255,255,0.35);
  font-size: var(--text-xs);
}

@media (min-width: 1024px) { .hero__scroll { display: flex; } }

.hero__scroll-line {
  width: 1px;
  height: 32px;
  background: linear-gradient(to bottom, rgba(255,255,255,0.35), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

@keyframes scrollPulse {
  0%, 100% { opacity: 0.4; }
  50%       { opacity: 1; }
}

/* ══════════════════════════════════════════════════════════
   SECTION GLOBAL
══════════════════════════════════════════════════════════ */
.section {
  padding-block: var(--section-py);
}

.section--sm {
  padding-block: var(--section-py-sm);
}

/* ── Section header — redesigned ───────────────────────── */
.section-header {
  margin-bottom: var(--space-2xl);
  position: relative;
}

.section-header--center {
  text-align: center;
}

.section-header--split {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-lg);
  flex-wrap: wrap;
}

.section-header__title {
  font-size: var(--text-2xl);
  font-weight: var(--font-black);
  line-height: var(--leading-tight);
  color: var(--gray-900);
  letter-spacing: -0.02em;
  margin-top: var(--space-sm);
  margin-bottom: var(--space-sm);
}

@media (min-width: 768px) {
  .section-header__title { font-size: var(--text-3xl); }
}

/* White title variant (for dark sections) */
.section-header--light .section-header__title {
  color: #ffffff;
}

.section-header__desc {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
  max-width: 520px;
}

.section-header--center .section-header__desc {
  margin-inline: auto;
}

.section-header--light .section-header__desc {
  color: rgba(255,255,255,0.65);
}

/* Eyebrow label */
.label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--primary);
  background: var(--primary-xlight);
  border: 1px solid rgba(29,122,74,0.2);
  padding: 4px 12px;
  border-radius: var(--radius-full);
}

.label--gold {
  color: var(--secondary-dark);
  background: var(--secondary-light);
  border-color: rgba(232,168,0,0.25);
}

/* Decorative line under section header center */

.section-header--split::after,
.section-header--light::after {
  display: none;
}

/* ══════════════════════════════════════════════════════════
   POPULAR VISAS — green-tinted background
══════════════════════════════════════════════════════════ */
.popular-visas {
  background: var(--color-bg-alt);
  position: relative;
}

.visas-scroll {
  display: flex;
  gap: var(--space-sm);
  overflow-x: auto;
  padding-bottom: var(--space-md);
  scrollbar-width: none;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.visas-scroll::-webkit-scrollbar { display: none; }

.visa-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: #ffffff;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--gray-700);
  text-decoration: none;
  white-space: nowrap;
  scroll-snap-align: start;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
  transition:
    border-color var(--transition-fast),
    color        var(--transition-fast),
    box-shadow   var(--transition-fast),
    transform    var(--transition-fast),
    background   var(--transition-fast);
  min-height: 40px;
}

.visa-chip:hover {
  border-color: var(--primary);
  color: var(--primary);
  background: var(--primary-xlight);
  box-shadow: 0 4px 16px rgba(29,122,74,0.14);
  transform: translateY(-2px);
}

.visa-chip:active {
  transform: translateY(0);
}

.visa-chip img {
  width: 26px;
  height: 18px;
  border-radius: 3px;
  object-fit: cover;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════
   HOW IT WORKS — white background, redesigned
══════════════════════════════════════════════════════════ */
.how-it-works {
  background: #ffffff;
  position: relative;
  overflow: hidden;
}

.steps {
  display: grid;
  gap: var(--space-md);
  grid-template-columns: 1fr;
  position: relative;
  counter-reset: step-counter;
}

@media (min-width: 640px) {
  .steps { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .steps { grid-template-columns: repeat(4, 1fr); }
}

.step {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--space-xl);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
  background: var(--color-bg-alt);
  transition: border-color var(--transition), box-shadow var(--transition),
              transform var(--transition);
  position: relative;
  overflow: hidden;
}

.step::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(to right, var(--primary), var(--secondary));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}

.step:hover {
  border-color: rgba(29,122,74,0.15);
  box-shadow: var(--shadow-card);
  transform: translateY(-4px);
}

.step:hover::before {
  transform: scaleX(1);
}

.step__number {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-md);
  font-weight: var(--font-black);
  flex-shrink: 0;
  margin-bottom: var(--space-lg);
  position: relative;
  z-index: 1;
  box-shadow: 0 4px 16px rgba(29,122,74,0.35);
  transition: transform var(--transition), box-shadow var(--transition);
}

.step:hover .step__number {
  transform: scale(1.1);
  box-shadow: 0 8px 28px rgba(29,122,74,0.45);
}

.step__title {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  color: var(--gray-900);
  margin-bottom: var(--space-sm);
  letter-spacing: -0.01em;
}

.step__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
}

/* ══════════════════════════════════════════════════════════
   WHY US — green-tinted background
══════════════════════════════════════════════════════════ */
.why-us {
  background: linear-gradient(135deg, var(--primary-darker) 0%, var(--primary) 60%, var(--primary-dark) 100%);
  position: relative;
}

.why-us__grid {
  display: grid;
  gap: var(--space-md);
  grid-template-columns: repeat(1fr);
}

@media (min-width: 480px)  { .why-us__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .why-us__grid { grid-template-columns: repeat(4, 1fr); } }

.why-card {
  background: rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  border: 1px solid var(--color-border);
  transition: transform var(--transition), border-color var(--transition);
  position: relative;
  overflow: hidden;
}

.why-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(to right, var(--primary), var(--secondary));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}

.why-card:hover {
  transform: translateY(-4px);
  border-color: rgba(29,122,74,0.12);
}

.why-card:hover::before {
  transform: scaleX(1);
}

.why-card__icon {
    width: 44px;
    height: 44px;
    color: var(--gray-100);
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background var(--transition);
}

.why-card__icon svg { width: 24px; height: 24px; }

/* The icon div wraps a span which wraps svg */
.why-card__icon span {
  display: flex;
  align-items: center;
  justify-content: center;
}

.why-card__title {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  color: var(--gray-100);
  letter-spacing: -0.01em;
}

.why-card__desc {
  font-size: var(--text-sm);
  color: var(--gray-100);
  line-height: var(--leading-normal);
}

/* ══════════════════════════════════════════════════════════
   SERVICES SECTION — white background
══════════════════════════════════════════════════════════ */
.services-section {
  background: #ffffff;
}

/* ══════════════════════════════════════════════════════════
   VISA GUIDE STRIP — green gradient
══════════════════════════════════════════════════════════ */
.visa-guide-strip {
  background: linear-gradient(135deg, var(--primary-darker) 0%, var(--primary) 60%, var(--primary-dark) 100%);
  color: #ffffff;
  position: relative;
  overflow: hidden;
}

.visa-guide-strip::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 24px 24px;
  pointer-events: none;
}

.guide-links {
  display: grid;
  gap: var(--space-md);
  grid-template-columns: 1fr;
  position: relative;
  z-index: 1;
}

@media (min-width: 480px)  { .guide-links { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .guide-links { grid-template-columns: repeat(4, 1fr); } }

.guide-link {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-xl);
  color: #ffffff;
  text-decoration: none;
  transition:
    background     var(--transition),
    transform      var(--transition),
    border-color   var(--transition),
    box-shadow     var(--transition);
  min-height: 80px;
}

.guide-link:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.30);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.20);
}

.guide-link:active {
  transform: translateY(-1px);
}

.guide-link__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background var(--transition);
}

.guide-link:hover .guide-link__icon {
  background: rgba(232,168,0,0.22);
}

.guide-link__icon svg { width: 20px; height: 20px; }

.guide-link__title {
  font-size: var(--text-base);
  font-weight: var(--font-semi);
  letter-spacing: -0.01em;
}

.guide-link__desc {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.58);
  margin-top: 3px;
}

/* ══════════════════════════════════════════════════════════
   TESTIMONIALS — white background
══════════════════════════════════════════════════════════ */
.testimonials-section {
  background: #ffffff;
}

.testimonials-grid {
  display: grid;
  gap: var(--space-md);
  grid-template-columns: 1fr;
}

@media (min-width: 640px)  { .testimonials-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1280px) { .testimonials-grid { grid-template-columns: repeat(3, 1fr); } }

/* ══════════════════════════════════════════════════════════
   BLOG STRIP — green-tinted background, redesigned
══════════════════════════════════════════════════════════ */
.blog-strip {
  background: var(--color-bg-alt);
  position: relative;
}

.blog-strip .section-header--split {
  margin-bottom: var(--space-2xl);
}

.blog-strip .section-header--split::after {
  display: none;
}

/* CTA BANNER styles moved to components/cta.css */

/* ══════════════════════════════════════════════════════════
   ARCHIVE GRID (shared)
══════════════════════════════════════════════════════════ */
.archive-grid {
  display: grid;
  gap: var(--space-lg);
  grid-template-columns: 1fr;
}

@media (min-width: 480px) {
  .archive-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .archive-grid { grid-template-columns: repeat(3, 1fr); }
}
