/* ============================================================
   LongHaulr — shared stylesheet
   Cream base · ink navy · royal blue (interaction) · gold (highlight)
   Type: Newsreader (editorial serif) + Hanken Grotesk (utility)
   ============================================================ */

:root{
  --cream:        #F6F0E6;
  --cream-deep:   #EFE6D6;
  --paper:        #FCF8F0;
  --ink:          #232C3D;
  --ink-soft:     #4A5468;
  --ink-faint:    rgba(35,44,61,.14);
  --royal:        #2B49C3;
  --royal-deep:   #1F379B;
  --gold:         #C08A3A;
  --gold-soft:    #D9B270;
  --gold-faint:   rgba(192,138,58,.16);

  --font-display: "Newsreader", "Times New Roman", serif;
  --font-body:    "Hanken Grotesk", "Helvetica Neue", sans-serif;

  --radius:       18px;
  --radius-sm:    10px;
  --shadow-card:  0 1px 2px rgba(35,44,61,.06), 0 12px 32px -12px rgba(35,44,61,.18);
  --shadow-lift:  0 2px 4px rgba(35,44,61,.08), 0 24px 48px -16px rgba(35,44,61,.28);
  --maxw:         1200px;
  --ease-lux:     cubic-bezier(.22,.8,.26,.99);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--gold-soft); color:var(--ink); }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 32px; }

/* ---------- type ---------- */
.display{
  font-family:var(--font-display);
  font-optical-sizing:auto;
  font-weight:400;
  letter-spacing:-.015em;
  line-height:1.04;
  text-wrap:balance;
}
.display em{ font-style:italic; color:var(--gold); }
.eyebrow{
  font-family:var(--font-body);
  font-size:12px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  display:flex; align-items:center; gap:12px;
}
.eyebrow::before{ content:""; width:28px; height:1px; background:var(--gold); flex:none; }
.lede{
  font-size:19px; line-height:1.65; color:var(--ink-soft);
  max-width:56ch; text-wrap:pretty;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-weight:600; font-size:15px;
  padding:14px 26px; border-radius:999px; border:1px solid transparent;
  cursor:pointer; transition:all .35s var(--ease-lux);
  white-space:nowrap;
}
.btn .arr{ transition:transform .35s var(--ease-lux); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-royal{ background:var(--royal); color:var(--paper); }
.btn-royal:hover{ background:var(--royal-deep); box-shadow:0 12px 28px -10px rgba(43,73,195,.5); }
.btn-ink{ background:var(--ink); color:var(--cream); }
.btn-ink:hover{ background:#161d2b; }
.btn-ghost{ background:transparent; color:var(--ink); border-color:rgba(35,44,61,.3); }
.btn-ghost:hover{ border-color:var(--ink); background:rgba(35,44,61,.04); }
.btn-gold{ background:var(--gold); color:#fff; }
.btn-gold:hover{ background:#A87527; }

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:color-mix(in oklab, var(--cream) 88%, transparent);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--ink-faint);
}
.nav-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 32px;
  display:flex; align-items:center; gap:36px; height:76px;
}
.brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.brand img{ width:42px; height:42px; border-radius:11px; }
.brand-name{
  font-family:var(--font-display); font-size:26px; font-weight:500;
  letter-spacing:-.02em; color:var(--ink);
}
.brand-name b{ font-weight:500; color:var(--gold); font-style:italic; }
.nav-links{ display:flex; gap:4px; list-style:none; }
.nav-links a{
  font-size:14.5px; font-weight:600; color:var(--ink-soft);
  padding:9px 14px; border-radius:999px;
  transition:all .25s var(--ease-lux);
}
.nav-links a:hover{ color:var(--ink); background:rgba(35,44,61,.06); }
.nav-links a[aria-current="page"]{ color:var(--royal); }

/* region switcher */
.region{
  display:flex; border:1px solid rgba(35,44,61,.22); border-radius:999px;
  padding:3px; gap:2px; background:var(--paper);
}
.region button{
  font-family:var(--font-body); font-size:13px; font-weight:700;
  border:0; background:transparent; color:var(--ink-soft);
  padding:6px 13px; border-radius:999px; cursor:pointer;
  transition:all .25s var(--ease-lux);
}
.region button[aria-pressed="true"]{ background:var(--ink); color:var(--cream); }

/* ---------- deal ticker ---------- */
.ticker{
  background:var(--ink); color:var(--cream);
  overflow:hidden; white-space:nowrap; height:42px;
  display:flex; align-items:center;
}
.ticker-track{ display:flex; gap:0; animation:ticker 46s linear infinite; }
.ticker:hover .ticker-track{ animation-play-state:paused; }
.ticker-item{
  display:inline-flex; align-items:center; gap:10px;
  font-size:13.5px; font-weight:600; letter-spacing:.02em;
  padding:0 26px; border-right:1px solid rgba(246,240,230,.16);
}
.ticker-item .tp{ color:var(--gold-soft); font-weight:700; }
.ticker-item .live{ width:6px; height:6px; border-radius:50%; background:var(--gold); }
@keyframes ticker{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .ticker-track{ animation:none; } }

/* ---------- deal cards (boarding-pass) ---------- */
.deal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:980px){ .deal-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .deal-grid{ grid-template-columns:1fr; } }

.deal{
  background:var(--paper); border:1px solid var(--ink-faint);
  border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-card);
  transition:transform .45s var(--ease-lux), box-shadow .45s var(--ease-lux);
  display:flex; flex-direction:column;
}
.deal:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lift); }
.deal-visual{
  height:170px; position:relative; overflow:hidden;
  display:flex; align-items:flex-end; padding:18px;
}
.deal-visual .code{
  font-family:var(--font-display); font-size:84px; font-weight:400;
  line-height:.8; letter-spacing:-.02em;
  color:rgba(252,248,240,.92); font-style:italic;
  position:relative; z-index:1;
}
.deal-visual .badge{
  position:absolute; top:14px; left:14px; z-index:1;
  font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  background:var(--paper); color:var(--ink); padding:6px 12px; border-radius:999px;
}
.deal-visual .badge.hot{ background:var(--gold); color:#fff; }
.deal-body{ padding:20px 22px 0; flex:1; }
.deal-route{
  display:flex; align-items:center; gap:10px;
  font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft);
}
.deal-route .dr-line{
  flex:1; height:1px;
  background-image:linear-gradient(90deg, var(--ink-soft) 40%, transparent 0);
  background-size:6px 1px; opacity:.5; position:relative;
}
.deal-route .dr-line::after{
  content:"✈"; position:absolute; right:-2px; top:50%;
  transform:translateY(-58%); font-size:11px; color:var(--gold); opacity:1;
}
.deal-dest{
  font-family:var(--font-display); font-size:30px; font-weight:500;
  letter-spacing:-.01em; line-height:1.15; margin-top:8px;
}
.deal-meta{ font-size:14px; color:var(--ink-soft); margin-top:6px; }
.deal-foot{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px 22px; margin-top:16px;
  border-top:1px dashed rgba(35,44,61,.22);
  position:relative;
}
.deal-foot::before,.deal-foot::after{
  content:""; position:absolute; top:-7px; width:14px; height:14px;
  border-radius:50%; background:var(--cream); border:1px solid var(--ink-faint);
}
.deal-foot::before{ left:-8px; }
.deal-foot::after{ right:-8px; }
.deal-price{ display:flex; flex-direction:column; }
.deal-price .was{ font-size:13px; color:var(--ink-soft); text-decoration:line-through; }
.deal-price .now{
  font-family:var(--font-display); font-size:30px; font-weight:500;
  color:var(--royal); line-height:1;
}
.deal-cta{
  font-size:14px; font-weight:700; color:var(--ink);
  display:inline-flex; align-items:center; gap:7px;
}
.deal-cta .arr{ transition:transform .35s var(--ease-lux); color:var(--gold); }
.deal:hover .deal-cta .arr{ transform:translateX(4px); }

/* destination gradient fills */
.g-tokyo   { background:linear-gradient(150deg,#2B3B6E 0%,#7A4E8C 55%,#D98A6A 100%); }
.g-bangkok { background:linear-gradient(150deg,#1F6E5E 0%,#C08A3A 100%); }
.g-cape    { background:linear-gradient(150deg,#27496D 0%,#3D7068 60%,#C9913F 100%); }
.g-sydney  { background:linear-gradient(150deg,#16324F 0%,#2B49C3 60%,#6FB3C8 100%); }
.g-rio     { background:linear-gradient(150deg,#14532D 0%,#2E8B57 55%,#E3B23C 100%); }
.g-bali    { background:linear-gradient(150deg,#234E52 0%,#3C8C7A 55%,#E0A95E 100%); }
.g-nyc     { background:linear-gradient(150deg,#1C2536 0%,#3D4F73 60%,#8C6A4E 100%); }
.g-delhi   { background:linear-gradient(150deg,#7A3B2E 0%,#C08A3A 100%); }
.g-buenos  { background:linear-gradient(150deg,#33415C 0%,#5C7AEA 60%,#C5A14E 100%); }
.g-nairobi { background:linear-gradient(150deg,#4F3A1E 0%,#A4631C 55%,#D9B270 100%); }
.g-seoul   { background:linear-gradient(150deg,#232C3D 0%,#4757A8 60%,#C77B8E 100%); }
.g-cairo   { background:linear-gradient(150deg,#594631 0%,#B98B45 100%); }
.g-vancouver{ background:linear-gradient(150deg,#1E3A3A 0%,#2F6F6F 55%,#9DBEBB 100%); }
.g-lima    { background:linear-gradient(150deg,#5B3A29 0%,#8C5E3C 55%,#D9A05B 100%); }
.g-auckland{ background:linear-gradient(150deg,#16324F 0%,#3E7C8C 60%,#A3C6C4 100%); }
.g-marrakech{ background:linear-gradient(150deg,#8C3B2E 0%,#C97B4A 60%,#E5B96E 100%); }
.g-rome    { background:linear-gradient(150deg,#3E4458 0%,#8A7253 60%,#D8C09A 100%); }
.g-lisbon  { background:linear-gradient(150deg,#2B5876 0%,#4E8DA6 55%,#E3C27E 100%); }
.g-athens  { background:linear-gradient(150deg,#1F3C88 0%,#4D7EA8 60%,#EAD7B7 100%); }
.g-reykjavik{ background:linear-gradient(150deg,#2E3A4E 0%,#5C7A99 55%,#BFD3DE 100%); }
.deal-visual::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(120% 90% at 80% 0%, rgba(252,248,240,.18), transparent 55%);
}

/* ---------- ad slots ---------- */
.ad{
  border:1px dashed rgba(35,44,61,.28); border-radius:var(--radius-sm);
  background:repeating-linear-gradient(-45deg, rgba(35,44,61,.025) 0 14px, transparent 14px 28px), var(--cream-deep);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  color:var(--ink-soft); text-align:center; padding:18px;
}
.ad .ad-tag{
  font-size:10px; font-weight:700; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold);
}
.ad .ad-size{ font-size:13px; font-weight:600; opacity:.7; }
.ad-leaderboard{ min-height:120px; }
.ad-mpu{ min-height:250px; width:300px; }

/* sponsored native card */
.deal.sponsored{ border:1px solid var(--gold-soft); background:linear-gradient(180deg, #FDF9F0, #FAF2E2); }
.deal.sponsored .sp-tag{
  font-size:10px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
}

/* ---------- newsletter band ---------- */
.news{
  background:var(--ink); color:var(--cream);
  border-radius:calc(var(--radius) + 6px);
  padding:64px 56px; position:relative; overflow:hidden;
}
.news::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 120% at 100% 0%, rgba(43,73,195,.35), transparent 60%),
    radial-gradient(50% 100% at 0% 100%, rgba(192,138,58,.22), transparent 55%);
}
.news > *{ position:relative; }
.news h2{ color:var(--cream); }
.news .display em{ color:var(--gold-soft); }
.news p{ color:rgba(246,240,230,.75); }
.news-form{ display:flex; gap:12px; margin-top:28px; max-width:520px; }
.news-form input{
  flex:1; font-family:var(--font-body); font-size:15px;
  padding:14px 22px; border-radius:999px; border:1px solid rgba(246,240,230,.28);
  background:rgba(246,240,230,.08); color:var(--cream); outline:none;
  transition:border-color .3s;
}
.news-form input::placeholder{ color:rgba(246,240,230,.5); }
.news-form input:focus{ border-color:var(--gold-soft); }
.news-fine{ font-size:12.5px; color:rgba(246,240,230,.45); margin-top:14px; }

/* ---------- footer ---------- */
.footer{
  background:var(--ink); color:rgba(246,240,230,.7);
  margin-top:96px; padding:64px 0 40px;
}
.footer .wrap{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
.footer h4{
  font-size:12px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold-soft); margin-bottom:16px;
}
.footer ul{ list-style:none; display:grid; gap:9px; font-size:14.5px; }
.footer a:hover{ color:var(--cream); }
.footer .brand-name{ color:var(--cream); }
.footer-note{ font-size:13px; max-width:34ch; margin-top:14px; line-height:1.6; }
.footer-base{
  max-width:var(--maxw); margin:48px auto 0; padding:24px 32px 0;
  border-top:1px solid rgba(246,240,230,.14);
  display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap;
  font-size:13px; color:rgba(246,240,230,.45);
}
@media (max-width:880px){ .footer .wrap{ grid-template-columns:1fr 1fr; } }

/* ---------- sections ---------- */
.section{ padding:88px 0; }
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:24px; margin-bottom:40px;
}
.section-head h2{ font-size:clamp(34px,4.2vw,52px); }
.see-all{
  font-size:14.5px; font-weight:700; color:var(--royal);
  display:inline-flex; align-items:center; gap:7px; white-space:nowrap;
  padding-bottom:6px;
}
.see-all:hover .arr{ transform:translateX(4px); }
.see-all .arr{ transition:transform .35s var(--ease-lux); }

/* ---------- scroll reveal ---------- */
@media (prefers-reduced-motion: no-preference){
  .rv{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease-lux), transform .9s var(--ease-lux); transition-delay:var(--d,0s); }
  .rv.in{ opacity:1; transform:none; }
}

/* ---------- continent hero ---------- */
.c-hero{ padding:84px 0 56px; position:relative; overflow:hidden; }
.c-hero .display{ font-size:clamp(56px,8.5vw,110px); }
.c-hero .lede{ margin-top:22px; }
.c-hero .big-code{
  position:absolute; right:-40px; top:-10px;
  font-family:var(--font-display); font-style:italic;
  font-size:clamp(180px,26vw,330px); line-height:1;
  color:transparent; -webkit-text-stroke:1px rgba(192,138,58,.35);
  pointer-events:none; user-select:none;
}
.crumb{ font-size:13px; font-weight:600; color:var(--ink-soft); margin-bottom:26px; display:flex; gap:8px; }
.crumb a:hover{ color:var(--royal); }
.crumb span{ color:var(--gold); }

/* featured deal banner */
.feature-deal{
  display:grid; grid-template-columns:1.1fr 1fr; border-radius:calc(var(--radius) + 6px);
  overflow:hidden; background:var(--paper); border:1px solid var(--ink-faint);
  box-shadow:var(--shadow-card); min-height:380px;
}
.feature-deal .fd-visual{ position:relative; display:flex; align-items:flex-end; padding:28px; min-height:280px; }
.feature-deal .fd-visual .code{
  font-family:var(--font-display); font-style:italic; font-size:120px;
  color:rgba(252,248,240,.92); line-height:.8;
}
.feature-deal .fd-body{ padding:44px 48px; display:flex; flex-direction:column; gap:14px; justify-content:center; }
.feature-deal .fd-price{ font-family:var(--font-display); font-size:54px; color:var(--royal); line-height:1; }
.feature-deal .fd-price .was{ font-family:var(--font-body); font-size:15px; color:var(--ink-soft); text-decoration:line-through; margin-left:12px; }
@media (max-width:880px){ .feature-deal{ grid-template-columns:1fr; } }

/* responsive nav */
@media (max-width:980px){
  .nav-links{ display:none; }
  .nav-inner{ gap:16px; }
}
@media (max-width:640px){
  .wrap{ padding:0 20px; }
  .section{ padding:64px 0; }
  .news{ padding:44px 28px; }
  .news-form{ flex-direction:column; }
}
