:root {
  --paper: #f7f1e7;
  --paper-warm: #f2e8da;
  --ivory: #fff8ee;
  --navy: #09233f;
  --navy-2: #0e2a47;
  --text: #13283d;
  --muted: #66707a;
  --orange: #d95f17;
  --orange-dark: #b84b0d;
  --sand: #c99a4a;
  --border: rgba(9, 35, 63, .16);
  --line: rgba(9, 35, 63, .11);
  --white: #fffaf2;
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans: Inter, Avenir, "Helvetica Neue", Arial, sans-serif;
  --script: Caveat, "Segoe Script", cursive;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: #e5dacb;
  color: var(--text);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
ul, ol { margin: 0; padding: 0; }
li { list-style: none; }

.page-shell {
  max-width: 1440px;
  margin: 0 auto;
  background:
    radial-gradient(circle at 15% 9%, rgba(217, 95, 23, .06), transparent 26%),
    linear-gradient(90deg, rgba(9,35,63,.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(9,35,63,.035) 1px, transparent 1px),
    var(--paper);
  background-size: auto, 80px 80px, 80px 80px, auto;
  min-height: 100vh;
  box-shadow: 0 0 50px rgba(9, 35, 63, .14);
  overflow: hidden;
}

.paper-panel { position: relative; background: var(--paper); overflow: hidden; }
.paper-panel::before {
  content: "";
  position: absolute;
  inset: -80px;
  pointer-events: none;
  opacity: .08;
  background-image: url("data:image/svg+xml,%3Csvg width='240' height='240' viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%2309233F' stroke-width='1'%3E%3Cpath d='M18 40c34-24 66-21 96 9 26 27 58 29 96 7'/%3E%3Cpath d='M5 88c41-30 78-27 112 8 29 29 66 32 116 3'/%3E%3Cpath d='M12 132c35-20 69-16 101 14 35 32 75 35 117 8'/%3E%3Cpath d='M22 181c23-17 52-17 85 1 39 21 75 21 108 0'/%3E%3Ccircle cx='184' cy='54' r='23'/%3E%3Ccircle cx='184' cy='54' r='11'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 240px 240px;
  mix-blend-mode: multiply;
}

.site-header {
  height: 88px;
  display: grid;
  grid-template-columns: 220px 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 0 68px;
  border-bottom: 1px solid var(--border);
  background: rgba(247, 241, 231, .94);
  position: relative;
  z-index: 4;
}
.brand { display: inline-flex; flex-direction: column; width: fit-content; color: var(--navy); }
.brand-mark { font-family: var(--serif); font-size: 43px; line-height: .78; font-weight: 600; letter-spacing: .19em; }
.brand-sub { margin-top: 9px; font-size: 9px; line-height: 1; font-weight: 900; letter-spacing: .23em; text-transform: uppercase; }
.main-nav { display: flex; justify-content: center; gap: 32px; color: var(--navy); font-size: 13px; font-weight: 700; letter-spacing: .025em; }
.main-nav a { opacity: .92; white-space: nowrap; }
.main-nav a:hover { color: var(--orange-dark); }

.btn {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 28px;
  border: 1px solid transparent;
  border-radius: 2px;
  font-size: 12px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .10em;
  text-transform: uppercase;
  white-space: nowrap;
}
.btn-orange { background: var(--orange); color: #fff7ed; border-color: var(--orange); }
.btn-orange:hover { background: var(--orange-dark); }
.btn-navy { background: var(--navy); color: #fff8ed; border-color: var(--navy); }
.btn-outline { color: var(--navy); border-color: rgba(9, 35, 63, .36); background: rgba(255, 248, 238, .44); }
.compact { min-height: 40px; padding: 0 20px; font-size: 10px; }

.hero {
  display: grid;
  grid-template-columns: 42% 58%;
  height: 492px;
  border-bottom: 1px solid var(--border);
}
.hero-copy {
  padding: 58px 60px 40px 70px;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.map-grid {
  position: absolute;
  right: 30px;
  top: 30px;
  width: 142px;
  height: 142px;
  border: 1px solid rgba(9,35,63,.13);
  transform: rotate(-7deg);
  opacity: .36;
  background: repeating-linear-gradient(90deg, transparent 0 22px, rgba(9,35,63,.09) 22px 23px), repeating-linear-gradient(0deg, transparent 0 22px, rgba(9,35,63,.09) 22px 23px);
}
.coordinates {
  position: relative;
  z-index: 1;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .09em;
  color: var(--navy-2);
  text-transform: uppercase;
}
.coordinates .bar { color: var(--orange); padding: 0 8px; }
.compass { color: var(--orange); margin-right: 8px; }
.hero h1 {
  position: relative;
  z-index: 1;
  margin: 24px 0 0;
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(62px, 5.85vw, 82px);
  line-height: .88;
  letter-spacing: -.035em;
  color: var(--navy);
}
.accent-rule { position: relative; z-index: 1; display: block; width: 55px; height: 2px; background: var(--orange); margin: 22px 0 18px; }
.hero-lede {
  position: relative;
  z-index: 1;
  max-width: 355px;
  margin: 0;
  font-size: 15px;
  line-height: 1.52;
  color: #33465b;
}
.hero-actions { position: relative; z-index: 1; display: flex; gap: 13px; flex-wrap: wrap; margin-top: 27px; }
.hero-note {
  position: relative;
  z-index: 1;
  margin-top: 24px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  color: var(--navy);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.hero-note span { padding: 7px 9px; border: 1px solid rgba(9,35,63,.14); background: rgba(255,248,238,.35); }
.hero-media { position: relative; min-width: 0; overflow: hidden; background: var(--navy); }
.hero-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(9,35,63,.24), transparent 34%), linear-gradient(0deg, rgba(9,35,63,.66), transparent 58%), radial-gradient(circle at 70% 18%, rgba(217,95,23,.16), transparent 30%); pointer-events: none; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; object-position: center 34%; filter: saturate(1.02) contrast(1.07); }
.torn-edge {
  position: absolute;
  left: -23px;
  top: 0;
  bottom: 0;
  width: 70px;
  z-index: 2;
  background: linear-gradient(90deg, var(--paper), rgba(247,241,231,.92) 25%, transparent 80%);
  clip-path: polygon(0 0, 58% 0, 49% 6%, 64% 12%, 44% 18%, 61% 25%, 51% 34%, 67% 42%, 45% 51%, 62% 61%, 48% 70%, 63% 79%, 50% 88%, 59% 100%, 0 100%);
}
.hero-quote {
  position: absolute;
  z-index: 3;
  right: 54px;
  bottom: 38px;
  max-width: 245px;
  margin: 0;
  color: #fff8ef;
  font-family: var(--script);
  font-size: 25px;
  line-height: 1.02;
  text-shadow: 0 3px 18px rgba(0,0,0,.45);
  padding: 16px 18px 14px;
  background: rgba(5,17,31,.38);
  border-left: 2px solid rgba(244,192,120,.85);
  backdrop-filter: blur(4px);
}
.hero-quote cite { display: block; margin-top: 8px; font-family: var(--sans); font-size: 10px; font-weight: 900; font-style: normal; letter-spacing: .12em; text-transform: uppercase; }
.flight-mark { position: absolute; z-index: 3; top: 28px; right: 34px; display: grid; gap: 3px; padding: 13px 15px; color: #fff8ed; background: rgba(5,17,31,.42); border: 1px solid rgba(255,248,237,.34); backdrop-filter: blur(4px); text-transform: uppercase; }
.flight-mark span { color: #f4c078; font-size: 10px; font-weight: 900; letter-spacing: .10em; }
.flight-mark strong { font-family: var(--serif); font-size: 24px; line-height: .92; font-weight: 600; text-transform: none; }
.round-seal {
  display: grid;
  place-items: center;
  border: 1px solid currentColor;
  border-radius: 999px;
  text-transform: uppercase;
  text-align: center;
  font-size: 8px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: .16em;
}
.round-seal strong { font-family: var(--serif); font-size: 19px; letter-spacing: .02em; }
.round-seal em { font-style: normal; }


.editorial-pause {
  min-height: 78px;
  display: grid;
  place-items: center;
  padding: 20px 56px;
  border-bottom: 1px solid var(--border);
  background: rgba(255,248,238,.42);
}
.editorial-pause p {
  margin: 0;
  max-width: 760px;
  font-family: var(--serif);
  font-size: clamp(24px, 2.4vw, 36px);
  line-height: 1.04;
  color: var(--navy);
  text-align: center;
}

.destinations {
  display: grid;
  grid-template-columns: .86fr 1.14fr 1.14fr 1.14fr;
  height: 318px;
  border-bottom: 1px solid var(--border);
}
.destination-intro {
  padding: 35px 34px 30px 56px;
  border-right: 1px solid var(--border);
}
.eyebrow {
  position: relative;
  z-index: 1;
  display: inline-block;
  color: var(--orange);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.destination-intro h2, .leader-copy h2, .process-heading h2, .info-card h3, .final-cta h2 {
  position: relative;
  z-index: 1;
  margin: 12px 0 0;
  font-family: var(--serif);
  color: var(--navy);
  font-weight: 500;
  letter-spacing: -.025em;
}
.destination-intro h2 { font-size: 47px; line-height: .95; }
.destination-intro p { position: relative; z-index: 1; margin: 18px 0 0; max-width: 205px; font-size: 14px; line-height: 1.48; color: #445469; }
.text-link { position: relative; z-index: 1; display: inline-block; margin-top: 22px; color: var(--orange); font-size: 11px; font-weight: 900; letter-spacing: .10em; text-transform: uppercase; }
.mini-coordinates { position: absolute; z-index: 1; left: 56px; bottom: 17px; font-family: ui-monospace, monospace; color: rgba(9,35,63,.28); font-size: 9px; letter-spacing: .12em; }
.destination-card { position: relative; overflow: hidden; color: #fff8ef; border-right: 1px solid rgba(255,255,255,.34); }
.destination-card:last-child { border-right: 0; }
.destination-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.destination-egypt img { object-position: center 44%; }
.destination-amazon img { object-position: center center; }
.destination-rio img { object-position: center 68%; }
.destination-card:hover img { transform: scale(1.035); }
.destination-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(4,12,22,.91), rgba(4,12,22,.42) 54%, rgba(4,12,22,.12)), linear-gradient(180deg, rgba(0,0,0,.30), transparent 36%); }
.card-label { position: absolute; z-index: 2; top: 18px; left: 20px; display: flex; align-items: center; gap: 9px; padding: 8px 10px; font-size: 12px; font-weight: 900; letter-spacing: .075em; text-transform: uppercase; text-shadow: 0 2px 10px rgba(0,0,0,.48); background: rgba(5,17,31,.38); border: 1px solid rgba(255,248,237,.28); backdrop-filter: blur(3px); }
.card-label span { width: 22px; height: 22px; border: 1px solid #fff8ef; border-radius: 50%; }
.card-content { position: absolute; z-index: 2; left: 22px; right: 22px; bottom: 24px; text-align: center; text-shadow: 0 2px 12px rgba(0,0,0,.50); }
.card-content h3 { margin: 0; font-family: var(--serif); font-size: 48px; line-height: .92; font-weight: 600; letter-spacing: .015em; }
.card-content p { margin: 9px 0 0; font-size: 12px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }
.card-content ul { margin-top: 17px; display: flex; justify-content: center; gap: 15px; color: #f4c078; font-size: 11.5px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }

.trust-strip {
  min-height: 100px;
  display: grid;
  grid-template-columns: .92fr repeat(3, .82fr) 2.05fr;
  border-bottom: 1px solid var(--border);
  background: rgba(255, 248, 238, .33);
}
.trust-title, .stat, .trust-human { border-right: 1px solid rgba(9,35,63,.07); display: flex; align-items: center; }
.trust-title { padding: 0 24px 0 50px; flex-direction: column; align-items: flex-start; justify-content: center; text-transform: uppercase; color: var(--navy); }
.trust-title span, .trust-title em { font-size: 11px; font-style: normal; font-weight: 900; letter-spacing: .10em; }
.trust-title strong { font-family: var(--serif); font-size: 27px; line-height: .92; font-weight: 600; text-transform: none; }
.stat { gap: 10px; padding: 0 14px; color: var(--navy); }
.stat-icon { width: 24px; height: 24px; display: grid; place-items: center; border: 1px solid rgba(9,35,63,.22); border-radius: 50%; color: var(--orange); font-size: 12px; }
.stat strong { font-family: var(--serif); font-size: 30px; font-weight: 600; line-height: .9; }
.stat span:last-child { font-size: 11.5px; line-height: 1.28; font-weight: 900; letter-spacing: .035em; text-transform: uppercase; color: #536172; }
.trust-human { border-right: 0; margin: 0; padding: 0 36px 0 24px; font-size: 12px; line-height: 1.45; color: #435469; }
.trust-human b { display: inline-block; margin-left: 8px; font-family: var(--script); color: var(--orange); font-size: 22px; }

.leader-section {
  min-height: 184px;
  display: grid;
  grid-template-columns: 28% 43% 29%;
  border-bottom: 1px solid var(--border);
  background: var(--paper-warm);
}
.leader-photo { margin: 0; overflow: hidden; border-right: 1px solid var(--border); }
.leader-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; filter: saturate(.92) contrast(1.05); }
.leader-copy { padding: 30px 48px 26px; border-right: 1px solid var(--border); background: var(--paper); }
.leader-copy h2 { font-size: 39px; line-height: .98; }
.leader-copy p { max-width: 530px; margin: 13px 0 0; font-size: 14px; line-height: 1.5; color: #46556a; }
.leader-list { padding: 28px 38px; display: flex; flex-direction: column; justify-content: center; gap: 14px; background: rgba(255,248,238,.45); }
.leader-list li { display: grid; grid-template-columns: 32px 1fr; align-items: start; gap: 14px; font-size: 13px; line-height: 1.35; font-weight: 700; color: var(--navy); }
.leader-list span { color: var(--orange); font-family: ui-monospace, monospace; font-size: 11px; }

.process-section {
  min-height: 196px;
  display: grid;
  grid-template-columns: 23% 1fr;
  position: relative;
  border-bottom: 1px solid var(--border);
  background: var(--paper);
}
.process-heading { padding: 32px 22px 28px 50px; border-right: 1px solid var(--line); }
.process-heading h2 { font-size: 35px; line-height: .98; }
.timeline { position: relative; display: grid; grid-template-columns: repeat(5, 1fr); align-items: stretch; }
.timeline::before { content: ""; position: absolute; left: 7%; right: 7%; top: 72px; border-top: 1px dashed rgba(217,95,23,.7); }
.timeline li { position: relative; padding: 42px 20px 26px; border-right: 1px solid var(--line); }
.timeline li span { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid var(--orange); border-radius: 50%; background: var(--paper); color: var(--orange); font-family: var(--serif); font-size: 18px; font-weight: 700; }
.timeline li strong { display: block; margin-top: 16px; color: var(--navy); font-size: 11px; font-weight: 900; letter-spacing: .15em; text-transform: uppercase; }
.timeline li p { margin: 8px 0 0; font-size: 12px; line-height: 1.42; color: #566576; }


.info-grid { display: grid; grid-template-columns: repeat(3, 1fr); min-height: 292px; border-bottom: 1px solid var(--border); }
.info-card { position: relative; overflow: hidden; border-right: 1px solid var(--border); background: var(--ivory); }
.info-card:last-child { border-right: 0; }
.info-card h3 { font-size: 35px; line-height: .98; }
.info-card ul { margin-top: 18px; margin-bottom: 18px; display: grid; gap: 8px; color: #47586b; font-size: 13px; font-weight: 700; }
.info-card li::before { content: "—"; color: var(--orange); margin-right: 8px; }
.portal-card { display: grid; grid-template-columns: 58% 42%; }
.portal-card .info-copy { padding: 31px 28px 28px 42px; }
.device-frame { align-self: center; margin-right: 34px; height: 178px; border: 8px solid var(--navy); background: linear-gradient(145deg, #fff8ee, #dfcfba); box-shadow: 0 18px 40px rgba(9,35,63,.12); padding: 22px 18px; color: var(--navy); }
.device-frame span { display: block; width: 48px; height: 4px; background: var(--orange); margin-bottom: 28px; }
.device-frame strong { display: block; font-family: var(--serif); font-size: 29px; line-height: .95; }
.device-frame em { display: block; margin-top: 12px; font-style: normal; font-size: 10px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; color: #66707a; }
.safety-card img, .film-card img { width: 100%; height: 100%; object-fit: cover; }
.safety-card img { object-position: center 36%; }
.film-card img { object-position: center center; }
.safety-card::after, .film-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(5,17,31,.92), rgba(5,17,31,.44) 60%, rgba(5,17,31,.13)); }
.overlay-copy { position: absolute; z-index: 2; left: 34px; right: 34px; bottom: 28px; color: #fff8ed; padding: 18px 18px 16px; background: rgba(5,17,31,.30); border-left: 2px solid rgba(244,192,120,.75); backdrop-filter: blur(3px); }
.overlay-copy h3 { color: #fff8ed; }
.overlay-copy ul { color: rgba(255,248,237,.88); }
.light { color: #f4c078; }
.light-label { color: #f4c078; }
.film-meta { margin: 16px 0 0; color: rgba(255,248,237,.90); font-size: 12px; font-weight: 900; letter-spacing: .055em; text-transform: uppercase; }


.final-cta { position: relative; height: 142px; overflow: hidden; display: grid; place-items: center; text-align: center; border-bottom: 1px solid var(--border); }
.final-cta img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 72%; filter: saturate(.95) contrast(1.03); }
.final-cta::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(9,35,63,.78), rgba(9,35,63,.38), rgba(217,95,23,.28)); }
.final-content { position: relative; z-index: 1; display: flex; align-items: center; justify-content: center; gap: 28px; color: #fff8ed; padding: 0 48px; }
.final-cta h2 { margin: 0; color: #fff8ed; font-size: 42px; line-height: .95; white-space: nowrap; }
.final-cta p { margin: 0; font-size: 14px; font-weight: 700; color: rgba(255,248,237,.86); }

.site-footer { min-height: 96px; display: grid; grid-template-columns: 220px 1fr auto; align-items: center; gap: 24px; padding: 0 68px; background: var(--navy); color: #fff8ed; }
.footer-brand { color: #fff8ed; }
.site-footer p { margin: 0; color: rgba(255,248,237,.75); font-size: 13px; }
.footer-links { display: flex; gap: 12px; align-items: center; font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; color: #f4c078; }

@media (max-width: 1160px) {
  .site-header { grid-template-columns: 185px 1fr auto; padding: 0 34px; gap: 18px; }
  .brand-mark { font-size: 36px; }
  .main-nav { gap: 18px; font-size: 12px; }
  .hero-copy { padding-left: 42px; padding-right: 36px; }
  .hero h1 { font-size: clamp(55px, 5.9vw, 72px); }
  .destinations { grid-template-columns: .95fr repeat(3, 1fr); }
  .destination-intro { padding-left: 36px; }
  .trust-strip { grid-template-columns: repeat(3, 1fr); }
  .trust-title, .stat, .trust-human { min-height: 92px; border-bottom: 1px solid var(--line); }
  .leader-section { grid-template-columns: 32% 1fr; }
  .leader-list { grid-column: 1 / -1; flex-direction: row; }
  .process-section { grid-template-columns: 1fr; }
  .process-heading { border-right: 0; border-bottom: 1px solid var(--line); padding: 28px 42px; }

  .final-content { gap: 18px; }
  .final-cta h2 { font-size: 34px; }
}

@media (max-width: 820px) {
  .page-shell { max-width: none; }
  .site-header { height: auto; min-height: 68px; grid-template-columns: minmax(0, 1fr) auto; padding: 12px 18px; gap: 12px; }
  .brand-sub { margin-top: 7px; font-size: 8.5px; letter-spacing: .16em; }
  .main-nav { display: none; }
  .header-cta { min-height: 34px; width: auto; padding: 0 12px; font-size: 10px; letter-spacing: .065em; background: transparent; color: var(--navy); border-color: rgba(9,35,63,.28); }
  .hero { grid-template-columns: 1fr; height: auto; }
  .hero-copy { min-height: auto; padding: 28px 22px 24px; border-right: 0; }
  .map-grid { opacity: .16; right: 14px; top: 18px; width: 104px; height: 104px; }
  .coordinates { font-size: 11px; letter-spacing: .045em; }
  .coordinates .bar { padding: 0 4px; }
  .hero h1 { margin-top: 18px; font-size: clamp(46px, 13vw, 60px); line-height: .94; }
  .accent-rule { margin: 18px 0 15px; }
  .hero-lede { font-size: 16px; }
  .hero-actions { margin-top: 20px; }
  .hero-actions .btn { min-height: 42px; font-size: 12px; letter-spacing: .065em; }
  .hero-actions .btn-outline { min-height: 44px; width: auto; padding: 10px 0 0; border: 0; background: transparent; justify-content: flex-start; color: var(--navy); }
  .hero-actions .btn-outline::after { content: " →"; }
  .hero-note { display: block; font-size: 11px; letter-spacing: .04em; text-transform: none; color: #435469; }
  .hero-note span { padding: 0; border: 0; background: transparent; }
  .hero-note span + span::before { content: " · "; }
  .hero-media { order: -1; height: 260px; }
  .torn-edge { display: none; }
  .flight-mark { top: 18px; right: 18px; padding: 10px 12px; }
  .flight-mark strong { font-size: 20px; }
  .hero-quote { right: 18px; bottom: 20px; max-width: 214px; font-size: 21px; }
  .destinations { height: auto; grid-template-columns: 1fr; }
  .destination-intro { min-height: 250px; padding: 34px 28px; border-right: 0; border-bottom: 1px solid var(--border); }
  .mini-coordinates { display: none; }
  .destination-card { height: 320px; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.34); }
  .trust-strip { grid-template-columns: 1fr 1fr; }
  .trust-title, .trust-human { grid-column: 1 / -1; }
  .leader-section { grid-template-columns: 1fr; }
  .leader-photo { height: 260px; border-right: 0; border-bottom: 1px solid var(--border); }
  .leader-copy { border-right: 0; padding: 32px 26px; }
  .leader-list { flex-direction: column; padding: 26px; }
  .timeline { grid-template-columns: 1fr; }
  .timeline::before { left: 45px; right: auto; top: 24px; bottom: 24px; border-top: 0; border-left: 1px dashed rgba(217,95,23,.7); }
  .timeline li { display: grid; grid-template-columns: 48px 1fr; column-gap: 16px; padding: 20px 24px; }
  .timeline li strong, .timeline li p { grid-column: 2; margin-top: 0; }
  .info-grid { grid-template-columns: 1fr; }
  .info-card { min-height: 310px; border-right: 0; border-bottom: 1px solid var(--border); }
  .portal-card { grid-template-columns: 1fr; }
  .device-frame { margin: 0 28px 28px; }
  .final-cta { height: auto; min-height: 270px; }
  .final-content { flex-direction: column; padding: 42px 24px; }
  .final-cta h2 { white-space: normal; font-size: 42px; }
  .site-footer { grid-template-columns: 1fr; padding: 28px 24px; }
}

@media (max-width: 480px) {
  .site-header { padding: 11px 14px; }
  .brand-mark { font-size: 31px; letter-spacing: .16em; }
  .brand-sub { font-size: 7.5px; letter-spacing: .13em; }
  .header-cta { min-height: 32px; padding: 0 10px; font-size: 9px; }
  .hero-copy { min-height: auto; padding: 24px 18px 22px; }
  .coordinates { display: none; }
  .hero h1 { font-size: clamp(42px, 12.4vw, 52px); }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions .btn-outline { min-height: auto; padding-top: 4px; }
  .hero-note { display: none; }
  .hero-media { height: 230px; }
  .flight-mark { display: none; }
  .btn { width: 100%; }
  .card-content h3 { font-size: 42px; }
  .trust-strip { grid-template-columns: 1fr; }
  .stat, .trust-title, .trust-human { border-right: 0; }
  .destination-intro h2, .leader-copy h2, .process-heading h2, .info-card h3 { font-size: 34px; }
}

@media (max-width: 360px) {
  .site-header { grid-template-columns: 1fr; justify-items: start; }
  .header-cta { justify-self: stretch; }
  .hero h1 { font-size: 40px; }
  .hero-lede { font-size: 15px; line-height: 1.45; }
  .hero-media { height: 220px; }
}


/* WNTT v3 simple subpages */
.simple-hero { min-height: 470px; display: grid; grid-template-columns: 46% 54%; border-bottom: 1px solid var(--border); }
.simple-hero .hero-copy { padding: 70px 68px; }
.simple-hero h1 { margin: 20px 0 0; font-family: var(--serif); color: var(--navy); font-size: clamp(56px, 6vw, 88px); line-height: .88; letter-spacing: -.035em; font-weight: 500; }
.simple-kicker { font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .14em; color: var(--orange-dark); }
.simple-lede { max-width: 480px; margin: 22px 0 0; color: #33465b; font-size: 18px; line-height: 1.45; }
.simple-media { position: relative; min-height: 470px; overflow: hidden; background: var(--navy); }
.simple-media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.02) contrast(1.06); }
.simple-media::after { content:""; position:absolute; inset:0; background: linear-gradient(0deg, rgba(9,35,63,.54), transparent 62%); }
.trip-facts { display: grid; grid-template-columns: repeat(4, 1fr); border-bottom: 1px solid var(--border); background: var(--ivory); }
.trip-fact { padding: 24px 34px; border-right: 1px solid var(--border); }
.trip-fact:last-child { border-right: 0; }
.trip-fact span { display:block; color: var(--muted); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: .14em; }
.trip-fact strong { display:block; margin-top: 8px; color: var(--navy); font-family: var(--serif); font-size: 30px; font-weight: 600; line-height: .95; }
.simple-section { padding: 72px 68px; border-bottom: 1px solid var(--border); }
.simple-section.narrow { max-width: 980px; margin: 0 auto; border-bottom: 0; }
.simple-section h2 { margin: 0; color: var(--navy); font-family: var(--serif); font-size: clamp(42px, 5vw, 64px); line-height: .92; font-weight: 500; letter-spacing: -.025em; }
.simple-section p { color: #3c4d5e; font-size: 17px; line-height: 1.58; max-width: 720px; }
.simple-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 34px; }
.simple-card { background: rgba(255,248,238,.62); border: 1px solid var(--border); padding: 28px; min-height: 156px; }
.simple-card span { color: var(--orange-dark); font-size: 11px; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }
.simple-card h3 { margin: 12px 0 0; color: var(--navy); font-family: var(--serif); font-size: 34px; line-height: .95; font-weight: 600; }
.simple-card p { margin: 12px 0 0; font-size: 14px; line-height: 1.45; }
.clean-list { display:grid; gap: 14px; margin-top: 32px; max-width: 780px; }
.clean-list li { display:flex; gap: 14px; align-items:flex-start; padding: 18px 0; border-bottom: 1px solid var(--line); color: #34475a; font-size: 17px; line-height: 1.45; }
.clean-list b { color: var(--orange-dark); min-width: 32px; }
.contact-panel { display:grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 34px; }
.contact-box { background: var(--ivory); border: 1px solid var(--border); padding: 34px; }
.contact-box h3 { margin:0; font-family:var(--serif); font-size:38px; color:var(--navy); font-weight:600; }
.contact-box p { font-size:16px; }
.inline-actions { display:flex; flex-wrap:wrap; gap: 12px; margin-top: 26px; }
.simple-footer-cta { padding: 80px 68px; background: var(--navy); color: #fff8ed; text-align: center; }
.simple-footer-cta h2 { margin:0 auto; max-width:760px; font-family:var(--serif); font-size: clamp(44px, 6vw, 74px); line-height:.9; font-weight:500; }
.simple-footer-cta p { color: rgba(255,248,237,.78); margin: 18px auto 0; max-width:540px; font-size:17px; line-height:1.5; }
.simple-footer-cta .inline-actions { justify-content:center; }
@media (max-width: 900px) {
  .simple-hero { display:flex; flex-direction:column-reverse; min-height:0; }
  .simple-hero .hero-copy { padding: 42px 24px 46px; }
  .simple-media { min-height: 330px; }
  .trip-facts { grid-template-columns: 1fr 1fr; }
  .trip-fact { padding: 20px 22px; }
  .trip-fact:nth-child(even) { border-right:0; }
  .simple-section { padding: 52px 24px; }
  .simple-grid { grid-template-columns: 1fr; }
  .contact-panel { grid-template-columns: 1fr; }
  .simple-footer-cta { padding: 60px 24px; }
}

@media (max-width: 600px) {
  .site-footer .footer-links { display: flex; flex-direction: column; gap: 8px; align-items: flex-start; }
  .site-footer .footer-links span { display: none; }
  .site-footer .footer-links a { white-space: nowrap; }
}


/* WNTT balanced essentials */
.essentials-band { display:grid; grid-template-columns: .95fr 1.05fr; gap:0; border-bottom:1px solid var(--border); background:rgba(255,248,238,.58); }
.essentials-panel { padding:44px 68px; border-right:1px solid var(--border); }
.essentials-panel:last-child { border-right:0; }
.essentials-panel h2 { margin:0; font-family:var(--serif); color:var(--navy); font-size: clamp(38px,4.2vw,58px); line-height:.95; font-weight:500; }
.essentials-list { margin-top:24px; display:grid; gap:12px; }
.essentials-list li { display:grid; grid-template-columns:126px 1fr; gap:16px; padding:13px 0; border-bottom:1px solid var(--line); color:#33465b; font-size:15px; line-height:1.38; }
.essentials-list b { color:var(--orange-dark); font-size:10px; letter-spacing:.13em; text-transform:uppercase; }
.included-list { margin-top:24px; display:grid; gap:12px; }
.included-list li { position:relative; padding-left:26px; color:#33465b; font-size:15px; line-height:1.45; }
.included-list li::before { content:"✓"; position:absolute; left:0; top:0; color:var(--orange-dark); font-weight:900; }
.note-small { margin-top:22px; max-width:620px; color:#596879; font-size:14px; line-height:1.5; }
@media (max-width: 900px) {
  .essentials-band { grid-template-columns:1fr; }
  .essentials-panel { padding:44px 24px; border-right:0; border-bottom:1px solid var(--border); }
  .essentials-panel:last-child { border-bottom:0; }
  .essentials-list li { grid-template-columns:96px 1fr; gap:12px; }
}


/* WNTT official programme compact info */
.programme-note { margin-top: 14px; display:inline-block; color: var(--orange-dark); font-size:10px; font-weight:900; letter-spacing:.12em; text-transform:uppercase; }


/* WNTT v3 final homepage */
.home-hero { display:grid; grid-template-columns:46% 54%; min-height:560px; border-bottom:1px solid var(--border); }
.home-hero-copy { padding:76px 68px; display:flex; flex-direction:column; justify-content:center; }
.home-hero h1 { margin:18px 0 0; font-family:var(--serif); color:var(--navy); font-size:clamp(58px,6.4vw,92px); line-height:.88; letter-spacing:-.04em; font-weight:500; }
.home-hero p { margin:24px 0 0; color:#33465b; font-size:18px; line-height:1.48; max-width:520px; }
.home-hero-media { position:relative; overflow:hidden; background:var(--navy); }
.home-hero-media img { width:100%; height:100%; object-fit:cover; filter:saturate(1.02) contrast(1.06); }
.home-hero-media::after { content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(9,35,63,.62),transparent 56%),linear-gradient(90deg,rgba(9,35,63,.24),transparent); }
.home-expeditions { padding:72px 68px; border-bottom:1px solid var(--border); }
.home-expeditions h2, .home-simple h2 { margin:0; font-family:var(--serif); color:var(--navy); font-size:clamp(44px,5vw,72px); line-height:.9; font-weight:500; letter-spacing:-.03em; }
.home-expeditions > p, .home-simple > p { margin:18px 0 0; max-width:700px; color:#445469; font-size:17px; line-height:1.5; }
.expedition-cards { margin-top:34px; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.expedition-card-v3 { display:flex; flex-direction:column; background:var(--ivory); border:1px solid var(--border); overflow:hidden; min-height:100%; }
.expedition-card-v3 figure { margin:0; height:220px; position:relative; overflow:hidden; background:var(--navy); }
.expedition-card-v3 img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.expedition-card-v3:hover img { transform:scale(1.035); }
.expedition-card-v3 .body { padding:26px; display:flex; flex-direction:column; flex:1; }
.expedition-card-v3 h3 { margin:10px 0 0; color:var(--navy); font-family:var(--serif); font-size:38px; line-height:.92; font-weight:600; }
.trip-meta { margin-top:22px; display:grid; gap:10px; }
.trip-meta div { display:grid; grid-template-columns:90px 1fr; gap:12px; padding:9px 0; border-bottom:1px solid var(--line); color:#33465b; font-size:14px; line-height:1.35; }
.trip-meta b { color:var(--orange-dark); font-size:10px; letter-spacing:.13em; text-transform:uppercase; }
.card-actions { margin-top:auto; padding-top:24px; display:flex; gap:10px; flex-wrap:wrap; }
.home-simple { padding:70px 68px; border-bottom:1px solid var(--border); background:rgba(255,248,238,.42); }
.why-grid { margin-top:32px; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.why-item { padding:28px; border:1px solid var(--border); background:rgba(255,248,238,.65); }
.why-item span { color:var(--orange-dark); font-size:11px; font-weight:900; letter-spacing:.14em; text-transform:uppercase; }
.why-item h3 { margin:12px 0 0; font-family:var(--serif); color:var(--navy); font-size:34px; line-height:.95; }
.why-item p { margin:12px 0 0; color:#445469; font-size:14px; line-height:1.45; }
@media (max-width:900px){
 .home-hero{display:flex; flex-direction:column-reverse; min-height:0}.home-hero-copy{padding:42px 24px 48px}.home-hero-media{height:330px}.home-expeditions,.home-simple{padding:52px 24px}.expedition-cards,.why-grid{grid-template-columns:1fr}.expedition-card-v3 figure{height:250px}.trip-meta div{grid-template-columns:82px 1fr}.card-actions .btn{width:100%}
}

.trip-gallery-section{padding-top:64px}.trip-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.trip-gallery figure{margin:0;height:230px;overflow:hidden;border:1px solid var(--border);background:var(--navy)}.trip-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.trip-gallery figure:hover img{transform:scale(1.035)}@media (max-width:700px){.trip-gallery{grid-template-columns:1fr}.trip-gallery figure{height:260px}}


/* WNTT Phase 1 — trust, WhatsApp and reserve UX */
.authority-strip { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-bottom:1px solid var(--border); background:rgba(255,248,238,.72); }
.authority-strip article { padding:24px 34px; border-right:1px solid var(--border); }
.authority-strip article:last-child { border-right:0; }
.authority-strip b { display:block; color:var(--navy); font-family:var(--serif); font-size:25px; line-height:1.02; font-weight:600; }
.authority-strip span { display:block; margin-top:8px; color:#506174; font-size:13px; line-height:1.45; }
.reserve-notice { display:flex; align-items:center; gap:14px; flex-wrap:wrap; padding:16px 68px; border-bottom:1px solid var(--border); background:#fff3df; color:#24384e; }
.reserve-notice b { color:var(--orange-dark); text-transform:uppercase; font-size:11px; letter-spacing:.12em; }
.reserve-notice span { flex:1; min-width:240px; font-size:14px; line-height:1.4; }
.contact-panel { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) {
  .authority-strip { grid-template-columns:1fr; }
  .authority-strip article { border-right:0; border-bottom:1px solid var(--border); padding:22px 24px; }
  .contact-panel { grid-template-columns:1fr; }
  .reserve-notice { padding:14px 24px; }
}


/* WNTT Phase 2 — lead form */
.contact-form-grid { display:grid; grid-template-columns:minmax(320px, .92fr) 1fr; gap:28px; align-items:start; margin-top:34px; }
.wntt-lead-form { background:#fff8ed; border:1px solid var(--border); padding:30px; display:grid; grid-template-columns:1fr 1fr; gap:16px; box-shadow:0 18px 45px rgba(9,35,63,.06); }
.wntt-lead-form label { display:grid; gap:8px; color:var(--navy); font-size:11px; font-weight:900; letter-spacing:.12em; text-transform:uppercase; }
.wntt-lead-form label.full { grid-column:1 / -1; }
.wntt-lead-form input, .wntt-lead-form select, .wntt-lead-form textarea { width:100%; border:1px solid rgba(9,35,63,.18); background:#fff; color:#22384f; padding:13px 14px; border-radius:0; font:500 14px/1.35 var(--sans); letter-spacing:0; text-transform:none; }
.wntt-lead-form textarea { resize:vertical; min-height:116px; }
.wntt-lead-form button { justify-self:start; }
.form-status { grid-column:1 / -1; margin:0; color:#506174; font-size:13px; line-height:1.45; }
.hp-field { position:absolute !important; left:-9999px !important; opacity:0 !important; }
@media (max-width: 980px) { .contact-form-grid { grid-template-columns:1fr; } .wntt-lead-form { grid-template-columns:1fr; padding:24px; } }


/* WNTT Phase 3 — testimonials + FAQ + about-extended */
.home-testimonials { padding: 72px 68px; border-bottom: 1px solid var(--border); background: var(--paper); }
.home-testimonials h2 { margin: 0; font-family: var(--serif); color: var(--navy); font-size: clamp(44px, 5vw, 72px); line-height: .9; font-weight: 500; letter-spacing: -.03em; }
.home-testimonials > p { margin: 18px 0 0; max-width: 700px; color: #445469; font-size: 17px; line-height: 1.5; }
.testimonials-grid { margin-top: 38px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.testimonial-card { background: var(--ivory); border: 1px solid var(--border); padding: 28px 26px; display: flex; flex-direction: column; gap: 14px; position: relative; box-shadow: 0 12px 30px rgba(9,35,63,.05); }
.testimonial-card::before { content: "\201C"; position: absolute; top: 8px; left: 18px; font-family: var(--serif); font-size: 72px; line-height: 1; color: var(--orange); opacity: .12; }
.testimonial-stars { display: inline-flex; gap: 3px; color: var(--orange); font-size: 14px; letter-spacing: 1px; }
.testimonial-quote { margin: 0; color: #2c3c50; font-size: 15px; line-height: 1.55; font-style: italic; flex: 1; }
.testimonial-meta { display: grid; grid-template-columns: 44px 1fr; gap: 14px; align-items: center; padding-top: 14px; border-top: 1px solid var(--line); }
.testimonial-meta .avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--navy), var(--orange-dark)); color: #fff8ed; display: grid; place-items: center; font-family: var(--serif); font-size: 18px; font-weight: 600; }
.testimonial-meta .who b { display: block; color: var(--navy); font-size: 14px; font-weight: 700; }
.testimonial-meta .who span { color: var(--muted); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
@media (max-width: 900px) {
  .home-testimonials { padding: 52px 24px; }
  .testimonials-grid { grid-template-columns: 1fr; }
}

.home-faq { padding: 72px 68px; border-bottom: 1px solid var(--border); background: rgba(255,248,238,.42); }
.home-faq h2 { margin: 0; font-family: var(--serif); color: var(--navy); font-size: clamp(44px, 5vw, 72px); line-height: .9; font-weight: 500; letter-spacing: -.03em; }
.home-faq > p { margin: 18px 0 0; max-width: 700px; color: #445469; font-size: 17px; line-height: 1.5; }
.faq-accordion { margin-top: 36px; max-width: 880px; display: grid; gap: 0; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-item:first-of-type { border-top: 1px solid var(--border); }
.faq-item summary { list-style: none; cursor: pointer; padding: 22px 56px 22px 4px; position: relative; color: var(--navy); font-family: var(--serif); font-size: 22px; font-weight: 600; line-height: 1.3; transition: color .2s ease; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-family: var(--sans); font-size: 28px; font-weight: 300; color: var(--orange); transition: transform .25s ease; }
.faq-item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq-item summary:hover { color: var(--orange-dark); }
.faq-item .faq-body { padding: 0 56px 22px 4px; color: #33465b; font-size: 16px; line-height: 1.6; }
.faq-item .faq-body p { margin: 0 0 10px; }
.faq-item .faq-body p:last-child { margin-bottom: 0; }
.faq-item .faq-body a { color: var(--orange-dark); text-decoration: underline; }
@media (max-width: 900px) {
  .home-faq { padding: 52px 24px; }
  .faq-item summary { font-size: 18px; padding-right: 44px; }
  .faq-item summary::after { right: 8px; font-size: 24px; }
  .faq-item .faq-body { padding-right: 44px; font-size: 15px; }
}


/* WNTT Phase 4 — blog */
/* ==========================================================================
   WNTT Blog — additional styles (append to wntt-v3-preview.css)
   ========================================================================== */

/* Blog index — intro band */
.blog-intro{max-width:760px;margin:0 auto;padding:14px 0 8px;color:#3c4d5e;font-size:17px;line-height:1.62}
.blog-intro p{margin:14px 0 0}

/* Blog grid */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:28px}
.blog-card{display:flex;flex-direction:column;background:var(--paper-warm,#fbf6ef);border:1px solid var(--line,#e6dccb);border-radius:14px;overflow:hidden;transition:transform .18s ease, box-shadow .18s ease;text-decoration:none;color:inherit}
.blog-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(20,33,52,.10)}
.blog-card-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:#e9e1d2}
.blog-card-media img{width:100%;height:100%;object-fit:cover;display:block}
.blog-card-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.blog-card .date{font-family:var(--sans,Inter,system-ui,sans-serif);font-size:12px;letter-spacing:.10em;text-transform:uppercase;color:var(--orange-dark,#c75d1e);font-weight:700}
.blog-card h3{font-family:var(--serif,'Cormorant Garamond',Georgia,serif);font-weight:600;font-size:24px;line-height:1.18;margin:2px 0 4px;color:var(--navy,#142134)}
.blog-card .excerpt{color:#46586c;font-size:15px;line-height:1.55;margin:0;flex:1}
.blog-card .read-more{margin-top:8px;font-family:var(--sans,Inter,system-ui,sans-serif);font-weight:700;font-size:14px;color:var(--orange-dark,#c75d1e);letter-spacing:.02em}

/* Blog post — back link */
.blog-back{display:inline-block;margin-top:10px;font-family:var(--sans,Inter,system-ui,sans-serif);font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--navy,#142134);text-decoration:none;opacity:.78}
.blog-back:hover{opacity:1;color:var(--orange-dark,#c75d1e)}

/* Blog content — prose styling inside post pages */
.blog-content{max-width:760px;margin:0 auto;color:#33465b;font-size:17px;line-height:1.68}
.blog-content > *:first-child{margin-top:0}
.blog-content p{margin:18px 0 0}
.blog-content h2{font-family:var(--serif,'Cormorant Garamond',Georgia,serif);font-weight:600;font-size:32px;line-height:1.18;color:var(--navy,#142134);margin:38px 0 6px;letter-spacing:-.01em}
.blog-content h3{font-family:var(--serif,'Cormorant Garamond',Georgia,serif);font-weight:600;font-size:23px;line-height:1.22;color:var(--navy,#142134);margin:28px 0 4px}
.blog-content ul,.blog-content ol{margin:14px 0 0;padding-left:22px}
.blog-content li{margin:6px 0;line-height:1.6}
.blog-content li strong{color:var(--navy,#142134)}
.blog-content a{color:var(--orange-dark,#c75d1e);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.blog-content a:hover{color:#a64a14}
.blog-content blockquote{margin:24px 0 0;padding:16px 22px;border-left:3px solid var(--orange-dark,#c75d1e);background:rgba(199,93,30,.05);color:#33465b;font-style:italic;font-size:17px;line-height:1.62;border-radius:0 8px 8px 0}
.blog-content blockquote p{margin:0}
.blog-content hr{margin:32px 0;border:0;border-top:1px solid var(--line,#e6dccb)}
.blog-content em{color:#33465b}
.blog-content strong{color:var(--navy,#142134)}
.blog-content table{width:100%;border-collapse:collapse;margin:22px 0 0;font-size:15px}
.blog-content table th,.blog-content table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line,#e6dccb);line-height:1.5}
.blog-content table th{font-family:var(--sans,Inter,system-ui,sans-serif);font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--navy,#142134);background:rgba(20,33,52,.03)}

/* Responsive */
@media (max-width:900px){
  .blog-grid{grid-template-columns:repeat(2,1fr);gap:22px}
  .blog-card h3{font-size:22px}
  .blog-content{font-size:16.5px}
  .blog-content h2{font-size:28px}
  .blog-content h3{font-size:21px}
}
@media (max-width:600px){
  .blog-grid{grid-template-columns:1fr;gap:20px}
  .blog-card-body{padding:16px 18px 18px}
  .blog-card h3{font-size:21px}
  .blog-content{font-size:16px;line-height:1.65}
  .blog-content h2{font-size:26px;margin-top:30px}
  .blog-content h3{font-size:20px;margin-top:22px}
  .blog-content table{display:block;overflow-x:auto}
}


/* WNTT Phase 5 — home gallery */
.home-gallery { padding: 72px 68px; border-bottom: 1px solid var(--border); background: var(--paper-warm); }
.home-gallery h2 { margin: 0; font-family: var(--serif); color: var(--navy); font-size: clamp(44px, 5vw, 72px); line-height: .9; font-weight: 500; letter-spacing: -.03em; }
.home-gallery > p { margin: 18px 0 0; max-width: 700px; color: #445469; font-size: 17px; line-height: 1.5; }
.gallery-grid { margin-top: 32px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.gallery-grid figure { margin: 0; aspect-ratio: 16/9; overflow: hidden; border: 1px solid var(--border); background: var(--navy); }
.gallery-grid img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.gallery-grid figure:hover img { transform: scale(1.04); }
@media (max-width: 900px) {
  .home-gallery { padding: 52px 24px; }
  .gallery-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
}
@media (max-width: 540px) {
  .gallery-grid { grid-template-columns: 1fr; }
}


/* WNTT Phase 6 — live spots badge */
.spots-badge { display: inline-block; margin: 8px 0 0 12px; padding: 4px 10px; font-family: var(--sans); font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--orange-dark); background: rgba(217, 95, 23, .12); border: 1px solid rgba(217, 95, 23, .35); border-radius: 2px; vertical-align: middle; }
.spots-badge.low { color: #c00; background: rgba(204, 0, 0, .08); border-color: rgba(204, 0, 0, .35); animation: spots-pulse 2.4s ease-in-out infinite; }
.spots-badge.soldout { color: #6b7280; background: #f3f4f6; border-color: #d1d5db; }
@keyframes spots-pulse { 0%,100% { opacity: 1; } 50% { opacity: .65; } }
