:root{
  --rl-navy:#041E42;
  --rl-navy-deep:#021430;
  --rl-navy-mid:#0B2D5B;
  --rl-gold:#B8926A;
  --rl-gold-light:#D4B896;
  --rl-gold-deep:#8C6D4F;
  --rl-cream:#FAF8F5;
  --rl-paper:#F3EDE2;
  --rl-ink:#1A2332;
  --rl-polo-red:#C41E3A;
  --heading-font:"Cormorant Garamond","Georgia",serif;
  --body-font:"Jost","Helvetica Neue","Arial",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:#000}
body{
  font-family:var(--body-font);color:var(--rl-ink);
  font-size:15px;line-height:1.6;background:var(--rl-cream);
  -webkit-font-smoothing:antialiased;
}

/* ═════════════════════════════════════════════════════════════
   PAGE SCROLLER — 4 full sections (page 1 hero, 2-4 text)
   ═════════════════════════════════════════════════════════════ */
.page{
  min-height:100vh;
  padding:clamp(40px,8vh,96px) clamp(24px,5vw,80px);
  position:relative;
}
.page + .page{border-top:1px solid rgba(4,30,66,.08)}

/* ─────────────────────────────────────────────────────────────
   PAGE 1 — HERO WITH ROTATING IMAGERY + LIQUID GLASS
   ───────────────────────────────────────────────────────────── */
.hero{
  min-height:100vh;
  padding:0;
  position:relative;
  overflow:hidden;
  color:#fff;
  display:flex;
  flex-direction:column;
}

/* Background rotating images */
.hero-bg{
  position:absolute;inset:0;z-index:0;background:#041E42;
}
.hero-bg .slide{
  position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:1;
  background-size:cover;
  background-position:center;
  background-color:#041E42;
  opacity:0;
  transition:opacity 2.2s ease-in-out;
  will-change:opacity;
}
.hero-bg .slide.is-active{opacity:1 !important}

/* Vignette + gradient overlays — kept light so the photo reads through */
.hero-bg::after{
  content:"";position:absolute;inset:0;z-index:2;
  background:
    radial-gradient(ellipse at 50% 55%, rgba(4,30,66,.0), rgba(2,20,48,.22) 75%, rgba(2,20,48,.45) 100%),
    linear-gradient(180deg, rgba(2,20,48,.38) 0%, rgba(2,20,48,.0) 20%, rgba(2,20,48,.0) 72%, rgba(2,20,48,.55) 100%);
  pointer-events:none;
}

/* Film grain for editorial warmth — subtle */
.hero-bg::before{
  content:"";position:absolute;inset:0;z-index:3;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.08  0 0 0 0 0.12  0 0 0 0 0.26  0 0 0 0.08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.18;mix-blend-mode:overlay;pointer-events:none;
}

.hero > *:not(.hero-bg){position:relative;z-index:1}

/* ── Top chrome ── */
.hero-top{
  display:flex;justify-content:space-between;align-items:center;
  padding:28px clamp(28px,5vw,64px);
  gap:24px;
}
.chapter{
  display:flex;align-items:center;gap:12px;
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.7);font-weight:500;
}
.chapter .dot{
  width:7px;height:7px;border-radius:50%;background:var(--rl-gold);
  box-shadow:0 0 0 3px rgba(184,146,106,.22);
}
.chapter strong{color:#fff;font-weight:600;letter-spacing:.24em}

.live{
  text-align:right;display:flex;flex-direction:column;gap:4px;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.6)
}
.live .main{color:#fff;letter-spacing:.18em}
.live .main strong{color:var(--rl-gold-light);font-family:var(--heading-font);font-weight:600;font-size:.95rem;letter-spacing:.04em;text-transform:none;margin-left:6px}
.live .meta{color:rgba(255,255,255,.55)}
.live .meta b{color:#fff;font-weight:600}

/* ── Center glass ── */
.hero-center{
  flex:1;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(40px,7vh,80px) clamp(28px,5vw,64px);
}

.glass{
  position:relative;
  width:min(560px, 72vw);
  padding:clamp(22px,3.5vh,36px) clamp(26px,4vw,44px);
  border-radius:22px;
  isolation:isolate;
  text-align:center;
  color:#fff;
  /* Liquid glass: frosted tinted surface + highlight + gold warm spill */
  background:
    radial-gradient(ellipse at 82% 72%, rgba(184,146,106,.32), transparent 60%),
    radial-gradient(ellipse at 18% 12%, rgba(255,255,255,.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.03) 50%, rgba(255,255,255,.05) 100%);
  backdrop-filter: blur(18px) saturate(130%);
  -webkit-backdrop-filter: blur(18px) saturate(130%);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.35),
    inset 0 -1px 0 rgba(255,255,255,.08),
    0 30px 80px rgba(2,20,48,.45),
    0 8px 24px rgba(0,0,0,.25);
}
/* Edge sheen — the telltale "liquid glass" highlight */
.glass::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:
    linear-gradient(115deg, rgba(255,255,255,.35) 0%, rgba(255,255,255,0) 18%, rgba(255,255,255,0) 82%, rgba(255,255,255,.25) 100%);
  mix-blend-mode:screen;opacity:.55;
}
/* Soft gold specular bottom-right */
.glass::after{
  content:"";position:absolute;inset:auto -18% -22% auto;width:60%;height:70%;border-radius:50%;
  background:radial-gradient(circle, rgba(212,184,150,.42), rgba(184,146,106,0) 65%);
  filter:blur(20px);pointer-events:none;z-index:-1;
}

.polo-crest{
  width:58px;height:58px;margin:0 auto 22px;
  display:grid;place-items:center;color:var(--rl-gold-light);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  backdrop-filter:blur(6px);
}
.polo-crest svg{width:34px;height:34px}

.glass .eyebrow{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--rl-gold-light);font-weight:600;margin-bottom:18px;
}
.brand-name{
  font-family:var(--heading-font);font-weight:500;
  font-size:clamp(2.4rem, 5.2vw, 3.8rem);
  line-height:1;letter-spacing:.005em;
  color:#fff;margin-top:4px;
  text-shadow:0 2px 30px rgba(2,20,48,.35);
}
.brand-name em{
  font-style:italic;font-weight:400;color:var(--rl-gold-light);
}
.divider{
  width:60px;height:1px;background:linear-gradient(90deg,transparent,rgba(212,184,150,.8),transparent);
  margin:16px auto 14px;
}
.authors{
  font-family:var(--heading-font);font-style:italic;font-weight:400;
  font-size:clamp(.95rem,1.4vw,1.15rem);
  color:rgba(255,255,255,.92);letter-spacing:.01em;
}
.authors .amp{color:var(--rl-gold-light);font-style:normal;padding:0 6px}
.course{
  margin-top:6px;
  font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.68);font-weight:500;
}
.course b{color:#fff;font-weight:600}

/* ── Bottom chrome ── */
.hero-bottom{
  display:flex;justify-content:space-between;align-items:flex-end;gap:32px;
  padding:28px clamp(28px,5vw,64px) 36px;
}
.city-tabs{
  display:flex;gap:clamp(14px,3vw,36px);align-items:center;
  font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(255,255,255,.55);font-weight:500;
}
.city-tabs button{
  appearance:none;border:0;background:transparent;font:inherit;color:inherit;
  padding:8px 0;cursor:pointer;position:relative;letter-spacing:inherit;
}
.city-tabs button.is-active{color:#fff}
.city-tabs button.is-active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--rl-gold-light);
}
.city-tabs button:hover{color:rgba(255,255,255,.85)}

.scroll-cue{
  display:flex;align-items:center;gap:10px;
  font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(255,255,255,.5);font-weight:500;
}
.scroll-cue .bar{
  width:1px;height:28px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.6),transparent);
  animation:cueFlow 2.4s ease-in-out infinite;
}
@keyframes cueFlow{
  0%,100%{transform:scaleY(.4);opacity:.3}
  50%{transform:scaleY(1);opacity:1}
}

/* ─────────────────────────────────────────────────────────────
   PAGES 2–4 — EDITORIAL TEXT
   ───────────────────────────────────────────────────────────── */
.page.text{
  background:var(--rl-cream);
  color:var(--rl-ink);
}
.page.text.alt{background:var(--rl-paper)}
.page.text.navy{
  background:
    radial-gradient(ellipse at 20% 0%, rgba(22,61,110,.5), transparent 55%),
    radial-gradient(ellipse at 80% 100%, rgba(184,146,106,.08), transparent 55%),
    var(--rl-navy-deep);
  color:#fff;
}
.page.text.navy .text-body p,
.page.text.navy .text-body li{color:rgba(255,255,255,.78)}
.page.text.navy .text-head h2{color:#fff}
.page.text.navy .text-head .eyebrow-dark{color:var(--rl-gold)}
.page.text.navy .pullquote{color:var(--rl-gold-light);border-color:rgba(184,146,106,.3)}
.page.text.navy .text-meta{color:rgba(255,255,255,.45);border-color:rgba(184,146,106,.22)}

.text-wrap{
  max-width:1140px;margin:0 auto;
  display:grid;grid-template-columns:260px 1fr;gap:clamp(40px,6vw,88px);
}
.text-meta{
  border-top:1px solid rgba(4,30,66,.12);
  padding-top:18px;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:#7A8A9A;font-weight:500;
  display:flex;flex-direction:column;gap:10px;
  position:sticky;top:40px;align-self:start;
}
.text-meta .num{
  font-family:var(--heading-font);font-size:3rem;font-weight:500;font-style:italic;
  color:var(--rl-gold-deep);letter-spacing:0;line-height:1;
}
.page.text.navy .text-meta .num{color:var(--rl-gold-light)}

.text-head{margin-bottom:36px}
.text-head .eyebrow-dark{
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--rl-gold-deep);font-weight:600;margin-bottom:14px;
}
.text-head h2{
  font-family:var(--heading-font);font-weight:500;
  font-size:clamp(2.2rem,4.5vw,3.6rem);line-height:1.08;letter-spacing:-.01em;
  color:var(--rl-ink);max-width:22ch;
}
.text-head h2 em{font-style:italic;color:var(--rl-gold-deep)}

.text-body{
  columns:2;column-gap:44px;column-rule:1px solid rgba(4,30,66,.08);
  font-size:1rem;line-height:1.75;
}
.text-body p{margin:0 0 1em;color:#2A3340;break-inside:avoid-column}
.text-body p:first-of-type::first-letter{
  font-family:var(--heading-font);font-size:3.4em;font-weight:500;
  float:left;line-height:.9;padding:6px 10px 0 0;color:var(--rl-gold-deep);
}
.page.text.navy .text-body p:first-of-type::first-letter{color:var(--rl-gold-light)}
.page.text.navy .text-body p{color:rgba(255,255,255,.82)}

.pullquote{
  break-inside:avoid-column;
  font-family:var(--heading-font);font-style:italic;font-weight:500;
  font-size:1.55rem;line-height:1.3;color:var(--rl-gold-deep);
  padding:12px 0 12px 18px;border-left:2px solid var(--rl-gold);
  margin:1.2em 0;
}

.text-body.single{columns:1;max-width:68ch}

.text-body ul{margin:0 0 1em 1.1em;padding:0;list-style:none}
.text-body ul li{
  position:relative;padding-left:22px;margin-bottom:.55em;
}
.text-body ul li::before{
  content:"—";position:absolute;left:0;color:var(--rl-gold);font-weight:600;
}

.section-foot{
  max-width:1140px;margin:48px auto 0;
  display:flex;justify-content:space-between;align-items:center;
  padding-top:20px;border-top:1px solid rgba(4,30,66,.1);
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#7A8A9A;
}
.page.text.navy .section-foot{border-color:rgba(184,146,106,.22);color:rgba(255,255,255,.5)}
.section-foot .mark{color:var(--rl-gold-deep);font-weight:600;letter-spacing:.28em}
.page.text.navy .section-foot .mark{color:var(--rl-gold-light)}

/* ─────────────────────────────────────────────────────────────
   SIDE NAV DOTS
   ───────────────────────────────────────────────────────────── */
.page-rail{
  position:fixed;right:22px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:12px;z-index:20;
  padding:14px 10px;border-radius:999px;
  background:rgba(2,20,48,.28);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1);
}
.page-rail a{
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.28);
  display:block;transition:all .25s ease;
}
.page-rail a:hover{background:rgba(255,255,255,.7)}
.page-rail a.is-active{background:var(--rl-gold-light);transform:scale(1.5)}

@media(max-width:820px){
  .text-wrap{grid-template-columns:1fr;gap:24px}
  .text-meta{position:static;top:auto}
  .text-body{columns:1}
  .hero-top,.hero-bottom{padding-left:20px;padding-right:20px}
  .city-tabs{gap:12px;overflow-x:auto;white-space:nowrap}
  .glass{padding:36px 26px}
  .page-rail{right:10px}
}

/* ─────────────────────────────────────────────────────────────
   LANDING NAV — fixed, theme-aware (dark over hero/navy,
   light-paper over cream/paper). data-theme is driven by
   IntersectionObserver in landing.js.
   ───────────────────────────────────────────────────────────── */
.landing-nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;justify-content:space-between;align-items:center;
  gap:24px;
  padding:16px clamp(24px,5vw,64px);
  font-family:var(--body-font);
  color:rgba(255,255,255,.92);
  background:rgba(2,20,48,.22);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:background .4s ease, color .4s ease, border-color .4s ease;
}
.landing-nav__brand{
  font-family:var(--heading-font);
  font-weight:500;font-size:1.15rem;letter-spacing:.01em;
  color:inherit;text-decoration:none;
  white-space:nowrap;
}
.landing-nav__brand em{
  font-style:italic;font-weight:400;color:var(--rl-gold-light);
}
.landing-nav__links{
  display:flex;align-items:center;
  gap:clamp(14px,2.4vw,30px);
  font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;
  font-weight:500;
}
.landing-nav__links a{
  color:inherit;text-decoration:none;
  opacity:.72;transition:opacity .2s ease;
  padding:6px 0;
}
.landing-nav__links a:hover{opacity:1}
.landing-nav__links .landing-nav__cta{
  padding:9px 16px;
  border:1px solid currentColor;
  border-radius:2px;
  opacity:.9;
  letter-spacing:.22em;
}
.landing-nav__links .landing-nav__cta:hover{
  opacity:1;
  background:rgba(255,255,255,.12);
}

/* Theme variants — triggered as user scrolls. */
.landing-nav[data-theme="cream"],
.landing-nav[data-theme="paper"]{
  color:var(--rl-ink);
  background:rgba(250,248,245,.78);
  border-bottom-color:rgba(4,30,66,.08);
}
.landing-nav[data-theme="cream"] .landing-nav__brand em,
.landing-nav[data-theme="paper"] .landing-nav__brand em{
  color:var(--rl-gold-deep);
}
.landing-nav[data-theme="cream"] .landing-nav__links .landing-nav__cta:hover,
.landing-nav[data-theme="paper"] .landing-nav__links .landing-nav__cta:hover{
  background:rgba(4,30,66,.06);
}

/* ─────────────────────────────────────────────────────────────
   CTA SYSTEM — three variants share the .landing-cta base:
     • .landing-cta--glass  → inside the hero liquid-glass card
     • .landing-cta--inline → at the end of each text-section body
   ───────────────────────────────────────────────────────────── */
.landing-cta{
  display:inline-block;
  padding:12px 24px;
  font-family:var(--heading-font);
  font-style:italic;
  font-size:1.02rem;
  letter-spacing:.02em;
  text-decoration:none;
  border-radius:2px;
  transition:all .25s ease;
  white-space:nowrap;
}

/* Hero-glass variant: warm-gold outline on translucent surface */
.landing-cta--glass{
  margin-top:18px;
  color:var(--rl-gold-light);
  border:1px solid rgba(212,184,150,.55);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.landing-cta--glass:hover{
  color:#fff;
  border-color:var(--rl-gold-light);
  background:rgba(184,146,106,.28);
  transform:translateY(-1px);
  box-shadow:0 10px 28px rgba(2,20,48,.35);
}

/* Inline variant: right-aligned at the end of each text-section body */
.landing-cta-row{
  display:flex;justify-content:flex-end;
  margin-top:28px;padding-top:18px;
  border-top:1px dashed rgba(4,30,66,.08);
}
.page.text.navy .landing-cta-row{border-top-color:rgba(184,146,106,.22)}
.landing-cta--inline{
  color:var(--rl-gold-deep);
  border:1px solid var(--rl-gold);
  background:transparent;
}
.landing-cta--inline:hover{
  color:#fff;
  background:var(--rl-gold);
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(184,146,106,.28);
}
.page.text.navy .landing-cta--inline{
  color:var(--rl-gold-light);
  border-color:rgba(212,184,150,.55);
}
.page.text.navy .landing-cta--inline:hover{
  color:var(--rl-navy-deep);
  background:var(--rl-gold-light);
}

/* Give page-rail a small top offset so it doesn't crash into the nav. */
.page-rail{top:calc(50% + 20px)}

/* Anchor jumps should clear the fixed nav. */
.page{scroll-margin-top:72px}

@media(max-width:820px){
  .landing-nav{padding:12px 20px}
  .landing-nav__links{gap:12px;font-size:.62rem;letter-spacing:.2em}
  /* Hide section anchors on narrow viewports; keep brand + Dashboard CTA. */
  .landing-nav__links a:not(.landing-nav__cta){display:none}
  .landing-cta-row{justify-content:stretch}
  .landing-cta--inline{display:block;text-align:center}
}
