/* =============================================================
   EASYVISA SOLUTIONS — style.css
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ── Variables ───────────────────────────────────────────── */
:root {
  --clr-navy:       #152340;
  --clr-navy-light: #1e3360;
  --clr-gold:       #c9a84c;
  --clr-gold-light: #dfc07a;
  --clr-cream:      #f7f4ef;
  --clr-white:      #ffffff;
  --clr-text:       #1a1a1a;
  --clr-text-mid:   #4a4a4a;
  --clr-text-muted: #6b7280;
  --clr-border:     #e4dfd6;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'DM Sans', 'Helvetica Neue', Arial, sans-serif;

  --fs-xs:   0.75rem;
  --fs-sm:   0.875rem;
  --fs-base: 1rem;
  --fs-md:   1.125rem;
  --fs-lg:   1.25rem;
  --fs-xl:   clamp(1.4rem, 2vw, 1.75rem);
  --fs-2xl:  clamp(1.75rem, 3vw, 2.25rem);
  --fs-3xl:  clamp(2rem, 4vw, 3rem);
  --fs-hero: clamp(2.75rem, 6vw, 4.5rem);

  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-8:  2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  --container-max: 1200px;
  --section-pad:   clamp(4rem, 8vw, 7rem);

  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   16px;
  --radius-full: 999px;

  --shadow-sm: 0 1px 3px rgba(0,0,0,.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,.10);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.14);

  --trans-fast: 150ms ease;
  --trans-base: 250ms ease;
  --trans-slow: 400ms ease;

  --nav-h: 72px;
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: var(--font-body); font-size: var(--fs-base); line-height: 1.7; color: var(--clr-text); background: var(--clr-white); -webkit-font-smoothing: antialiased; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: inherit; font-size: inherit; }
address { font-style: normal; }

/* ── Typography ──────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); font-weight: 600; line-height: 1.2; color: var(--clr-navy); }
h1 { font-size: var(--fs-hero); }
h2 { font-size: var(--fs-3xl); }
h3 { font-size: var(--fs-2xl); }
h4 { font-size: var(--fs-xl); }
h5 { font-size: var(--fs-lg); font-family: var(--font-body); }
p  { max-width: 72ch; }
p + p { margin-top: var(--space-4); }

/* ── Layout ──────────────────────────────────────────────── */
.container { width: 100%; max-width: var(--container-max); margin-inline: auto; padding-inline: clamp(1.25rem, 5vw, 2.5rem); }
section { padding-block: var(--section-pad); }
.bg-cream { background: var(--clr-cream); }

/* ── Shared ──────────────────────────────────────────────── */
.section-label { display: inline-block; font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--clr-gold); margin-bottom: var(--space-4); }
.section-header { margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section-header p { margin-top: var(--space-5); font-size: var(--fs-md); color: var(--clr-text-mid); }
.gold-rule { display: block; width: 48px; height: 3px; background: var(--clr-gold); border-radius: 2px; margin-top: var(--space-4); margin-bottom: var(--space-5); }
.text-center { text-align: center; }
.text-center p { margin-inline: auto; }
.visually-hidden { position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0; border: 0; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }

/* ── Buttons ─────────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; gap: var(--space-2); padding: 0.875rem 2rem; font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; border-radius: var(--radius-sm); transition: all var(--trans-base); white-space: nowrap; }
.btn--primary { background: var(--clr-gold); color: var(--clr-navy); }
.btn--primary:hover { background: var(--clr-gold-light); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--outline { border: 2px solid var(--clr-white); color: var(--clr-white); }
.btn--outline:hover { background: var(--clr-white); color: var(--clr-navy); }
.btn--navy { background: var(--clr-navy); color: var(--clr-white); }
.btn--navy:hover { background: var(--clr-navy-light); transform: translateY(-2px); }
.btn--ghost { color: var(--clr-navy); border: 2px solid var(--clr-navy); }
.btn--ghost:hover { background: var(--clr-navy); color: var(--clr-white); }

/* ── Card ────────────────────────────────────────────────── */
.card { background: var(--clr-white); border-radius: var(--radius-lg); padding: var(--space-8); border: 1px solid var(--clr-border); transition: box-shadow var(--trans-base), transform var(--trans-base); }
.card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.card-icon { width: 56px; height: 56px; background: var(--clr-cream); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-5); }
.card-icon svg { width: 26px; height: 26px; fill: var(--clr-navy); }

/* ── Forms ───────────────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: var(--space-2); }
.form-group label { font-size: var(--fs-sm); font-weight: 600; color: var(--clr-text-mid); }
.form-group input, .form-group textarea, .form-group select { padding: 0.875rem 1.125rem; border: 1.5px solid var(--clr-border); border-radius: var(--radius-md); background: var(--clr-white); color: var(--clr-text); width: 100%; transition: border-color var(--trans-fast), box-shadow var(--trans-fast); }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--clr-navy); box-shadow: 0 0 0 3px rgba(21,35,64,.08); }
.form-group textarea { resize: vertical; min-height: 130px; }

/* ── Page hero ───────────────────────────────────────────── */
.page-hero { background: var(--clr-navy); padding-top: calc(var(--nav-h) + var(--space-16)); padding-bottom: var(--space-16); position: relative; overflow: hidden; }
.page-hero::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23c9a84c' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E"); pointer-events: none; }
.page-hero-content { position: relative; z-index: 1; }
.page-hero h1 { color: var(--clr-white); }
.page-hero p { margin-top: var(--space-5); font-size: var(--fs-md); color: rgba(255,255,255,.75); max-width: 55ch; }

/* ── Breadcrumb ──────────────────────────────────────────── */
.breadcrumb { display: flex; align-items: center; gap: var(--space-2); font-size: var(--fs-sm); color: rgba(255,255,255,.65); margin-bottom: var(--space-5); }
.breadcrumb a { color: rgba(255,255,255,.65); transition: color var(--trans-fast); }
.breadcrumb a:hover { color: var(--clr-gold); }
.breadcrumb-current { color: var(--clr-gold); }

/* ── FAQ accordion ───────────────────────────────────────── */
.faq-item { border-bottom: 1px solid var(--clr-border); }
.faq-question { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-5) 0; font-size: var(--fs-md); font-weight: 600; color: var(--clr-navy); text-align: left; transition: color var(--trans-fast); }
.faq-question:hover, .faq-question[aria-expanded="true"] { color: var(--clr-gold); }
.faq-chevron { width: 20px; height: 20px; fill: currentColor; flex-shrink: 0; transition: transform var(--trans-base); }
.faq-question[aria-expanded="true"] .faq-chevron { transform: rotate(180deg); }
.faq-answer { padding-bottom: var(--space-6); }
.faq-answer p { font-size: var(--fs-sm); color: var(--clr-text-mid); max-width: none; }
.faq-answer ul { margin-top: var(--space-3); display: flex; flex-direction: column; gap: var(--space-2); padding-left: var(--space-5); list-style: disc; }
.faq-answer ul li { font-size: var(--fs-sm); color: var(--clr-text-mid); }

/* ── CTA banner ──────────────────────────────────────────── */
.cta-banner { background: linear-gradient(135deg, var(--clr-gold) 0%, #b8922f 100%); padding-block: var(--space-16); }
.cta-banner-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); flex-wrap: wrap; }
.cta-banner h2 { color: var(--clr-navy); }
.cta-banner p { color: rgba(21,35,64,.75); font-size: var(--fs-md); max-width: 48ch; margin-top: var(--space-2); }
.cta-banner-actions { display: flex; gap: var(--space-4); flex-wrap: wrap; flex-shrink: 0; }
.cta-banner .btn--navy { background: var(--clr-navy); color: var(--clr-white); }
.cta-banner .btn--navy:hover { background: var(--clr-navy-light); }
.cta-banner .btn--ghost { border-color: var(--clr-navy); color: var(--clr-navy); }
.cta-banner .btn--ghost:hover { background: var(--clr-navy); color: var(--clr-white); }

/* ── Nav ─────────────────────────────────────────────────── */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 100; height: var(--nav-h); display: flex; align-items: center; background: rgba(21,35,64,.96); backdrop-filter: blur(8px); border-bottom: 1px solid rgba(201,168,76,.2); transition: box-shadow var(--trans-base); }
.site-header.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,.25); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); width: 100%; max-width: var(--container-max); margin-inline: auto; padding-inline: clamp(1.25rem, 5vw, 2.5rem); }
.nav-logo { display: flex; align-items: center; gap: var(--space-3); }
.nav-logo-icon { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.nav-logo-text { display: flex; flex-direction: column; line-height: 1.1; }
.logo-main { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: var(--clr-white); }
.logo-sub  { font-size: var(--fs-xs); font-weight: 500; color: var(--clr-gold); letter-spacing: 0.1em; text-transform: uppercase; }
.nav-links { display: flex; align-items: center; gap: var(--space-2); }
.nav-links a { padding: var(--space-2) var(--space-4); font-size: var(--fs-sm); font-weight: 500; color: rgba(255,255,255,.85); border-radius: var(--radius-sm); transition: all var(--trans-fast); }
.nav-links a:hover, .nav-links a.active { color: var(--clr-white); background: rgba(255,255,255,.1); }
.nav-links a.active { color: var(--clr-gold); }
.nav-hamburger { display: none; flex-direction: column; gap: 5px; padding: var(--space-2); }
.nav-hamburger span { display: block; width: 24px; height: 2px; background: var(--clr-white); border-radius: 2px; transition: all var(--trans-base); }
.nav-mobile { display: none; position: fixed; inset: var(--nav-h) 0 0 0; background: var(--clr-navy); z-index: 99; flex-direction: column; padding: var(--space-8) var(--space-6); gap: var(--space-2); overflow-y: auto; }
.nav-mobile.open { display: flex; }
.nav-mobile a { padding: var(--space-4); font-size: var(--fs-lg); font-family: var(--font-display); color: rgba(255,255,255,.85); border-bottom: 1px solid rgba(255,255,255,.08); transition: color var(--trans-fast); }
.nav-mobile a:hover { color: var(--clr-gold); }
.nav-mobile .btn { margin-top: var(--space-4); justify-content: center; }

/* ── Footer ──────────────────────────────────────────────── */
.site-footer { background: var(--clr-navy); color: rgba(255,255,255,.75); padding-top: var(--space-20); padding-bottom: var(--space-10); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: var(--space-10); padding-bottom: var(--space-12); border-bottom: 1px solid rgba(255,255,255,.1); }
.footer-logo-icon { width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-4); }
.footer-logo-name { font-family: var(--font-display); font-size: var(--fs-xl); font-weight: 700; color: var(--clr-white); }
.footer-brand p { margin-top: var(--space-5); font-size: var(--fs-sm); max-width: 34ch; line-height: 1.8; }
.footer-col h5 { font-family: var(--font-body); font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--clr-gold); margin-bottom: var(--space-5); }
.footer-col ul { display: flex; flex-direction: column; gap: var(--space-3); }
.footer-col ul li a { font-size: var(--fs-sm); color: rgba(255,255,255,.7); transition: color var(--trans-fast); }
.footer-col ul li a:hover { color: var(--clr-white); }
.footer-contact-item { display: flex; align-items: flex-start; gap: var(--space-3); font-size: var(--fs-sm); color: rgba(255,255,255,.7); margin-bottom: var(--space-4); }
.footer-contact-item svg, .footer-contact-item img { width: 16px; height: 16px; flex-shrink: 0; margin-top: 3px; }
.footer-contact-item svg { fill: var(--clr-gold); }
.footer-bottom { padding-top: var(--space-8); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--space-4); font-size: var(--fs-xs); color: rgba(255,255,255,.45); }

/* ── Home: Hero ──────────────────────────────────────────── */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; padding-top: var(--nav-h); overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(13,27,53,0.85) 0%, rgba(21,35,64,0.80) 100%), url('/assets/images/travel-people-airport.webp') center/cover no-repeat; }
.hero-bg::after { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 20% 50%, rgba(201,168,76,.08) 0%, transparent 50%), radial-gradient(circle at 80% 20%, rgba(201,168,76,.06) 0%, transparent 40%); pointer-events: none; }
.hero-content { position: relative; z-index: 1; padding-block: var(--space-24); }
.hero-eyebrow { font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--clr-gold); margin-bottom: var(--space-5); max-width: none; }
.hero-heading { color: var(--clr-white); max-width: 14ch; line-height: 1.1; }
.hero-heading em { font-style: italic; color: var(--clr-gold); }
.hero-sub { margin-top: var(--space-6); font-size: clamp(1rem, 1.5vw, 1.2rem); color: rgba(255,255,255,.78); max-width: 52ch; line-height: 1.8; }
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--space-4); margin-top: var(--space-8); }

/* ── Home: Intro ─────────────────────────────────────────── */
.intro-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem, 6vw, 6rem); align-items: center; }
.intro-badges { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); margin-top: var(--space-8); }
.intro-badge { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--clr-cream); border-radius: var(--radius-md); border: 1px solid var(--clr-border); font-size: var(--fs-sm); font-weight: 500; color: var(--clr-text-mid); }
.intro-badge svg { width: 18px; height: 18px; fill: var(--clr-gold); flex-shrink: 0; }
.intro-visual { position: relative; display: flex; flex-direction: column; gap: var(--space-4); }
.intro-visual-card { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-5) var(--space-6); border-radius: var(--radius-lg); position: relative; z-index: 1; }
.intro-visual-card--main { background: var(--clr-navy); color: var(--clr-white); }
.intro-visual-card--secondary { background: var(--clr-cream); border: 1px solid var(--clr-border); margin-left: var(--space-8); }
.intro-visual-card--accent { background: var(--clr-gold); color: var(--clr-navy); }
.intro-visual-card strong { display: block; font-size: var(--fs-md); }
.intro-visual-card--main strong { color: var(--clr-gold); }
.intro-visual-card p { font-size: var(--fs-sm); max-width: none; margin: 0; }
.intro-visual-card--main p { color: rgba(255,255,255,.7); }
.intro-visual-card--secondary p { color: var(--clr-text-muted); }
.intro-visual-card--accent p { opacity: .75; }
.intro-visual-icon { width: 48px; height: 48px; background: rgba(255,255,255,.15); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.intro-visual-card--secondary .intro-visual-icon { background: var(--clr-navy); }
.intro-visual-card--accent .intro-visual-icon { background: rgba(21,35,64,.15); }
.intro-visual-icon svg { width: 24px; height: 24px; fill: currentColor; }
.intro-visual-card--main .intro-visual-icon svg { fill: var(--clr-gold); }
.intro-visual-card--secondary .intro-visual-icon svg { fill: var(--clr-white); }
.intro-visual-bg-shape { position: absolute; bottom: -2rem; right: -2rem; width: 180px; height: 180px; background: radial-gradient(circle, rgba(201,168,76,.12) 0%, transparent 70%); border-radius: 50%; pointer-events: none; }

/* ── Home: Services ──────────────────────────────────────── */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.services-card { display: flex; flex-direction: column; }
.services-card h3 { font-size: var(--fs-xl); margin-bottom: var(--space-3); }
.services-card > p { font-size: var(--fs-sm); color: var(--clr-text-mid); flex: 1; }
.services-card-link { display: inline-flex; align-items: center; gap: 0.25rem; margin-top: var(--space-5); font-size: var(--fs-sm); font-weight: 600; color: var(--clr-navy); transition: gap var(--trans-fast), color var(--trans-fast); }
.services-card-link:hover { color: var(--clr-gold); gap: var(--space-3); }
.services-card-link svg { width: 16px; height: 16px; fill: currentColor; }
.services-card-link span { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }
.services-card--cta { background: var(--clr-navy); border-color: transparent; display: flex; align-items: center; justify-content: center; text-align: center; }
.services-card--cta h3 { color: var(--clr-white); font-size: var(--fs-2xl); margin-top: var(--space-3); }
.services-card--cta > p { color: rgba(255,255,255,.7); margin-inline: auto; margin-top: var(--space-4); }

/* ── Home: Why ───────────────────────────────────────────── */
.why-section { background: var(--clr-navy); }
.why-grid { display: grid; grid-template-columns: 1fr 1.6fr; gap: clamp(3rem, 6vw, 6rem); align-items: start; }
.why-list { display: flex; flex-direction: column; gap: var(--space-6); }
.why-item { display: flex; gap: var(--space-5); padding: var(--space-6); background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius-lg); transition: background var(--trans-base), border-color var(--trans-base); }
.why-item:hover { background: rgba(255,255,255,.08); border-color: rgba(201,168,76,.3); }
.why-item-icon { width: 48px; height: 48px; background: rgba(201,168,76,.12); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.why-item-icon svg { width: 24px; height: 24px; fill: var(--clr-gold); }
.why-item h3 { font-size: var(--fs-lg); color: var(--clr-white); margin-bottom: var(--space-2); }
.why-item p { font-size: var(--fs-sm); color: rgba(255,255,255,.65); max-width: none; }

/* ── Home: Process ───────────────────────────────────────── */
.process-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }
.process-step { position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; }
.process-step-num { width: 56px; height: 56px; background: var(--clr-navy); color: var(--clr-gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: var(--fs-xl); font-weight: 700; flex-shrink: 0; position: relative; z-index: 1; border: 3px solid var(--clr-gold); }
.process-step-connector { position: absolute; top: 28px; left: calc(50% + 28px); right: calc(-50% + 28px); height: 2px; background: linear-gradient(90deg, var(--clr-gold), rgba(201,168,76,.3)); }
.process-step:last-child .process-step-connector { display: none; }
.process-step-body { margin-top: var(--space-5); padding: var(--space-5); }
.process-step-body h3 { font-size: var(--fs-lg); margin-bottom: var(--space-3); }
.process-step-body p { font-size: var(--fs-sm); color: var(--clr-text-mid); max-width: none; }

/* ── Home: FAQ teaser ────────────────────────────────────── */
.faq-teaser-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(3rem, 6vw, 6rem); align-items: start; }
.faq-teaser-list { display: flex; flex-direction: column; }

/* ── Practice Areas ──────────────────────────────────────── */
.practice-nav { background: var(--clr-cream); border-bottom: 1px solid var(--clr-border); padding-block: var(--space-4); }
.practice-nav-list { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.practice-nav-list a { font-size: var(--fs-sm); font-weight: 500; color: var(--clr-text-mid); padding: var(--space-2) var(--space-4); border-radius: var(--radius-full); border: 1px solid var(--clr-border); background: var(--clr-white); transition: all var(--trans-fast); white-space: nowrap; }
.practice-nav-list a:hover { background: var(--clr-navy); color: var(--clr-white); border-color: var(--clr-navy); }
.practice-section { padding-block: var(--section-pad); scroll-margin-top: calc(var(--nav-h) + 2rem); }
.practice-section:nth-child(even) { background: var(--clr-cream); }
.practice-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem, 6vw, 6rem); align-items: center; }
.practice-grid--reverse { direction: rtl; }
.practice-grid--reverse > * { direction: ltr; }
.practice-text h2 { font-size: var(--fs-3xl); margin-bottom: var(--space-5); }
.practice-text p { color: var(--clr-text-mid); }
.practice-text p + p { margin-top: var(--space-4); }
.practice-image { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3; }
.practice-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform var(--trans-slow); }
.practice-image:hover img { transform: scale(1.03); }
.visa-types { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-6); }
.visa-type-tag { font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.05em; color: var(--clr-navy); background: var(--clr-cream); border: 1px solid var(--clr-border); padding: var(--space-2) var(--space-4); border-radius: var(--radius-full); }
.practice-section:nth-child(even) .visa-type-tag { background: var(--clr-white); }
.practice-cta { margin-top: var(--space-8); }

/* ── FAQ Page ────────────────────────────────────────────── */
.faq-layout { display: grid; grid-template-columns: 1fr 280px; gap: var(--space-12); align-items: start; }
.faq-group { margin-bottom: var(--space-12); }
.faq-group-title { font-size: var(--fs-xl); color: var(--clr-navy); margin-bottom: var(--space-6); padding-bottom: var(--space-4); border-bottom: 2px solid var(--clr-border); }
.faq-list { display: flex; flex-direction: column; }
.faq-sidebar { position: sticky; top: calc(var(--nav-h) + var(--space-8)); display: flex; flex-direction: column; gap: var(--space-6); }
.faq-sidebar-card { background: var(--clr-cream); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: var(--space-6); }
.faq-sidebar-card h3 { font-size: var(--fs-lg); margin-bottom: var(--space-3); }
.faq-sidebar-card p { font-size: var(--fs-sm); color: var(--clr-text-mid); max-width: none; }
.faq-sidebar-card .btn { width: 100%; justify-content: center; margin-top: var(--space-5); }
.faq-sidebar-card--navy { background: var(--clr-navy); border-color: transparent; }
.faq-sidebar-card--navy h3 { color: var(--clr-white); }
.faq-sidebar-card--navy p { color: rgba(255,255,255,.7); }
.faq-category-link { font-size: var(--fs-sm); color: var(--clr-text-mid); padding: var(--space-2) 0; border-bottom: 1px solid var(--clr-border); transition: color var(--trans-fast); display: flex; justify-content: space-between; align-items: center; }
.faq-category-link:hover { color: var(--clr-navy); }
.faq-category-link svg { width: 16px; height: 16px; fill: currentColor; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
  .footer-brand { grid-column: 1 / -1; }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .process-steps { grid-template-columns: repeat(2, 1fr); }
  .process-step-connector { display: none; }
}

@media (max-width: 860px) {
  .nav-links, .nav-cta { display: none; }
  .nav-hamburger { display: flex; }
  .intro-grid { grid-template-columns: 1fr; }
  .intro-visual { display: none; }
  .why-grid { grid-template-columns: 1fr; }
  .faq-teaser-grid { grid-template-columns: 1fr; }
  .practice-grid { grid-template-columns: 1fr; }
  .practice-grid--reverse { direction: ltr; }
  .faq-layout { grid-template-columns: 1fr; }
  .faq-sidebar { position: static; }
}

@media (max-width: 640px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .services-grid { grid-template-columns: 1fr; }
  .process-steps { grid-template-columns: 1fr; }
  .intro-badges { grid-template-columns: 1fr; }
  .cta-banner-inner { flex-direction: column; text-align: center; }
  .cta-banner-actions { justify-content: center; }
}

/* ── Blog ────────────────────────────────────────────────── */
.blog-filters { background: var(--clr-cream); border-bottom: 1px solid var(--clr-border); padding-block: var(--space-4); }
.blog-filters-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--space-4); }
.blog-category-list { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.blog-category-btn { font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.05em; color: var(--clr-text-mid); background: var(--clr-white); border: 1px solid var(--clr-border); padding: var(--space-2) var(--space-4); border-radius: var(--radius-full); cursor: pointer; transition: all var(--trans-fast); }
.blog-category-btn:hover, .blog-category-btn.active { background: var(--clr-navy); color: var(--clr-white); border-color: var(--clr-navy); }
.blog-search { display: flex; align-items: center; gap: var(--space-2); background: var(--clr-white); border: 1.5px solid var(--clr-border); border-radius: var(--radius-full); padding: var(--space-2) var(--space-4); transition: border-color var(--trans-fast); }
.blog-search:focus-within { border-color: var(--clr-navy); }
.blog-search svg { width: 16px; height: 16px; fill: var(--clr-text-muted); flex-shrink: 0; }
.blog-search input { border: none; background: none; outline: none; font-size: var(--fs-sm); color: var(--clr-text); width: 180px; }

.blog-layout { display: grid; grid-template-columns: 1fr 300px; gap: var(--space-10); align-items: start; }

.blog-featured { margin-bottom: var(--space-10); }
.blog-featured-card { display: grid; grid-template-columns: 1fr 1fr; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--clr-border); background: var(--clr-white); transition: box-shadow var(--trans-base); }
.blog-featured-card:hover { box-shadow: var(--shadow-lg); }
.blog-featured-image { aspect-ratio: 4/3; overflow: hidden; }
.blog-featured-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--trans-slow); }
.blog-featured-card:hover .blog-featured-image img { transform: scale(1.04); }
.blog-featured-body { padding: var(--space-8); display: flex; flex-direction: column; justify-content: center; }

.blog-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
.blog-card { background: var(--clr-white); border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--clr-border); transition: box-shadow var(--trans-base), transform var(--trans-base); display: flex; flex-direction: column; }
.blog-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.blog-card-image { aspect-ratio: 16/9; overflow: hidden; }
.blog-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--trans-slow); }
.blog-card:hover .blog-card-image img { transform: scale(1.04); }
.blog-card-body { padding: var(--space-6); display: flex; flex-direction: column; flex: 1; }

.post-tag { display: inline-block; font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--clr-gold); margin-bottom: var(--space-3); }
.post-title { font-family: var(--font-display); font-size: var(--fs-xl); font-weight: 600; color: var(--clr-navy); line-height: 1.3; margin-bottom: var(--space-3); }
.post-title a { transition: color var(--trans-fast); }
.post-title a:hover { color: var(--clr-gold); }
.post-excerpt { font-size: var(--fs-sm); color: var(--clr-text-mid); line-height: 1.7; max-width: none; flex: 1; }
.post-meta { display: flex; align-items: center; gap: var(--space-4); margin-top: var(--space-5); padding-top: var(--space-4); border-top: 1px solid var(--clr-border); font-size: var(--fs-xs); color: var(--clr-text-muted); }
.post-meta-item { display: flex; align-items: center; gap: var(--space-2); }
.post-meta-item svg { width: 13px; height: 13px; fill: currentColor; }
.post-read-more { display: inline-flex; align-items: center; gap: var(--space-2); margin-top: var(--space-5); font-size: var(--fs-sm); font-weight: 600; color: var(--clr-navy); transition: color var(--trans-fast), gap var(--trans-fast); }
.post-read-more:hover { color: var(--clr-gold); gap: var(--space-3); }
.post-read-more svg { width: 16px; height: 16px; fill: currentColor; }

.no-results { display: none; padding: var(--space-16) 0; text-align: center; color: var(--clr-text-muted); }
.no-results.visible { display: block; }

.blog-sidebar { position: sticky; top: calc(var(--nav-h) + var(--space-8)); display: flex; flex-direction: column; gap: var(--space-6); }
.sidebar-card { background: var(--clr-cream); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: var(--space-6); }
.sidebar-card--navy { background: var(--clr-navy); border-color: transparent; }
.sidebar-card h3 { font-size: var(--fs-lg); margin-bottom: var(--space-5); }
.sidebar-card--navy h3 { color: var(--clr-white); }
.sidebar-card--navy p { color: rgba(255,255,255,.7); font-size: var(--fs-sm); max-width: none; }
.sidebar-card--navy .btn { width: 100%; justify-content: center; margin-top: var(--space-5); }
.sidebar-category-list { display: flex; flex-direction: column; gap: var(--space-1); }
.sidebar-category-link { display: flex; justify-content: space-between; align-items: center; padding: var(--space-3) 0; border-bottom: 1px solid var(--clr-border); font-size: var(--fs-sm); color: var(--clr-text-mid); transition: color var(--trans-fast); }
.sidebar-category-link:last-child { border-bottom: none; }
.sidebar-category-link:hover { color: var(--clr-navy); }
.sidebar-category-count { font-size: var(--fs-xs); background: var(--clr-white); border: 1px solid var(--clr-border); border-radius: var(--radius-full); padding: 2px 8px; }
.sidebar-post-list { display: flex; flex-direction: column; gap: var(--space-4); }
.sidebar-post { display: flex; gap: var(--space-3); }
.sidebar-post-image { width: 64px; height: 64px; border-radius: var(--radius-md); overflow: hidden; flex-shrink: 0; }
.sidebar-post-image img { width: 100%; height: 100%; object-fit: cover; }
.sidebar-post-title { font-size: var(--fs-sm); font-weight: 600; color: var(--clr-navy); line-height: 1.4; transition: color var(--trans-fast); }
.sidebar-post-title:hover { color: var(--clr-gold); }
.sidebar-post-date { font-size: var(--fs-xs); color: var(--clr-text-muted); margin-top: var(--space-1); }

.blog-card[data-category] { transition: opacity var(--trans-base), transform var(--trans-base); }
.blog-card.hidden { display: none; }

@media (max-width: 1024px) {
  .blog-layout { grid-template-columns: 1fr; }
  .blog-sidebar { position: static; }
}
@media (max-width: 860px) {
  .blog-featured-card { grid-template-columns: 1fr; }
  .blog-filters-inner { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 640px) {
  .blog-grid { grid-template-columns: 1fr; }
  .blog-search input { width: 140px; }
}

/* ── Blog ────────────────────────────────────────────────── */
.blog-filter { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-10); }
.blog-filter-btn { font-size: var(--fs-sm); font-weight: 500; color: var(--clr-text-mid); padding: var(--space-2) var(--space-4); border-radius: var(--radius-full); border: 1px solid var(--clr-border); background: var(--clr-white); cursor: pointer; transition: all var(--trans-fast); }
.blog-filter-btn:hover { border-color: var(--clr-navy); color: var(--clr-navy); }
.blog-filter-btn.active { background: var(--clr-navy); color: var(--clr-white); border-color: var(--clr-navy); }

.blog-featured { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); align-items: center; margin-bottom: var(--space-12); background: var(--clr-cream); border-radius: var(--radius-lg); overflow: hidden; }
.blog-featured-image { aspect-ratio: 16/9; overflow: hidden; }
.blog-featured-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--trans-slow); }
.blog-featured:hover .blog-featured-image img { transform: scale(1.03); }
.blog-featured-body { padding: var(--space-8); }
.blog-featured-title { font-size: var(--fs-2xl); margin: var(--space-3) 0 var(--space-4); }
.blog-featured-title a { color: var(--clr-navy); transition: color var(--trans-fast); }
.blog-featured-title a:hover { color: var(--clr-gold); }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.blog-card { background: var(--clr-white); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); overflow: hidden; transition: box-shadow var(--trans-base), transform var(--trans-base); }
.blog-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.blog-card-image { aspect-ratio: 3/2; overflow: hidden; }
.blog-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--trans-slow); }
.blog-card:hover .blog-card-image img { transform: scale(1.04); }
.blog-card-body { padding: var(--space-6); }
.blog-card-title { font-size: var(--fs-lg); margin: var(--space-3) 0 var(--space-3); line-height: 1.35; }
.blog-card-title a { color: var(--clr-navy); transition: color var(--trans-fast); }
.blog-card-title a:hover { color: var(--clr-gold); }

.blog-category { display: inline-block; font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--clr-gold); }
.blog-excerpt { font-size: var(--fs-sm); color: var(--clr-text-mid); margin-top: var(--space-2); max-width: none; }
.blog-meta { display: flex; gap: var(--space-4); font-size: var(--fs-xs); color: var(--clr-text-muted); margin-top: var(--space-4); }

@media (max-width: 1024px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 860px) {
  .blog-featured { grid-template-columns: 1fr; }
  .blog-featured-image { aspect-ratio: 16/9; }
}

@media (max-width: 640px) {
  .blog-grid { grid-template-columns: 1fr; }
}

/* ── Contact ──────────────────────────────────────────────── */
.contact-grid { display: grid; grid-template-columns: 1fr 380px; gap: var(--space-12); align-items: start; }
.contact-form-wrap h2 { font-size: var(--fs-2xl); margin-bottom: var(--space-3); }
.contact-form-wrap > p { color: var(--clr-text-mid); margin-bottom: var(--space-8); }
.contact-form { display: flex; flex-direction: column; gap: var(--space-5); margin-top: var(--space-6); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }
.field-error { font-size: var(--fs-xs); color: #c62828; margin-top: var(--space-1); }
.form-status { font-size: var(--fs-sm); font-weight: 500; padding: var(--space-4); border-radius: var(--radius-md); margin-bottom: var(--space-6); }
.form-status--success { background: #e8f5e9; color: #2e7d32; }
.form-status--error { background: #ffebee; color: #c62828; }

.contact-info { display: flex; flex-direction: column; gap: var(--space-6); position: sticky; top: calc(var(--nav-h) + var(--space-8)); }
.contact-info-card { background: var(--clr-cream); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: var(--space-6); }
.contact-info-card h3 { font-size: var(--fs-xl); margin-bottom: var(--space-5); }
.contact-info-card p { font-size: var(--fs-sm); color: var(--clr-text-mid); max-width: none; margin-bottom: var(--space-5); }
.contact-info-card--navy { background: var(--clr-navy); border-color: transparent; }
.contact-info-card--navy h3 { color: var(--clr-white); }
.contact-info-card--navy p { color: rgba(255,255,255,.7); }
.contact-info-item { display: flex; align-items: flex-start; gap: var(--space-4); padding: var(--space-4) 0; border-bottom: 1px solid var(--clr-border); }
.contact-info-item:last-child { border-bottom: none; }
.contact-info-item svg { width: 18px; height: 18px; fill: var(--clr-gold); flex-shrink: 0; margin-top: 3px; }
.contact-info-item img { flex-shrink: 0; margin-top: 3px; }
.contact-info-item div { display: flex; flex-direction: column; gap: 2px; }
.contact-info-item strong { font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--clr-text-muted); }
.contact-info-item span, .contact-info-item a { font-size: var(--fs-sm); color: var(--clr-text-mid); }
.contact-info-item a:hover { color: var(--clr-navy); }

@media (max-width: 860px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact-info { position: static; }
  .form-row { grid-template-columns: 1fr; }
}

/* ── Blog Post ────────────────────────────────────────────── */
.post-meta { display: flex; gap: var(--space-4); font-size: var(--fs-xs); color: rgba(255,255,255,.6); margin-top: var(--space-4); text-transform: uppercase; letter-spacing: 0.06em; }
.post-layout { display: grid; grid-template-columns: 1fr 300px; gap: var(--space-12); align-items: start; padding-block: var(--section-pad); }
.post-body { min-width: 0; }
.post-hero-image { width: 100%; border-radius: var(--radius-lg); margin-bottom: var(--space-10); aspect-ratio: 16/9; object-fit: cover; }
.post-intro { font-size: var(--fs-md); color: var(--clr-text-mid); border-left: 3px solid var(--clr-gold); padding-left: var(--space-5); margin-bottom: var(--space-8); max-width: none; }
.post-body h2 { font-size: var(--fs-2xl); margin-top: var(--space-10); margin-bottom: var(--space-4); }
.post-body h3 { font-size: var(--fs-xl); margin-top: var(--space-8); margin-bottom: var(--space-3); }
.post-body p { color: var(--clr-text-mid); margin-bottom: var(--space-4); max-width: none; }
.post-body ul { margin: var(--space-4) 0 var(--space-6) var(--space-6); display: flex; flex-direction: column; gap: var(--space-2); list-style: disc; }
.post-body ul li { font-size: var(--fs-base); color: var(--clr-text-mid); }
.post-body a { color: var(--clr-navy); text-decoration: underline; text-underline-offset: 3px; }
.post-body a:hover { color: var(--clr-gold); }
.post-affiliate-box { background: var(--clr-cream); border: 1px solid var(--clr-border); border-left: 3px solid var(--clr-gold); border-radius: var(--radius-md); padding: var(--space-6); margin: var(--space-8) 0; }
.post-affiliate-box p { font-size: var(--fs-sm); color: var(--clr-text-mid); margin-bottom: var(--space-4); max-width: none; }
.post-cta-box { background: var(--clr-navy); border-radius: var(--radius-lg); padding: var(--space-8); margin-top: var(--space-10); }
.post-cta-box h3 { color: var(--clr-white); font-size: var(--fs-xl); margin-bottom: var(--space-3); }
.post-cta-box p { color: rgba(255,255,255,.75); font-size: var(--fs-sm); max-width: none; margin-bottom: var(--space-5); }

.post-sidebar { position: sticky; top: calc(var(--nav-h) + var(--space-8)); display: flex; flex-direction: column; gap: var(--space-5); }
.sidebar-card { background: var(--clr-cream); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: var(--space-6); }
.sidebar-card h3 { font-size: var(--fs-lg); margin-bottom: var(--space-3); }
.sidebar-card p { font-size: var(--fs-sm); color: var(--clr-text-mid); max-width: none; margin-bottom: var(--space-4); }
.sidebar-card .btn { width: 100%; justify-content: center; }
.sidebar-links { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-2); }
.sidebar-links li a { font-size: var(--fs-sm); color: var(--clr-navy); text-decoration: underline; text-underline-offset: 3px; transition: color var(--trans-fast); }
.sidebar-links li a:hover { color: var(--clr-gold); }

@media (max-width: 860px) {
  .post-layout { grid-template-columns: 1fr; }
  .post-sidebar { position: static; }
}