/* ============================================================
   NOMADICA TRAVEL — MAIN STYLESHEET
   Version 1.0 | Vietnamese Default | Dark Expedition Premium
   ============================================================ */

/* -------- VARIABLES -------- */
:root {
  --bg:           #080E08;
  --bg-2:         #0C160C;
  --bg-card:      #101E10;
  --green-dark:   #1A3D1A;
  --green-mid:    #2A5A2A;
  /* Colors extracted directly from Nomadica logo */
  --orange:       #C84818;   /* burnt orange outer arc of logo sun */
  --orange-warm:  #D96020;   /* middle arc */
  --gold:         #E89020;   /* amber inner arc — warm, inviting */
  --gold-bright:  #F5C030;   /* center gold — used for accents */
  --gold-dim:     rgba(232,144,32,0.32);
  --cream:        #F2EAD8;   /* warm ivory, matches logo background */
  --cream-dim:    #9E9488;
  --cream-faint:  rgba(242,234,216,0.05);
  --border:       rgba(242,234,216,0.09);
  --border-hover: rgba(242,234,216,0.28);
  /* Playfair Display: warm editorial serif — "ấm áp, thân thuộc" */
  /* Nunito: humanist rounded sans — friendly, readable Vietnamese */
  --font-serif:   'Playfair Display', Georgia, serif;
  --font-sans:    'Nunito', -apple-system, BlinkMacSystemFont, sans-serif;
  --section-gap:  clamp(80px,10vw,140px);
  --container:    1320px;
  --t-fast:  150ms ease;
  --t-med:   300ms ease;
  --t-slow:  600ms ease;
  --t-cinematic: 900ms cubic-bezier(0.22,1,0.36,1);
  --z-grain:   9996;
  --z-social:  900;
  --z-nav:     1000;
  --z-mobile:  1001;
  --z-preload: 9999;
}

/* -------- RESET -------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--cream);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img,video { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { background:none; border:none; cursor:pointer; font:inherit; color:inherit; }
::selection { background: rgba(200,72,24,0.28); color: var(--cream); }

/* -------- CUSTOM CURSOR RING (native arrow stays visible) -------- */
.cursor-ring {
  position: fixed; top: 0; left: 0; z-index: 99998;
  pointer-events: none;
  width: 32px; height: 32px;
  border: 1.5px solid rgba(232,144,32,0.5);
  border-radius: 50%;
  transform: translate(-50%,-50%);
  transition: width 0.22s ease, height 0.22s ease, border-color 0.22s ease, opacity 0.2s ease;
  opacity: 0;
}
.cursor-ring.active { opacity: 1; }
.cursor-ring.hovering { width: 48px; height: 48px; border-color: rgba(200,72,24,0.7); }
@media(max-width:900px){ .cursor-ring { display:none; } }

/* -------- MARQUEE TICKER -------- */
.marquee-strip {
  overflow: hidden; white-space: nowrap;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--bg-2);
  padding: 14px 0;
  user-select: none;
}
.marquee-inner {
  display: inline-flex; gap: 0;
  animation: marquee-scroll 30s linear infinite;
}
.marquee-strip:hover .marquee-inner { animation-play-state: paused; }
.marquee-item {
  display: inline-flex; align-items: center; gap: 32px;
  padding: 0 36px;
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--cream-dim);
  white-space: nowrap;
}
.marquee-item strong { color: var(--gold); font-weight: 600; }
.marquee-dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--orange); flex-shrink: 0;
}
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* -------- TESTIMONIAL STRIP -------- */
.testimonial-strip {
  padding: clamp(60px,8vw,100px) 0;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.testimonial-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 28px; margin-top: 48px;
}
.testimonial-card {
  padding: 32px 28px;
  border: 1px solid var(--border); border-radius: 16px;
  background: var(--bg-card);
  position: relative;
  transition: border-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}
.testimonial-card:hover {
  border-color: var(--border-hover);
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.4);
}
.testimonial-quote-mark {
  font-family: var(--font-serif);
  font-size: 64px; line-height: 0.7;
  color: rgba(232,144,32,0.2);
  margin-bottom: 16px; display: block;
}
.testimonial-text {
  font-family: var(--font-serif);
  font-size: clamp(15px,1.4vw,17px);
  font-style: italic; line-height: 1.7;
  color: var(--cream); margin-bottom: 20px;
}
.testimonial-author {
  display: flex; align-items: center; gap: 12px;
}
.testimonial-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--green-dark);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-serif); font-size: 16px;
  color: var(--gold); flex-shrink: 0;
}
.testimonial-name { font-size: 13px; font-weight: 500; color: var(--cream); }
.testimonial-detail { font-size: 11px; letter-spacing: 0.1em; color: var(--cream-dim); margin-top: 2px; }
.testimonial-stars { color: var(--gold); font-size: 12px; letter-spacing: 1px; }
@media(max-width:900px){ .testimonial-grid { grid-template-columns: 1fr; } }
@media(min-width:600px) and (max-width:900px){ .testimonial-grid { grid-template-columns: 1fr 1fr; } }

/* -------- GRAIN OVERLAY -------- */
.grain {
  position: fixed;
  top:-50%; left:-50%;
  width:200%; height:200%;
  pointer-events: none;
  z-index: var(--z-grain);
  opacity: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation: grain-shift 8s steps(10) infinite;
}
@media (prefers-reduced-motion: no-preference) { .grain { opacity:0.035; } }
@keyframes grain-shift {
  0%,100%{ transform:translate(0,0); }
  10%{ transform:translate(-5%,-10%); }
  20%{ transform:translate(-15%,5%); }
  30%{ transform:translate(7%,-25%); }
  40%{ transform:translate(-5%,25%); }
  50%{ transform:translate(-15%,10%); }
  60%{ transform:translate(15%,0); }
  70%{ transform:translate(0,15%); }
  80%{ transform:translate(3%,35%); }
  90%{ transform:translate(-10%,10%); }
}

/* -------- PRELOADER -------- */
/* -------- PRELOADER -------- */
.no-preloader #preloader { display: none !important; }
.preloader {
  position: fixed; inset: 0;
  background: var(--bg);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  z-index: var(--z-preload);
  transition: opacity 0.9s ease 0.2s, visibility 0.9s ease 0.2s;
  overflow: hidden;
}
.preloader.done { opacity:0; visibility:hidden; pointer-events:none; }
.preloader-inner { text-align: center; position: relative; z-index: 2; }
.preloader-glow {
  position: absolute;
  bottom: -30px; left: 50%; transform: translateX(-50%);
  width: 320px; height: 120px;
  background: radial-gradient(ellipse at center, rgba(200,72,24,0.55) 0%, rgba(232,144,32,0.22) 45%, transparent 75%);
  filter: blur(18px);
  opacity: 0;
  animation: pl-glow-in 1.4s ease 0.5s forwards;
  pointer-events: none;
}
.preloader-logo {
  font-family: var(--font-serif);
  font-size: clamp(28px,5vw,52px);
  font-weight: 300;
  letter-spacing: 0.5em;
  color: var(--cream);
  text-transform: uppercase;
  animation: pl-in 1.2s ease forwards;
}
.preloader-tagline {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--orange);
  margin-top: 6px;
  opacity: 0;
  animation: pl-in 0.8s ease 0.5s forwards;
}
.preloader-sub {
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--cream-dim);
  margin-top: 6px;
  opacity: 0;
  animation: pl-in 0.7s ease 0.75s forwards;
}
.preloader-line {
  width: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  margin: 20px auto 0;
  animation: pl-line 1.4s ease 0.4s forwards;
}
@keyframes pl-in {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes pl-glow-in {
  from { opacity:0; }
  to   { opacity:1; }
}
@keyframes pl-line { to { width: 160px; } }

/* -------- PAGE TRANSITION -------- */
.pg-transition {
  position: fixed; inset: 0;
  background: var(--bg);
  z-index: calc(var(--z-preload) - 1);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  opacity: 1;
  overflow: hidden;
  pointer-events: none;
}
/* Solid: instant full black (start of every page, before fade-out) */
.pg-transition--solid {
  opacity: 1;
  pointer-events: all;
}
/* Fade out: reveal new page gradually */
.pg-transition--out {
  opacity: 0;
  transition: opacity 0.75s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}
/* Fade in: darken when leaving page */
.pg-transition--in {
  opacity: 1;
  transition: opacity 0.35s ease;
  pointer-events: all;
}
.pg-transition-inner {
  text-align: center; position: relative; z-index: 2;
  opacity: 0;
  transition: opacity 0.15s ease;
}
.pg-transition--in .pg-transition-inner { opacity: 1; }
.pg-transition-glow {
  position: absolute;
  bottom: -24px; left: 50%; transform: translateX(-50%);
  width: 280px; height: 100px;
  background: radial-gradient(ellipse at center, rgba(200,72,24,0.6) 0%, rgba(232,144,32,0.25) 45%, transparent 75%);
  filter: blur(16px);
  pointer-events: none;
}
.pg-transition-logo {
  font-family: var(--font-serif);
  font-size: clamp(24px,4vw,46px);
  font-weight: 300;
  letter-spacing: 0.5em;
  color: var(--cream);
  text-transform: uppercase;
}
.pg-transition-tagline {
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--orange);
  margin-top: 8px;
}
.pg-transition-line {
  width: 120px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  margin: 18px auto 0;
}

/* -------- UTILITIES -------- */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(20px,4vw,64px);
}
.section { padding: var(--section-gap) 0; }

/* Ornamental line */
.ornament {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 24px;
}
.ornament::before,.ornament::after {
  content:'';
  flex: 1; height: 1px;
  background: var(--border);
}
.ornament span {
  font-size:10px;
  letter-spacing:0.4em;
  text-transform:uppercase;
  color: var(--gold);
  white-space: nowrap;
}

/* Section labels */
.section-num {
  display: block;
  font-size: 10px;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
  font-family: var(--font-sans);
  font-weight: 500;
}
.section-heading {
  font-family: var(--font-serif);
  font-size: clamp(34px,5vw,62px);
  font-weight: 300;
  line-height: 1.1;
  color: var(--cream);
}
.section-body {
  color: var(--cream-dim);
  line-height: 1.85;
  font-size: 15px;
  max-width: 540px;
  margin-top: 18px;
}
.section-sub {
  color: var(--cream-dim);
  font-size: 14px;
  margin-top: 14px;
  max-width: 520px;
}

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1), transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}
.reveal.d1 { transition-delay: 0.1s; }
.reveal.d2 { transition-delay: 0.22s; }
.reveal.d3 { transition-delay: 0.36s; }
.reveal.d4 { transition-delay: 0.52s; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* slide-from-left for headings */
.reveal-left {
  opacity: 0;
  transform: translateX(-32px);
  transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1), transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.reveal-left.visible { opacity:1; transform:translateX(0); }

/* scale-in for cards */
.reveal-scale {
  opacity: 0;
  transform: scale(0.94) translateY(20px);
  transition: opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1), transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}
.reveal-scale.d1 { transition-delay: 0.08s; }
.reveal-scale.d2 { transition-delay: 0.18s; }
.reveal-scale.d3 { transition-delay: 0.28s; }
.reveal-scale.visible { opacity:1; transform:scale(1) translateY(0); }

/* Section enter line — decorative underline sweep */
@keyframes line-grow { from { transform: scaleX(0); } to { transform: scaleX(1); } }
.section-num-animated {
  display: inline-block; position: relative;
}
.section-num-animated::after {
  content: '';
  position: absolute; bottom: -3px; left: 0; right: 0; height: 1px;
  background: var(--gold); transform-origin: left;
  transform: scaleX(0);
  transition: transform 0.6s ease 0.4s;
}
.section-num-animated.visible::after { transform: scaleX(1); }

/* -------- BUTTONS -------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 32px;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-radius: 100px;
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--t-med);
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}
.btn:hover { box-shadow: 0 8px 28px rgba(0,0,0,0.45); transform: translateY(-1px); }
.btn-primary {
  background: var(--orange);
  color: #fff;
  border: 1px solid var(--orange);
}
.btn-primary:hover { background:transparent; color:var(--orange); }
.btn-lg {
  padding: 17px 48px;
  font-size: 13px;
}
.btn-outline {
  background: transparent;
  color: var(--cream);
  border: 1px solid var(--border-hover);
}
.btn-outline:hover { border-color:var(--cream); }
.btn-gold {
  background: transparent;
  color: var(--gold);
  border: 1px solid var(--gold-dim);
}
.btn-gold:hover { background: rgba(232,144,32,0.1); border-color:var(--gold); }
.btn-zalo {
  background: #0068ff;
  color: #fff;
  border: 1px solid #0068ff;
}
.btn-zalo:hover { background:transparent; color:#4d99ff; border-color:#4d99ff; }
.btn svg { width:16px; height:16px; flex-shrink:0; }

/* -------- FLOATING SOCIAL -------- */
.social-float {
  position: fixed;
  right: 22px; top: 50%;
  transform: translateY(-50%);
  display: flex; flex-direction: column;
  gap: 8px;
  z-index: var(--z-social);
}
.social-float a {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(240,232,213,0.38);
  border-radius: 50%;
  color: rgba(240,232,213,0.82);
  transition: color 0.25s ease, border-color 0.25s ease, background 0.25s ease, transform 0.25s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.25s ease;
  background: rgba(8,14,8,0.72);
  backdrop-filter: blur(12px);
  box-shadow: 0 2px 14px rgba(0,0,0,0.5), inset 0 1px 0 rgba(240,232,213,0.06);
}
.social-float a:hover {
  color: var(--gold);
  border-color: rgba(232,144,32,0.7);
  background: rgba(232,144,32,0.1);
  transform: scale(1.18);
  box-shadow: 0 0 0 3px rgba(232,144,32,0.15), 0 4px 20px rgba(200,72,24,0.25);
}
.social-float a svg { width:15px; height:15px; }
.social-float-z {
  font-family: var(--font-serif);
  font-size: 17px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.02em;
}
@media(max-width:900px){ .social-float { display:none; } }

/* -------- NAVBAR -------- */
.navbar {
  position: fixed; top:0; left:0; right:0;
  padding: 22px clamp(20px,4vw,64px);
  display: flex; align-items: center; justify-content: space-between;
  z-index: var(--z-nav);
  transition: padding var(--t-med), background var(--t-med), backdrop-filter var(--t-med), border-color var(--t-med);
  border-bottom: 1px solid transparent;
}
.navbar.scrolled {
  padding: 14px clamp(20px,4vw,64px);
  background: rgba(10,26,14,0.9);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom-color: var(--border);
}
.nav-logo { display:flex; align-items:center; flex-shrink:0; }
.nav-logo img {
  height: 48px;
  width: auto;
  mix-blend-mode: screen;
  /* Makes black PNG background invisible on dark surfaces */
}
.logo-fallback {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 400;
  letter-spacing: 0.3em;
  color: var(--cream);
  text-transform: uppercase;
}
.nav-links {
  display: flex; gap: 24px; align-items: center;
}
.nav-links a {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(240,232,213,0.65);
  transition: color var(--t-fast);
  position: relative; padding-bottom: 2px;
}
.nav-links a::after {
  content:'';
  position:absolute; bottom:0; left:0;
  width:0; height:1px;
  background: var(--gold);
  transition: width var(--t-med);
}
.nav-links a:hover { color:var(--cream); }
.nav-links a:hover::after { width:100%; }
.nav-links .hl { color:var(--gold); }
.nav-links .hl:hover { color:var(--cream); }

/* Dropdown */
.nav-dropdown { position:relative; }
.nav-dropdown > button {
  font-size:11px; font-weight:400; letter-spacing:0.15em;
  text-transform:uppercase; color:rgba(240,232,213,0.65);
  background:none; border:none; cursor:pointer;
  display:flex; align-items:center; gap:5px;
  padding-bottom:2px; position:relative;
  transition:color var(--t-fast);
  font-family:var(--font-sans);
}
.nav-dropdown > button svg { transition:transform .25s ease; }
.nav-dropdown > button:hover { color:var(--cream); }
.nav-dropdown.dd-open > button { color:var(--cream); }
.nav-dropdown.dd-open > button svg { transform:rotate(180deg); }
.nav-dropdown-menu {
  position:absolute; top:calc(100% + 14px); left:50%;
  transform:translateX(-50%) translateY(-6px);
  min-width:200px;
  background:rgba(10,26,14,0.97);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border:1px solid var(--border);
  border-radius:14px; padding:8px;
  opacity:0; pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
  z-index:100;
}
.nav-dropdown.dd-open .nav-dropdown-menu {
  opacity:1; pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.nav-dropdown-menu a {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:9px;
  font-size:11px; letter-spacing:0.12em;
  color:rgba(240,232,213,0.7) !important;
  transition:background .15s, color .15s;
  text-decoration:none; font-weight:400;
}
.nav-dropdown-menu a::after { display:none !important; }
.nav-dropdown-menu a:hover { background:rgba(242,234,216,0.07); color:var(--cream) !important; }
.nav-dropdown-menu a .ddm-flag { font-size:15px; line-height:1; flex-shrink:0; }
.nav-dropdown-divider { height:1px; background:var(--border); margin:4px 8px; }
.nav-right { display:flex; align-items:center; gap:14px; }
.lang-btn {
  font-size:11px; letter-spacing:0.15em;
  color:var(--cream-dim); padding:6px 14px;
  border:1px solid var(--border); border-radius:100px;
  transition:all var(--t-fast); text-transform:uppercase;
}
.lang-btn:hover { color:var(--cream); border-color:var(--border-hover); }
.hamburger {
  display:none; flex-direction:column; gap:5px;
  padding:6px; width:36px; height:36px;
  align-items:center; justify-content:center;
}
.hamburger span {
  display:block; width:22px; height:1px;
  background:var(--cream); border-radius:1px;
  transition: all var(--t-med);
}
.hamburger.open span:nth-child(1){ transform:rotate(45deg) translate(4px,4px); }
.hamburger.open span:nth-child(2){ opacity:0; }
.hamburger.open span:nth-child(3){ transform:rotate(-45deg) translate(4px,-4px); }
@media(max-width:860px){ .nav-links { display:none; } }
@media(max-width:860px){
  .hamburger { display:flex; }
  .nav-right .btn { display:none; }
}

/* -------- MOBILE MENU -------- */
.mobile-menu {
  position: fixed; inset:0;
  background: var(--bg);
  display: flex; flex-direction:column;
  align-items:center; justify-content:center; gap:8px;
  z-index: var(--z-mobile);
  opacity:0; visibility:hidden;
  transition: opacity var(--t-slow), visibility var(--t-slow);
}
.mobile-menu.open { opacity:1; visibility:visible; }
.mobile-menu-close {
  position:absolute; top:20px; right:20px;
  width:44px; height:44px;
  display:flex; align-items:center; justify-content:center;
  color:var(--cream-dim);
  transition:color var(--t-fast);
}
.mobile-menu-close:hover { color:var(--cream); }
.mobile-menu-close svg { width:20px; height:20px; }
.mobile-menu a {
  font-family: var(--font-serif);
  font-size: clamp(26px,5vw,40px);
  font-weight:300; letter-spacing:0.06em;
  color:var(--cream); display:block;
  text-align:center; padding:10px 0;
  transition:color var(--t-fast);
}
.mobile-menu a:hover,.mobile-menu a.hl { color:var(--gold); }
.mobile-menu-cta {
  display:flex; gap:12px; flex-wrap:wrap;
  justify-content:center; margin-top:24px;
}
.mobile-menu-divider {
  width:40px; height:1px;
  background:var(--border);
  margin:12px auto;
}

/* -------- HERO -------- */
.hero {
  position:relative;
  height:100svh; min-height:620px;
  overflow:hidden;
  display:flex; align-items:flex-end;
  padding-bottom: clamp(56px,8vw,96px);
}

/* Photo slideshow — replaces video */
.hero-slides {
  position:absolute; inset:0;
  z-index:0;
}
/* Opacity crossfade wrapper — separate from Ken Burns so no jerk on reset */
.hero-slide {
  position:absolute; inset:0;
  opacity:0;
  animation: slide-crossfade 36s infinite;
}
.hero-slide:nth-child(1) { animation-delay: 0s; }
.hero-slide:nth-child(2) { animation-delay: -30s; }
.hero-slide:nth-child(3) { animation-delay: -24s; }
.hero-slide:nth-child(4) { animation-delay: -18s; }
.hero-slide:nth-child(5) { animation-delay: -12s; }
.hero-slide:nth-child(6) { animation-delay: -6s; }

/* Ken Burns on inner img — alternate direction so never snaps back */
.hero-slide-img {
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  animation: hero-img-fadein 0.8s ease both;
  will-change:transform;
  animation: kenburns-1 18s ease-in-out infinite alternate;
}
.hero-slide:nth-child(1) .hero-slide-img { animation-name: kenburns-1; }
.hero-slide:nth-child(2) .hero-slide-img { animation-name: kenburns-2; }
.hero-slide:nth-child(3) .hero-slide-img { animation-name: kenburns-3; }
.hero-slide:nth-child(4) .hero-slide-img { animation-name: kenburns-4; }
.hero-slide:nth-child(5) .hero-slide-img { animation-name: kenburns-1; }
.hero-slide:nth-child(6) .hero-slide-img { animation-name: kenburns-3; }

@keyframes hero-img-fadein {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes slide-crossfade {
  0%    { opacity: 1; }
  13%   { opacity: 1; }
  17%   { opacity: 0; }
  95%   { opacity: 0; }
  100%  { opacity: 1; }
}
@keyframes kenburns-1 {
  from { transform: scale(1)    translate(0,     0); }
  to   { transform: scale(1.09) translate(-1.5%, -1%); }
}
@keyframes kenburns-2 {
  from { transform: scale(1.06) translate(-2%,  1%); }
  to   { transform: scale(1)    translate(1%,   0); }
}
@keyframes kenburns-3 {
  from { transform: scale(1)    translate(1.5%, 0); }
  to   { transform: scale(1.08) translate(0,    -1.5%); }
}
@keyframes kenburns-4 {
  from { transform: scale(1.07) translate(0,    -2%); }
  to   { transform: scale(1)    translate(2%,   0); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-slide { animation: slide-crossfade 36s infinite !important; }
  .hero-slide-img { animation: none !important; }
}

.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background: linear-gradient(
    155deg,
    rgba(8,14,8,0.18) 0%,
    rgba(8,14,8,0.05) 30%,
    rgba(8,14,8,0.90) 100%
  );
}
.hero-top-fade {
  position:absolute; top:0; left:0; right:0; z-index:1;
  height:200px;
  background:linear-gradient(to bottom,rgba(8,14,8,0.72),transparent);
}
.hero-content { position:relative; z-index:2; width:100%; }
.hero-scroll { z-index:2; }
.hero-eyebrow {
  font-size:9px; letter-spacing:0.5em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:14px; display:block;
  opacity:0; animation:fade-up 0.9s ease 0.7s forwards;
}
.hero-title-wrap {
  position: relative;
  display: block;
}
.hero-title {
  font-family:var(--font-serif);
  font-size:clamp(68px,13.5vw,196px);
  font-weight:300; line-height:0.88;
  letter-spacing:-0.02em;
  color:var(--cream); text-transform:uppercase;
  opacity:0; animation:fade-up 1.1s ease 0.5s forwards;
}
#nomadica-particle-canvas {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: none;
  pointer-events: auto;
}
@media (max-width:900px) {
  #nomadica-particle-canvas { display: none !important; }
}
.hero-tagline {
  font-family:var(--font-serif);
  font-size:clamp(17px,2.8vw,26px);
  font-weight:300; font-style:italic;
  color:rgba(240,232,213,0.82);
  margin-top:14px; line-height:1.5;
  opacity:0; animation:fade-up 0.9s ease 0.9s forwards;
}
.hero-tagline em { font-style:normal; color:var(--gold); }
.hero-sub-tagline {
  font-family: var(--font-sans);
  font-size: clamp(10px, 1.1vw, 13px);
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(232,144,32,0.7);
  margin-top: 10px;
  opacity: 0; animation: fade-up 0.8s ease 1.05s forwards;
}
.hero-actions {
  margin-top:40px;
  display:flex; align-items:center; gap:28px; flex-wrap:wrap;
  opacity:0; animation:fade-up 0.9s ease 1.1s forwards;
}
.hero-dest-links { display:flex; gap:20px; align-items:center; }
.hero-dest-link {
  display:flex; align-items:center; gap:8px;
  font-size:11px; letter-spacing:0.2em;
  text-transform:uppercase;
  color:rgba(240,232,213,0.6);
  transition:color var(--t-med);
}
.hero-dest-link:hover { color:var(--cream); }
.dest-dot {
  width:5px; height:5px; border-radius:50%;
  background:var(--gold); flex-shrink:0;
}
.hero-separator {
  width:1px; height:18px;
  background:var(--border);
}
.hero-scroll {
  position:absolute; bottom:28px; left:50%;
  transform:translateX(-50%);
  display:flex; flex-direction:column;
  align-items:center; gap:10px;
  z-index:2; opacity:0;
  animation:fade-up 0.8s ease 1.8s forwards;
}
.hero-scroll span {
  font-size:9px; letter-spacing:0.4em;
  text-transform:uppercase;
  color:rgba(240,232,213,0.4);
}
.scroll-line {
  width:1px; height:44px;
  background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scroll-breathe 2.2s ease-in-out infinite;
}
@keyframes scroll-breathe {
  0%,100%{ opacity:1; transform:scaleY(1); transform-origin:top; }
  50%{ opacity:0.3; transform:scaleY(0.4); transform-origin:top; }
}
@keyframes fade-up {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}

/* -------- STATS BAND -------- */
.stats-band {
  background:var(--bg-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:44px 0;
}
.stats-inner {
  display:flex; align-items:center; justify-content:center;
}
.stat-item {
  flex:1; text-align:center; padding:0 24px;
}
.stat-num {
  display:block;
  font-family:var(--font-serif);
  font-size:clamp(28px,4vw,46px);
  font-weight:300; color:var(--cream);
  line-height:1; margin-bottom:8px;
}
.stat-label {
  font-size:10px; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--cream-dim);
}
.stat-rule {
  width:1px; height:52px;
  background:var(--border); flex-shrink:0;
}
@media(max-width:600px){
  .stats-inner { flex-direction:column; gap:28px; }
  .stat-rule { width:40px; height:1px; }
}

/* -------- PHILOSOPHY -------- */
.philosophy-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(48px,8vw,96px); align-items:center;
}
.philosophy-quote {
  font-family:var(--font-serif);
  font-size:clamp(17px,2.4vw,24px);
  font-style:italic; color:var(--gold);
  border-left:2px solid var(--gold);
  padding-left:22px; margin:28px 0;
  line-height:1.5;
}
.philosophy-tenets {
  margin: 28px 0;
  display: flex; flex-direction: column; gap: 14px;
}
.philosophy-tenet {
  display: flex; flex-direction: column; gap: 4px;
  padding: 14px 18px;
  border-left: 2px solid rgba(232,144,32,0.35);
  background: rgba(232,144,32,0.04);
  border-radius: 0 8px 8px 0;
  transition: border-color 0.25s ease, background 0.25s ease;
}
.philosophy-tenet:hover {
  border-color: var(--gold);
  background: rgba(232,144,32,0.08);
}
.philosophy-tenet strong {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
}
.philosophy-tenet span {
  font-size: 13px;
  color: var(--cream-dim);
  line-height: 1.65;
}
.philosophy-img {
  position:relative; aspect-ratio:3/4;
  overflow:hidden; border-radius:20px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.5), 0 4px 16px rgba(0,0,0,0.3);
}
.philosophy-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform 0.9s ease;
}
.philosophy-img:hover img { transform:scale(1.03); }
.philosophy-img-caption {
  position:absolute; bottom:14px; left:14px;
  font-size:10px; letter-spacing:0.25em;
  text-transform:uppercase;
  color:rgba(240,232,213,0.55);
  background:rgba(10,26,14,0.72);
  padding:7px 14px; backdrop-filter:blur(4px);
}
.philosophy-img-frame {
  position:absolute; top:16px; right:16px;
  width:80px; height:80px;
  border:1px solid rgba(184,144,64,0.3);
  border-radius:1px;
  pointer-events:none;
}
@media(max-width:860px){
  .philosophy-grid { grid-template-columns:1fr; gap:40px; }
}

/* -------- WHY NOMADICA -------- */
.why-bg { background:var(--bg-2); }
.pillars {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:52px;
}
.pillars-4 { grid-template-columns: repeat(4,1fr); }
.pillar {
  padding:36px 28px;
  border:1px solid var(--border); border-radius:16px;
  transition:border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, transform 0.35s ease;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  position:relative; overflow:hidden;
}
.pillar::before {
  content:'';
  position:absolute; inset:0; border-radius:16px;
  background: radial-gradient(ellipse at 50% 0%, rgba(232,144,32,0.18) 0%, rgba(200,72,24,0.08) 45%, transparent 70%);
  opacity:0;
  transition: opacity 0.4s ease;
  pointer-events:none;
}
.pillar:hover {
  border-color: rgba(232,144,32,0.45);
  background: rgba(18,10,4,0.7);
  box-shadow: 0 0 0 1px rgba(232,144,32,0.12), 0 16px 48px rgba(200,72,24,0.25), 0 4px 12px rgba(0,0,0,0.4);
  transform: translateY(-5px);
}
.pillar:hover::before { opacity:1; }
.pillar-icon {
  width:36px; height:36px; color:var(--gold); margin-bottom:22px;
  position:relative; z-index:1;
  transition: color 0.35s ease;
}
.pillar:hover .pillar-icon { color:#F5A832; }
.pillar-icon svg { width:100%; height:100%; }
.pillar h3 {
  font-family:var(--font-serif);
  font-size:20px; font-weight:400;
  color:var(--cream); margin-bottom:10px;
  line-height:1.3; position:relative; z-index:1;
  transition: color 0.35s ease;
}
.pillar:hover h3 { color:#fff; }
.pillar p { font-size:13px; color:var(--cream-dim); line-height:1.75; position:relative; z-index:1; }
@media(max-width:1100px){ .pillars-4 { grid-template-columns:repeat(2,1fr); gap:20px; } }
@media(max-width:900px){ .pillars, .pillars-4 { grid-template-columns:1fr; gap:16px; } }
@media(min-width:601px) and (max-width:900px){ .pillars:not(.pillars-4) { grid-template-columns:1fr 1fr; } }

/* -------- DESTINATIONS -------- */
.dest-intro { text-align:center; padding:var(--section-gap) 0 48px; }
.dest-card {
  position:relative; height:82vh; min-height:520px;
  overflow:hidden; display:flex; align-items:flex-end;
  cursor:pointer;
}
.dest-bg {
  position:absolute; inset:0;
}
.dest-bg-img {
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.3s ease;
}
.dest-card:hover .dest-bg-img { transform:scale(1.05); }
.dest-bg-gradient {
  position:absolute; inset:0;
}
.dest-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,
    rgba(10,26,14,0.92) 0%,
    rgba(10,26,14,0.35) 55%,
    rgba(10,26,14,0.1) 100%);
  transition:background var(--t-slow);
}
.dest-card:hover .dest-overlay {
  background:linear-gradient(to top,
    rgba(10,26,14,0.88) 0%,
    rgba(10,26,14,0.45) 65%,
    rgba(10,26,14,0.15) 100%);
}
.dest-content {
  position:relative; z-index:2;
  padding:clamp(32px,5vw,64px);
  max-width:580px;
}
.dest-tag {
  display:inline-block; font-size:9px;
  letter-spacing:0.5em; text-transform:uppercase;
  color:var(--gold);
  border:1px solid rgba(184,144,64,0.4);
  padding:5px 14px; margin-bottom:18px;
}
.dest-content h2 {
  font-family:var(--font-serif);
  font-size:clamp(28px,3.8vw,52px);
  font-weight:300; line-height:1.12;
  color:var(--cream); margin-bottom:14px;
}
.dest-content p {
  font-size:12px; letter-spacing:0.12em;
  color:rgba(240,232,213,0.55);
  text-transform:uppercase; margin-bottom:28px;
}
.dest-card-num {
  position:absolute; top:40px; right:48px;
  font-family:var(--font-serif);
  font-size:clamp(80px,12vw,140px);
  font-weight:300; color:rgba(240,232,213,0.05);
  line-height:1; pointer-events:none;
  z-index:1; letter-spacing:-0.05em;
}

/* -------- TOUR CARDS -------- */
.journeys-bg { background:var(--bg); }
.section-header { margin-bottom:52px; }
.tour-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.tour-card {
  background:var(--bg-card);
  border:1px solid var(--border); border-radius:16px;
  overflow:hidden;
  transition:border-color var(--t-med), transform var(--t-cinematic), box-shadow var(--t-med);
  cursor:pointer;
  box-shadow: 0 4px 24px rgba(0,0,0,0.35), 0 1px 4px rgba(0,0,0,0.2);
}
.tour-card:hover {
  border-color:var(--border-hover);
  transform:translateY(-8px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.5), 0 4px 12px rgba(0,0,0,0.3);
}
.tour-thumb {
  aspect-ratio:16/10; overflow:hidden;
  position:relative;
}
.tour-thumb-bg {
  width:100%; height:100%;
  transition:transform 0.9s ease;
}
.tour-card:hover .tour-thumb-bg { transform:scale(1.06); }
.tour-thumb-label {
  position:absolute; bottom:12px; left:12px;
  font-size:9px; letter-spacing:0.25em;
  text-transform:uppercase; color:rgba(240,232,213,0.8);
  background:rgba(10,26,14,0.65); padding:5px 10px;
  backdrop-filter:blur(4px); border-radius:100px;
}
.tour-body { padding:24px 24px 28px; }
.tour-country {
  font-size:9px; letter-spacing:0.35em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:8px; display:block;
}
.tour-body h3 {
  font-family:var(--font-serif);
  font-size:20px; font-weight:400;
  color:var(--cream); line-height:1.3;
  margin-bottom:10px;
}
.tour-body p {
  font-size:12px; color:var(--cream-dim);
  line-height:1.7; margin-bottom:18px;
}
.tour-meta {
  display:flex; gap:16px; flex-wrap:wrap;
  font-size:11px; color:var(--cream-dim);
  border-top:1px solid var(--border); padding-top:14px;
  margin-bottom:18px;
}
.tour-meta span { display:flex; align-items:center; gap:5px; }
.tour-meta svg { width:11px; height:11px; color:var(--gold); }
.waitlist {
  display:inline-flex; align-items:center; gap:7px;
  font-size:10px; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--orange);
}
.waitlist-pulse {
  width:6px; height:6px; border-radius:50%;
  background:var(--orange);
  animation:pulse 2.2s ease-in-out infinite;
}
@keyframes pulse {
  0%,100%{ opacity:1; transform:scale(1); }
  50%{ opacity:0.4; transform:scale(0.7); }
}
@media(max-width:900px){ .tour-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:600px){ .tour-grid { grid-template-columns:1fr; } }

/* -------- PRIVATE TRIPS TEASER -------- */
.private-bg { background:var(--bg-2); position:relative; overflow:hidden; }
.private-watermark {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  font-family:var(--font-serif);
  font-size:clamp(80px,18vw,220px);
  font-weight:300; color:rgba(240,232,213,0.018);
  white-space:nowrap; pointer-events:none;
  letter-spacing:0.1em; line-height:1;
  z-index:0;
}
.private-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(48px,7vw,96px); align-items:center;
}
.style-filters {
  display:flex; flex-wrap:wrap; gap:10px; margin-top:28px;
}
.style-tag {
  padding:9px 20px; border:1px solid var(--border);
  border-radius:40px; font-size:12px; color:var(--cream-dim);
  transition:all var(--t-med); cursor:default;
}
.style-tag:hover {
  border-color:var(--gold); color:var(--gold);
  background:rgba(184,144,64,0.05);
}
.countries-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:10px;
}
.country-tile {
  background:var(--cream-faint); border:1px solid var(--border);
  border-radius:14px; padding:18px 12px;
  text-align:center; transition:all var(--t-med); cursor:default;
  box-shadow: 0 2px 12px rgba(0,0,0,0.25);
}
.country-tile:hover {
  border-color:var(--border-hover);
  background:rgba(240,232,213,0.07);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
}
.country-tile-name {
  font-size:11px; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--cream-dim);
  margin-top:8px; display:block;
}
.country-tile-flag {
  display:block;
  width:36px; height:27px;
  object-fit:cover;
  border-radius:4px;
  margin:0 auto;
  box-shadow:0 2px 6px rgba(0,0,0,0.4);
}
.private-principle {
  margin-top:32px; padding:20px 24px;
  border:1px solid var(--border); border-radius:12px;
  border-left:3px solid var(--gold);
  background: rgba(232,144,32,0.04);
}
.private-principle p {
  font-family:var(--font-serif); font-style:italic;
  font-size:14px; color:var(--cream-dim); line-height:1.7;
}
@media(max-width:800px){
  .private-inner { grid-template-columns:1fr; gap:40px; }
}

/* -------- SACRED OBJECTS -------- */
.sacred-band {
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:40px 0;
  background:linear-gradient(135deg,rgba(200,72,24,0.04) 0%,var(--bg) 40%,rgba(232,144,32,0.04) 100%);
  position:relative; overflow:hidden;
}
.sacred-band::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:4px;
  background:linear-gradient(to bottom,var(--orange),var(--gold));
}
.sacred-inner {
  display:flex; align-items:center;
  gap:32px; flex-wrap:wrap;
  padding:0 clamp(20px,4vw,64px);
}
.sacred-gem { font-size:28px; flex-shrink:0; color:var(--gold); }
.sacred-inner p {
  flex:1; font-family:var(--font-serif); font-style:italic;
  font-size:clamp(15px,1.8vw,18px); color:var(--cream-dim); line-height:1.65;
  min-width:240px;
}
.sacred-inner p strong { font-size:1.1em; }

/* -------- JOURNAL PREVIEW -------- */
.journal-bg { background:var(--bg); }
.journal-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:28px; margin-top:48px;
}
.j-card {
  display:flex; flex-direction:column;
  border-bottom:1px solid var(--border);
  padding-bottom:24px; cursor:pointer;
  transition:border-color var(--t-med);
}
.j-card:hover { border-bottom-color:var(--border-hover); }
.j-thumb {
  aspect-ratio:16/9; overflow:hidden;
  border-radius:12px; margin-bottom:18px;
}
.j-thumb-bg {
  width:100%; height:100%;
  transition:transform 0.9s ease;
}
.j-card:hover .j-thumb-bg { transform:scale(1.05); }
.j-cat {
  font-size:9px; letter-spacing:0.35em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:8px; display:block;
}
.j-card h3 {
  font-family:var(--font-serif);
  font-size:19px; font-weight:400;
  color:var(--cream); line-height:1.35;
  margin-bottom:8px;
}
.j-card p {
  font-size:12px; color:var(--cream-dim);
  line-height:1.65; flex:1;
}
.j-date {
  margin-top:14px; font-size:10px;
  letter-spacing:0.15em; text-transform:uppercase;
  color:rgba(240,232,213,0.3);
}
@media(max-width:860px){ .journal-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:580px){ .journal-grid { grid-template-columns:1fr; } }

/* -------- LEAD CAPTURE -------- */
.lead-bg {
  background:var(--bg);
  position:relative; overflow:hidden;
}
.lead-glow {
  position:absolute; top:0; left:50%;
  transform:translateX(-50%);
  width:800px; height:600px;
  background:radial-gradient(ellipse,rgba(42,96,64,0.18) 0%,transparent 70%);
  pointer-events:none;
}
.lead-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(40px,7vw,96px); align-items:center;
  position:relative; z-index:1;
}
.lead-text h2 {
  font-family:var(--font-serif);
  font-size:clamp(32px,5vw,54px);
  font-weight:300; line-height:1.12;
  color:var(--cream); margin-bottom:18px;
}
.lead-text p {
  color:var(--cream-dim); margin-bottom:32px;
  line-height:1.8; font-size:14px;
}
.lead-promise {
  margin-top:14px; font-size:11px;
  letter-spacing:0.15em; text-transform:uppercase;
  color:rgba(240,232,213,0.35);
  display:flex; align-items:center; gap:8px;
}
.lead-promise::before {
  content:''; width:20px; height:1px;
  background:var(--border-hover);
}
.lead-box {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:20px; padding:40px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.4), 0 2px 8px rgba(0,0,0,0.2);
}
.lead-box h3 {
  font-family:var(--font-serif);
  font-size:22px; font-weight:400;
  color:var(--cream); margin-bottom:8px;
}
.lead-box > p {
  font-size:13px; color:var(--cream-dim); margin-bottom:24px;
}
.form-link-btn {
  display:block; width:100%; padding:14px;
  text-align:center; font-size:12px;
  font-weight:500; letter-spacing:0.14em;
  text-transform:uppercase;
  background:transparent; color:var(--cream-dim);
  border:1px solid var(--border); border-radius:100px;
  margin-top:12px; cursor:pointer;
  transition:all var(--t-med);
}
.form-link-btn:hover {
  color:var(--cream); border-color:var(--border-hover);
  background:var(--cream-faint);
}
@media(max-width:800px){
  .lead-grid { grid-template-columns:1fr; gap:40px; }
}

/* -------- ALUMNI -------- */
.alumni-bg { background:var(--bg-2); }
.alumni-header { margin-bottom:40px; }
.alumni-tiers {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.alumni-tier {
  text-align:center; padding:32px 24px;
  border:1px solid var(--border); border-radius:16px;
  transition:border-color var(--t-med), box-shadow var(--t-med), transform var(--t-med);
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}
.alumni-tier:hover {
  border-color:var(--gold);
  box-shadow: 0 12px 40px rgba(232,144,32,0.15), 0 4px 12px rgba(0,0,0,0.3);
  transform: translateY(-4px);
}
.alumni-discount {
  font-family:var(--font-serif);
  font-size:52px; font-weight:300;
  color:var(--gold); line-height:1; margin-bottom:6px;
}
.alumni-trips {
  font-size:10px; letter-spacing:0.2em;
  text-transform:uppercase; color:var(--cream-dim);
  margin-bottom:14px;
}
.alumni-tier p {
  font-size:12px; color:var(--cream-dim); line-height:1.6;
}
.alumni-en-label {
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(232,144,32,0.5);
  margin-bottom: 8px;
}
.alumni-notes {
  margin-top:28px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.alumni-note-item {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 11px; color: rgba(240,232,213,0.35);
  letter-spacing: 0.04em; line-height: 1.55;
  padding: 10px 14px;
  border: 1px solid rgba(240,232,213,0.06);
  border-radius: 8px;
  background: rgba(240,232,213,0.02);
}
.alumni-note-item svg { flex-shrink:0; margin-top:1px; color:rgba(232,144,32,0.4); }
@media(max-width:700px){ .alumni-notes { grid-template-columns:1fr; } }
@media(max-width:600px){
  .alumni-tiers { grid-template-columns:1fr; }
}

/* -------- INLINE CONTACT FORM -------- */
.contact-form { display:flex; flex-direction:column; gap:14px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label {
  font-size:10px; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--gold); font-weight:600;
}
.form-group input,
.form-group select,
.form-group textarea {
  background:rgba(242,234,216,0.06);
  border:1px solid var(--border);
  border-radius:12px;
  padding:11px 16px;
  color:var(--cream);
  font-family:var(--font-sans);
  font-size:13px;
  transition:border-color var(--t-fast), background var(--t-fast);
  outline:none;
  width:100%;
}
.form-group select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%239E9488' d='M0 0l6 8 6-8z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:rgba(158,148,136,0.6); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color:var(--gold);
  background:rgba(232,144,32,0.06);
}
.form-group textarea { resize:vertical; min-height:80px; }
.form-group select option { background:var(--bg-card); color:var(--cream); }
@media(max-width:540px){ .form-row { grid-template-columns:1fr; } }

/* -------- FOOTER PHOTO STRIP -------- */
.footer-photo-strip {
  position:relative; height:440px; overflow:hidden;
}
.footer-photo-strip img {
  width:100%; height:100%; object-fit:cover;
  object-position:center 35%;
  filter:brightness(0.38) saturate(0.7);
  transform:scale(1.04);
  transition:transform 8s ease;
}
.footer-photo-strip:hover img { transform:scale(1.0); }
/* Top & bottom fade into page bg */
.footer-photo-strip::before {
  content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(to bottom, var(--bg) 0%, transparent 22%, transparent 72%, var(--bg) 100%);
}
/* Centered tagline overlay */
.footer-photo-caption {
  position:absolute; inset:0; z-index:2;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:0 24px;
  pointer-events:none;
}
.footer-photo-caption-line {
  display:block; width:1px; height:48px;
  background:linear-gradient(to bottom, transparent, rgba(232,144,32,0.6));
  margin:0 auto 24px;
}
.footer-photo-caption h3 {
  font-family:var(--font-serif);
  font-size:clamp(28px,4vw,52px);
  font-weight:400; font-style:italic;
  color:var(--cream); line-height:1.25;
  letter-spacing:0.01em;
}
.footer-photo-caption h3 em { color:var(--gold); font-style:normal; }
.footer-photo-caption p {
  margin-top:14px;
  font-size:clamp(11px,1.2vw,13px); letter-spacing:0.2em;
  text-transform:uppercase; color:rgba(242,234,216,0.45);
  font-weight:600;
}
.footer-photo-sub {
  font-size: clamp(10px, 1vw, 12px) !important;
  letter-spacing: 0.28em !important;
  color: rgba(232,144,32,0.55) !important;
  font-weight: 400 !important;
  text-transform: uppercase;
  margin-top: 16px !important;
  margin-bottom: -4px;
}
@media(max-width:768px){ .footer-photo-strip { height:320px; } }
@media(max-width:480px){ .footer-photo-strip { height:260px; } }

/* -------- FOOTER -------- */
.site-footer {
  background:#060E09;
  border-top:1px solid var(--border);
  padding:64px 0 28px;
}
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr;
  gap:48px; margin-bottom:48px;
}
.footer-brand-name {
  font-family:var(--font-serif);
  font-size:20px; font-weight:300;
  letter-spacing:0.28em; text-transform:uppercase;
  color:var(--cream); margin-bottom:10px; display:block;
}
.footer-brand-line {
  font-family:var(--font-serif); font-style:italic;
  font-size:13px; color:var(--cream-dim); margin-bottom:24px;
}
.footer-social {
  display:flex; gap:10px;
}
.footer-social a {
  width:34px; height:34px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border); border-radius:50%;
  color:var(--cream-dim); transition:all var(--t-med);
}
.footer-social a:hover {
  color:var(--cream); border-color:var(--border-hover);
}
.footer-social a svg { width:12px; height:12px; }
.footer-col h4 {
  font-size:9px; letter-spacing:0.3em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:18px;
}
.footer-col ul { display:flex; flex-direction:column; gap:9px; }
.footer-col ul a {
  font-size:13px; color:var(--cream-dim);
  transition:color var(--t-fast);
}
.footer-col ul a:hover { color:var(--cream); }
.footer-col .contact-line {
  font-size:12px; color:var(--cream-dim);
  margin-bottom:6px; display:flex; gap:8px; align-items:center;
}
.footer-col .contact-line svg { width:12px; height:12px; color:var(--gold); flex-shrink:0; }
.footer-bottom {
  padding-top:20px; border-top:1px solid var(--border);
  display:flex; justify-content:space-between;
  align-items:center; flex-wrap:wrap; gap:12px;
}
.footer-bottom p {
  font-size:10px; color:rgba(240,232,213,0.25);
  letter-spacing:0.05em;
}
.footer-legal { display:flex; gap:18px; }
.footer-legal a {
  font-size:10px; color:rgba(240,232,213,0.25);
  transition:color var(--t-fast);
}
.footer-legal a:hover { color:var(--cream-dim); }
.footer-lang {
  display:flex; gap:12px; margin-top:16px;
}
.footer-lang a {
  font-size:11px; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--cream-dim);
  transition:color var(--t-fast);
}
.footer-lang a.active { color:var(--cream); }
.footer-lang a:hover { color:var(--cream); }
@media(max-width:860px){
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
}
@media(max-width:500px){
  .footer-grid { grid-template-columns:1fr; gap:28px; }
}

/* -------- MOBILE STICKY CTA -------- */
.sticky-mobile {
  position:fixed; bottom:0; left:0; right:0;
  display:none;
  background:rgba(10,26,14,0.96);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--border);
  padding:10px 16px 10px;
  z-index:980; gap:8px;
}
@media(max-width:768px){ .sticky-mobile { display:flex; } }
.sticky-mobile a {
  flex:1; text-align:center; padding:12px;
  font-size:11px; font-weight:500;
  letter-spacing:0.12em; text-transform:uppercase;
  border-radius:1px; transition:opacity var(--t-fast);
}
.sticky-mobile a:hover { opacity:0.85; }
.sticky-zalo { background:#0068ff; color:#fff; }
.sticky-consult { background:var(--orange); color:#fff; }

/* -------- BACK TO TOP -------- */
.back-top {
  position:fixed; bottom:72px; right:20px;
  width:44px; height:44px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--cream-dim); font-size:16px;
  opacity:0; pointer-events:none;
  transition:all var(--t-med); z-index:95;
}
.back-top.show { opacity:1; pointer-events:auto; }
.back-top:hover {
  background:var(--green-dark); color:var(--cream);
  border-color:var(--border-hover);
}
@media(min-width:769px){ .back-top { bottom:32px; } }

/* -------- IMAGE PLACEHOLDER UTILITY -------- */
.img-ph {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.img-ph-label {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:9px; letter-spacing:0.25em;
  text-transform:uppercase; color:rgba(240,232,213,0.2);
  font-family:var(--font-sans);
}

/* -------- DESTINATION PAGE STYLES -------- */
.dest-page-hero {
  position:relative; height:92vh; min-height:580px;
  overflow:hidden; display:flex; align-items:flex-end;
  padding-bottom:clamp(48px,7vw,80px);
  background-color: var(--bg);
}
.dest-page-hero .hero-overlay {
  background:linear-gradient(
    to top,
    rgba(10,26,14,0.92) 0%,
    rgba(10,26,14,0.4) 60%,
    rgba(10,26,14,0.1) 100%
  );
}
.dest-page-content { position:relative; z-index:2; }
.dest-page-content .dest-tag { margin-bottom:16px; }
.dest-page-content h1 {
  font-family:var(--font-serif);
  font-size:clamp(48px,8vw,100px);
  font-weight:300; line-height:1.05;
  color:var(--cream);
}
.dest-page-content .subtitle {
  font-family:var(--font-serif); font-style:italic;
  font-size:clamp(16px,2.5vw,22px);
  color:rgba(240,232,213,0.7); margin-top:12px;
}
.dest-info-band {
  background:var(--bg-2); border-bottom:1px solid var(--border);
  padding:20px 0;
}
.dest-info-inner {
  display:flex; gap:32px; flex-wrap:wrap; align-items:center;
}
.dest-info-item {
  display:flex; gap:8px; align-items:center;
  font-size:12px; color:var(--cream-dim);
  letter-spacing:0.08em;
}
.dest-info-item svg { width:13px; height:13px; color:var(--gold); }
.dest-overview {
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(40px,7vw,80px); align-items:start;
}
.dest-overview-text h2 {
  font-family:var(--font-serif);
  font-size:clamp(28px,4vw,44px);
  font-weight:300; color:var(--cream); margin-bottom:16px;
}
.dest-overview-text p {
  color:var(--cream-dim); font-size:14px;
  line-height:1.85; margin-bottom:14px;
}
.warning-block {
  margin-top:28px; padding:20px 24px;
  border:1px solid rgba(200,104,48,0.3);
  border-left:2px solid var(--orange);
  border-radius:1px;
}
.warning-block h4 {
  font-size:11px; letter-spacing:0.25em;
  text-transform:uppercase; color:var(--orange);
  margin-bottom:8px;
}
.warning-block p {
  font-size:13px; color:var(--cream-dim); line-height:1.7;
}
.not-for-everyone {
  background:var(--cream-faint); border:1px solid var(--border);
  border-radius:1px; padding:28px;
  margin-top:28px;
}
.not-for-everyone h4 {
  font-family:var(--font-serif);
  font-size:18px; color:var(--cream); margin-bottom:10px;
}
.not-for-everyone p {
  font-size:13px; color:var(--cream-dim); line-height:1.7;
}
@media(max-width:800px){
  .dest-overview { grid-template-columns:1fr; gap:36px; }
}

/* -------- FAQ -------- */
.faq-list { margin-top:36px; }
.faq-item {
  border-bottom:1px solid var(--border);
  overflow:hidden;
}
.faq-q {
  width:100%; text-align:left;
  padding:20px 0; display:flex;
  justify-content:space-between; align-items:center;
  gap:16px; cursor:pointer;
  transition:color var(--t-fast);
}
.faq-q:hover { color:var(--cream); }
.faq-q-text {
  font-family:var(--font-serif);
  font-size:18px; font-weight:400;
  color:var(--cream); line-height:1.4;
}
.faq-icon {
  width:20px; height:20px; flex-shrink:0;
  color:var(--gold); transition:transform var(--t-med);
}
.faq-item.open .faq-icon { transform:rotate(45deg); }
.faq-a {
  max-height:0; overflow:hidden;
  transition:max-height var(--t-slow);
}
.faq-item.open .faq-a { max-height:400px; }
.faq-a p {
  padding-bottom:20px; font-size:13px;
  color:var(--cream-dim); line-height:1.8;
}
