
:root{
  --black:#020202;
  --charcoal:#090909;
  --gold:#b8902e;
  --gold2:#d4ad42;
  --white:#f5f2ea;
  --muted:#c8c2b5;
  --line:rgba(255,255,255,.18);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  background:var(--black);
  color:var(--white);
  line-height:1.5;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.site-header{
  height:64px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 38px;
  background:#030303;
  position:sticky;
  top:0;
  z-index:20;
  border-bottom:1px solid rgba(255,255,255,.06);
}

.brand{
  font-weight:900;
  font-style:italic;
  font-size:26px;
  letter-spacing:-1px;
}
.brand span{color:var(--gold)}

.nav{
  display:flex;
  gap:31px;
  font-size:12px;
  text-transform:uppercase;
  font-weight:800;
}
.nav a:first-child{color:var(--gold);border-bottom:2px solid var(--gold);padding-bottom:14px}

.header-cta,.button,button{
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#fff;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:.3px;
  border:0;
  padding:14px 28px;
  font-size:13px;
  cursor:pointer;
}

.hero{
  position:relative;
  min-height:575px;
  background:
    linear-gradient(90deg, rgba(0,0,0,.98) 0%, rgba(0,0,0,.78) 32%, rgba(0,0,0,.15) 63%, rgba(0,0,0,.75) 100%),
    url("assets/cycling-hero.jpg") center center/cover no-repeat;
  overflow:hidden;
}

.hero-content{
  position:relative;
  z-index:2;
  min-height:575px;
  display:grid;
  grid-template-columns:minmax(320px, 42%) 1fr;
  align-items:center;
  padding:52px 8vw;
}

.hero-copy{max-width:520px}
.eyebrow{
  margin:0 0 8px;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:.4px;
  font-size:13px;
}
.gold-text{color:var(--gold)}

.hero h1{
  margin:0;
  text-transform:uppercase;
  font-size:clamp(58px, 8vw, 108px);
  line-height:.85;
  letter-spacing:-4px;
  font-style:italic;
  font-weight:1000;
}
.hero h1 span{
  display:block;
  color:var(--gold);
}
.hero h2{
  margin:22px 0 8px;
  color:var(--gold2);
  max-width:420px;
  font-size:clamp(24px, 3vw, 35px);
  line-height:1;
  text-transform:uppercase;
  font-style:italic;
}
.rule{width:86px;height:4px;background:var(--gold);margin:18px 0}
.name{
  margin:20px 0 0;
  text-transform:uppercase;
  font-weight:1000;
  font-style:italic;
  font-size:32px;
}
.credentials{
  margin:0 0 22px;
  text-transform:uppercase;
  font-size:15px;
  font-weight:800;
}

.hero-quote{
  justify-self:end;
  max-width:430px;
  margin-top:95px;
  font-size:18px;
  font-style:italic;
  color:#fff;
}
.quote-mark{
  color:var(--gold);
  font-size:76px;
  line-height:.45;
  font-weight:bold;
}
.hero-quote span{
  display:block;
  margin-top:22px;
  color:var(--gold2);
  font-family:cursive;
  font-size:26px;
}

.metrics{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  background:#080808;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.metric{
  min-height:118px;
  display:grid;
  place-items:center;
  text-align:center;
  padding:18px 24px;
  border-right:1px solid var(--line);
}
.metric:last-child{border-right:0}
.metric-link{
  transition:background .2s ease, color .2s ease;
}
.metric-link:hover,
.metric-link:focus-visible{
  background:rgba(184,144,46,.14);
}
.metric-link:focus-visible{
  outline:2px solid var(--gold2);
  outline-offset:-2px;
}
.icon{font-size:32px;color:var(--gold);line-height:1}
.metric strong{
  display:block;
  font-size:21px;
  text-transform:uppercase;
}
.metric span{
  display:block;
  text-transform:uppercase;
  font-size:13px;
}

.section{padding:68px 8vw}
.light{
  color:#101010;
  background:radial-gradient(circle at 50% 0%, #fff 0%, #f3f0e8 45%, #e9e5db 100%);
}
.dark{
  background:#060606;
  color:#fff;
}

.section-title.centered{text-align:center}
.section-title h2{
  margin:0;
  text-transform:uppercase;
  font-size:34px;
  line-height:1.05;
}
.section-title p{margin:8px auto;max-width:780px}

.achievements{
  border-top:1px solid rgba(255,255,255,.08);
}
.achievement-list{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  max-width:1180px;
  margin:34px auto 0;
}
.achievement-item{
  min-height:112px;
  display:flex;
  align-items:flex-end;
  padding:18px;
  border:1px solid rgba(212,173,66,.35);
  background:linear-gradient(145deg, rgba(255,255,255,.06), rgba(255,255,255,.015));
  color:#f4efe2;
  font-size:14px;
  font-weight:900;
  line-height:1.25;
  text-transform:uppercase;
}

.book-showcase{
  display:grid;
  grid-template-columns:220px 1fr 1px 220px 1fr;
  align-items:center;
  gap:32px;
  max-width:1180px;
  margin:34px auto 0;
}
.book-cover{
  width:220px;
  height:330px;
  object-fit:cover;
  box-shadow:0 20px 30px rgba(0,0,0,.25);
}
.book-copy h3{
  margin:0 0 12px;
  font-size:30px;
  line-height:.98;
  text-transform:uppercase;
}
.book-copy p{font-size:15px}
.divider{height:280px;background:rgba(0,0,0,.2)}
.button.outline{
  display:inline-block;
  border:1px solid var(--gold);
  color:var(--gold);
  background:transparent;
  margin-top:12px;
}

.video-framework{
  display:grid;
  grid-template-columns:1.15fr .95fr;
  gap:46px;
}
.video-block{
  display:grid;
  grid-template-columns:.55fr 1fr;
  gap:32px;
  align-items:center;
}
.video-block h2,.framework h2,.split h2{
  text-transform:uppercase;
  font-size:32px;
  line-height:1;
  margin:0;
}
.video-frame{
  aspect-ratio:16/9;
  background:#111;
  border:1px solid rgba(255,255,255,.25);
  box-shadow:0 20px 40px rgba(0,0,0,.4);
}
.video-frame iframe{
  width:100%;
  height:100%;
  border:0;
}
.media-links{
  display:grid;
  gap:10px;
  margin-top:20px;
}
.media-links a{
  color:var(--gold2);
  font-size:13px;
  font-weight:900;
  letter-spacing:.3px;
  text-transform:uppercase;
}
.framework .steps{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
  margin-top:22px;
}
.steps span{
  border:1px solid rgba(212,173,66,.45);
  color:var(--gold2);
  padding:12px 8px;
  text-align:center;
  text-transform:uppercase;
  font-size:11px;
  font-weight:800;
}

.about-banner{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:260px;
  background:#060606;
}
.about-image{
  min-height:360px;
  position:relative;
  overflow:hidden;
}
.about-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,0) 55%, #060606 100%);
}
.about-image img{
  width:100%;
  height:100%;
  min-height:360px;
  object-fit:cover;
  object-position:center 28%;
}
.about-copy{
  padding:46px 8vw 46px 46px;
  align-self:center;
}
.about-copy h2{
  text-transform:uppercase;
  font-style:italic;
  font-size:38px;
  line-height:1;
  margin:0 0 16px;
}
.about-copy h2 span{color:var(--gold)}
.about-copy p{max-width:620px;color:#eee}

.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
}
.split h2{font-size:38px}

.booking{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:48px;
  align-items:start;
  border-top:1px solid rgba(255,255,255,.08);
}
.booking-copy h2{
  margin:0;
  text-transform:uppercase;
  font-size:38px;
  line-height:1;
  max-width:560px;
}
.booking-copy p{
  max-width:560px;
  color:#ddd;
}
.contact-details{
  display:grid;
  gap:10px;
  margin-top:24px;
}
.contact-details a{
  color:var(--gold2);
  font-size:18px;
  font-weight:800;
}
.booking-form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  padding:28px;
  background:#0b0b0b;
  border:1px solid rgba(255,255,255,.14);
}
.booking-form label{
  display:grid;
  gap:8px;
  color:#eee;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}
.booking-form .full-field,
.booking-form button{
  grid-column:1 / -1;
}
.booking-form input,
.booking-form textarea{
  min-width:0;
  width:100%;
  padding:14px;
  background:#050505;
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
  font:inherit;
}
.booking-form textarea{
  resize:vertical;
}
.hidden-field{
  display:none;
}

.footer{
  position:relative;
  display:grid;
  grid-template-columns:1.5fr .8fr .8fr 1.5fr;
  gap:38px;
  padding:36px 8vw 62px;
  background:#050505;
  border-top:1px solid rgba(255,255,255,.1);
}
.footer h4{
  margin:0 0 10px;
  text-transform:uppercase;
}
.footer a{
  display:block;
  color:#ddd;
  font-size:13px;
  margin:7px 0;
}
.footer .subscribe-link{
  display:inline-block;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#fff;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:.3px;
  border:0;
  padding:14px 18px;
  font-size:12px;
  cursor:pointer;
}
.footer p{color:#bbb;font-size:13px}
.footer p a{display:inline;color:#ddd;font-size:13px}
.footer-brand{display:block;margin-bottom:6px}
.socials{
  display:flex;
  flex-wrap:wrap;
  gap:10px 16px;
  margin-top:14px;
}
.footer .socials a{
  color:var(--gold2);
  font-weight:800;
  letter-spacing:.4px;
  text-transform:uppercase;
}
form{
  display:flex;
  gap:0;
}
input{
  min-width:0;
  width:100%;
  padding:14px;
  background:#0b0b0b;
  color:#fff;
  border:1px solid rgba(255,255,255,.2);
}
form button{padding:14px 18px;font-size:12px}
.copyright{
  position:absolute;
  left:8vw;
  bottom:18px;
}
.thank-you{
  min-height:calc(100vh - 272px);
  display:grid;
  align-content:center;
  justify-items:start;
}
.thank-you h1{
  margin:0;
  text-transform:uppercase;
  font-size:clamp(46px, 7vw, 84px);
  line-height:.95;
  font-style:italic;
}
.thank-you p:not(.eyebrow){
  max-width:560px;
  color:#ddd;
  font-size:18px;
}

@media (max-width: 980px){
  .site-header{height:auto;gap:18px;flex-wrap:wrap;padding:20px}
  .nav{order:3;width:100%;justify-content:center;flex-wrap:wrap;gap:18px}
  .hero-content{grid-template-columns:1fr;padding:42px 28px}
  .hero-quote{justify-self:start;margin-top:20px}
  .metrics{grid-template-columns:1fr 1fr}
  .book-showcase{grid-template-columns:1fr;justify-items:center;text-align:center}
  .divider{display:none}
  .video-framework,.video-block,.about-banner,.split,.booking,.footer{grid-template-columns:1fr}
  .booking-form{grid-template-columns:1fr}
  .about-image::after{background:linear-gradient(180deg, rgba(0,0,0,0) 65%, #060606 100%)}
  .framework .steps{grid-template-columns:1fr 1fr 1fr}
  .achievement-list{grid-template-columns:1fr 1fr}
}
