/* AeroRide — route landing pages */
/* Route & blog pages don't load the homepage reveal observer — keep content visible */
.reveal { opacity: 1 !important; transform: none !important; }

.rt-header { position: sticky; top: 0; z-index: 60; background: rgba(255,255,255,.9); backdrop-filter: saturate(160%) blur(12px); border-bottom: 1px solid var(--line); }
.rt-nav { display: flex; align-items: center; gap: 20px; height: 70px; }
.rt-nav .brand .wordmark { font-family: var(--font-display); font-weight: 800; font-size: 22px; letter-spacing: -.03em; }
.rt-nav-links { display: flex; align-items: center; gap: 22px; margin-left: 6px; }
.rt-nav-links a { font-weight: 600; font-size: 14.5px; color: var(--ink-2); }
.rt-nav-links a:hover { color: var(--red); }
.rt-nav .spacer { flex: 1; }
.rt-link { font-weight: 600; color: var(--ink-2); font-size: 15px; }
.rt-link:hover { color: var(--red); }
.rt-home { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: 14.5px; color: var(--ink); }
.rt-home svg { width: 16px; height: 16px; }
.rt-home:hover { color: var(--red); }

/* FAQ + quote two-column */
.rt-faq-grid { display: grid; grid-template-columns: 1.4fr .9fr; gap: clamp(28px,4vw,48px); align-items: start; }
.rt-book { position: sticky; top: 90px; background: #fff; border: 1px solid var(--line); border-radius: var(--r-xl); box-shadow: var(--shadow-md); padding: 24px; display: grid; gap: 12px; }
.rt-book h3 { font-size: 21px; }
.qfield { display: flex; flex-direction: column; gap: 5px; }
.qfield label { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); }
.qstatic { font-weight: 700; background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r-md); padding: 11px 13px; font-size: 15px; }
.qfield input, .qfield select { font-family: var(--font-body); font-weight: 700; font-size: 15px; border: 1.5px solid var(--line); border-radius: var(--r-md); padding: 11px 13px; background: var(--paper-2); outline: 0; width: 100%; -webkit-appearance: none; appearance: none; }
.qfield input:focus, .qfield select:focus { border-color: var(--red); background: #fff; }
.qrow { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.qprice { background: var(--red-tint); color: var(--ink); border-radius: var(--r-md); padding: 12px 14px; font-size: 13.5px; font-weight: 600; }
.qprice b { font-family: var(--font-display); font-weight: 800; font-size: 18px; }
.qprice span { color: var(--red); font-weight: 800; }
.q-dl { margin-top: 4px; padding-top: 14px; border-top: 1px solid var(--line); display: grid; gap: 10px; }
.q-dl > span { font-size: 13px; color: var(--ink-3); font-weight: 600; }
.q-dl .store-badges { gap: 10px; }
.q-dl .store-badge { padding: 9px 14px; }
.btn-block { width: 100%; }

.other-routes { display: flex; flex-wrap: wrap; gap: 9px; }
.other-routes a { border: 1px solid var(--line); border-radius: 999px; padding: 9px 16px; font-weight: 700; font-size: 14px; background: #fff; }
.other-routes a:hover { border-color: var(--red); color: var(--red); transform: translateY(-2px); }

@media (max-width: 860px) {
  .rt-hero-grid { grid-template-columns: 1fr; }
  .rt-photo { max-width: 460px; }
  .facts { grid-template-columns: 1fr 1fr; }
  .rt-nav-links, .rt-link { display: none; }
  .rt-faq-grid { grid-template-columns: 1fr; }
  .rt-book { position: static; }
}

.rt-hero { background: var(--paper-2); position: relative; overflow: hidden; }
.rt-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(55% 50% at 92% 6%, rgba(255,197,30,.16), transparent 60%), radial-gradient(50% 60% at 4% 100%, rgba(255,68,56,.08), transparent 60%); pointer-events: none; }
.rt-hero-grid { position: relative; display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(30px,4vw,56px); align-items: center; padding-block: clamp(36px,6vw,72px); }
.breadcrumb { font-family: var(--font-mono); font-size: 12px; color: var(--ink-3); margin-bottom: 16px; }
.breadcrumb a { color: var(--ink-3); }
.breadcrumb a:hover { color: var(--red); }
.rt-hero h1 { font-size: clamp(32px,5vw,56px); font-weight: 800; margin-top: 14px; }
.rt-photo { aspect-ratio: 4/4.4; border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--line); }
.rt-photo image-slot { width: 100%; height: 100%; display: block; }

.facts { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin: 28px 0 6px; }
.fact { background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); padding: 15px 16px; }
.fact .k { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); }
.fact .v { font-family: var(--font-display); font-weight: 800; font-size: 22px; margin-top: 5px; }
.fact .v.red { color: var(--red); }
.rt-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 18px; }

.rt-faq { border-top: 1px solid var(--line); padding: 16px 0; }
.rt-faq summary { cursor: pointer; font-family: var(--font-display); font-weight: 700; font-size: 18px; list-style: none; position: relative; padding-right: 30px; }
.rt-faq summary::-webkit-details-marker { display: none; }
.rt-faq summary::after { content: "+"; position: absolute; right: 4px; top: -2px; font-size: 24px; color: var(--red); font-weight: 400; }
.rt-faq[open] summary::after { content: "\2013"; }
.rt-faq p { color: var(--ink-2); margin-top: 12px; font-size: 16px; }

.other-routes { display: flex; flex-wrap: wrap; gap: 9px; }
.other-routes a { border: 1px solid var(--line); border-radius: 999px; padding: 9px 16px; font-weight: 700; font-size: 14px; background: #fff; }
.other-routes a:hover { border-color: var(--red); color: var(--red); transform: translateY(-2px); }

@media (max-width: 860px) {
  .rt-hero-grid { grid-template-columns: 1fr; }
  .rt-photo { max-width: 460px; }
  .facts { grid-template-columns: 1fr 1fr; }
  .rt-link { display: none; }
}

/* Itinerary + full-width FAQ */
.rt-faqfull { max-width: 840px; margin-inline: auto; }
.rt-highlights { display: grid; gap: 14px; }
.rt-highlights .vcard { padding: 20px 22px; }
.itin { margin-top: 34px; }
.itin h3 { font-size: 23px; margin-bottom: 4px; }
.itin .itin-sub { color: var(--ink-3); font-size: 14.5px; margin-bottom: 16px; }
.itin-list { list-style: none; margin: 0; padding: 0; }
.itin-list li { position: relative; padding: 0 0 22px 30px; border-left: 2px solid var(--line); }
.itin-list li:last-child { border-left-color: transparent; padding-bottom: 0; }
.itin-list li::before { content: ""; position: absolute; left: -7px; top: 2px; width: 12px; height: 12px; border-radius: 50%; background: var(--red); border: 3px solid #fff; box-shadow: 0 0 0 1px var(--line); }
.itin-when { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--red); font-weight: 700; }
.itin-list p { margin: 4px 0 0; color: var(--ink-2); font-size: 15.5px; }
