/* ═══════════════════════════════════════════════════════
   Visa Holidays – Main Stylesheet
   ═══════════════════════════════════════════════════════ */

:root {
  --gold:       #F5A61E;
  --gold-light: #FFD166;
  --gold-dark:  #C4831A;
  --bg:         #080808;
  --bg2:        #101010;
  --bg3:        #181818;
  --bg4:        #222222;
  --white:      #FFFFFF;
  --off:        #F0EBE0;
  --gray:       #888888;
  --lgray:      #CCCCCC;
  --border:     rgba(245,166,30,0.12);
  --glow:       rgba(245,166,30,0.15);
  --radius:     8px;
  --trans:      all .3s ease;
}

/* ── RESET & BASE ──────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:'DM Sans',sans-serif; background:var(--bg); color:var(--white); overflow-x:hidden; cursor:none; }
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--gold); border-radius:3px; }

/* ── CURSOR ───────────────────────────────────────── */
#cursor { position:fixed; width:8px; height:8px; background:var(--gold); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:transform .1s; }
#cursor-ring { position:fixed; width:36px; height:36px; border:1.5px solid rgba(245,166,30,.5); border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:all .15s ease; }
body:hover #cursor { display:block; }

/* ── UTILITIES ────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 40px; }
.section { padding:100px 0; }
.section-label { font-family:'Syne',sans-serif; font-size:.72rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.section-label::before { content:''; width:28px; height:1.5px; background:var(--gold); }
.section-title { font-family:'Instrument Serif',serif; font-size:clamp(2rem,4vw,3.4rem); font-weight:400; line-height:1.1; margin-bottom:18px; }
.section-title em { font-style:italic; color:var(--gold); }
.section-sub { color:var(--gray); font-size:1rem; line-height:1.7; max-width:560px; }
.body-text { color:var(--lgray); line-height:1.8; font-size:.97rem; margin-bottom:16px; }
.section-header { margin-bottom:60px; }

/* ── REVEAL ANIMATIONS ────────────────────────────── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .8s ease, transform .8s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-d1 { transition-delay:.15s; }
.reveal-d2 { transition-delay:.25s; }
.reveal-d3 { transition-delay:.35s; }

/* ── BUTTONS ──────────────────────────────────────── */
.btn-gold {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gold); color:#000;
  padding:14px 32px; border-radius:6px;
  font-family:'Syne',sans-serif; font-weight:700; font-size:.85rem; letter-spacing:.5px;
  transition:var(--trans); border:2px solid var(--gold);
}
.btn-gold:hover { background:transparent; color:var(--gold); }
.btn-gold-sm { display:inline-flex; align-items:center; gap:6px; background:var(--gold); color:#000; padding:10px 22px; border-radius:5px; font-weight:700; font-size:.8rem; margin-top:20px; transition:var(--trans); }
.btn-gold-sm:hover { opacity:.85; }
.btn-outline { display:inline-flex; align-items:center; gap:8px; background:transparent; color:var(--white); padding:14px 32px; border-radius:6px; border:1.5px solid rgba(255,255,255,.25); font-weight:500; font-size:.85rem; transition:var(--trans); }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.btn-whatsapp { display:inline-flex; align-items:center; gap:8px; background:#25D366; color:#fff; padding:14px 28px; border-radius:6px; font-weight:600; font-size:.85rem; transition:var(--trans); }
.btn-whatsapp:hover { background:#1daa54; }

/* ═══ NAV ════════════════════════════════════════════ */
#site-nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:12px 40px;
  display:flex; align-items:center; justify-content:space-between; gap:30px;
  background:rgba(8,8,8,.92); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:var(--trans);
  min-height:80px;
}
#site-nav.scrolled { padding:8px 40px; min-height:68px; background:rgba(8,8,8,.98); }

.nav-brand { display:flex; align-items:center; flex-shrink:0; }
.nav-logo-img {
  height:64px;
  width:auto;
  display:block;
  object-fit:contain;
  transition:var(--trans);
  filter:brightness(1.05) drop-shadow(0 2px 8px rgba(245,166,30,.15));
}
#site-nav.scrolled .nav-logo-img { height:52px; }

.nav-center { flex:1; display:flex; justify-content:center; align-items:center; }
.nav-menu { display:flex; align-items:center; gap:4px; list-style:none; padding:0; margin:0; }
.nav-menu li { position:relative; }
.nav-menu a {
  font-family:'Syne',sans-serif; font-size:.75rem; font-weight:600;
  color:var(--lgray); padding:9px 16px; border-radius:5px;
  letter-spacing:1px; transition:var(--trans); white-space:nowrap;
  display:block; text-transform:uppercase;
}
.nav-menu a:hover { color:var(--gold); background:rgba(245,166,30,.07); }

/* Dropdown */
.has-drop > a::after { content:' ▾'; font-size:.6rem; }
.dropdown { display:none; position:absolute; top:100%; left:0; background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:8px 0; min-width:180px; box-shadow:0 20px 60px rgba(0,0,0,.6); }
.has-drop:hover .dropdown { display:block; }
.dropdown li a { padding:10px 20px; border-radius:0; font-size:.82rem; text-transform:none; letter-spacing:0; }
.dropdown li a:hover { background:rgba(245,166,30,.08); color:var(--gold); }

.nav-cta-btn { display:flex; align-items:center; gap:8px; background:var(--gold); color:#000; padding:11px 24px; border-radius:6px; font-family:'Syne',sans-serif; font-weight:700; font-size:.78rem; letter-spacing:.5px; transition:var(--trans); white-space:nowrap; }
.nav-cta-btn:hover { background:var(--gold-light); }

.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:none; padding:4px; }
.hamburger span { width:22px; height:1.5px; background:var(--gold); transition:var(--trans); display:block; }

/* Mobile Menu */
#mobile-menu { display:none; position:fixed; top:72px; left:0; right:0; bottom:0; background:rgba(8,8,8,.97); z-index:999; backdrop-filter:blur(20px); padding:40px; flex-direction:column; gap:0; }
#mobile-menu.open { display:flex; }
#mobile-menu ul { list-style:none; }
#mobile-menu ul li a { font-family:'Syne',sans-serif; font-size:1.6rem; font-weight:700; color:var(--white); display:block; padding:16px 0; border-bottom:1px solid rgba(255,255,255,.06); transition:var(--trans); }
#mobile-menu ul li a:hover { color:var(--gold); padding-left:12px; }
.mobile-cta { background:var(--gold) !important; color:#000 !important; padding:16px 28px !important; border-radius:6px; margin-top:16px !important; text-align:center; border-bottom:none !important; }

/* ═══ HERO ═══════════════════════════════════════════ */
.hero-section {
  min-height:100vh; position:relative;
  display:flex; align-items:center;
  padding-top:80px; overflow:hidden;
}
#hero-canvas { position:absolute; inset:0; width:100%; height:100%; opacity:.4; }
.hero-orb { position:absolute; border-radius:50%; filter:blur(80px); pointer-events:none; }
.orb-1 { width:600px; height:600px; background:radial-gradient(circle, rgba(245,166,30,.12) 0%, transparent 70%); top:-200px; right:-100px; animation:orbFloat 8s ease-in-out infinite; }
.orb-2 { width:400px; height:400px; background:radial-gradient(circle, rgba(245,166,30,.07) 0%, transparent 70%); bottom:-100px; left:-50px; animation:orbFloat 10s 2s ease-in-out infinite reverse; }
.orb-3 { width:200px; height:200px; background:radial-gradient(circle, rgba(245,166,30,.1) 0%, transparent 70%); top:40%; left:40%; animation:orbFloat 6s 1s ease-in-out infinite; }

@keyframes orbFloat { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-30px) scale(1.05)} }

.hero-content { position:relative; z-index:2; padding:0 40px; max-width:1200px; margin:0 auto; width:100%; }
.hero-badge { display:inline-flex; align-items:center; gap:10px; background:rgba(245,166,30,.08); border:1px solid rgba(245,166,30,.25); padding:8px 18px; border-radius:100px; margin-bottom:32px; animation:fadeUp .8s ease both; }
.badge-dot { width:7px; height:7px; border-radius:50%; background:var(--gold); animation:pulse 2s infinite; }
.hero-badge span { font-size:.75rem; color:var(--gold); letter-spacing:1.5px; text-transform:uppercase; font-weight:600; }

@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.8)} }

.hero-title { font-family:'Instrument Serif',serif; font-size:clamp(3.2rem,7vw,7rem); font-weight:400; line-height:1.0; margin-bottom:24px; animation:fadeUp .8s .15s ease both; }
.hero-italic { font-style:italic; color:var(--gold); }
.hero-sub { font-size:1.1rem; color:var(--gray); line-height:1.7; margin-bottom:40px; animation:fadeUp .8s .25s ease both; }
.hero-sub strong { color:var(--lgray); }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:70px; animation:fadeUp .8s .35s ease both; }
.hero-stats { display:flex; align-items:center; gap:0; animation:fadeUp .8s .45s ease both; border-top:1px solid rgba(255,255,255,.06); padding-top:36px; flex-wrap:wrap; }
.hstat { padding:0 40px 0 0; }
.hstat:first-child { padding-left:0; }
.hstat-num { font-family:'Syne',sans-serif; font-size:2.6rem; font-weight:800; color:var(--gold); }
sup { font-size:1.2rem; color:var(--gold); vertical-align:super; }
.hstat-label { font-size:.72rem; color:var(--gray); letter-spacing:1.5px; text-transform:uppercase; margin-top:4px; }
.hstat-div { width:1px; height:50px; background:rgba(255,255,255,.08); margin:0 40px 0 0; }

.hero-scroll-hint { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; animation:fadeUp 1s 1s both; }
.scroll-line { width:1px; height:50px; background:linear-gradient(to bottom, var(--gold), transparent); animation:scrollAnim 2s ease-in-out infinite; }
.hero-scroll-hint span { font-size:.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--gray); }
@keyframes scrollAnim { 0%{opacity:1;transform:scaleY(1) translateY(0)} 100%{opacity:0;transform:scaleY(.5) translateY(20px)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }

/* ═══ ABOUT ═══════════════════════════════════════════ */
.about-section { background:var(--bg2); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-quote { font-family:'Instrument Serif',serif; font-style:italic; font-size:1.15rem; color:var(--gold); border-left:3px solid var(--gold); padding:12px 20px; margin:28px 0; background:rgba(245,166,30,.04); border-radius:0 6px 6px 0; }
.mission-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:28px; margin-bottom:16px; transition:var(--trans); }
.mission-card:hover { border-color:rgba(245,166,30,.35); }
.mc-icon { font-size:1.8rem; margin-bottom:12px; }
.mission-card h3 { font-family:'Syne',sans-serif; font-size:.78rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.mission-card p { color:var(--gray); font-size:.9rem; line-height:1.7; }
.about-badge-row { display:flex; gap:10px; flex-wrap:wrap; margin-top:6px; }
.ab-badge { background:rgba(245,166,30,.08); border:1px solid rgba(245,166,30,.2); border-radius:100px; padding:6px 14px; font-size:.78rem; color:var(--gold); font-weight:500; }
.ab-badge span { margin-right:4px; }

/* ═══ SERVICES ════════════════════════════════════════ */
.services-section { background:var(--bg); position:relative; overflow:hidden; }
.services-bg-text { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-family:'Syne',sans-serif; font-size:18vw; font-weight:800; color:rgba(255,255,255,.018); white-space:nowrap; pointer-events:none; letter-spacing:-4px; }
.services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(255,255,255,.04); border-radius:var(--radius); overflow:hidden; }
.service-card { background:var(--bg); padding:36px 28px; position:relative; overflow:hidden; transition:var(--trans); }
.service-card::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at bottom left, rgba(245,166,30,.06) 0%, transparent 70%); opacity:0; transition:var(--trans); }
.service-card:hover { background:var(--bg2); }
.service-card:hover::before { opacity:1; }
.service-card::after { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--gold); transition:width .4s ease; }
.service-card:hover::after { width:100%; }
.sc-icon { font-size:2rem; margin-bottom:18px; }
.sc-title { font-family:'Syne',sans-serif; font-size:.92rem; font-weight:700; color:var(--white); margin-bottom:10px; line-height:1.3; }
.sc-desc { font-size:.83rem; color:var(--gray); line-height:1.65; margin-bottom:20px; }
.sc-arrow { font-size:1.2rem; color:rgba(245,166,30,.3); transition:var(--trans); }
.service-card:hover .sc-arrow { color:var(--gold); transform:translateX(5px); }

/* ═══ HOME SERVICE ════════════════════════════════════ */
.home-service-section { background:var(--bg2); position:relative; overflow:hidden; }
.hs-bg-orb { position:absolute; top:-200px; right:-200px; width:700px; height:700px; background:radial-gradient(circle, rgba(245,166,30,.06) 0%, transparent 65%); border-radius:50%; pointer-events:none; }
.hs-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.hs-features { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:32px 0; }
.hs-feat { display:flex; align-items:flex-start; gap:14px; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:20px; transition:var(--trans); }
.hs-feat:hover { border-color:rgba(245,166,30,.3); }
.hs-feat-icon { font-size:1.5rem; flex-shrink:0; }
.hs-feat strong { font-size:.9rem; font-family:'Syne',sans-serif; color:var(--white); display:block; margin-bottom:4px; }
.hs-feat p { font-size:.8rem; color:var(--gray); line-height:1.5; }
.hs-actions { display:flex; gap:14px; flex-wrap:wrap; }

.hs-steps-card { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:36px; position:relative; overflow:hidden; }
.hs-steps-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg, var(--gold), var(--gold-light), var(--gold)); }
.hs-card-label { font-family:'Syne',sans-serif; font-size:.72rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:28px; }
.hs-step { display:flex; gap:20px; padding:20px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hs-step:last-of-type { border-bottom:none; }
.hs-step-num { font-family:'Instrument Serif',serif; font-size:2.2rem; color:rgba(245,166,30,.2); line-height:1; flex-shrink:0; width:40px; }
.hs-step-content strong { font-size:.92rem; color:var(--white); display:block; margin-bottom:4px; font-family:'Syne',sans-serif; }
.hs-step-content p { font-size:.82rem; color:var(--gray); line-height:1.6; }
.hs-cta-strip { display:flex; align-items:center; justify-content:space-between; margin-top:24px; padding:16px 20px; background:rgba(245,166,30,.06); border-radius:6px; border:1px solid rgba(245,166,30,.15); }
.hs-cta-strip span { font-size:.82rem; color:var(--gray); }
.hs-cta-strip a { color:var(--gold); font-weight:700; font-size:.9rem; transition:var(--trans); }
.hs-cta-strip a:hover { color:var(--gold-light); }

/* ═══ VISA ════════════════════════════════════════════ */
.visa-section { background:var(--bg); }
.visa-tabs-wrap { margin-bottom:60px; }
.visa-tabs { display:flex; gap:0; border-bottom:1px solid rgba(255,255,255,.08); margin-bottom:0; flex-wrap:wrap; }
.vtab { background:none; border:none; color:var(--gray); font-family:'Syne',sans-serif; font-size:.8rem; font-weight:600; letter-spacing:.5px; padding:14px 28px; cursor:none; border-bottom:2px solid transparent; margin-bottom:-1px; transition:var(--trans); }
.vtab.active, .vtab:hover { color:var(--gold); border-bottom-color:var(--gold); }
.vtab-panel { display:none; padding-top:40px; }
.vtab-panel.active { display:block; }
.req-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.req-box { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:32px; }
.req-box h4 { font-family:'Syne',sans-serif; font-size:.75rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.req-box ul li { display:flex; gap:10px; padding:10px 0; border-bottom:1px solid rgba(255,255,255,.04); font-size:.88rem; color:var(--lgray); line-height:1.5; }
.req-box ul li::before { content:'→'; color:var(--gold); flex-shrink:0; }
.req-box ul li:last-child { border-bottom:none; }
.req-note { margin-top:20px; padding:14px 16px; background:rgba(245,166,30,.06); border-radius:6px; font-size:.82rem; color:var(--gray); line-height:1.6; border-left:3px solid var(--gold); }

.countries-section { margin-top:60px; padding-top:60px; border-top:1px solid rgba(255,255,255,.06); }
.countries-title { font-family:'Syne',sans-serif; font-size:.78rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:24px; }
.countries-grid { display:flex; flex-wrap:wrap; gap:10px; }
.country-chip { background:var(--bg3); border:1px solid var(--border); border-radius:100px; padding:8px 18px; font-size:.85rem; color:var(--lgray); transition:var(--trans); cursor:default; }
.country-chip:hover { border-color:var(--gold); color:var(--gold); }
.country-more { color:var(--gold); border-color:rgba(245,166,30,.3); font-weight:600; cursor:pointer; }

/* ═══ PACKAGES ═══════════════════════════════════════ */
.packages-section { background:var(--bg2); position:relative; }
.pkg-bg-strip { position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg, transparent, var(--gold), transparent); }
.packages-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.pkg-card { background:var(--bg3); border:1px solid var(--border); border-radius:12px; overflow:hidden; transition:var(--trans); display:flex; flex-direction:column; }
.pkg-card:hover { border-color:rgba(245,166,30,.4); transform:translateY(-8px); box-shadow:0 24px 80px rgba(245,166,30,.08); }
.pkg-top { padding:40px 24px 20px; background:var(--bg4); display:flex; align-items:center; justify-content:space-between; }
.pkg-flag { font-size:3.5rem; }
.pkg-dest-badge { background:rgba(245,166,30,.1); border:1px solid rgba(245,166,30,.2); border-radius:100px; padding:4px 14px; font-size:.72rem; color:var(--gold); font-weight:600; letter-spacing:1px; text-transform:uppercase; }
.pkg-body { padding:22px 24px; flex:1; }
.pkg-title { font-family:'Instrument Serif',serif; font-size:1.4rem; color:var(--white); margin-bottom:6px; }
.pkg-dur { font-size:.82rem; color:var(--gold); margin-bottom:16px; font-weight:500; }
.pkg-includes { display:flex; flex-wrap:wrap; gap:8px; }
.pkg-includes span { background:rgba(255,255,255,.05); border-radius:4px; padding:4px 10px; font-size:.75rem; color:var(--gray); }
.pkg-btn { display:block; margin:0 24px 24px; padding:12px; text-align:center; background:transparent; border:1px solid rgba(245,166,30,.3); border-radius:6px; color:var(--gold); font-size:.8rem; font-weight:700; font-family:'Syne',sans-serif; letter-spacing:.5px; transition:var(--trans); }
.pkg-btn:hover { background:var(--gold); color:#000; border-color:var(--gold); }
.pkg-custom { display:flex; align-items:stretch; background:linear-gradient(135deg, rgba(245,166,30,.06), rgba(245,166,30,.02)); }
.pkg-custom-inner { padding:40px 28px; display:flex; flex-direction:column; align-items:flex-start; justify-content:center; gap:12px; width:100%; }
.pkg-custom-icon { font-size:2.5rem; }
.pkg-custom h3 { font-family:'Instrument Serif',serif; font-size:1.5rem; }
.pkg-custom p { color:var(--gray); font-size:.88rem; line-height:1.6; }

/* ═══ WHY ═════════════════════════════════════════════ */
.why-section { background:var(--bg); }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.why-items { margin-top:36px; }
.why-item { display:flex; gap:24px; padding:24px 0; border-bottom:1px solid rgba(255,255,255,.05); transition:var(--trans); }
.why-item:hover .why-num { color:var(--gold); }
.why-num { font-family:'Instrument Serif',serif; font-size:2.2rem; color:rgba(245,166,30,.15); flex-shrink:0; width:48px; line-height:1; transition:var(--trans); }
.why-content strong { font-size:.97rem; color:var(--white); display:block; margin-bottom:5px; font-family:'Syne',sans-serif; font-weight:700; }
.why-content p { font-size:.84rem; color:var(--gray); line-height:1.6; }

.why-card { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:48px 40px; position:relative; overflow:hidden; }
.wc-glow { position:absolute; top:-100px; right:-100px; width:300px; height:300px; background:radial-gradient(circle, rgba(245,166,30,.12) 0%, transparent 70%); border-radius:50%; pointer-events:none; }
.wc-big-num { font-family:'Instrument Serif',serif; font-size:6rem; font-weight:400; color:var(--gold); line-height:1; }
.wc-big-num sup { font-size:2.5rem; vertical-align:super; }
.wc-label { font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--gray); margin-bottom:24px; font-family:'Syne',sans-serif; }
.wc-hr { border:none; border-top:1px solid rgba(255,255,255,.07); margin:24px 0; }
.wc-quote { font-family:'Instrument Serif',serif; font-style:italic; font-size:1.2rem; color:var(--lgray); line-height:1.5; margin-bottom:24px; }
.wc-badges { display:flex; flex-direction:column; gap:10px; }
.wc-badge { background:rgba(245,166,30,.08); border:1px solid rgba(245,166,30,.2); border-radius:6px; padding:10px 16px; font-size:.84rem; color:var(--gold); font-weight:500; }

/* ═══ OTHER SERVICES ══════════════════════════════════ */
.other-section { background:var(--bg2); }
.other-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.other-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:32px 26px; transition:var(--trans); }
.other-card:hover { border-color:rgba(245,166,30,.35); transform:translateY(-4px); }
.oc-icon { font-size:2.2rem; margin-bottom:16px; }
.other-card h4 { font-family:'Syne',sans-serif; font-weight:700; font-size:.95rem; color:var(--white); margin-bottom:8px; }
.other-card p { font-size:.84rem; color:var(--gray); line-height:1.6; }

/* ═══ CONTACT ═════════════════════════════════════════ */
.contact-section { background:var(--bg); position:relative; overflow:hidden; }
.contact-bg-strip { position:absolute; bottom:0; left:0; right:0; height:3px; background:linear-gradient(90deg, transparent, var(--gold), transparent); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.contact-details { display:flex; flex-direction:column; gap:20px; margin:32px 0; }
.cd-item { display:flex; align-items:flex-start; gap:16px; padding:16px 20px; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); transition:var(--trans); }
.cd-item:hover { border-color:rgba(245,166,30,.3); }
.cd-icon { font-size:1.3rem; flex-shrink:0; margin-top:2px; }
.cd-item > div strong { font-size:.75rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:3px; font-family:'Syne',sans-serif; }
.cd-item > div span, .cd-item > div a { font-size:.92rem; color:var(--lgray); display:block; }

.home-service-promo { display:flex; gap:16px; align-items:flex-start; padding:20px 22px; background:linear-gradient(135deg, rgba(245,166,30,.08), rgba(245,166,30,.03)); border:1px solid rgba(245,166,30,.25); border-radius:var(--radius); }
.hsp-icon { font-size:2rem; flex-shrink:0; }
.home-service-promo strong { font-family:'Syne',sans-serif; font-size:.9rem; color:var(--gold); display:block; margin-bottom:5px; }
.home-service-promo p { font-size:.83rem; color:var(--gray); line-height:1.6; }

.contact-form-card { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:40px; }
.contact-form-card h3 { font-family:'Instrument Serif',serif; font-size:1.8rem; margin-bottom:6px; }
.form-sub { color:var(--gray); font-size:.88rem; margin-bottom:28px; }
.form-status { padding:12px 16px; border-radius:6px; margin-bottom:16px; font-size:.88rem; display:none; }
.form-status.success { background:rgba(37,211,102,.1); border:1px solid rgba(37,211,102,.3); color:#25d366; display:block; }
.form-status.error { background:rgba(255,80,80,.1); border:1px solid rgba(255,80,80,.3); color:#ff5050; display:block; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { margin-bottom:16px; }
.form-group label { font-size:.72rem; color:var(--gray); letter-spacing:1.5px; text-transform:uppercase; display:block; margin-bottom:8px; font-family:'Syne',sans-serif; font-weight:600; }
.form-group input, .form-group select, .form-group textarea { width:100%; background:var(--bg4); border:1px solid rgba(255,255,255,.08); color:var(--white); padding:13px 16px; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:.9rem; transition:var(--trans); outline:none; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--gold); background:var(--bg); }
.form-group select { appearance:none; cursor:none; }
.form-group select option, .form-group select optgroup { background:var(--bg3); }
.form-group textarea { height:110px; resize:none; }
.form-group-check { display:flex; align-items:center; }
.check-label { display:flex; align-items:center; gap:12px; cursor:none; font-size:.88rem; color:var(--lgray); }
.check-label input[type="checkbox"] { display:none; }
.check-box { width:20px; height:20px; border:1.5px solid rgba(245,166,30,.4); border-radius:4px; flex-shrink:0; transition:var(--trans); display:flex; align-items:center; justify-content:center; background:var(--bg4); }
.check-label input:checked + .check-box { background:var(--gold); border-color:var(--gold); }
.check-label input:checked + .check-box::after { content:'✓'; font-size:.75rem; color:#000; font-weight:700; }
.btn-submit { width:100%; background:var(--gold); color:#000; border:none; padding:16px; font-family:'Syne',sans-serif; font-size:.88rem; font-weight:800; letter-spacing:1px; text-transform:uppercase; border-radius:6px; cursor:none; display:flex; align-items:center; justify-content:center; gap:8px; transition:var(--trans); }
.btn-submit:hover { background:var(--gold-light); }
.btn-submit:disabled { opacity:.6; }

/* ═══ FOOTER ══════════════════════════════════════════ */
#site-footer { background:#030303; padding:64px 0 0; position:relative; border-top:1px solid rgba(245,166,30,.1); }
.footer-glow { position:absolute; top:-100px; left:50%; transform:translateX(-50%); width:600px; height:200px; background:radial-gradient(ellipse, rgba(245,166,30,.04) 0%, transparent 70%); pointer-events:none; }
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:44px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.05); align-items:start; }
.footer-logo-link { display:inline-block; margin-bottom:14px; }
.footer-logo-img {
  height:52px;
  width:auto;
  max-width:160px;
  object-fit:contain;
  display:block;
  filter:drop-shadow(0 2px 10px rgba(245,166,30,.18));
}
.footer-tagline { font-size:.68rem; letter-spacing:1.8px; text-transform:uppercase; color:var(--gray); margin-bottom:12px; line-height:1.6; }
.footer-desc { font-size:.83rem; color:var(--gray); line-height:1.75; max-width:260px; }
.footer-socials { display:flex; gap:8px; margin-top:20px; }
.social-link { width:34px; height:34px; border-radius:50%; border:1px solid rgba(245,166,30,.25); display:flex; align-items:center; justify-content:center; color:var(--gold); transition:var(--trans); flex-shrink:0; }
.social-link:hover { background:var(--gold); color:#000; border-color:var(--gold); }
.footer-col { padding-top:4px; }
.footer-col h4 { font-family:'Syne',sans-serif; font-size:.68rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; font-weight:600; }
.footer-col ul { list-style:none; padding:0; margin:0; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { font-size:.83rem; color:var(--gray); transition:var(--trans); display:inline-block; }
.footer-col ul li a:hover { color:var(--gold); padding-left:4px; }
.footer-contact-col { padding-top:4px; }
.footer-contact-col h4 { font-family:'Syne',sans-serif; font-size:.68rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; font-weight:600; }
.footer-contact-col .footer-contact-item { display:flex; align-items:flex-start; gap:10px; margin-bottom:12px; }
.footer-contact-item svg { flex-shrink:0; margin-top:2px; }
.footer-contact-item span, .footer-contact-item a { font-size:.82rem; color:var(--gray); transition:var(--trans); line-height:1.45; }
.footer-contact-item a:hover { color:var(--gold); }
.whatsapp-btn { display:inline-flex; align-items:center; gap:8px; background:#25D366; color:#fff; padding:9px 16px; border-radius:6px; font-size:.8rem; font-weight:600; margin-top:12px; transition:var(--trans); }
.whatsapp-btn:hover { background:#1daa54; }
.footer-bottom { padding:20px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.footer-copy, .footer-made { font-size:.74rem; color:rgba(255,255,255,.22); }

/* WhatsApp Float */
.wa-float { position:fixed; bottom:30px; right:30px; z-index:998; width:56px; height:56px; border-radius:50%; background:#25D366; display:flex; align-items:center; justify-content:center; box-shadow:0 8px 32px rgba(37,211,102,.4); transition:var(--trans); animation:waPulse 3s ease-in-out infinite; }
.wa-float:hover { transform:scale(1.1); box-shadow:0 12px 40px rgba(37,211,102,.5); }
@keyframes waPulse { 0%,100%{box-shadow:0 8px 32px rgba(37,211,102,.4)} 50%{box-shadow:0 8px 48px rgba(37,211,102,.6)} }

/* ═══ RESPONSIVE ══════════════════════════════════════ */
@media (max-width:1100px) {
  #site-nav { padding:14px 24px; }
  .container { padding:0 24px; }
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .packages-grid { grid-template-columns:repeat(2,1fr); }
  .footer-top { grid-template-columns:1fr 1fr; gap:40px; }
}
@media (max-width:900px) {
  .about-grid, .hs-grid, .why-grid, .contact-grid { grid-template-columns:1fr; gap:48px; }
  .visa-tabs { flex-wrap:wrap; }
  .req-grid { grid-template-columns:1fr; }
  .other-grid { grid-template-columns:repeat(2,1fr); }
  .hs-features { grid-template-columns:1fr; }
}
@media (max-width:1024px) {
  .nav-center, .nav-cta-btn { display:none; }
  .hamburger { display:flex; }
  #site-nav { padding:10px 24px; }
}
  .hero-section { padding-top:70px; }
  .hero-stats { gap:20px; }
  .hstat { padding:0 20px 0 0; }
  .hstat-div { margin:0 20px 0 0; }
  .packages-grid { grid-template-columns:1fr; }
  .other-grid { grid-template-columns:1fr 1fr; }
  .footer-top { grid-template-columns:1fr; gap:36px; }
  .form-row { grid-template-columns:1fr; }
  body { cursor:auto; }
  #cursor, #cursor-ring { display:none; }
  .vtab { cursor:pointer; }
  .btn-submit, .hamburger { cursor:pointer; }
  .check-label { cursor:pointer; }
}

/* ═══ PAGE TEMPLATES STYLES ══════════════════════════════ */

/* Page Hero */
.page-hero { min-height:55vh; position:relative; display:flex; align-items:center; padding-top:80px; overflow:hidden; }
.page-hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse at 60% 50%, rgba(245,166,30,.07) 0%, transparent 65%), linear-gradient(135deg,#080808,#111); }
.page-hero-content { position:relative; z-index:2; padding:60px 0; }
.page-breadcrumb { font-size:.78rem; color:var(--gray); margin-bottom:20px; letter-spacing:.5px; }
.page-breadcrumb a { color:var(--gold); }
.page-breadcrumb span { margin:0 8px; }
.page-hero-badge { display:inline-block; background:rgba(245,166,30,.1); border:1px solid rgba(245,166,30,.25); padding:7px 16px; border-radius:100px; font-size:.78rem; color:var(--gold); letter-spacing:1px; margin-bottom:20px; }
.page-hero-title { font-family:'Instrument Serif',serif; font-size:clamp(2.4rem,5vw,5rem); font-weight:400; line-height:1.08; margin-bottom:20px; }
.page-hero-title em { font-style:italic; color:var(--gold); }
.page-hero-sub { font-size:1rem; color:var(--gray); line-height:1.7; max-width:540px; margin-bottom:32px; }

/* Alt background */
.alt-bg { background:var(--bg2) !important; }
.visa-detail-section { border-top:1px solid rgba(255,255,255,.04); }

/* Visa Detail Header */
.visa-detail-header { display:flex; gap:24px; align-items:flex-start; margin-bottom:40px; }
.vd-flag { font-size:3.5rem; flex-shrink:0; line-height:1; }

/* Visa type cards */
.visa-type-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.vtype-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:28px; transition:var(--trans); }
.vtype-card:hover { border-color:rgba(245,166,30,.4); transform:translateY(-4px); }
.vtype-icon { font-size:2rem; margin-bottom:14px; }
.vtype-card h3 { font-family:'Syne',sans-serif; font-size:.95rem; font-weight:700; color:var(--white); margin-bottom:8px; }
.vtype-card p { font-size:.84rem; color:var(--gray); line-height:1.6; }

/* Package highlights */
.pkg-highlights { list-style:none; padding:0; margin:12px 0 14px; }
.pkg-highlights li { font-size:.8rem; color:var(--gray); padding:4px 0; }
.pkg-includes-tags { display:flex; flex-wrap:wrap; gap:6px; }
.pkg-includes-tags span { background:rgba(255,255,255,.04); border-radius:4px; padding:3px 8px; font-size:.72rem; color:var(--gray); }

/* CTA strip */
.cta-strip-section { background:var(--bg3); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:50px 0; }
.cta-strip { display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; }
.cta-strip h3 { font-family:'Instrument Serif',serif; font-size:1.8rem; margin-bottom:6px; }
.cta-strip p { color:var(--gray); font-size:.9rem; }
.cta-strip-btns { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

/* Package includes section */
.pkg-includes-section { background:var(--bg2); }
.pkg-includes-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.pi-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:28px 24px; text-align:center; transition:var(--trans); }
.pi-card:hover { border-color:rgba(245,166,30,.3); }
.pi-icon { font-size:2.2rem; margin-bottom:14px; }
.pi-card h4 { font-family:'Syne',sans-serif; font-size:.9rem; color:var(--white); margin-bottom:8px; font-weight:700; }
.pi-card p { font-size:.83rem; color:var(--gray); line-height:1.6; }

/* Honeymoon section */
.honeymoon-section { background:var(--bg2); }
.hm-card { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; background:var(--bg3); border:1px solid rgba(245,166,30,.15); border-radius:12px; padding:50px; }
.hm-features { display:flex; flex-wrap:wrap; gap:10px; margin-top:20px; }
.hm-features span { background:rgba(245,166,30,.08); border:1px solid rgba(245,166,30,.2); padding:7px 14px; border-radius:100px; font-size:.82rem; color:var(--gold); }
.hm-dest-list { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.hm-dest { background:var(--bg4); border:1px solid var(--border); border-radius:6px; padding:14px 18px; font-size:.9rem; color:var(--lgray); text-align:center; transition:var(--trans); }
.hm-dest:hover { border-color:var(--gold); color:var(--gold); }

/* How steps */
.how-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.how-step { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:32px 26px; text-align:center; transition:var(--trans); }
.how-step:hover { border-color:rgba(245,166,30,.3); }
.how-step-num { font-family:'Instrument Serif',serif; font-size:2rem; color:rgba(245,166,30,.25); margin-bottom:8px; }
.how-step-icon { font-size:2rem; margin-bottom:14px; }
.how-step h4 { font-family:'Syne',sans-serif; font-size:.92rem; color:var(--white); margin-bottom:8px; font-weight:700; }
.how-step p { font-size:.83rem; color:var(--gray); line-height:1.6; }

/* Coverage areas */
.areas-grid { display:flex; flex-wrap:wrap; gap:12px; }
.area-chip { background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:12px 20px; font-size:.88rem; color:var(--lgray); transition:var(--trans); }
.area-chip:hover { border-color:var(--gold); color:var(--gold); }

/* Stats grid (About page) */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.stat-box { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:36px 24px; text-align:center; }
.stat-big { font-family:'Instrument Serif',serif; font-size:3.5rem; color:var(--gold); line-height:1; }
.stat-big sup { font-size:1.5rem; vertical-align:super; }
.stat-lbl { font-size:.75rem; color:var(--gray); letter-spacing:1.5px; text-transform:uppercase; margin-top:8px; font-family:'Syne',sans-serif; }

/* Values grid (About page) */
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.val-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:30px 26px; transition:var(--trans); }
.val-card:hover { border-color:rgba(245,166,30,.35); transform:translateY(-4px); }
.val-icon { font-size:2rem; margin-bottom:14px; }
.val-card h4 { font-family:'Syne',sans-serif; font-size:.95rem; color:var(--white); margin-bottom:8px; font-weight:700; }
.val-card p { font-size:.84rem; color:var(--gray); line-height:1.6; }

/* Visa intro section */
.visa-intro-section { background:var(--bg2); }

/* Responsive page templates */
@media (max-width:900px) {
  .visa-type-cards { grid-template-columns:1fr 1fr; }
  .pkg-includes-grid { grid-template-columns:1fr 1fr; }
  .how-steps { grid-template-columns:1fr 1fr; }
  .values-grid { grid-template-columns:1fr 1fr; }
  .hm-card { grid-template-columns:1fr; gap:36px; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px) {
  .visa-type-cards, .pkg-includes-grid, .how-steps, .values-grid { grid-template-columns:1fr; }
  .cta-strip { flex-direction:column; text-align:center; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .visa-detail-header { flex-direction:column; gap:12px; }
}
