/* =========================================================
   DRIFT TOUR JAPAN — design system
   Cinematic asphalt + rising-sun red, motorsport editorial
   ========================================================= */

:root {
  /* palette */
  --ink:       #0a0a0b;
  --ink-2:     #111114;
  --ink-3:     #18181c;
  --ink-4:     #222228;
  --red:       #e4080a;
  --red-2:     #ff2b2b;
  --red-deep:  #9c0608;
  /* complementary electric-teal accent */
  --cyan:      #19d9c6;
  --cyan-2:    #3ff0dd;
  --cyan-deep: #0a5d56;
  /* racing yellow accent */
  --yellow:    #ffcd05;
  --yellow-2:  #ffe04a;
  /* alternating section panels (cool vs warm asphalt) */
  --panel:     #0c1013;
  --panel-2:   #100e10;
  --paper:     #f4f1ea;
  --paper-dim: #cfccc4;
  --muted:     #8c8c93;
  --line:      rgba(244, 241, 234, 0.10);
  --line-2:    rgba(244, 241, 234, 0.18);

  /* type */
  --display: "Saira Condensed", "Arial Narrow", sans-serif;
  --body:    "Hanken Grotesk", system-ui, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, monospace;
  --jp:      "Noto Sans JP", sans-serif;

  /* motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-2: cubic-bezier(0.16, 1, 0.3, 1);

  --maxw: 1320px;
  --gutter: clamp(20px, 5vw, 72px);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.6;
  letter-spacing: 0.01em;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ambient grain + vignette overlay */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none; z-index: 9000;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
  opacity: 0.04;
  mix-blend-mode: overlay;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--red); color: #fff; }

/* keyboard focus visibility (a11y) */
:focus-visible {
  outline: 2px solid var(--cyan-2);
  outline-offset: 3px;
}
a:focus-visible, button:focus-visible, [tabindex]:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--cyan-2);
  outline-offset: 3px;
}
/* don't show the ring on mouse click for inputs (they have their own focus style) */
.btn:focus:not(:focus-visible), a:focus:not(:focus-visible) { outline: none; }

/* skip-to-content link */
.skip-link {
  position: fixed; left: 14px; top: -80px; z-index: 2000;
  background: var(--red); color: #fff;
  font-family: var(--mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
  padding: 13px 20px; transition: top .25s var(--ease);
}
.skip-link:focus { top: 14px; }

/* scrollbar */
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--ink); }
::-webkit-scrollbar-thumb { background: var(--ink-4); border-radius: 0; }
::-webkit-scrollbar-thumb:hover { background: var(--red); }

/* ---------- layout helpers ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }
section { position: relative; }

.eyebrow {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--red-2);
  display: inline-flex;
  align-items: center;
  gap: 0.8em;
  font-weight: 500;
}
.eyebrow::before {
  content: "";
  width: 26px; height: 1px;
  background: var(--red);
  display: inline-block;
}

h1, h2, h3 { font-family: var(--display); font-weight: 800; line-height: 0.92; letter-spacing: -0.01em; text-transform: uppercase; }

.h-section {
  font-size: clamp(2.6rem, 7vw, 6rem);
  line-height: 0.86;
}
.h-section .stroke {
  -webkit-text-stroke: 1.4px var(--paper-dim);
  color: transparent;
}
.accent { color: var(--red-2); }

.lead { color: var(--paper-dim); font-size: clamp(1rem, 1.5vw, 1.18rem); max-width: 56ch; }

/* ---------- buttons ---------- */
.btn {
  --bg: var(--red);
  position: relative;
  display: inline-flex; align-items: center; gap: 0.7em;
  font-family: var(--mono);
  font-size: 12.5px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 17px 30px;
  background: var(--bg); color: #fff;
  border: 1px solid var(--bg);
  overflow: hidden;
  transition: color .5s var(--ease), border-color .4s var(--ease);
  cursor: pointer;
  clip-path: polygon(10px 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%, 0 10px);
}
.btn::after {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background: var(--paper);
  transform: translateY(101%);
  transition: transform .5s var(--ease);
}
.btn > * { position: relative; z-index: 1; }
.btn:hover { color: var(--ink); }
.btn:hover::after { transform: translateY(0); }
.btn .arrow { transition: transform .4s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }

.btn--ghost {
  --bg: transparent;
  background: transparent; color: var(--paper);
  border-color: var(--line-2);
}
.btn--ghost::after { background: var(--paper); }
.btn--ghost:hover { color: var(--ink); border-color: var(--paper); }

/* ===================================================
   NAV
   =================================================== */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px var(--gutter);
  transition: background .5s var(--ease), padding .5s var(--ease), border-color .5s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(10,10,11,0.82);
  backdrop-filter: blur(16px) saturate(140%);
  padding-top: 14px; padding-bottom: 14px;
  border-color: var(--line);
}
.nav__logo img { height: 34px; width: auto; }
.nav__links { display: flex; align-items: center; gap: 34px; }
.nav__links a {
  font-family: var(--mono);
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--paper-dim);
  position: relative; padding: 4px 0;
  transition: color .3s;
}
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 0;
  background: var(--red-2); transition: width .4s var(--ease);
}
.nav__links a:hover { color: var(--paper); }
.nav__links a:hover::after { width: 100%; }
.nav__right { display: flex; align-items: center; gap: 18px; }
.nav__phone {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em;
  color: var(--paper); display: flex; align-items: center; gap: 8px;
}
.nav__phone .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--red); box-shadow: 0 0 0 0 var(--red); animation: pulse 2.4s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(228,8,10,.6);} 70%{ box-shadow:0 0 0 9px rgba(228,8,10,0);} 100%{box-shadow:0 0 0 0 rgba(228,8,10,0);} }

.nav__mcta { display: none; }   /* mobile-menu CTA: hidden on desktop, shown in open burger menu */
.nav__burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 6px; }
.nav__burger span { width: 26px; height: 2px; background: var(--paper); transition: .35s var(--ease); }
.nav.open .nav__burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav.open .nav__burger span:nth-child(2) { opacity: 0; }
.nav.open .nav__burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ===================================================
   HERO
   =================================================== */
.hero { min-height: 100svh; display: flex; align-items: flex-end; overflow: hidden; padding-bottom: clamp(40px, 7vh, 90px); }
.hero__bg { position: absolute; inset: 0; z-index: 0; }
/* single-image hero (subpages still use this via .hero__bg > img) */
.hero__bg > img {
  width: 100%; height: 100%; object-fit: cover; object-position: center 42%;
  transform: scale(1.18); filter: saturate(0.95) contrast(1.05);
  animation: kenburns 18s var(--ease) forwards;
}
@keyframes kenburns { to { transform: scale(1.0); } }

/* crossfading carousel slides */
.hero__slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1.6s ease; will-change: opacity; }
.hero__slide img { width: 100%; height: 100%; object-fit: cover; object-position: center 45%; filter: saturate(0.95) contrast(1.05); transform: scale(1.08); }
.hero__slide.is-active { opacity: 1; }
.hero__slide.is-active img { animation: heroZoom 8s linear forwards; }
@keyframes heroZoom { from { transform: scale(1.06); } to { transform: scale(1.2); } }

.hero__bg::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(to top, var(--ink) 2%, rgba(10,10,11,.25) 45%, rgba(10,10,11,.55) 100%),
    radial-gradient(120% 80% at 80% 0%, rgba(228,8,10,.22), transparent 55%);
}

/* carousel progress dots */
.hero__dots { position: absolute; left: var(--gutter); bottom: 26px; z-index: 3; display: flex; gap: 9px; }
.hero__dots button { width: 26px; height: 3px; background: rgba(244,241,234,.25); border: 0; padding: 0; cursor: pointer; transition: background .3s; position: relative; overflow: hidden; }
.hero__dots button.is-active { background: rgba(244,241,234,.35); }
.hero__dots button.is-active::after { content: ""; position: absolute; inset: 0; background: var(--red); transform: scaleX(0); transform-origin: left; animation: dotFill 6s linear forwards; }
@keyframes dotFill { to { transform: scaleX(1); } }

/* rising sun motif */
.hero__sun {
  position: absolute; z-index: 0; top: -18vh; right: -12vw;
  width: 60vw; height: 60vw; max-width: 760px; max-height: 760px; border-radius: 50%;
  background: radial-gradient(circle, rgba(228,8,10,.55), rgba(228,8,10,.08) 55%, transparent 70%);
  filter: blur(8px);
  animation: floaty 9s ease-in-out infinite alternate;
}
@keyframes floaty { to { transform: translateY(26px) scale(1.04); } }

.hero__vert {
  position: absolute; z-index: 1; right: clamp(16px, 4vw, 60px); top: 50%; transform: translateY(-50%);
  writing-mode: vertical-rl;
  font-family: var(--jp); font-weight: 700;
  font-size: clamp(1rem, 1.5vw, 1.3rem); letter-spacing: 0.35em;
  color: rgba(244,241,234,.55);
}
.hero__vert b { color: var(--red-2); }

.hero__inner { position: relative; z-index: 2; width: 100%; }
.hero__tag { margin-bottom: 26px; }
.hero h1 {
  font-size: clamp(4.2rem, 16vw, 15rem);
  line-height: 0.82;
  letter-spacing: -0.02em;
}
.hero h1 .line { display: block; overflow: hidden; }
.hero h1 .line > span { display: block; }
.hero h1 .word-japan { color: var(--red-2); }
.hero__sub {
  display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between;
  gap: 30px; margin-top: 34px; border-top: 1px solid var(--line); padding-top: 28px;
}
.hero__sub p { max-width: 40ch; color: var(--paper-dim); }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }

.hero__scroll {
  position: absolute; left: var(--gutter); bottom: 26px; z-index: 2;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--muted); display: flex; align-items: center; gap: 12px;
}
.hero__scroll .bar { width: 46px; height: 1px; background: var(--line-2); position: relative; overflow: hidden; }
.hero__scroll .bar::after { content:""; position:absolute; inset:0; width:40%; background: var(--red-2); animation: scrollbar 2.2s var(--ease) infinite; }
@keyframes scrollbar { 0%{ transform: translateX(-100%);} 100%{ transform: translateX(280%);} }

/* ===================================================
   MARQUEE
   =================================================== */
.marquee {
  background: var(--red);
  color: #fff;
  padding: 16px 0;
  overflow: hidden;
  border-block: 1px solid rgba(0,0,0,.25);
  position: relative; z-index: 3;
}
.marquee__track { display: flex; width: max-content; animation: marq 32s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__track span {
  font-family: var(--display); font-weight: 800; text-transform: uppercase;
  font-size: clamp(1.3rem, 2.6vw, 2.1rem); letter-spacing: 0.02em;
  padding: 0 28px; display: inline-flex; align-items: center; gap: 28px; white-space: nowrap;
}
.marquee__track span::after { content: "✦"; color: rgba(255,255,255,.6); font-size: 0.7em; }
@keyframes marq { to { transform: translateX(-50%); } }

/* ===================================================
   GENERIC SECTION SHELL
   =================================================== */
.block { padding-block: clamp(80px, 12vh, 160px); }
.block--tight { padding-block: clamp(60px, 8vh, 110px); }

.section-head { display: grid; grid-template-columns: 1fr; gap: 22px; margin-bottom: 64px; }
.section-head .top { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.section-head .idx { font-family: var(--mono); font-size: 12px; color: var(--muted); letter-spacing: 0.2em; }

/* ---------- INTRO / stats ---------- */
.intro__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(40px, 6vw, 90px); align-items: end; }
.intro__big { font-family: var(--display); font-weight: 800; text-transform: uppercase; font-size: clamp(2.2rem, 4.4vw, 4rem); line-height: 0.95; }
.intro__big em { font-style: normal; color: var(--red-2); }
.intro__copy p + p { margin-top: 18px; }
.partner {
  margin-top: 30px; display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted);
  border: 1px solid var(--line); padding: 10px 16px;
}
.partner b { color: var(--paper); }

.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 80px; border-top: 1px solid var(--line); }
.stat { padding: 30px 24px 30px 0; border-right: 1px solid var(--line); }
.stat:last-child { border-right: 0; }
.stat .num { font-family: var(--display); font-weight: 800; font-size: clamp(2.6rem, 5vw, 4.4rem); line-height: 1; color: var(--paper); }
.stat .num .accent { color: var(--red-2); }
.stat .lbl { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-top: 10px; }

/* ===================================================
   EXPERIENCE CARDS
   =================================================== */
/* bold, colour-popping treatment for the Choose section */
#experience { background: linear-gradient(180deg, var(--ink), #0e0a09); }
#experience::after {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(55% 45% at 12% 6%, rgba(228,8,10,.18), transparent 62%),
    radial-gradient(55% 50% at 90% 100%, rgba(255,205,5,.13), transparent 62%);
}
#experience > .wrap { position: relative; z-index: 1; }
#experience .eyebrow { color: var(--red-2); }
#experience .eyebrow::before { background: var(--red); }

/* centered section header */
.section-head--center { text-align: center; justify-items: center; }
.section-head--center .eyebrow { justify-content: center; }
.choose-title { font-family: var(--display); font-weight: 800; text-transform: uppercase; line-height: .9; letter-spacing: -0.01em; font-size: clamp(2.4rem, 5.4vw, 4.4rem); }
.choose-title .c-day { color: var(--red-2); }
.choose-title .c-tour { color: var(--yellow); }
.section-sub { color: var(--paper-dim); max-width: 52ch; margin: 6px auto 0; font-size: clamp(1rem, 1.3vw, 1.12rem); }

/* ---------- CHOOSE: big colour-coded cards ---------- */
.choose { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 2.6vw, 34px); max-width: 1160px; margin: 0 auto; }
.choice {
  --c: var(--red); --c2: var(--red-2); --ct: #fff;
  display: flex; flex-direction: column; color: inherit;
  background: var(--ink-2); border: 1px solid var(--line-2); overflow: hidden;
  transition: transform .45s var(--ease), border-color .4s, box-shadow .45s var(--ease);
}
.choice--tour { --c: var(--yellow); --c2: var(--yellow-2); --ct: var(--ink); }
.choice::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 5px; background: var(--c); z-index: 3; }
.choice { position: relative; }
.choice:hover { transform: translateY(-7px); border-color: var(--c); box-shadow: 0 40px 80px -45px var(--c); }

.choice__card { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.choice__card img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.28) contrast(1.03); transition: transform .9s var(--ease), filter .55s; }
.choice:hover .choice__card img { transform: scale(1.05); filter: none; }
.choice__card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(17,17,20,.5), transparent 45%); }
.choice__ribbon {
  position: absolute; top: 16px; left: 16px; z-index: 2;
  font-family: var(--mono); font-size: 12px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ct); background: var(--c); padding: 9px 16px;
  clip-path: polygon(9px 0, 100% 0, 100% calc(100% - 9px), calc(100% - 9px) 100%, 0 100%, 0 9px);
}

.choice__body { display: flex; flex-direction: column; flex: 1; padding: clamp(24px, 2.4vw, 34px); }
.choice__title { font-family: var(--display); font-weight: 800; text-transform: uppercase; font-size: clamp(1.7rem, 2.6vw, 2.4rem); line-height: .98; margin-bottom: 12px; }
.choice__desc { color: var(--paper-dim); font-size: 15px; line-height: 1.55; margin-bottom: 28px; max-width: 40ch; }
.choice__foot { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: auto; padding-top: 22px; border-top: 1px solid var(--line); }
.choice__price { font-family: var(--display); font-weight: 800; font-size: clamp(1.8rem, 2.4vw, 2.4rem); color: var(--c2); white-space: nowrap; line-height: 1; }
.choice__price small { font-family: var(--mono); font-size: .42em; font-weight: 500; color: var(--muted); letter-spacing: .1em; text-transform: uppercase; display: block; margin-bottom: 5px; }
.choice__cta { --bg: var(--c); background: var(--c); border-color: var(--c); color: var(--ct); }
.choice__cta::after { background: var(--paper); }
.choice:hover .choice__cta .arrow { transform: translateX(5px); }

/* ===================================================
   INCLUDED GRID
   =================================================== */
.incl__grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.incl__item {
  border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: 38px 30px; min-height: 230px;
  display: flex; flex-direction: column; gap: 16px; position: relative; overflow: hidden;
  transition: background .4s var(--ease);
}
.incl__item::before { content:""; position:absolute; left:0; top:0; width:100%; height: 2px; background: var(--red); transform: scaleX(0); transform-origin: left; transition: transform .5s var(--ease); }
.incl__item:hover { background: var(--ink-2); }
.incl__item:hover::before { transform: scaleX(1); }
.incl__item .ico { width: 46px; height: 46px; object-fit: contain; filter: brightness(0) invert(1); opacity: .92; transition: transform .5s var(--ease); }
.incl__item:hover .ico { transform: translateY(-4px) scale(1.06); }
.incl__item .n { font-family: var(--mono); font-size: 11px; color: var(--muted); letter-spacing: 0.18em; }
.incl__item h4 { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 1.5rem; line-height: 1; margin-top: auto; }
.incl__item p { font-size: 14px; color: var(--paper-dim); line-height: 1.45; }

/* ===================================================
   ROADMAP / ITINERARY
   =================================================== */
.road { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(40px, 6vw, 90px); }
.road__media { position: relative; align-self: stretch; min-height: 420px; overflow: hidden; border: 1px solid var(--line); }
.road__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.road__media .tag { position: absolute; left: 18px; bottom: 18px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; background: var(--red); color:#fff; padding: 8px 12px; }
.timeline { display: flex; flex-direction: column; }
.tl { display: grid; grid-template-columns: 84px 1fr; gap: 22px; padding: 28px 0; border-top: 1px solid var(--line); }
.tl:last-child { border-bottom: 1px solid var(--line); }
.tl .day { font-family: var(--mono); font-size: 12px; color: var(--red-2); letter-spacing: 0.12em; padding-top: 6px; }
.tl h4 { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 1.7rem; line-height: 1; margin-bottom: 8px; }
.tl p { color: var(--paper-dim); font-size: 15px; max-width: 52ch; }

/* ===================================================
   GALLERY
   =================================================== */
.gallery { display: grid; grid-template-columns: repeat(12, 1fr); grid-auto-rows: 200px; gap: 14px; grid-auto-flow: dense; }
.gItem { position: relative; overflow: hidden; border: 1px solid var(--line); }
.gItem img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease), filter .6s; filter: grayscale(.35) contrast(1.02); }
.gItem::after { content:""; position:absolute; inset:0; background: linear-gradient(to top, rgba(10,10,11,.5), transparent 60%); opacity:0; transition: opacity .5s; }
.gItem:hover img { transform: scale(1.08); filter: grayscale(0); }
.gItem:hover::after { opacity:1; }
.gItem .cap { position:absolute; left:14px; bottom:12px; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: #fff; opacity: 0; transform: translateY(8px); transition: .5s var(--ease); z-index:1; }
.gItem:hover .cap { opacity: 1; transform: translateY(0); }
.g-a { grid-column: span 6; grid-row: span 2; }
.g-b { grid-column: span 3; grid-row: span 1; }
.g-c { grid-column: span 3; grid-row: span 2; }
.g-d { grid-column: span 3; grid-row: span 1; }
.g-e { grid-column: span 4; grid-row: span 1; }
.g-f { grid-column: span 5; grid-row: span 1; }
.g-g { grid-column: span 3; grid-row: span 1; }

/* ===================================================
   TESTIMONIAL
   =================================================== */
.quote { text-align: center; max-width: 1000px; margin: 0 auto; position: relative; }
.quote .mark { font-family: var(--display); font-size: 9rem; line-height: 0.6; color: var(--red); opacity: .5; }
.quote blockquote {
  font-family: var(--display); font-weight: 700; text-transform: none;
  font-size: clamp(1.6rem, 3.4vw, 3rem); line-height: 1.12; letter-spacing: -0.01em;
  margin: 10px 0 30px;
}
.quote blockquote em { font-style: normal; color: var(--red-2); }
.quote .who { font-family: var(--mono); font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.quote .who b { color: var(--paper); }

/* ===================================================
   PRICING / TOURS
   =================================================== */
.pricing { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.price__card { border: 1px solid var(--line-2); padding: 44px; position: relative; overflow: hidden; background: var(--ink-2); }
.price__card.is-feature { background: linear-gradient(150deg, var(--red-deep), var(--ink-2) 70%); border-color: var(--red); }
.price__badge { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--red-2); }
.price__card.is-feature .price__badge { color: #fff; }
.price__amt { font-family: var(--display); font-weight: 800; font-size: clamp(3rem, 6vw, 5rem); line-height: 1; margin: 16px 0 4px; }
.price__amt small { font-size: 1.1rem; font-family: var(--mono); font-weight: 500; color: var(--muted); letter-spacing: 0.05em; }
.price__card.is-feature .price__amt small { color: var(--paper-dim); }
.price__per { font-family: var(--mono); font-size: 12px; color: var(--muted); letter-spacing: 0.12em; text-transform: uppercase; }
.price__list { list-style: none; margin: 28px 0; display: flex; flex-direction: column; gap: 12px; }
.price__list li { display: flex; gap: 12px; align-items: baseline; font-size: 15px; color: var(--paper-dim); }
.price__list li::before { content: "//"; color: var(--red-2); font-family: var(--mono); font-size: 12px; }
.finance { font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em; color: var(--muted); margin-top: 8px; }

.tours { margin-top: 30px; border-top: 1px solid var(--line); }
.tour-row { display: grid; grid-template-columns: 60px 1fr auto auto; gap: 24px; align-items: center; padding: 22px 0; border-bottom: 1px solid var(--line); transition: padding-left .4s var(--ease), background .4s; }
.tour-row:hover { padding-left: 14px; background: linear-gradient(to right, rgba(228,8,10,.08), transparent); }
.tour-row .t-no { font-family: var(--mono); font-size: 12px; color: var(--muted); }
.tour-row .t-name { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 1.5rem; }
.tour-row .t-date { font-family: var(--mono); font-size: 13px; color: var(--paper-dim); letter-spacing: 0.06em; }
.pill { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; padding: 6px 12px; border: 1px solid var(--line-2); color: var(--muted); }
.pill.sold { color: var(--muted); }
.pill.open { color: #fff; background: var(--red); border-color: var(--red); }

/* ===================================================
   FAQ
   =================================================== */
.faq { border-top: 1px solid var(--line); }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q { width: 100%; background: none; border: 0; cursor: pointer; color: var(--paper); text-align: left; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 28px 0; font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: clamp(1.25rem, 2.2vw, 1.9rem); line-height: 1.05; transition: color .3s; }
.faq__q:hover { color: var(--red-2); }
.faq__q .pm { flex: none; width: 30px; height: 30px; position: relative; }
.faq__q .pm::before, .faq__q .pm::after { content:""; position:absolute; background: var(--red-2); top:50%; left:50%; transform: translate(-50%,-50%); transition: transform .4s var(--ease); }
.faq__q .pm::before { width: 16px; height: 2px; }
.faq__q .pm::after { width: 2px; height: 16px; }
.faq__item.open .pm::after { transform: translate(-50%,-50%) scaleY(0); }
.faq__a { overflow: hidden; max-height: 0; transition: max-height .5s var(--ease); }
.faq__a p { color: var(--paper-dim); padding-bottom: 28px; max-width: 75ch; font-size: 16px; }

/* ===================================================
   CONTACT / CTA
   =================================================== */
.cta { position: relative; overflow: hidden; }
.cta__bg { position: absolute; inset: 0; z-index: -2; }
.cta__bg img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.4); }
.cta::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(to right, var(--ink) 20%, rgba(10,10,11,.7) 60%, rgba(10,10,11,.45)); }
.cta__inner { padding-block: clamp(90px, 16vh, 200px); max-width: 720px; }
.cta h2 { font-size: clamp(3rem, 9vw, 8rem); line-height: 0.84; }
.cta p { color: var(--paper-dim); margin: 24px 0 36px; max-width: 46ch; }
.cta__row { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.cta__phone { font-family: var(--mono); font-size: 14px; letter-spacing: 0.08em; }
.cta__phone b { display:block; font-family: var(--display); font-size: 1.8rem; letter-spacing: 0; }

/* ===================================================
   FOOTER
   =================================================== */
.footer { border-top: 1px solid var(--line); padding-block: 60px 40px; }
.footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.footer__brand img { height: 38px; margin-bottom: 20px; }
.footer__brand p { color: var(--muted); font-size: 14px; max-width: 34ch; }
.footer h5 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); margin-bottom: 18px; }
.footer ul { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.footer ul a { color: var(--paper-dim); font-size: 14px; transition: color .3s; }
.footer ul a:hover { color: var(--red-2); }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--line); font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--muted); text-transform: uppercase; }
.footer__bottom a:hover { color: var(--red-2); }

/* ===================================================
   SCROLL REVEAL
   =================================================== */
[data-reveal] { opacity: 0; transform: translateY(38px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal-stagger] > * { opacity: 0; transform: translateY(30px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal-stagger].in > * { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  [data-reveal], [data-reveal-stagger] > * { opacity: 1 !important; transform: none !important; }
  .hero__bg img { transform: scale(1); }
}

/* ===================================================
   RESPONSIVE
   =================================================== */
@media (max-width: 1024px) {
  .intro__grid { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .stat:nth-child(2) { border-right: 0; }
  .choose { grid-template-columns: 1fr; gap: 22px; }
  .incl__grid { grid-template-columns: repeat(2, 1fr); }
  .road { grid-template-columns: 1fr; }
  .pricing { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .gallery { grid-auto-rows: 170px; }
}

/* nav collapses to a burger menu on tablet + mobile (prevents crowding) */
@media (max-width: 1100px) {
  .nav__links, .nav__phone { display: none; }
  .nav__right .btn--sm { display: none; }      /* hide desktop CTA; menu has its own */
  .nav__burger { display: flex; }
  .nav.open .nav__links {
    display: flex; flex-direction: column; gap: 4px;
    position: fixed; inset: 68px 0 auto 0; background: var(--ink-2);
    padding: 18px var(--gutter) 30px; border-bottom: 1px solid var(--line);
    box-shadow: 0 24px 50px -20px rgba(0,0,0,.7);
  }
  .nav.open .nav__links a { font-size: 17px; padding: 13px 0; }       /* ~44px tap target */
  .nav__mcta { display: none; }
  .nav.open .nav__mcta { display: inline-flex; justify-content: center; width: 100%; margin-top: 12px; }
}

@media (max-width: 760px) {
  body { font-size: 16px; }
  .hero__sub { flex-direction: column; align-items: flex-start; }
  .hero__vert { display: none; }
  .stats { grid-template-columns: 1fr 1fr; }
  .stat { padding-right: 16px; }
  .tour-row { grid-template-columns: 36px 1fr; gap: 10px 14px; }
  .tour-row .t-date { grid-column: 2; }
  .tour-row .pill { grid-column: 2; justify-self: start; }
  .gallery { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 130px; }
  .g-a, .g-c { grid-column: span 6; grid-row: span 2; }
  .g-b, .g-d, .g-e, .g-f, .g-g { grid-column: span 3; grid-row: span 1; }
  .footer__grid { grid-template-columns: 1fr; gap: 30px; }
  .cta__phone { margin-top: 8px; }
}

/* =========================================================
   v2 ADDITIONS — multi-page, booking, packages, videos, CMS
   ========================================================= */

.btn--sm { padding: 12px 20px; font-size: 11.5px; }
.nav__links a.is-active { color: var(--paper); }
.nav__links a.is-active::after { width: 100%; }

.footer__call { display:inline-block; margin-top:16px; font-family: var(--display); font-weight:700; font-size:1.4rem; color:var(--paper); }
.footer__legal { display:flex; flex-wrap:wrap; gap:24px; margin-top:48px; padding-top:24px; border-top:1px solid var(--line); }
.footer__legal a { font-family: var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.footer__legal a:hover { color:var(--red-2); }

/* ---------- hero booking widget ---------- */
.hero--home { align-items: stretch; }
.hero__grid { position:relative; z-index:2; width:100%; display:grid; grid-template-columns: 1.5fr 0.9fr; gap: 48px; align-items:end; }
@media (max-width: 1080px){ .hero__grid{ grid-template-columns:1fr; gap:32px; } }

.bookwidget {
  background: rgba(17,17,20,0.72);
  backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid var(--line-2);
  padding: 26px;
  clip-path: polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px);
}
.bookwidget__head { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:18px; }
.bookwidget__head .eyebrow { margin:0; }
.bookwidget__head .live { font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); display:flex; align-items:center; gap:7px; }
.bookwidget__head .live::before { content:""; width:7px;height:7px;border-radius:50%; background:#37d67a; box-shadow:0 0 0 0 rgba(55,214,122,.5); animation:pulse 2.4s infinite; }
.field { display:flex; flex-direction:column; gap:7px; margin-bottom:14px; min-width:0; }
.field label { font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.field input, .field select, .field textarea {
  width:100%; min-width:0; background:var(--ink); color:var(--paper);
  border:1px solid var(--line-2); padding:13px 14px; font-family:var(--body); font-size:16px;
  border-radius:0; transition:border-color .3s, background .3s;
}
.field textarea { resize:vertical; min-height:96px; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--red); background:#0d0d0f; }
.field input::-webkit-calendar-picker-indicator { filter: invert(1); opacity:.6; cursor:pointer; }
.field--row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.field--row .field { margin-bottom:0; min-width:0; }
.bookwidget .btn { width:100%; justify-content:center; margin-top:6px; }
.bookwidget__note { font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; color:var(--muted); margin-top:12px; text-align:center; }
.bookwidget__note a { color:var(--paper-dim); text-decoration:underline; }

/* ---------- booking confirmation ---------- */
.booking-done__inner { border:1px solid var(--red); background:linear-gradient(160deg, rgba(156,6,8,.28), var(--ink-2) 70%); padding:40px; text-align:center; }
.booking-done__check { width:64px;height:64px;border-radius:50%;border:2px solid var(--red-2); color:var(--red-2); display:flex;align-items:center;justify-content:center; font-size:32px; margin:0 auto 18px; }
.booking-done h3 { font-family:var(--display); font-weight:800; text-transform:uppercase; font-size:2rem; margin-bottom:10px; }
.booking-done p { color:var(--paper-dim); max-width:54ch; margin:0 auto 8px; }
.booking-done__sub { font-size:14px; color:var(--muted); margin-top:14px; }
.booking-done .btn { margin:14px 8px 0; }

/* ---------- subpage hero ---------- */
.subhero { position:relative; min-height:62vh; display:flex; align-items:flex-end; overflow:hidden; padding-bottom:clamp(40px,7vh,80px); padding-top:140px; }
.subhero__bg { position:absolute; inset:0; z-index:0; }
.subhero__bg img { width:100%;height:100%;object-fit:cover; transform:scale(1.06); filter:saturate(.95) contrast(1.04); }
.subhero__bg::after { content:""; position:absolute; inset:0; background:linear-gradient(to top, var(--ink) 3%, rgba(10,10,11,.35) 55%, rgba(10,10,11,.6)); }
.subhero__inner { position:relative; z-index:2; width:100%; }
.subhero h1 { font-size:clamp(3rem,9vw,8rem); line-height:.84; margin:18px 0 0; }
.subhero h1 .accent { color:var(--red-2); }
.subhero__lead { color:var(--paper-dim); max-width:56ch; margin-top:20px; font-size:clamp(1rem,1.5vw,1.15rem); }
.subhero__cta { display:flex; gap:14px; flex-wrap:wrap; margin-top:28px; }
.crumbs { font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.crumbs a:hover { color:var(--red-2); }

/* ---------- package cards ---------- */
.pkgs { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:1024px){ .pkgs{ grid-template-columns:1fr; } }
.pkg { border:1px solid var(--line-2); background:var(--ink-2); padding:34px; display:flex; flex-direction:column; position:relative; overflow:hidden; transition:transform .5s var(--ease), border-color .4s; }
.pkg::before { content:""; position:absolute; left:0;top:0; width:100%;height:2px; background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.pkg:hover { transform:translateY(-6px); border-color:var(--line-2); }
.pkg:hover::before { transform:scaleX(1); }
.pkg.is-feature { background:linear-gradient(160deg, rgba(156,6,8,.30), var(--ink-2) 65%); border-color:var(--red); }
.pkg__tag { font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--red-2); }
.pkg.is-feature .pkg__tag { color:#fff; }
.pkg__name { font-family:var(--display); font-weight:800; text-transform:uppercase; font-size:2.1rem; line-height:1; margin:14px 0 12px; }
.pkg__price { font-family:var(--display); font-weight:800; font-size:2.6rem; line-height:1; }
.pkg__price small { font-family:var(--mono); font-size:.78rem; font-weight:500; color:var(--muted); letter-spacing:.04em; }
.pkg.is-feature .pkg__price small { color:var(--paper-dim); }
.pkg__dur { font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:6px; }
.pkg__blurb { color:var(--paper-dim); font-size:15px; margin:18px 0; }
.pkg__list { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:26px; }
.pkg__list li { display:flex; gap:10px; align-items:baseline; font-size:14.5px; color:var(--paper-dim); }
.pkg__list li::before { content:"//"; color:var(--red-2); font-family:var(--mono); font-size:11px; }
.pkg .btn { margin-top:auto; justify-content:center; }
.pkg__note { font-family:var(--mono); font-size:11px; color:var(--muted); letter-spacing:.04em; margin-top:30px; text-align:center; }

/* ---------- video grid ---------- */
.videos { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media (max-width:1024px){ .videos{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .videos{ grid-template-columns:1fr; } }
.vcard { text-align:left; background:none; border:1px solid var(--line); padding:0; cursor:pointer; overflow:hidden; display:flex; flex-direction:column; transition:border-color .4s, transform .5s var(--ease); color:inherit; }
.vcard:hover { border-color:var(--line-2); transform:translateY(-4px); }
.vcard__thumb { position:relative; display:block; aspect-ratio:16/9; background-size:cover; background-position:center; }
.vcard__thumb::after { content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(10,10,11,.55), transparent 55%); }
.vcard__play { position:absolute; inset:0; margin:auto; width:56px;height:56px;border-radius:50%; background:var(--red); display:flex; align-items:center; justify-content:center; transition:transform .4s var(--ease), background .3s; z-index:1; }
.vcard__play::before { content:""; border-style:solid; border-width:9px 0 9px 15px; border-color:transparent transparent transparent #fff; margin-left:3px; }
.vcard:hover .vcard__play { transform:scale(1.12); background:var(--red-2); }
.vcard__meta { padding:16px 16px 18px; display:flex; flex-direction:column; gap:5px; }
.vcard__note { font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--red-2); }
.vcard__title { font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:1.15rem; line-height:1.05; }
.vcard__frame { width:100%; aspect-ratio:16/9; border:1px solid var(--line-2); display:block; }

/* ---------- detailed itinerary (full tour page) ---------- */
.itin { display:flex; flex-direction:column; }
.itin__day { display:grid; grid-template-columns: 150px 1fr; gap:36px; padding:40px 0; border-top:1px solid var(--line); }
.itin__day:last-child { border-bottom:1px solid var(--line); }
@media (max-width:760px){ .itin__day{ grid-template-columns:1fr; gap:14px; } }
.itin__tag { font-family:var(--mono); font-size:12px; letter-spacing:.14em; color:var(--red-2); text-transform:uppercase; }
.itin__tag b { display:block; font-family:var(--display); font-size:2.4rem; color:var(--paper); letter-spacing:0; line-height:1; margin-top:4px; }
.itin__day h3 { font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:1.9rem; line-height:1; margin-bottom:10px; }
.itin__day p { color:var(--paper-dim); max-width:62ch; }
.itin__day ul { list-style:none; margin-top:14px; display:flex; flex-wrap:wrap; gap:8px 10px; }
.itin__day ul li { font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); border:1px solid var(--line); padding:6px 11px; }

/* ---------- generic content / prose / legal ---------- */
.prose { max-width:820px; margin:0 auto; }
.prose h2 { font-family:var(--display); font-weight:800; text-transform:uppercase; font-size:clamp(1.6rem,3vw,2.4rem); margin:46px 0 14px; line-height:1; }
.prose h3 { font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:1.3rem; margin:28px 0 10px; }
.prose p, .prose li { color:var(--paper-dim); font-size:16px; line-height:1.7; }
.prose p { margin-bottom:14px; }
.prose ul, .prose ol { margin:0 0 16px 22px; display:flex; flex-direction:column; gap:8px; }
.prose a { color:var(--red-2); text-decoration:underline; }
.prose strong { color:var(--paper); }
.prose .updated { font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.legal-note { border:1px solid var(--line); background:var(--ink-2); padding:18px 22px; margin:24px 0; font-size:14px; color:var(--muted); }

/* ---------- booking page layout ---------- */
.bookpage { display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(36px,6vw,80px); align-items:start; }
@media (max-width:960px){ .bookpage{ grid-template-columns:1fr; } }
.bookpage__aside .lead { margin-bottom:26px; }
.bookpage__points { list-style:none; display:flex; flex-direction:column; gap:14px; }
.bookpage__points li { display:flex; gap:12px; font-size:15px; color:var(--paper-dim); }
.bookpage__points li::before { content:""; flex:none; width:22px;height:22px; margin-top:1px; border:1px solid var(--red); color:var(--red-2); display:inline-flex; align-items:center; justify-content:center; }
.bookform { border:1px solid var(--line-2); background:var(--ink-2); padding:clamp(24px,4vw,40px); }

/* ---------- admin / CMS ---------- */
.admin { max-width:1080px; margin:0 auto; }
.admin__bar { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:30px; padding-bottom:22px; border-bottom:1px solid var(--line); }
.admin__status { font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--muted); }
.admin__status b { color:var(--red-2); }
.admin__tabs { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:24px; }
.admin__tab { font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; padding:10px 16px; border:1px solid var(--line-2); background:none; color:var(--paper-dim); cursor:pointer; }
.admin__tab.active { background:var(--red); border-color:var(--red); color:#fff; }
.admin__panel { display:none; }
.admin__panel.active { display:block; }
.arow { display:grid; grid-template-columns:1fr 1fr 140px auto; gap:12px; align-items:center; padding:14px 0; border-bottom:1px solid var(--line); }
.arow input, .arow select { background:var(--ink); color:var(--paper); border:1px solid var(--line-2); padding:10px 12px; font-family:var(--body); font-size:14px; }
.arow .del { background:none; border:1px solid var(--line-2); color:var(--muted); padding:9px 13px; cursor:pointer; font-family:var(--mono); font-size:12px; }
.arow .del:hover { border-color:var(--red); color:var(--red-2); }
.admin__actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:26px; }
.admin__hint { font-family:var(--mono); font-size:12px; color:var(--muted); line-height:1.7; margin-top:20px; border-top:1px solid var(--line); padding-top:18px; }
.admin__hint code { color:var(--paper-dim); }

/* utility spacing for simple pages */
.pad-top-nav { padding-top:120px; }

/* =========================================================
   v3 — colour rhythm, section banding, About page
   ========================================================= */

/* hide single scroll cue on the carousel hero */
.hero--home .hero__scroll { display: none; }

/* section divider + alternating panels for scroll rhythm */
.block { position: relative; }
.block + .block::before,
.block--alt::before {
  content: ""; position: absolute; top: 0; left: var(--gutter); right: var(--gutter);
  height: 1px; background: linear-gradient(90deg, transparent, var(--line-2), transparent);
}
.block--alt { background: var(--panel); }
.block--warm { background: var(--panel-2); }

/* cyan accenting on alternate sections — introduces the complementary colour */
.block--alt .eyebrow { color: var(--cyan-2); }
.block--alt .eyebrow::before { background: var(--cyan); }
.block--alt .accent { color: var(--cyan-2); }
.block--alt .idx { color: var(--cyan); opacity: .65; }
.block--alt .stat .num .accent { color: var(--cyan-2); }
.block--alt .tl .day,
.block--alt .itin__tag,
.block--alt .vcard__note,
.block--alt .pkg__tag { color: var(--cyan-2); }
.block--alt .exp__link .arrow,
.block--alt .price__list li::before,
.block--alt .pkg__list li::before { color: var(--cyan-2); }
.block--alt .incl__item::before { background: var(--cyan); }
.block--alt .tour-row:hover { background: linear-gradient(to right, rgba(25,217,198,.10), transparent); }
.block--alt .faq__q:hover { color: var(--cyan-2); }
.block--alt .faq__q .pm::before, .block--alt .faq__q .pm::after { background: var(--cyan-2); }
.block--alt ::selection { background: var(--cyan); color: var(--ink); }
.block--alt .road__media .tag { background: var(--cyan); color: var(--ink); }

/* a touch of cyan glow in alt sections for depth */
.block--alt::after {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(80% 60% at 12% 0%, rgba(25,217,198,.07), transparent 60%);
}
.block--alt > .wrap { position: relative; z-index: 1; }

/* keep the marquee energetic; give an alt variant for visual breaks */
.marquee--cyan { background: var(--cyan); color: var(--ink); }
.marquee--cyan .marquee__track span::after { color: rgba(10,16,19,.5); }

/* ---------- ABOUT PAGE ---------- */
.about-lead { display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(36px,6vw,80px); align-items:start; }
@media (max-width:960px){ .about-lead{ grid-template-columns:1fr; } }
.about-lead .intro__big { margin-bottom:22px; }
.about-figure { position:relative; border:1px solid var(--line); overflow:hidden; aspect-ratio:4/5; }
.about-figure img { width:100%; height:100%; object-fit:cover; }
.about-figure figcaption { position:absolute; left:16px; bottom:14px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#fff; background:rgba(10,10,11,.6); padding:7px 11px; }

.team { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:900px){ .team{ grid-template-columns:1fr; } }
.team__card { border:1px solid var(--line); background:var(--ink-2); overflow:hidden; transition:transform .5s var(--ease), border-color .4s; }
.team__card:hover { transform:translateY(-6px); border-color:var(--line-2); }
.team__media { aspect-ratio:1/1; overflow:hidden; }
.team__media img { width:100%; height:100%; object-fit:cover; filter:grayscale(.3); transition:transform 1s var(--ease), filter .5s; }
.team__card:hover .team__media img { transform:scale(1.06); filter:grayscale(0); }
.team__body { padding:24px; }
.team__role { font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--cyan-2); }
.team__name { font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:1.7rem; line-height:1; margin:8px 0 10px; }
.team__body p { color:var(--paper-dim); font-size:14.5px; }

/* contact / location */
.contact { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line); }
@media (max-width:760px){ .contact{ grid-template-columns:1fr; } }
.contact__cell { padding:34px 30px 34px 0; border-right:1px solid var(--line); }
.contact__cell:last-child { border-right:0; }
@media (max-width:760px){ .contact__cell{ border-right:0; border-bottom:1px solid var(--line); padding-right:0; } }
.contact__k { font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--cyan-2); margin-bottom:14px; }
.contact__v { font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:1.5rem; line-height:1.05; }
.contact__v a:hover { color:var(--red-2); }
.contact__sub { color:var(--paper-dim); font-size:14px; margin-top:8px; }

.milestones { display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line); margin-top:10px; }
@media (max-width:760px){ .milestones{ grid-template-columns:1fr 1fr; } }
.milestone { padding:30px 24px 30px 0; border-right:1px solid var(--line); }
.milestone:last-child { border-right:0; }
.milestone .my { font-family:var(--display); font-weight:800; font-size:2.4rem; line-height:1; color:var(--cyan-2); }
.milestone .ml { font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:10px; }

/* =========================================================
   v4 — hype promo video section (contained, full frame visible)
   ========================================================= */
.promo-block { padding-block: clamp(80px, 12vh, 160px); position: relative; background: var(--panel-2); }
.promo-block::before {
  content: ""; position: absolute; top: 0; left: var(--gutter); right: var(--gutter);
  height: 1px; background: linear-gradient(90deg, transparent, var(--line-2), transparent);
}
.promo__frame {
  position: relative; width: 100%; aspect-ratio: 16 / 9; background: #000;
  border: 1px solid var(--line-2); overflow: hidden;
  box-shadow: 0 40px 90px -40px rgba(0,0,0,.85);
}
.promo__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; background: #000; }

/* corner sound toggle — small, never covers the action */
.promo__sound {
  position: absolute; top: 16px; right: 16px; z-index: 3;
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--paper); background: rgba(10,10,11,.55); backdrop-filter: blur(8px);
  border: 1px solid var(--line-2); padding: 10px 14px; cursor: pointer;
  transition: border-color .3s, background .3s;
}
.promo__sound:hover { border-color: var(--red); background: rgba(10,10,11,.78); }
.promo__sound .ic::before { content: "🔇"; }
.is-unmuted .promo__sound .ic::before { content: "🔊"; }
.promo__sound .lbl::after { content: "Tap for sound"; }
.is-unmuted .promo__sound .lbl::after { content: "Sound on"; }

.promo__big-play {
  position: absolute; inset: 0; margin: auto; z-index: 3;
  width: 84px; height: 84px; border-radius: 50%; border: 0; cursor: pointer;
  background: var(--red); display: none; align-items: center; justify-content: center;
  box-shadow: 0 0 0 0 rgba(228,8,10,.5); animation: pulse 2.6s infinite;
}
.is-paused .promo__big-play { display: flex; }
.promo__big-play::before { content: ""; border-style: solid; border-width: 13px 0 13px 22px; border-color: transparent transparent transparent #fff; margin-left: 5px; }

.promo__row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 30px; }

@media (prefers-reduced-motion: reduce) { .promo__big-play { animation: none; } }

/* =========================================================
   v5 — accessibility & mobile polish
   ========================================================= */
/* larger tap targets for footer links */
.footer ul a { display: inline-block; padding: 3px 0; }
.footer__legal a { display: inline-block; padding: 4px 0; }

/* reduce empty top gap on simple pages on mobile */
@media (max-width: 760px) {
  .pad-top-nav { padding-top: 92px; }
  /* comfortable tap targets for in-video controls */
  .promo__sound { padding: 12px 15px; }
  .vcard__play { width: 60px; height: 60px; }
  /* hero dots easier to hit */
  .hero__dots button { height: 5px; }
}

/* respect users who prefer reduced motion for the carousel/marquee too */
@media (prefers-reduced-motion: reduce) {
  .marquee__track { animation: none !important; }
  .hero__slide { transition: none !important; }
  .hero__dots button.is-active::after { animation: none !important; }
}

/* =========================================================
   v6 — interactive route map (Leaflet, DTJ-themed)
   ========================================================= */
.routemap { display: grid; grid-template-columns: 320px 1fr; gap: 24px; align-items: stretch; }
@media (max-width: 880px) { .routemap { grid-template-columns: 1fr; } }

/* stop list */
.routemap__list { list-style: none; display: flex; flex-direction: column; gap: 8px; margin: 0; padding: 0; }
.routestop { display: flex; align-items: center; gap: 16px; padding: 16px 18px; border: 1px solid var(--line); background: var(--ink-2); cursor: pointer; transition: border-color .3s, background .3s, transform .3s var(--ease); }
.routestop:hover, .routestop.is-active { border-color: var(--red); transform: translateX(4px); }
.routestop.is-active { background: linear-gradient(to right, rgba(228,8,10,.12), var(--ink-2) 70%); }
.routestop__no { flex: none; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; font-family: var(--display); font-weight: 800; font-size: 1rem; color: #fff; background: var(--red); }
.routestop__no.dtj-pin--yellow { background: var(--yellow); color: var(--ink); }
.routestop__txt { display: flex; flex-direction: column; gap: 1px; line-height: 1.2; }
.routestop__day { font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--red-2); }
.routestop__name { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 1.15rem; }
.routestop__sub { font-size: 12.5px; color: var(--muted); }

/* map shell */
.routemap__map { position: relative; min-height: 460px; border: 1px solid var(--line-2); overflow: hidden; }
#dtjMap { position: absolute; inset: 0; width: 100%; height: 100%; background: #0a0a0b; }
@media (max-width: 880px) { .routemap__map { min-height: 380px; height: 380px; } }
.routemap__reset { position: absolute; z-index: 500; right: 12px; bottom: 12px; font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--paper); background: rgba(10,10,11,.7); backdrop-filter: blur(8px); border: 1px solid var(--line-2); padding: 9px 13px; cursor: pointer; transition: border-color .3s; }
.routemap__reset:hover { border-color: var(--red); }

/* subtle warm tint on the dark tiles so it feels on-brand */
.routemap__map .leaflet-tile-pane { filter: brightness(.92) saturate(1.05) hue-rotate(-6deg) contrast(1.04); }

/* branded pins */
.dtj-pin { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 50%; font-family: var(--display); font-weight: 800; font-size: .95rem; color: #fff; box-shadow: 0 0 0 4px rgba(228,8,10,.22), 0 6px 16px rgba(0,0,0,.6); transition: transform .25s var(--ease); }
.dtj-pin--red { background: var(--red); }
.dtj-pin--yellow { background: var(--yellow); color: var(--ink); box-shadow: 0 0 0 4px rgba(255,205,5,.22), 0 6px 16px rgba(0,0,0,.6); }
.leaflet-marker-icon:hover .dtj-pin, .leaflet-marker-icon.is-hover .dtj-pin { transform: scale(1.18); }

/* animated dashed route */
.dtj-route { animation: dtjdash 1.1s linear infinite; }
@keyframes dtjdash { to { stroke-dashoffset: -22; } }

/* themed popups + controls */
.routemap__map .leaflet-popup-content-wrapper { background: var(--ink-2); color: var(--paper); border: 1px solid var(--red); border-radius: 0; box-shadow: 0 20px 40px -16px rgba(0,0,0,.8); }
.routemap__map .leaflet-popup-tip { background: var(--ink-2); border: 1px solid var(--red); }
.routemap__map .leaflet-popup-content { margin: 14px 18px; }
.dtj-pop { display: flex; flex-direction: column; gap: 2px; }
.dtj-pop__day { font-family: var(--mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--red-2); }
.dtj-pop strong { font-family: var(--display); font-weight: 800; text-transform: uppercase; font-size: 1.3rem; line-height: 1; }
.dtj-pop__sub { font-size: 13px; color: var(--paper-dim); }
.routemap__map .leaflet-control-zoom a { background: var(--ink-2); color: var(--paper); border-color: var(--line-2); }
.routemap__map .leaflet-control-zoom a:hover { background: var(--red); color: #fff; border-color: var(--red); }
.routemap__map .leaflet-control-attribution { background: rgba(10,10,11,.7); color: var(--muted); }
.routemap__map .leaflet-control-attribution a { color: var(--paper-dim); }

/* =========================================================
   v7 — phone country code + booking validation
   ========================================================= */
.field__phone { display: flex; }
.field__phone .cc { flex: none; width: 108px; border-right: 0; padding-inline: 10px; }
.field__phone input { flex: 1; min-width: 0; }
.field__error { color: var(--red-2); font-family: var(--mono); font-size: 11px; letter-spacing: .03em; margin-top: 7px; display: none; }
.field__error.show { display: block; }
.field__note { font-family: var(--mono); font-size: 10.5px; letter-spacing: .04em; color: var(--muted); margin-top: 7px; }

/* =========================================================
   v8 — admin bookings + email draft + waiver/pay page
   ========================================================= */
.bookbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 22px; }
.bookfilters { display: flex; gap: 8px; flex-wrap: wrap; }
.bf { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; padding: 9px 14px; border: 1px solid var(--line-2); background: none; color: var(--paper-dim); cursor: pointer; }
.bf.active { background: var(--paper); color: var(--ink); border-color: var(--paper); }

.bcard { border: 1px solid var(--line); background: var(--ink-2); padding: 20px 22px; margin-bottom: 14px; }
.bcard__top { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 14px; }
.bcard__name { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 1.3rem; }
.bcard__when { font-family: var(--mono); font-size: 11px; color: var(--muted); }
.bcard__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px 24px; }
@media (max-width: 700px){ .bcard__grid { grid-template-columns: 1fr 1fr; } }
.bcard__grid > div, .bcard__notes { font-size: 14px; color: var(--paper-dim); }
.bcard__grid a { color: var(--paper); }
.bcard .k { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
.bcard__notes { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); }
.bcard__actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; }

.bpill { font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; padding: 4px 9px; border: 1px solid var(--line-2); color: var(--muted); }
.bpill--pending  { color: var(--yellow); border-color: rgba(255,205,5,.4); }
.bpill--approved { color: #37d67a; border-color: rgba(55,214,122,.4); }
.bpill--denied   { color: var(--red-2); border-color: rgba(255,43,43,.4); }

/* email draft modal */
.draft { position: fixed; inset: 0; z-index: 3000; background: rgba(5,5,6,.7); backdrop-filter: blur(4px); display: flex; align-items: flex-start; justify-content: center; overflow-y: auto; padding: 6vh 16px; }
.draft[hidden] { display: none; }
.draft__box { width: 100%; max-width: 680px; background: var(--ink-2); border: 1px solid var(--line-2); padding: clamp(24px, 4vw, 40px); position: relative; }
.draft__close { position: absolute; top: 14px; right: 16px; background: none; border: 0; color: var(--muted); font-size: 26px; line-height: 1; cursor: pointer; }
.draft__close:hover { color: var(--red-2); }
.draft__head { font-family: var(--display); font-weight: 800; text-transform: uppercase; font-size: 1.8rem; margin: 8px 0 4px; }
.draft__meta { font-family: var(--mono); font-size: 12px; color: var(--muted); margin-bottom: 18px; }
.draft__lbl { display: block; font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin: 16px 0 7px; }
.draft__in, .draft__txt { width: 100%; background: var(--ink); color: var(--paper); border: 1px solid var(--line-2); padding: 12px 14px; font-family: var(--body); font-size: 15px; }
.draft__txt { font-family: var(--mono); font-size: 13px; line-height: 1.6; resize: vertical; }
.draft__actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 22px; }

/* ---------- admin auth gate ---------- */
.authgate { position: fixed; inset: 0; z-index: 4000; background: var(--ink); display: flex; align-items: center; justify-content: center; padding: 24px; }
.authgate[hidden] { display: none; }
.authgate__box { width: 100%; max-width: 400px; background: var(--ink-2); border: 1px solid var(--line-2); padding: clamp(28px, 5vw, 44px); }
.authgate__logo { display: block; height: auto; margin-bottom: 22px; }
.authgate__head { font-family: var(--display); font-weight: 800; text-transform: uppercase; font-size: 2rem; margin: 6px 0 4px; }
.authgate__sub { color: var(--muted); font-size: 14px; margin: 0 0 4px; }
.authgate__err { color: var(--red-2); font-family: var(--mono); font-size: 12.5px; line-height: 1.5; margin: 14px 0 0; }
.authgate__btn { width: 100%; justify-content: center; margin-top: 22px; }
.authgate__btn[disabled] { cursor: progress; }
.authgate__loading { display: flex; align-items: center; gap: 10px; color: var(--muted); font-family: var(--mono); font-size: 13px; margin: 6px 0 0; }
.authgate__loading[hidden] { display: none; }

/* spinner (sign-in / session loading) */
.spinner { display: none; flex: none; width: 15px; height: 15px; border: 2px solid rgba(244,241,234,.22); border-top-color: var(--paper); border-radius: 50%; animation: dtjspin .7s linear infinite; }
.spinner--lg { display: inline-block; width: 18px; height: 18px; }
.is-busy .spinner { display: inline-block; }
@keyframes dtjspin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .spinner { animation-duration: 1.6s; } }

/* keep the admin behind the gate until authenticated */
body[data-page="admin"]:not(.is-authed) main { display: none; }
.admin__barright { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
body[data-page="admin"]:not(.is-authed) #authSignOut { display: none; }

/* waiver + payment page */
.cb { max-width: 760px; margin: 0 auto; }
.cb__summary { border: 1px solid var(--line-2); background: var(--ink-2); padding: 22px 24px; display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-bottom: 36px; }
@media (max-width:640px){ .cb__summary { grid-template-columns: 1fr 1fr; } }
.cb__summary .k { display:block; font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 5px; }
.cb__summary .v { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 1.15rem; }
.cb__step { font-family: var(--mono); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--red-2); margin: 40px 0 14px; }
.waiverbox { max-height: 260px; overflow-y: auto; border: 1px solid var(--line); background: var(--ink-2); padding: 22px 24px; font-size: 14px; color: var(--paper-dim); line-height: 1.6; }
.waiverbox h4 { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 1.05rem; color: var(--paper); margin: 16px 0 6px; }
.waiverbox h4:first-child { margin-top: 0; }
.check { display: flex; gap: 12px; align-items: flex-start; margin-top: 16px; font-size: 14.5px; color: var(--paper-dim); cursor: pointer; }
.check input { margin-top: 3px; width: 18px; height: 18px; accent-color: var(--red); flex: none; }
.cb__pay { margin-top: 30px; opacity: .45; pointer-events: none; transition: opacity .3s; }
.cb__pay.is-ready { opacity: 1; pointer-events: auto; }
.cb__pay .btn { width: 100%; justify-content: center; }
.cb__paynote { font-family: var(--mono); font-size: 11px; color: var(--muted); margin-top: 12px; text-align: center; }
