/* ============================================================
   RESET & BASE
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;}
h1,h2,h3,h4{line-height:1.05;}

/* ============================================================
   DESIGN TOKENS
============================================================ */
:root{
  --ink:#111827;
  --paper:#F8FAFC;
  --paper-deep:#FCFCFD;
  --contour:#4B5563;
  --contour-light:#6B7280;
  --forest:#3445FB;
  --forest-mid:#5B6CFF;
  --forest-deep:#0C082B;
  --sunrise:#CBEA1C;
  --sunrise-deep:#C4DF22;
  --gold:#FFB703;
  --white:#FFFFFF;
  --border:#DDE4EE;
  --border-input:#D8DEE8;
  --border-input-hover:#AEBBD3;
  --border-card:#E7ECF5;
  --bg-card:#FCFCFD;
  --success:#22C55E;
  --error:#EF4444;

  --font-display:'Big Shoulders Display',sans-serif;
  --font-mono:'Space Mono',monospace;
  --font-body:'Plus Jakarta Sans',sans-serif;

  --container:1180px;
  --radius-sm:4px;
  --radius-md:8px;
  --radius-form:14px;
}

/* ============================================================
   UTILITIES
============================================================ */
.container{max-width:var(--container);margin:0 auto;padding:0 1.5rem;}
.section{padding:6rem 0;position:relative;}
.section--tight{padding:4.5rem 0;}
.section--dark{background:var(--forest-deep);color:var(--paper);}
.section--forest{background:var(--forest-deep);color:var(--paper);}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sunrise);font-weight:700;margin-bottom:1rem;
}
.eyebrow::before{content:'';width:18px;height:2px;background:var(--sunrise);display:inline-block;}
.section-title{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(2.1rem,4.6vw,3.4rem);
  letter-spacing:-0.01em;
  text-transform:uppercase;
  margin-bottom:1.1rem;
}
.section-lead{
  max-width:640px;
  font-size:1.05rem;
  color:var(--ink);
  opacity:.85;
}
.section--dark .section-lead{color:var(--paper);opacity:.8;}
.section-head{margin-bottom:3rem;}
.mono-tag{
  font-family:var(--font-mono);
  font-size:.78rem;
  letter-spacing:.08em;
}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;}

/* buttons — corner notch nods to a torn ticket stub */
.btn{
  font-family:var(--font-body);
  font-weight:700;
  font-size:.95rem;
  padding:.95rem 1.9rem;
  display:inline-flex;align-items:center;gap:.6rem;
  border:2px solid transparent;
  transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease;
  white-space:nowrap;
}
.btn svg{width:16px;height:16px;}
.btn-primary{
  background:var(--sunrise);
  color:var(--forest-deep);
  clip-path:polygon(0 0,100% 0,100% 100%,14px 100%,0 calc(100% - 14px));
}
.btn-primary:hover{
  background:#D4F030;
  transform:translateY(-3px);
  box-shadow:0 10px 24px rgba(203, 234, 28, 0.3);
}
.btn-secondary{
  background:transparent;
  border-color:currentColor;
  color:var(--ink);
}
.section--dark .btn-secondary,.hero .btn-secondary{color:var(--paper);}
.btn-secondary:hover{background:rgba(0,0,0,.06);transform:translateY(-2px);}
.hero .btn-secondary:hover{background:rgba(255,255,255,.1);}
.btn-lg{padding:1.1rem 2.4rem;font-size:1.05rem;}

/* contour divider — the page's recurring signature line */
.contour-divider{width:100%;height:34px;line-height:0;overflow:hidden;color:var(--contour);}
.contour-divider svg{width:100%;height:100%;}
.contour-divider--flip{transform:scaleY(-1);}
.section--dark + .contour-divider,.contour-divider--on-dark{color:var(--contour-light);}

/* focus & motion */
:focus-visible{outline:2px solid var(--sunrise);outline-offset:3px;}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}
}

/* reveal-on-scroll with stagger */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(0.4, 0, 0.2, 1),transform .7s cubic-bezier(0.4, 0, 0.2, 1);}
.reveal.visible{opacity:1;transform:translateY(0);}
.hero-wordmark,.hero-subtitle,.hero-tagline,.hero-actions,.countdown{
  opacity:0;animation:fadeInUp .8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
.hero-wordmark{animation-delay:.2s;}
.hero-subtitle{animation-delay:.4s;}
.hero-tagline{animation-delay:.6s;}
.hero-stats{animation-delay:.7s;}
.hero-meta{animation-delay:.8s;}
.hero-actions{animation-delay:1s;}
.countdown{animation-delay:1.2s;}
.scroll-indicator{animation-delay:1.4s;}
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(30px);}
  to{opacity:1;transform:translateY(0);}
}

/* ============================================================
   ICON SPRITE (hidden — referenced via <use>)
============================================================ */
.sprite{position:absolute;width:0;height:0;overflow:hidden;}

/* ============================================================
   NAVBAR - Apple-style blur & transparency
============================================================ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,0);
  backdrop-filter:blur(0px);
  -webkit-backdrop-filter:blur(0px);
  transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.navbar.scrolled{
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 4px 24px rgba(27,43,34,.08);
}
/* Navbar solid on non-index pages */
body:not(.page-index) .navbar{
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 4px 24px rgba(27,43,34,.08);
}
body:not(.page-index) .navbar .brand-text strong,
body:not(.page-index) .navbar .brand-text span,
body:not(.page-index) .navbar .nav-link,
body:not(.page-index) .navbar .nav-toggle{
  color:var(--ink);
}
body:not(.page-index) .navbar .brand-mark{
  color:var(--forest);
}
.navbar .brand-text span,
.navbar .nav-link{
  color:rgba(255,255,255,.95);
  transition:color 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.navbar.scrolled .brand-text strong,
.navbar.scrolled .brand-text span,
.navbar.scrolled .nav-link,
.navbar.scrolled .nav-toggle{
  color:var(--ink);
}
.navbar .brand-mark{
  color:rgba(203, 234, 28, 0.95);
  transition:color 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.navbar.scrolled .brand-mark{
  color:var(--forest);
}
.navbar::after{
  content:'';position:absolute;left:0;right:0;bottom:-14px;height:14px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 14' preserveAspectRatio='none'%3E%3Cpath d='M0,7 Q25,1 50,7 T100,7 T150,7 T200,7' fill='none' stroke='%238A7355' stroke-width='1.4' opacity='.45'/%3E%3C/svg%3E");
  background-size:200px 14px;background-repeat:repeat-x;
}
.navbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.5rem;max-width:var(--container);margin:0 auto;
}
.brand{display:flex;align-items:center;gap:.6rem;}
.brand-mark{width:34px;height:34px;color:var(--forest);flex-shrink:0;}
.brand-mark .dot{fill:var(--sunrise);}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-text strong{font-family:var(--font-display);font-size:1.35rem;font-weight:800;letter-spacing:.01em;}
.brand-text span{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;color:var(--contour);text-transform:uppercase;margin-top:2px;}

.nav-links{display:flex;align-items:center;gap:2rem;}
.nav-link{font-size:.92rem;font-weight:600;position:relative;padding:.3rem 0;}
.nav-link::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--sunrise);transition:width .2s ease;}
.nav-link:hover::after{width:100%;}
.nav-cta{display:flex;align-items:center;gap:1rem;}
.nav-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;color:rgba(255,255,255,.95);transition:color 0.4s cubic-bezier(0.4, 0, 0.2, 1);}
.nav-toggle svg{width:24px;height:24px;}
.nav-toggle .icon-close{display:none;}
.nav-toggle.active .icon-menu{display:none;}
.nav-toggle.active .icon-close{display:block;}

.mobile-menu{
  display:none;position:fixed;top:64px;left:0;right:0;bottom:0;
  background:var(--white);z-index:99;padding:2rem 1.5rem;
  transform:translateY(-12px);opacity:0;pointer-events:none;
  transition:transform .25s ease,opacity .25s ease;
  overflow-y:auto;
  box-shadow:0 -4px 24px rgba(0,0,0,.1);
}
.mobile-menu.active{transform:translateY(0);opacity:1;pointer-events:auto;}
.mobile-menu .nav-link{display:block;font-size:1.25rem;padding:.9rem 0;border-bottom:1px solid var(--paper-deep);}
.mobile-menu .btn{margin-top:1.5rem;width:100%;justify-content:center;}

/* ============================================================
   HERO
============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  padding:8rem 0 5rem;
  background:linear-gradient(180deg,var(--forest-deep) 0%,var(--forest-deep) 45%,var(--forest-mid) 70%,var(--sunrise-deep) 100%);
  color:var(--paper);
  overflow:hidden;
}
.hero-bg{
  content:'';position:absolute;inset:0;
  background-image:url('../images/hero/hero-bg.jpg');
  background-size:cover;background-position:center;
  opacity:.15;pointer-events:none;z-index:0;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 50%, rgba(203, 234, 28, 0.03) 0%, transparent 50%),
    radial-gradient(circle at 80% 30%, rgba(52, 69, 251, 0.05) 0%, transparent 50%);
  pointer-events:none;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' /%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  opacity:.4;pointer-events:none;
}
.hero-sun{
  position:absolute;left:50%;bottom:8%;width:340px;height:340px;
  background:radial-gradient(circle,var(--gold) 0%,var(--sunrise) 60%,rgba(255,90,54,0) 72%);
  border-radius:50%;transform:translateX(-50%);opacity:.55;filter:blur(2px);
}
.hero-contours{position:absolute;inset:0;color:rgba(244,241,230,.16);}
.hero-contours svg{width:100%;height:100%;}
.hero-inner{
  position:relative;z-index:2;
  max-width:800px;
}
.hero-content{position:relative;}
.hero-badges{position:absolute;width:100%;height:100%;pointer-events:none;}
.hero-badge{
  position:absolute;
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;
  text-transform:uppercase;font-weight:700;
  background:rgba(203, 234, 28, 0.15);
  border:1.5px solid var(--sunrise);
  color:var(--sunrise);
  padding:.4rem .8rem;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  opacity:.85;
  animation:float 3s ease-in-out infinite;
}
.hero-badge-1{top:8%;left:5%;transform:rotate(-8deg);animation-delay:0s;}
.hero-badge-2{top:15%;right:8%;transform:rotate(5deg);animation-delay:0.5s;}
.hero-badge-3{top:28%;left:12%;transform:rotate(-4deg);animation-delay:1s;}
@keyframes float{
  0%,100%{transform:translateY(0) rotate(-3deg);}
  50%{transform:translateY(-10px) rotate(-3deg);}
}
.hero-eyebrow{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--sunrise);font-weight:700;
  margin-bottom:.8rem;opacity:.9;
}
.hero-coord{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;
  color:var(--gold);opacity:.9;margin-bottom:1.6rem;
}
.hero-wordmark{
  font-family:var(--font-display);
  font-weight:900;
  font-size:clamp(4.5rem,16vw,11rem);
  line-height:.82;
  letter-spacing:-0.02em;
  color:var(--white);
  text-shadow:0 6px 40px rgba(0,0,0,.25);
}
.hero-subtitle{
  font-family:var(--font-mono);
  font-size:clamp(.85rem,1.6vw,1.05rem);
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--paper);
  margin-top:.6rem;
  margin-bottom:1.8rem;
}
.hero-tagline{
  font-size:clamp(1.05rem,2.2vw,1.4rem);
  max-width:560px;
  font-weight:500;
  margin-bottom:2.2rem;
  color:var(--white);
}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:.7rem 1.4rem;
  font-family:var(--font-mono);font-size:.82rem;letter-spacing:.04em;
  margin-bottom:2.6rem;color:var(--paper);
}
.hero-meta-item{display:flex;align-items:center;gap:.5rem;}
.hero-meta-item svg{width:15px;height:15px;color:var(--gold);}

.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:3.2rem;}

.countdown{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2rem;}
.countdown-box{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 4px 16px rgba(0,0,0,.15), 0 0 40px rgba(203, 234, 28, 0.1);
  transition:all 0.3s ease;
  padding:1rem 1.3rem;min-width:90px;text-align:center;
}
.countdown-box:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(0,0,0,.2), 0 0 60px rgba(203, 234, 28, 0.2);
}
.countdown-box .num{
  font-family:var(--font-mono);font-weight:700;font-size:2.4rem;
  color:var(--white);font-variant-numeric:tabular-nums;line-height:1;
  text-shadow:0 0 20px rgba(203, 234, 28, 0.4);
}
.countdown-box .lbl{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;
  color:rgba(255,255,255,.85);text-transform:uppercase;margin-top:.5rem;display:block;
}
.scroll-indicator{
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;
  text-transform:uppercase;color:rgba(255,255,255,.6);
  animation:bounce 2s ease-in-out infinite;
}
.scroll-indicator svg{
  width:20px;height:20px;
  animation:bounce 2s ease-in-out infinite;
}
@keyframes bounce{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(8px);}
}
.hero-stats{
  display:flex;gap:2rem;flex-wrap:wrap;margin-top:2rem;
}
.hero-stat{
  display:flex;flex-direction:column;
}
.hero-stat-num{
  font-family:var(--font-display);font-size:2.2rem;font-weight:800;
  color:var(--sunrise);line-height:1;
}
.hero-stat-label{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;
  color:rgba(255,255,255,.7);text-transform:uppercase;margin-top:.3rem;
}

/* ============================================================
   EVENT BANNER
============================================================ */
.event-banner-section{
  position:relative;padding:3rem 0;
  background:linear-gradient(135deg, #f8fafc 0%, #f1f5f9 50%, #f8fafc 100%);
  overflow:hidden;
}
.event-banner-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 50%, rgba(203,234,28,0.06) 0%, transparent 50%);
  pointer-events:none;
}
.event-banner-wrap{
  position:relative;overflow:hidden;height:500px;display:flex;
  align-items:center;justify-content:center;
}
.event-banner-wrap::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center, transparent 40%, rgba(248,250,252,0.8) 100%);
  pointer-events:none;z-index:1;
}
.event-banner-img{
  height:100%;width:auto;max-width:none;display:block;
  object-fit:cover;object-position:center 45%;
  transition:transform .4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.event-banner-wrap:hover .event-banner-img{
  transform:translateY(-12px) scale(1.02);
}
@media (max-width:1200px){
  .event-banner-wrap{height:450px;}
}
@media (max-width:768px){
  .event-banner-section{padding:2rem 0;}
  .event-banner-wrap{height:350px;}
}

/* ============================================================
   ABOUT
============================================================ */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:start;}
.about-body p{margin-bottom:1.1rem;font-size:1.05rem;}
.about-body p:last-child{margin-bottom:0;}

.section--light-gray{background:#F7F9FA;}
.section--subtle-texture{
  background:#FCFCFD;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(52, 69, 251, 0.015) 2px, rgba(52, 69, 251, 0.015) 4px);
}

.ledger{
  background:var(--bg-card);
  border:1px solid var(--border-card);
  border-left:4px solid var(--contour);
  padding:1.6rem 1.8rem;
}
.ledger-title{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--contour);margin-bottom:1.1rem;
}
.ledger-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:.65rem 0;border-top:1px dashed var(--paper-deep);
  font-family:var(--font-mono);
}
.ledger-row:first-of-type{border-top:none;}
.ledger-row .k{font-size:.82rem;color:var(--ink);opacity:.75;}
.ledger-row .v{font-size:1.15rem;font-weight:700;color:var(--forest);}

/* ============================================================
   CATEGORIES
============================================================ */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;}
.cat-card{
  background:var(--bg-card);border:1px solid var(--border-card);
  padding:3rem 2.5rem;display:flex;flex-direction:column;
  position:relative;transition:transform .2s ease,box-shadow .2s ease;
}
.cat-card:hover{transform:translateY(-6px);box-shadow:0 18px 36px rgba(52, 69, 251, 0.12);}
.cat-card--feat{border-color:var(--sunrise);}
.cat-badge{
  position:absolute;top:0;right:1.6rem;transform:translateY(-50%);
  background:var(--sunrise);color:var(--forest-deep);
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;
  padding:.35rem .7rem;text-transform:uppercase;font-weight:700;
}
.cat-badge--coming{
  background:#FF9500;color:var(--white);
}
.cat-badge--closed{
  background:#8A7355;color:var(--white);opacity:0.9;
}
.cat-distance{
  font-family:var(--font-display);font-weight:900;font-size:3.6rem;
  color:var(--forest);line-height:.9;
}
.cat-distance span{font-size:1.4rem;vertical-align:super;}
.cat-name{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--contour);margin:.6rem 0 1.2rem;
}
.cat-spark{width:100%;height:38px;color:var(--contour-light);margin-bottom:1.2rem;}
.cat-price{font-family:var(--font-mono);font-weight:700;font-size:1.5rem;color:var(--ink);margin-bottom:1.3rem;}
.cat-price small{font-size:.7rem;font-weight:400;opacity:.6;display:block;}
.cat-list{margin-bottom:1.6rem;flex-grow:1;}
.cat-list li{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;padding:.35rem 0;}
.cat-list svg{width:16px;height:16px;color:var(--forest);flex-shrink:0;margin-top:.2rem;}
.cat-card .btn{justify-content:center;width:100%;}

/* ============================================================
   BENEFITS
============================================================ */
.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.2rem 1.8rem;}
.benefit-item{display:flex;gap:1rem;align-items:flex-start;}
.benefit-icon{
  width:72px;height:72px;flex-shrink:0;
  border:2px solid rgba(244,241,230,.3);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;color:var(--gold);
  transition:transform .3s ease,background .3s ease,border-color .3s ease;
}
.benefit-icon svg{width:40px;height:40px;}
.benefit-item:hover .benefit-icon{
  transform:scale(1.1);
  background:rgba(255,182,39,.1);
  border-color:var(--gold);
}
.benefit-title{font-weight:700;margin-bottom:.3rem;font-size:1.02rem;}
.benefit-text{font-size:.88rem;opacity:.75;}

/* ============================================================
   ROUTE / ELEVATION CHART
============================================================ */
.route-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;}
.route-chart-wrap{
  background:var(--bg-card);border:1px solid var(--border-card);
  padding:1.8rem 1.8rem 1.2rem;
}
.route-chart-wrap svg{width:100%;height:auto;}
.chart-legend{display:flex;flex-wrap:wrap;gap:1.6rem;margin-top:.6rem;font-family:var(--font-mono);font-size:.76rem;}
.chart-legend span{display:flex;align-items:center;gap:.5rem;}
.chart-legend i{width:14px;height:3px;display:inline-block;}

.route-info{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.2rem;}
.route-info-item{
  border-top:2px solid var(--contour);padding-top:.9rem;
}
.route-info-item .lbl{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--contour);display:block;margin-bottom:.4rem;}
.route-info-item .val{font-weight:700;font-size:1rem;}

/* ============================================================
   RUNDOWN (timeline)
============================================================ */
.timeline{max-width:720px;margin:0 auto;position:relative;}
.tl-item{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:2rem;
  padding:1.5rem 2rem;
  margin-bottom:1rem;
  background:rgba(244,241,230,0.06);
  border:1px solid rgba(244,241,230,0.15);
  border-radius:12px;
  transition:all 0.3s ease;
  position:relative;
  overflow:hidden;
}
.tl-item::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  background:var(--gold);
  opacity:0.5;
  transition:opacity 0.3s ease;
}
.tl-item:hover{
  background:rgba(244,241,230,0.12);
  border-color:rgba(244,241,230,0.25);
  transform:translateX(4px);
}
.tl-item:hover::before{opacity:1;}
.tl-time{
  font-family:var(--font-mono);
  font-weight:800;
  font-size:1.1rem;
  color:var(--gold);
  text-align:left;
  padding-top:0.15rem;
  letter-spacing:-0.02em;
}
.tl-content{position:relative;}
.tl-content strong{
  display:block;
  font-family:var(--font-display);
  font-size:1.1rem;
  font-weight:700;
  margin-bottom:0.4rem;
  color:var(--paper);
  letter-spacing:-0.01em;
}
.tl-content span{font-size:0.9rem;opacity:0.75;line-height:1.5;color:var(--paper);}

/* ============================================================
   REGISTRATION TIERS (ledger rows)
============================================================ */
.tiers{border-top:1px solid var(--paper-deep);}
.tier-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:1.5rem;align-items:center;
  padding:1.6rem 0;border-bottom:1px solid var(--paper-deep);
}
.tier-num{font-family:var(--font-mono);font-size:.78rem;color:var(--contour);}
.tier-name{font-family:var(--font-display);font-weight:800;font-size:1.5rem;text-transform:uppercase;}
.tier-date{font-family:var(--font-mono);font-size:.85rem;opacity:.7;}
.tier-price{font-family:var(--font-mono);font-weight:700;font-size:1.3rem;text-align:right;color:var(--forest);}
.tier-save{
  display:inline-block;background:var(--gold);color:var(--forest-deep);
  font-family:var(--font-mono);font-size:.65rem;letter-spacing:.05em;
  padding:.2rem .55rem;margin-left:.6rem;text-transform:uppercase;font-weight:700;
}

/* ============================================================
   FAQ
============================================================ */
.faq-list{max-width:760px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--paper-deep);}
.faq-item summary{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.4rem 0;font-weight:700;font-size:1.04rem;cursor:pointer;list-style:none;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-plus{
  flex-shrink:0;width:26px;height:26px;border:1.5px solid var(--contour);
  display:flex;align-items:center;justify-content:center;position:relative;
  transition:transform .2s ease,background .2s ease;
}
.faq-plus::before,.faq-plus::after{content:'';position:absolute;background:var(--contour);}
.faq-plus::before{width:11px;height:1.5px;}
.faq-plus::after{width:1.5px;height:11px;}
.faq-item[open] .faq-plus{background:var(--sunrise);border-color:var(--sunrise);}
.faq-item[open] .faq-plus::before,.faq-item[open] .faq-plus::after{background:var(--white);}
.faq-item[open] .faq-plus::after{transform:scaleY(0);}
.faq-item p{padding-bottom:1.4rem;max-width:640px;opacity:.8;font-size:.96rem;}

/* ============================================================
   CTA FINAL
============================================================ */
.cta-final{
  background:linear-gradient(120deg,var(--sunrise) 0%,var(--gold) 100%);
  color:var(--forest-deep);text-align:center;
  padding:5.5rem 0;
}
.cta-final .section-title{color:var(--forest-deep);}
.cta-final p{font-size:1.1rem;max-width:520px;margin:0 auto 2.2rem;font-weight:500;}
.cta-final .btn-primary{background:var(--forest-deep);color:var(--white);}
.cta-final .btn-primary:hover{background:var(--ink);}
.cta-final .contour-divider{color:rgba(21,36,26,.25);}

/* ============================================================
   GALLERY
============================================================ */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.2rem;
  margin-top:3rem;
}
.gallery-item{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius-md);
  aspect-ratio:4/3;
  background:var(--bg-card);
  border:1px solid var(--border-card);
  transition:transform .3s ease,box-shadow .3s ease;
}
.gallery-item--large{
  aspect-ratio:16/9;
}
.gallery-item:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 40px rgba(52, 69, 251, 0.15);
}
.gallery-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.gallery-caption{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:1rem 1.2rem;
  background:linear-gradient(to top,rgba(12, 8, 43, 0.92),rgba(12, 8, 43, 0.7),transparent);
  color:var(--white);
  font-family:var(--font-mono);
  font-size:.82rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:700;
  opacity:0;
  transition:opacity .3s ease;
}
.gallery-item:hover .gallery-caption{
  opacity:1;
}
@media (max-width:980px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:560px){
  .gallery-grid{grid-template-columns:1fr;}
  .gallery-item--large{aspect-ratio:4/3;}
}

/* ============================================================
   FOOTER
============================================================ */
.footer{
  background:var(--forest-deep);color:var(--paper);padding:4.5rem 0 0;
  position:relative;overflow:hidden;
}
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:200px;
  background-image:
    repeating-linear-gradient(90deg, transparent, transparent 49px, rgba(203, 234, 28, 0.03) 49px, rgba(203, 234, 28, 0.03) 50px),
    repeating-linear-gradient(0deg, transparent, transparent 49px, rgba(203, 234, 28, 0.03) 49px, rgba(203, 234, 28, 0.03) 50px);
  opacity:.15;pointer-events:none;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;position:relative;z-index:1;}
.footer-brand .brand-mark{color:var(--paper);}
.footer-brand .brand-text strong{color:var(--white);}
.footer-brand .brand-text span{color:var(--contour-light);}
.footer-blurb{margin-top:1rem;font-size:.92rem;opacity:.7;max-width:320px;}
.footer-social{display:flex;gap:.8rem;margin-top:1.4rem;}
.footer-social a{
  width:38px;height:38px;border:1px solid rgba(244,241,230,.25);
  display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease;
}
.footer-social a:hover{background:var(--sunrise);border-color:var(--sunrise);}
.footer-social svg{width:17px;height:17px;}
.footer-h{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;}
.footer-links li{margin-bottom:.8rem;font-size:.92rem;opacity:.85;}
.footer-links a:hover{opacity:.7;}
.footer-contact li{margin-bottom:.9rem;font-size:.92rem;opacity:.85;display:flex;gap:.6rem;}
.footer-contact svg{width:16px;height:16px;color:var(--gold);flex-shrink:0;margin-top:.15rem;}
.footer-bottom{
  border-top:1px solid rgba(244,241,230,.15);
  padding:1.6rem 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.8rem;
  font-family:var(--font-mono);font-size:.74rem;opacity:.6;
}

/* ============================================================
   LEAFLET MAP
============================================================ */
#map{height:400px;border-radius:var(--radius-md);border:1px solid var(--border-card);}
.leaflet-popup-content{font-family:var(--font-body);}

/* ============================================================
   FORMS (daftar, pembayaran, admin)
============================================================ */
.form-group{margin-bottom:1.25rem;}
.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.92rem;color:var(--ink);}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;padding:.75rem .9rem;height:52px;
  border:1px solid var(--border-input);border-radius:var(--radius-form);
  font-family:var(--font-body);font-size:.95rem;
  background:var(--white);color:var(--ink);
  transition:border-color .18s ease,box-shadow .18s ease;
}
.form-group textarea{height:auto;min-height:80px;}
.form-group input:hover,
.form-group select:hover,
.form-group textarea:hover{
  border-color:var(--border-input-hover);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;border-color:var(--forest);
  box-shadow:0 0 0 4px rgba(52, 69, 251, 0.15);
}
.form-group select{cursor:pointer;}

/* Error Messages */
.error-message{color:var(--sunrise-deep);font-size:.82rem;margin-top:.3rem;display:block;}

/* Loading state */
.loading{opacity:.6;pointer-events:none;}
.spinner{
  display:inline-block;width:20px;height:20px;
  border:3px solid var(--paper-deep);border-top:3px solid var(--sunrise);
  border-radius:50%;animation:spin 1s linear infinite;
}
@keyframes spin{0%{transform:rotate(0deg);}100%{transform:rotate(360deg);}}

/* Modal backdrop */
.modal-backdrop{position:fixed;inset:0;background:rgba(21,36,26,.5);z-index:200;}

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width:980px){
  .about-grid{grid-template-columns:1fr;}
  .cat-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto;}
  .benefit-grid{grid-template-columns:repeat(2,1fr);}
  .route-info{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem;}
  .footer-brand{grid-column:1/-1;}
}
@media (max-width:768px){
  .nav-links,.nav-cta .btn{display:none;}
  .nav-toggle{display:flex;}
  .mobile-menu{display:block;}
  .section{padding:4rem 0;}
  .hero{padding-top:7rem;}
  .hero-badges{display:none;}
  .hero-stats{gap:1.5rem;}
  .hero-stat-num{font-size:1.8rem;}
  .countdown{gap:.7rem;}
  .countdown-box{min-width:70px;padding:.8rem 1rem;}
  .countdown-box .num{font-size:1.8rem;}
  .tier-row{grid-template-columns:1fr;text-align:left;gap:.4rem;}
  .tier-price{text-align:left;}
  .benefit-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:2.2rem;}
}
@media (max-width:560px){
  .hero-meta{flex-direction:column;gap:.6rem;}
  .countdown-box{min-width:64px;padding:.7rem .6rem;}
  .countdown-box .num{font-size:1.4rem;}
  .route-info{grid-template-columns:1fr 1fr;}
  .tl-item{grid-template-columns:60px 1fr;gap:.9rem;}
  .timeline::before{left:60px;}
  .tl-time{font-size:.78rem;}
}

/* ============================================================
   PRINT STYLES
============================================================ */
@media print{
  body{background:white;}
  .navbar,.nav-buttons,.filter-section,.footer-social{display:none;}
}

/* ============================================================
   SIZE GUIDE MODAL
============================================================ */
.size-guide-modal{
  position:fixed;inset:0;
  background:rgba(21,36,26,.75);
  display:none;align-items:center;justify-content:center;
  z-index:9999;padding:1rem;
  animation:fadeIn .25s ease;
}
.size-guide-content{
  background:var(--bg-card);
  border-radius:var(--radius-md);
  max-width:800px;width:100%;
  max-height:90vh;overflow-y:auto;
  padding:2.5rem;position:relative;
  box-shadow:0 10px 40px rgba(27,43,34,.2);
  animation:slideUp .3s ease;
}
.size-guide-close{
  position:absolute;top:1rem;right:1rem;
  width:40px;height:40px;
  border-radius:50%;
  background:var(--paper-deep);
  color:var(--forest);
  font-size:1.8rem;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:all .18s ease;
  font-weight:400;
}
.size-guide-close:hover{
  background:var(--sunrise);
  color:var(--white);
  transform:rotate(90deg);
}
.size-guide-image{
  margin:1.5rem 0 2rem;
  border-radius:var(--radius-sm);
  overflow:hidden;
  border:1px solid var(--paper-deep);
}
.size-guide-image img{
  width:100%;height:auto;display:block;
}
.size-guide-placeholder{
  background:var(--paper);
  padding:3rem 2rem;text-align:center;
}
.size-guide-placeholder code{
  background:var(--white);
  padding:.3rem .6rem;
  border-radius:var(--radius-sm);
  font-family:var(--font-mono);
  font-size:.75rem;
  color:var(--forest);
}
.size-guide-table{margin:2rem 0;}
.size-guide-table table{
  width:100%;border-collapse:collapse;
  font-size:.92rem;
}
.size-guide-table thead{
  background:var(--forest-deep);
  color:var(--paper);
}
.size-guide-table th,
.size-guide-table td{
  padding:.85rem 1rem;text-align:left;
  border-bottom:1px solid var(--paper-deep);
}
.size-guide-table th{
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.size-guide-table tbody tr:hover{
  background:var(--paper);
}
.size-guide-table tbody tr:last-child td{
  border-bottom:none;
}
.size-guide-tips{
  background:var(--paper);
  padding:1.5rem;
  border-radius:var(--radius-sm);
  margin-top:2rem;
}
.size-guide-tips h3{
  font-family:var(--font-display);
  font-size:1.1rem;
  color:var(--forest);
  margin-bottom:.8rem;
}
.size-guide-tips ul{
  list-style:none;padding:0;
}
.size-guide-tips li{
  padding:.4rem 0 .4rem 1.5rem;
  position:relative;
  color:var(--ink);
  line-height:1.5;
}
.size-guide-tips li::before{
  content:'✓';
  position:absolute;left:0;
  color:var(--sunrise);
  font-weight:700;
}
@keyframes fadeIn{
  from{opacity:0;}
  to{opacity:1;}
}
@keyframes slideUp{
  from{transform:translateY(20px);opacity:0;}
  to{transform:translateY(0);opacity:1;}
}
@media (max-width:768px){
  .size-guide-content{
    padding:2rem 1.5rem;
    max-height:85vh;
  }
  .size-guide-table{
    font-size:.85rem;
    overflow-x:auto;
  }
  .size-guide-table th,
  .size-guide-table td{
    padding:.7rem .8rem;
  }
}

/* ============================================================
   HERO ENHANCEMENTS - BEYOND THE LIMIT BRANDING
============================================================ */
.hero-theme-typography{
  position:absolute;top:15%;right:-5%;
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(6rem,12vw,14rem);
  letter-spacing:-0.03em;text-transform:uppercase;
  color:rgba(203, 234, 28, 0.08);
  transform:rotate(-90deg);transform-origin:center;
  pointer-events:none;white-space:nowrap;
  line-height:1;z-index:1;
}
.hero-motion-lines{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1;
}
.motion-line{
  position:absolute;height:2px;width:100%;
  background:linear-gradient(90deg,transparent 0%,var(--sunrise) 50%,transparent 100%);
  opacity:0.15;
  animation:slideRight 8s ease-in-out infinite;
}
.motion-line-1{top:25%;animation-delay:0s;width:60%;}
.motion-line-2{top:45%;animation-delay:2s;width:80%;}
.motion-line-3{top:65%;animation-delay:4s;width:70%;}
@keyframes slideRight{
  0%{transform:translateX(-100%);}
  100%{transform:translateX(200%);}
}
.hero-runner-silhouette{
  position:absolute;bottom:10%;right:8%;
  width:clamp(120px,15vw,200px);height:clamp(120px,15vw,200px);
  color:rgba(255,255,255,0.12);
  pointer-events:none;z-index:1;
  animation:runnerPulse 3s ease-in-out infinite;
}
.hero-runner-silhouette svg{width:100%;height:100%;}
@keyframes runnerPulse{
  0%,100%{opacity:0.12;transform:scale(1);}
  50%{opacity:0.18;transform:scale(1.05);}
}

/* ============================================================
   BEYOND THE LIMIT STATEMENT SECTION
============================================================ */
.section--statement{
  background:linear-gradient(135deg,var(--forest-deep) 0%,#1a1f4d 50%,var(--forest-mid) 100%);
  color:var(--paper);padding:8rem 0;
  position:relative;overflow:hidden;
}
.section--statement::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 30% 40%, rgba(203, 234, 28, 0.08) 0%, transparent 60%),
    radial-gradient(circle at 70% 60%, rgba(52, 69, 251, 0.12) 0%, transparent 60%);
  pointer-events:none;
}
.statement-content{
  text-align:center;position:relative;z-index:2;
  max-width:1000px;margin:0 auto;
}
.statement-title{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(4rem,12vw,11rem);
  line-height:0.88;letter-spacing:-0.03em;
  text-transform:uppercase;margin-bottom:2rem;
}
.statement-line{
  display:block;
  background:linear-gradient(90deg,transparent 0%,var(--sunrise) 20%,var(--gold) 50%,var(--sunrise) 80%,transparent 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;background-size:200% auto;
  animation:statementShine 4s ease-in-out infinite;
}
@keyframes statementShine{
  0%,100%{background-position:0% 50%;}
  50%{background-position:100% 50%;}
}
.statement-subtitle{
  font-size:clamp(1.1rem,2.5vw,1.6rem);
  font-weight:500;max-width:700px;margin:0 auto;
  color:rgba(255,255,255,0.85);line-height:1.5;
}

/* ============================================================
   ABOUT SECTION ENHANCEMENTS
============================================================ */
.about-grid-enhanced{
  display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:start;
}
.about-stats-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2rem;
}
.stat-card{
  background:var(--bg-card);border:1px solid var(--border-card);
  padding:1.5rem 1.2rem;display:flex;flex-direction:column;
  align-items:center;text-align:center;
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.stat-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 28px rgba(52, 69, 251, 0.12);
  border-color:var(--forest);
}
.stat-card-icon{
  width:48px;height:48px;margin-bottom:1rem;
  color:var(--forest);
}
.stat-card-icon svg{width:100%;height:100%;}
.stat-card-content{display:flex;flex-direction:column;}
.stat-card-value{
  font-family:var(--font-display);font-weight:800;
  font-size:2rem;color:var(--forest);line-height:1;
}
.stat-card-label{
  font-family:var(--font-mono);font-size:.72rem;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--contour);margin-top:.4rem;
}

/* ============================================================
   PREMIUM BENEFITS LAYOUT
============================================================ */
.benefit-grid-premium{
  display:grid;grid-template-columns:repeat(3,1fr);gap:3rem 2.5rem;
}
.benefit-item-premium{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:2rem 1.5rem;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(244,241,230,.15);
  border-radius:var(--radius-md);
  transition:transform .3s ease,background .3s ease,border-color .3s ease;
}
.benefit-item-premium:hover{
  transform:translateY(-6px);
  background:rgba(255,255,255,.08);
  border-color:var(--gold);
}
.benefit-icon-premium{
  width:96px;height:96px;flex-shrink:0;
  border:2px solid var(--gold);
  border-radius:50%;margin-bottom:1.5rem;
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);
  transition:transform .3s ease,background .3s ease,box-shadow .3s ease;
}
.benefit-icon-premium svg{width:52px;height:52px;}
.benefit-item-premium:hover .benefit-icon-premium{
  transform:scale(1.1) rotate(5deg);
  background:rgba(255,182,39,.15);
  box-shadow:0 8px 24px rgba(255,182,39,.3);
}
.benefit-title-premium{
  font-family:var(--font-display);font-weight:700;
  font-size:1.3rem;text-transform:uppercase;
  margin-bottom:.6rem;color:var(--gold);
}

/* ============================================================
   ROUTE METRICS
============================================================ */
.route-metrics{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
  margin-bottom:3rem;
}
.route-metric-card{
  background:var(--bg-card);border:1px solid var(--border-card);
  border-left:4px solid var(--forest);
  padding:1.5rem 1.2rem;
  transition:transform .3s ease,box-shadow .3s ease;
}
.route-metric-card:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 20px rgba(52, 69, 251, 0.12);
}
.route-metric-label{
  font-family:var(--font-mono);font-size:.7rem;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--contour);margin-bottom:.8rem;
}
.route-metric-value{
  font-family:var(--font-display);font-weight:800;
  font-size:1.8rem;color:var(--forest);line-height:1.1;
  margin-bottom:.4rem;
}
.route-metric-detail{
  font-size:.85rem;color:var(--contour);opacity:.75;
}
.difficulty-stars{
  display:inline-flex;gap:.2rem;margin-bottom:.5rem;
}
.difficulty-stars svg{
  width:18px;height:18px;color:var(--gold);
}
.difficulty-text{
  display:block;font-family:var(--font-mono);
  font-size:.85rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--contour);
}

/* ============================================================
   ENHANCED TIMELINE
============================================================ */
.timeline-enhanced{
  max-width:750px;margin:0 auto;position:relative;
}
.tl-item-enhanced{
  display:grid;grid-template-columns:100px 1fr;gap:2rem;
  padding:0 0 2.5rem;position:relative;
}
.tl-time-marker{
  position:absolute;left:100px;top:.5rem;
  display:flex;flex-direction:column;align-items:center;
  height:100%;
}
.tl-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--gold);border:3px solid var(--forest-deep);
  box-shadow:0 0 0 4px rgba(203, 234, 28, 0.2);
  flex-shrink:0;z-index:2;
  transition:transform .3s ease,box-shadow .3s ease;
}
.tl-item-enhanced:hover .tl-dot{
  transform:scale(1.3);
  box-shadow:0 0 0 6px rgba(203, 234, 28, 0.3);
}
.tl-line{
  width:2px;flex-grow:1;
  background:linear-gradient(to bottom,var(--gold) 0%,rgba(203, 234, 28, 0.3) 100%);
  margin-top:.3rem;
}
.tl-item-enhanced:last-child .tl-line{display:none;}
.tl-item-enhanced .tl-time{
  font-family:var(--font-display);font-weight:800;
  font-size:1.8rem;color:var(--gold);text-align:right;
  padding-top:.3rem;line-height:1;
}
.tl-item-enhanced .tl-content{
  padding-left:2.5rem;padding-top:.1rem;
}
.tl-item-highlight{
  background:rgba(203, 234, 28, 0.08);
  border:1px solid rgba(203, 234, 28, 0.25);
  border-radius:var(--radius-md);
  padding:1.5rem 2rem 1.5rem 0;margin-left:-1rem;
}
.tl-item-highlight .tl-dot{
  background:var(--sunrise);
  box-shadow:0 0 0 6px rgba(203, 234, 28, 0.35),0 0 20px rgba(203, 234, 28, 0.5);
  transform:scale(1.2);
}

/* ============================================================
   MASONRY GALLERY
============================================================ */
.section--gallery{
  background:linear-gradient(180deg,var(--paper) 0%,#F7F9FA 100%);
  padding:6rem 0;
}
.gallery-masonry{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  grid-auto-rows:220px;
  gap:1.2rem;
  margin-top:3rem;
}
.gallery-item-masonry{
  position:relative;overflow:hidden;
  border-radius:var(--radius-md);
  background:var(--bg-card);
  border:1px solid var(--border-card);
  transition:transform .4s ease,box-shadow .4s ease;
  cursor:pointer;
}
.gallery-item-masonry:hover{
  transform:translateY(-8px) scale(1.02);
  box-shadow:0 20px 40px rgba(52, 69, 251, 0.18);
  z-index:10;
}
.gallery-item--large{
  grid-row:span 2;
}
.gallery-item--wide{
  grid-column:span 2;
}
.gallery-item-masonry img{
  width:100%;height:100%;object-fit:cover;
  display:block;transition:transform .4s ease;
}
.gallery-item-masonry:hover img{
  transform:scale(1.08);
}
.gallery-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(12, 8, 43, 0.95) 0%,rgba(12, 8, 43, 0.6) 40%,transparent 70%);
  display:flex;align-items:flex-end;
  padding:1.5rem;
  opacity:0;
  transition:opacity .4s ease;
}
.gallery-item-masonry:hover .gallery-overlay{
  opacity:1;
}
.gallery-caption-masonry{
  font-family:var(--font-mono);font-size:.82rem;
  letter-spacing:.08em;text-transform:uppercase;
  font-weight:700;color:var(--white);
  line-height:1.4;
}

/* ============================================================
   RESPONSIVE UPDATES FOR NEW ELEMENTS
============================================================ */
@media (max-width:980px){
  .about-grid-enhanced{grid-template-columns:1fr;}
  .about-stats-cards{grid-template-columns:repeat(3,1fr);}
  .benefit-grid-premium{grid-template-columns:repeat(2,1fr);}
  .route-metrics{grid-template-columns:repeat(2,1fr);}
  .gallery-masonry{
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    grid-auto-rows:200px;
  }
  .gallery-item--wide{grid-column:span 1;}
  .statement-title{font-size:clamp(3rem,10vw,8rem);}
}
@media (max-width:768px){
  .hero-theme-typography{display:none;}
  .hero-runner-silhouette{width:100px;height:100px;bottom:15%;right:5%;}
  .section--statement{padding:5rem 0;}
  .statement-title{font-size:clamp(2.5rem,9vw,6rem);}
  .about-stats-cards{grid-template-columns:1fr;gap:1rem;}
  .benefit-grid-premium{grid-template-columns:1fr;}
  .route-metrics{grid-template-columns:1fr;}
  .tl-item-enhanced{grid-template-columns:80px 1fr;gap:1.5rem;}
  .tl-time-marker{left:80px;}
  .tl-item-enhanced .tl-time{font-size:1.4rem;}
  .gallery-masonry{
    grid-template-columns:1fr;
    grid-auto-rows:240px;
  }
  .gallery-item--large{grid-row:span 1;}
}
@media (max-width:560px){
  .hero-motion-lines{display:none;}
  .statement-title{font-size:clamp(2rem,8vw,4.5rem);}
  .statement-subtitle{font-size:1rem;}
  .tl-item-enhanced{grid-template-columns:60px 1fr;gap:1rem;}
  .tl-time-marker{left:60px;}
  .tl-item-enhanced .tl-time{font-size:1.1rem;}
  .tl-item-enhanced .tl-content{padding-left:1.5rem;}
}

