:root{
  --pine:#1F4D3F;
  --cream:#FBF8F3;
  --magenta:#E8336D;
  --mint:#3FB87F;
  --sun:#FFD93D;
  --ink:#2A2A2A;
  --line: rgba(31,77,63,0.12);
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  font-family:'Inter',sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
}

h1,h2,h3{
  font-family:'Fraunces',serif;
  color:var(--pine);
  letter-spacing:-0.01em;
}

.mono{
  font-family:'JetBrains Mono',monospace;
}

a{color:var(--magenta);}

.wrap{
  max-width:1100px;
  margin:0 auto;
  padding:0 24px;
}

/* NAV */
header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,248,243,0.85);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px;
  max-width:1100px; margin:0 auto;
}
.brand{display:flex; align-items:center; gap:10px;}
.brand img{width:36px; height:36px; border-radius:50%;}
.brand span{font-family:'Fraunces',serif; font-weight:700; font-size:1.3rem; color:var(--pine);}
nav ul{display:flex; gap:28px; list-style:none;}
nav a{color:var(--ink); text-decoration:none; font-weight:500; font-size:0.95rem;}
nav a:hover{color:var(--magenta);}

/* HERO */
.hero{
  padding:64px 0 40px;
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap:48px;
  align-items:center;
}
.hero h1{
  font-size:3.2rem;
  line-height:1.08;
  margin-bottom:22px;
}
.hero h1 em{
  font-style:italic;
  color:var(--magenta);
}
.hero p.lead{
  font-size:1.15rem;
  color:#4a4a4a;
  max-width:46ch;
  margin-bottom:32px;
}
.cta-row{display:flex; gap:14px; flex-wrap:wrap; align-items:center;}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 26px;
  border-radius:100px;
  font-weight:600;
  text-decoration:none;
  font-size:0.98rem;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  border:2px solid transparent;
}
.btn-primary{
  background:var(--magenta); color:#fff;
  box-shadow:0 4px 14px rgba(232,51,109,0.3);
}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 6px 18px rgba(232,51,109,0.4);}
.btn-ghost{
  background:transparent; color:var(--pine); border-color:var(--pine);
}
.btn-ghost:hover{background:var(--pine); color:#fff;}
.badge-soon{
  font-size:0.82rem; color:#888; font-style:italic;
}

/* COMING SOON BANNER */
.coming-soon-bar{
  background:var(--pine);
  color:#fff;
  text-align:center;
  padding:10px 16px;
  font-size:0.92rem;
  font-weight:500;
}
.coming-soon-bar strong{
  color:var(--sun);
}

/* PILL BADGE for hero */
.hero-badge{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--mint); color:#fff;
  border-radius:100px;
  padding:7px 16px;
  font-size:0.85rem;
  font-weight:600;
  font-family:'JetBrains Mono',monospace;
  margin-bottom:18px;
}

/* PHONE MOCK */
.phone-stage{
  position:relative;
  display:flex; justify-content:center;
}
.phone{
  width:260px;
  border-radius:32px;
  overflow:hidden;
  box-shadow: 0 30px 60px -20px rgba(31,77,63,0.35), 0 0 0 8px #1a1a1a, 0 0 0 9px #333;
  transform: rotate(3deg);
}
.phone img{display:block; width:100%;}
.float-pill{
  position:absolute;
  background:#fff;
  border-radius:14px;
  padding:10px 16px;
  box-shadow:0 10px 30px rgba(31,77,63,0.18);
  font-family:'JetBrains Mono',monospace;
  font-size:0.78rem;
  font-weight:600;
  color:var(--pine);
  border:1px solid var(--line);
}
.pill-1{ top:8%; left:-8%; transform:rotate(-6deg); }
.pill-2{ bottom:14%; right:-10%; transform:rotate(4deg); color:var(--magenta);}

/* RIDE STRIP - signature divider */
.ride-strip{
  margin:64px 0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.ride-card{
  border-radius:16px;
  padding:18px 20px;
  border:1px solid var(--line);
}
.ride-card .day{
  font-family:'Fraunces',serif; font-weight:600; font-size:0.95rem;
  color:var(--pine); margin-bottom:6px;
}
.ride-card .title{
  font-weight:700; font-size:1.05rem; margin-bottom:10px;
}
.ride-card .stats{
  display:flex; gap:18px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.78rem;
  color:#5a5a5a;
}
.ride-card .stats b{display:block; color:var(--ink); font-size:0.95rem; font-family:'Inter',sans-serif; font-weight:700;}
.ride-card.sun{ background:#FFF6CC; }
.ride-card.coral{ background:#FBDADC; }
.ride-card.mint{ background:#E1F5EB; }

/* SECTIONS */
section{padding:60px 0;}
.section-head{
  max-width:62ch;
  margin-bottom:44px;
}
.section-head .eyebrow{
  font-family:'JetBrains Mono',monospace;
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-size:0.78rem;
  color:var(--mint);
  font-weight:600;
  margin-bottom:10px;
  display:block;
}
.section-head h2{
  font-size:2.2rem;
  margin-bottom:14px;
}
.section-head p{color:#555; font-size:1.05rem;}

/* FEATURES GRID */
.features{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:36px;
  align-items:start;
}
.feature-shot{
  border-radius:20px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 16px 40px -16px rgba(31,77,63,0.25);
  margin-bottom:20px;
}
.feature-shot img{display:block; width:100%;}
.feature h3{font-size:1.2rem; margin-bottom:8px;}
.feature p{color:#555; font-size:0.96rem;}

/* MORE FEATURES (icon grid) */
.more-features{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.mf-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:22px;
}
.mf-item .mf-icon{
  width:40px; height:40px;
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem;
  margin-bottom:14px;
}
.mf-item.tone-sun .mf-icon{ background:#FFF6CC; }
.mf-item.tone-coral .mf-icon{ background:#FBDADC; }
.mf-item.tone-mint .mf-icon{ background:#E1F5EB; }
.mf-item h3{font-size:1.05rem; margin-bottom:6px;}
.mf-item p{color:#555; font-size:0.92rem;}
.coming-tag{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;
  font-weight:600;
  color:var(--magenta);
  text-transform:uppercase;
  letter-spacing:0.08em;
  margin-top:8px;
}

/* BAND */
.band{
  background:var(--pine);
  color:#fff;
  border-radius:28px;
  padding:56px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}
.band h2{color:#fff; font-size:2.1rem; margin-bottom:18px;}
.band p{color:#cfe3da; font-size:1.02rem; margin-bottom:0;}
.band .feature-shot{box-shadow:0 16px 50px -10px rgba(0,0,0,0.4); border:1px solid rgba(255,255,255,0.15);}
.band-list{list-style:none; margin-top:22px; display:flex; flex-direction:column; gap:14px;}
.band-list li{display:flex; gap:12px; align-items:flex-start; color:#e8f3ee; font-size:0.98rem;}
.band-list .dot{
  width:8px; height:8px; border-radius:50%; background:var(--sun);
  margin-top:8px; flex-shrink:0;
}

/* FOR CLUBS */
.clubs-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.club-item{
  padding:24px;
  border-radius:16px;
  background:#fff;
  border:1px solid var(--line);
}
.club-item .num{
  font-family:'JetBrains Mono',monospace;
  color:var(--magenta);
  font-weight:600;
  font-size:0.85rem;
  margin-bottom:10px;
  display:block;
}
.club-item h3{font-size:1.05rem; margin-bottom:6px;}
.club-item p{font-size:0.92rem; color:#555;}

/* FOOTER / CONTACT */
footer{
  border-top:1px solid var(--line);
  padding:40px 0;
  margin-top:40px;
}
.footer-grid{
  display:flex; justify-content:space-between; align-items:flex-start;
  flex-wrap:wrap; gap:32px;
}
.footer-brand{display:flex; align-items:center; gap:10px;}
.footer-brand img{width:32px; height:32px; border-radius:50%;}
.footer-brand span{font-family:'Fraunces',serif; font-weight:700; color:var(--pine);}
.footer-links{display:flex; gap:32px; flex-wrap:wrap;}
.footer-col h4{
  font-family:'JetBrains Mono',monospace;
  font-size:0.78rem; text-transform:uppercase; letter-spacing:0.1em;
  color:#888; margin-bottom:10px; font-weight:600;
}
.footer-col ul{list-style:none; display:flex; flex-direction:column; gap:8px;}
.footer-col a{color:var(--ink); text-decoration:none; font-size:0.95rem;}
.footer-col a:hover{color:var(--magenta);}
.copyright{
  margin-top:36px; padding-top:24px; border-top:1px solid var(--line);
  font-size:0.85rem; color:#888;
}

/* RESPONSIVE */
@media (max-width: 880px){
  .hero{grid-template-columns:1fr; gap:40px; padding-top:40px;}
  .hero h1{font-size:2.4rem;}
  .phone{width:220px;}
  .ride-strip{grid-template-columns:1fr;}
  .features{grid-template-columns:1fr;}
  .more-features{grid-template-columns:1fr;}
  .band{grid-template-columns:1fr; padding:32px; border-radius:20px;}
  .band .phone-stage{order:-1;}
  .clubs-grid{grid-template-columns:1fr 1fr;}
  nav ul{display:none;}
  .float-pill{display:none;}
}
@media (max-width: 520px){
  .clubs-grid{grid-template-columns:1fr;}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  .btn{transition:none;}
}