:root {
  --green: #174f3b;
  --green-2: #216449;
  --mint: #d9eadc;
  --sky: #dceff1;
  --cream: #f6f3e9;
  --paper: #fffdf7;
  --sun: #f3be49;
  --coral: #ed765b;
  --ink: #18372d;
  --muted: #65756e;
  --line: rgba(23, 79, 59, .14);
  --radius: 24px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: "DM Sans", sans-serif; color: var(--ink); background: var(--paper); line-height: 1.6; overflow-x: hidden; }
button, a { font: inherit; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; }
.container { width: min(1160px, calc(100% - 48px)); margin: 0 auto; }
.section { padding: 120px 0; }
.skip-link { position: fixed; left: 16px; top: -80px; z-index: 1000; background: white; padding: 12px 18px; border-radius: 10px; }
.skip-link:focus { top: 16px; }

.site-header { height: 82px; position: absolute; inset: 0 0 auto; z-index: 50; border-bottom: 1px solid rgba(23,79,59,.12); }
.nav-wrap { height: 100%; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 10px; font: 700 16px/1.05 "Manrope", sans-serif; }
.brand span:last-child { display: flex; flex-direction: column; }
.brand strong { color: var(--green-2); }
.brand-mark { width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; background: var(--green); color: white; }
.brand-mark svg { width: 28px; fill: none; stroke: white; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.main-nav { display: flex; align-items: center; gap: 32px; font-weight: 600; font-size: 14px; }
.main-nav > a:not(.nav-cta) { position: relative; }
.main-nav > a:not(.nav-cta)::after { content: ""; height: 2px; position: absolute; inset: auto 100% -6px 0; background: var(--green); transition: .25s; }
.main-nav > a:hover::after { right: 0; }
.nav-cta { background: var(--green); color: white; padding: 11px 17px; border-radius: 100px; }
.nav-cta span { margin-left: 8px; }
.menu-toggle { display: none; border: 0; background: none; width: 44px; height: 44px; padding: 10px; }
.menu-toggle span { display: block; height: 2px; background: var(--green); margin: 5px 0; }

.hero { min-height: 820px; height: 100vh; max-height: 980px; position: relative; display: flex; align-items: center; overflow: hidden; background: #dceff1; }
.hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(238,249,248,.98) 0%, rgba(238,249,248,.93) 29%, rgba(238,249,248,.48) 47%, rgba(238,249,248,0) 66%); }
.hero-art { position: absolute; inset: 0; background: url("assets/muro-cycling-hero.png?v=2") center/cover no-repeat; }
.hero-content { position: relative; z-index: 2; padding-top: 70px; }
.hero-copy { width: 540px; }
.eyebrow, .kicker { margin: 0 0 18px; text-transform: uppercase; letter-spacing: .16em; font: 700 12px/1 "Manrope", sans-serif; color: var(--green-2); }
.eyebrow { display: flex; align-items: center; gap: 9px; }
.eyebrow span { display: block; width: 26px; height: 2px; background: var(--coral); }
h1, h2, h3, p { margin-top: 0; }
h1, h2 { font-family: "Manrope", sans-serif; letter-spacing: -.055em; }
h1 { font-size: clamp(70px, 7vw, 108px); line-height: .84; margin-bottom: 28px; color: var(--green); }
h1 em, .final-cta h2 em { color: var(--coral); font-style: normal; }
.hero-lead { max-width: 440px; font-size: 20px; line-height: 1.45; margin-bottom: 30px; color: #345a4e; }
.event-pills { display: flex; align-items: stretch; width: max-content; border-block: 1px solid var(--line); padding: 14px 0; margin-bottom: 28px; }
.event-pills > div { display: flex; align-items: center; gap: 10px; padding-right: 22px; margin-right: 22px; border-right: 1px solid var(--line); font-weight: 700; font-size: 14px; line-height: 1.15; }
.event-pills > div:last-child { border: 0; margin: 0; padding: 0; }
.event-pills small { display: block; color: var(--muted); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 4px; }
.pill-icon { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; background: var(--sun); font-weight: 800; font-size: 12px; }
.hero-actions { display: flex; align-items: center; gap: 28px; }
.button { border: 0; border-radius: 100px; padding: 16px 22px; display: inline-flex; align-items: center; justify-content: center; gap: 18px; font-weight: 700; transition: transform .2s, background .2s; }
.button:hover { transform: translateY(-2px); }
.button-primary { color: white; background: var(--green); box-shadow: 0 10px 25px rgba(23,79,59,.18); }
.button-primary:hover { background: #0e3b2c; }
.button span { font-size: 18px; }
.text-link { font-size: 14px; font-weight: 700; border-bottom: 1px solid var(--green); }
.text-link span { margin-left: 8px; }
.hero-note { position: absolute; z-index: 3; right: 34px; bottom: 34px; background: rgba(255,253,247,.94); backdrop-filter: blur(10px); padding: 12px 18px; border-radius: 100px; font-size: 12px; font-weight: 700; box-shadow: 0 8px 30px rgba(24,55,45,.1); }
.hero-note span { color: var(--coral); margin-right: 7px; }

.split-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 110px; }
.section-heading h2, .why h2, .details h2, .organizers h2 { font-size: clamp(48px, 5vw, 72px); line-height: 1.02; margin: 0; }
.section-heading h2 span, .why h2 span { color: var(--coral); }
.intro-copy { padding-top: 18px; }
.intro-copy .lead { font-size: 24px; line-height: 1.5; color: var(--ink); }
.intro-copy > p:not(.lead) { color: var(--muted); font-size: 17px; }
blockquote { margin: 48px 0 0; padding: 24px 0 24px 28px; border-left: 4px solid var(--sun); font: 700 25px/1.4 "Manrope", sans-serif; color: var(--green); }

.activities { background: var(--green); color: white; }
.section-top { display: flex; justify-content: space-between; align-items: end; margin-bottom: 48px; }
.section-top h2 { font-size: clamp(52px, 6vw, 80px); line-height: .95; margin: 0; }
.section-top > p { max-width: 410px; margin: 0 0 8px; color: rgba(255,255,255,.7); }
.kicker.light { color: var(--sun); }
.activity-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.activity-card { min-height: 390px; position: relative; display: flex; flex-direction: column; padding: 25px; border-radius: 20px; background: #236249; overflow: hidden; }
.activity-card:nth-child(3) { background: #285b63; }
.activity-card:nth-child(4) { background: #335947; }
.activity-card.featured { background: var(--sun); color: var(--ink); transform: translateY(-8px); }
.card-number { position: absolute; right: 20px; top: 18px; font: 700 12px "Manrope"; opacity: .55; }
.line-icon { font-size: 42px; margin: 40px 0 40px; filter: saturate(.8); }
.activity-card h3 { font: 700 25px/1.18 "Manrope", sans-serif; letter-spacing: -.035em; }
.activity-card p { font-size: 14px; color: rgba(255,255,255,.7); }
.featured p { color: rgba(24,55,45,.75); }
.card-tag { margin-top: auto; width: max-content; border: 1px solid currentColor; border-radius: 100px; padding: 6px 10px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; opacity: .75; }

.activity-infographics { background: var(--cream); }
.edition-heading { display: grid; grid-template-columns: 1.15fr .85fr; align-items: end; gap: 100px; margin-bottom: 52px; }
.edition-heading h2 { margin: 0; font-size: clamp(48px, 5vw, 72px); line-height: 1.02; }
.edition-heading > p { margin-bottom: 7px; color: var(--muted); font-size: 17px; }
.infographic-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; align-items: start; }
.infographic-card { min-width: 0; overflow: hidden; border-radius: 22px; background: white; box-shadow: 0 16px 40px rgba(23,79,59,.06); }
.infographic-card figure { height: 410px; margin: 0; overflow: hidden; background: var(--mint); }
.infographic-card figure img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.infographic-card:hover figure img { transform: scale(1.025); }
.infographic-copy { position: relative; min-height: 290px; padding: 30px 28px; }
.infographic-copy .kicker { margin-bottom: 12px; }
.infographic-copy h3 { margin-bottom: 14px; font: 700 26px/1.15 "Manrope", sans-serif; letter-spacing: -.04em; }
.infographic-copy > p:not(.kicker) { color: var(--muted); font-size: 14px; }
.infographic-number { position: absolute; right: 24px; top: 27px; color: var(--coral); font: 800 11px "Manrope", sans-serif; }
.infographic-copy ul { display: flex; flex-wrap: wrap; gap: 6px; margin: 20px 0 0; padding: 0; list-style: none; }
.infographic-copy li { padding: 6px 9px; border-radius: 100px; background: var(--mint); color: var(--green); font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.featured-infographic { box-shadow: inset 0 -5px 0 var(--sun), 0 16px 40px rgba(23,79,59,.09); }

.route { background: var(--paper); }
.route-heading { display: grid; grid-template-columns: 1fr .9fr; gap: 120px; align-items: end; margin-bottom: 55px; }
.route-heading h2 { margin: 0; font-size: clamp(48px, 5vw, 72px); line-height: 1.02; }
.route-heading h2 span { color: var(--coral); }
.route-summary > p { margin-bottom: 27px; color: var(--muted); font-size: 17px; }
.route-loop { display: flex; align-items: center; gap: 11px; padding: 13px 16px; border-radius: 100px; background: var(--mint); color: var(--green); font-size: 12px; font-weight: 700; }
.route-loop span { color: var(--coral); }
.route-loop i { flex: 1; height: 1px; background: repeating-linear-gradient(90deg, var(--green) 0 4px, transparent 4px 8px); }
.route-animation { overflow: hidden; margin: 0; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 18px 45px rgba(23,79,59,.08); }
.route-animation img { display: block; width: 100%; height: auto; aspect-ratio: 3 / 2; object-fit: cover; background: var(--mint); }
.route-animation figcaption { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 15px 20px; color: var(--muted); font-size: 13px; }
.route-animation figcaption > span { display: flex; align-items: center; gap: 9px; }
.route-animation figcaption > span::before { content: ""; width: 10px; height: 10px; border-radius: 50%; background: var(--sun); box-shadow: 0 0 0 2px var(--green); }
.route-animation-toggle { flex: 0 0 auto; border: 1px solid var(--line); border-radius: 100px; padding: 8px 13px; background: var(--paper); color: var(--green); font: 700 11px/1 "Manrope", sans-serif; }
.route-animation-toggle:hover { border-color: var(--green); }
.route-street-details { margin-top: 14px; border: 1px solid var(--line); border-radius: 15px; background: rgba(255,255,255,.72); }
.route-street-details summary { position: relative; padding: 16px 52px 16px 20px; color: var(--green); cursor: pointer; list-style: none; font: 700 13px/1.3 "Manrope", sans-serif; }
.route-street-details summary::-webkit-details-marker { display: none; }
.route-street-details summary::after { content: "+"; position: absolute; right: 18px; top: 50%; transform: translateY(-50%); color: var(--coral); font-size: 20px; }
.route-street-details[open] summary::after { content: "−"; }
.route-street-details p { margin: 0; padding: 0 20px 18px; color: var(--muted); font-size: 13px; line-height: 1.75; }
.activity-stops { display: grid; grid-template-columns: .7fr 1.3fr; gap: 70px; align-items: center; margin-top: 48px; padding: 42px; border-radius: var(--radius); background: var(--sky); }
.stops-intro .kicker { margin-bottom: 12px; }
.stops-intro h3 { margin: 0; font: 700 27px/1.2 "Manrope", sans-serif; letter-spacing: -.04em; }
.stop-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 9px; }
.stop-grid article { position: relative; min-height: 130px; padding: 22px 14px 14px; border-radius: 15px; background: rgba(255,255,255,.7); }
.stop-grid article > span { position: absolute; right: 10px; top: 9px; color: var(--muted); font: 700 8px "Manrope"; }
.stop-grid i { display: grid; place-items: center; width: 30px; height: 30px; margin-bottom: 20px; border-radius: 50%; background: var(--sun); color: var(--green); font-style: normal; }
.stop-grid h4 { margin: 0; font: 700 13px/1.25 "Manrope", sans-serif; }

.why { background: var(--cream); }
.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 130px; }
.why-copy > p:not(.kicker) { max-width: 440px; color: var(--muted); }
.why-copy h2 { margin-bottom: 36px; }
.benefit-list { border-top: 1px solid var(--line); }
.benefit-list div { display: grid; grid-template-columns: 45px 1fr 35px; align-items: center; min-height: 84px; border-bottom: 1px solid var(--line); }
.benefit-list span { color: var(--coral); font: 700 11px "Manrope"; }
.benefit-list p { margin: 0; font: 700 22px "Manrope"; letter-spacing: -.03em; }
.benefit-list i { width: 30px; height: 30px; border-radius: 50%; background: white; display: grid; place-items: center; font-style: normal; transition: transform .2s; }
.benefit-list div:hover i { transform: rotate(45deg); }

.details { background: var(--paper); }
.details-heading { text-align: center; margin-bottom: 55px; }
.details-layout { display: grid; grid-template-columns: 1.1fr .9fr; gap: 24px; max-width: 1000px; margin: 0 auto; }
.event-card { min-height: 500px; border-radius: var(--radius); overflow: hidden; display: grid; grid-template-columns: 150px 1fr; background: var(--sky); box-shadow: 0 20px 50px rgba(24,55,45,.08); }
.event-date { background: var(--sun); padding: 42px 28px; }
.event-date strong { display: block; font: 800 78px/.8 "Manrope"; letter-spacing: -.08em; }
.event-date span { display: block; margin-top: 18px; font: 800 13px/1.35 "Manrope"; letter-spacing: .12em; }
.event-card-body { padding: 46px; }
.mini-label { margin-bottom: 13px; text-transform: uppercase; letter-spacing: .13em; font: 700 10px "Manrope"; color: var(--green-2); }
.event-card h3, .tips h3 { font: 700 30px/1.15 "Manrope"; letter-spacing: -.04em; }
dl { margin: 34px 0; }
dl div { display: flex; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid rgba(23,79,59,.12); }
dt { color: var(--muted); }
dd { margin: 0; font-weight: 700; }
.button-dark { width: 100%; background: var(--green); color: white; }
.tips { border-radius: var(--radius); padding: 46px; background: var(--cream); }
.tips ul { list-style: none; margin: 38px 0 0; padding: 0; }
.tips li { display: flex; align-items: center; gap: 13px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.tips li span { display: grid; place-items: center; flex: 0 0 25px; height: 25px; border-radius: 50%; background: var(--mint); color: var(--green); font-size: 12px; font-weight: 700; }

.organizers { background: var(--mint); }
.organizer-wrap { display: block; }
.organizer-intro { display: grid; grid-template-columns: .9fr 1.1fr; gap: 120px; align-items: center; }
.organizer-copy > p { font-size: 19px; color: #4e6b61; }
.logo-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-top: 55px; }
.logo-card { position: relative; min-width: 0; height: 180px; margin: 0; padding: 30px 20px 24px; display: flex; align-items: center; justify-content: center; border: 1px solid rgba(23,79,59,.13); border-radius: 18px; background: white; overflow: hidden; transition: transform .2s ease, box-shadow .2s ease; }
.logo-card:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(23,79,59,.08); }
.logo-card-featured { border-color: rgba(23,79,59,.35); box-shadow: inset 0 -4px 0 var(--sun); }
.logo-link { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; border-radius: 10px; }
.logo-link:focus-visible { outline: 3px solid var(--coral); outline-offset: 4px; }
.logo-card img { display: block; width: 100%; height: 105px; object-fit: contain; }
.logo-card:nth-child(2) img { height: 120px; }
.logo-card figcaption { position: absolute; left: 14px; top: 12px; padding: 4px 7px; border-radius: 100px; background: var(--cream); color: var(--green); text-transform: uppercase; letter-spacing: .1em; font: 700 8px/1 "Manrope", sans-serif; }
.logo-card-featured figcaption { background: var(--sun); }

.final-cta { position: relative; background: var(--green); color: white; min-height: 620px; display: grid; place-items: center; text-align: center; overflow: hidden; }
.final-inner { position: relative; z-index: 2; padding: 90px 0; }
.final-cta h2 { font-size: clamp(74px, 9vw, 128px); line-height: .82; margin: 0 0 35px; }
.final-cta h2 em { color: var(--sun); }
.final-cta p:not(.kicker) { max-width: 500px; margin: 0 auto 30px; font-size: 18px; color: rgba(255,255,255,.74); }
.button-sun { background: var(--sun); color: var(--ink); }
.final-cta small { display: block; margin-top: 18px; color: rgba(255,255,255,.55); }
.wheel { position: absolute; width: 280px; aspect-ratio: 1; border: 2px solid rgba(255,255,255,.06); border-radius: 50%; }
.wheel::before, .wheel::after { content: ""; position: absolute; inset: 50% -20%; height: 2px; background: rgba(255,255,255,.05); }
.wheel::after { transform: rotate(60deg); }
.wheel-left { left: -120px; bottom: -80px; }
.wheel-right { right: -90px; top: -80px; transform: rotate(25deg); }

footer { background: #0e3327; color: rgba(255,255,255,.7); padding: 30px 0; }
.footer-inner { display: flex; justify-content: space-between; align-items: center; font-size: 12px; }
.footer-inner p { margin: 0; }
.footer-brand { color: white; }
.footer-brand .brand-mark { background: var(--sun); color: var(--ink); }
.footer-brand strong { color: var(--sun); }
.toast { position: fixed; z-index: 100; left: 50%; bottom: 28px; transform: translate(-50%, 100px); opacity: 0; background: #102f25; color: white; padding: 13px 20px; border-radius: 100px; box-shadow: 0 15px 45px rgba(0,0,0,.2); transition: .35s; font-size: 14px; }
.toast.show { transform: translate(-50%, 0); opacity: 1; }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 900px) {
  .container { width: min(100% - 32px, 720px); }
  .section { padding: 88px 0; }
  .site-header { height: 70px; }
  .menu-toggle { display: block; }
  .main-nav { position: absolute; left: 16px; right: 16px; top: 70px; display: none; flex-direction: column; align-items: stretch; gap: 4px; padding: 16px; border-radius: 16px; background: var(--paper); box-shadow: 0 20px 60px rgba(24,55,45,.16); }
  .main-nav.open { display: flex; }
  .main-nav a { padding: 12px; }
  .nav-cta { text-align: center; margin-top: 6px; }
  .hero { min-height: 880px; height: auto; align-items: start; padding-top: 120px; }
  .hero-art { inset: auto 0 0; height: 58%; background-position: 69% center; }
  .hero::after { background: linear-gradient(180deg, rgba(238,249,248,1) 0%, rgba(238,249,248,1) 41%, rgba(238,249,248,.8) 56%, rgba(238,249,248,0) 78%); }
  .hero-content { padding-top: 0; }
  .hero-copy { width: 100%; }
  h1 { font-size: clamp(65px, 18vw, 90px); }
  .hero-lead { font-size: 18px; max-width: 360px; }
  .hero-note { display: none; }
  .split-grid, .why-grid, .organizer-intro { grid-template-columns: 1fr; gap: 45px; }
  .activity-grid { grid-template-columns: repeat(2, 1fr); }
  .edition-heading { grid-template-columns: 1fr; gap: 30px; }
  .infographic-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-infographic { grid-row: span 1; }
  .route-heading { grid-template-columns: 1fr; gap: 35px; }
  .activity-stops { grid-template-columns: 1fr; gap: 30px; }
  .section-top { align-items: start; gap: 35px; }
  .details-layout { grid-template-columns: 1fr; }
  .logo-row { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 600px) {
  .container { width: calc(100% - 28px); }
  .section { padding: 72px 0; }
  .brand { font-size: 14px; }
  .brand-mark { width: 34px; height: 34px; }
  .hero { min-height: 860px; padding-top: 105px; }
  .hero-art { height: 49%; background-position: 68% center; }
  .hero::after { background: linear-gradient(180deg, rgba(238,249,248,1) 0%, rgba(238,249,248,1) 48%, rgba(238,249,248,.78) 65%, transparent 85%); }
  h1 { font-size: 63px; margin-bottom: 20px; }
  .hero-lead { margin-bottom: 22px; }
  .event-pills { width: 100%; }
  .event-pills > div { flex: 1; gap: 6px; margin-right: 8px; padding-right: 8px; font-size: 11px; }
  .pill-icon { width: 26px; height: 26px; flex: 0 0 26px; }
  .hero-actions { gap: 16px; align-items: flex-start; flex-direction: column; }
  .button { width: 100%; }
  .text-link { margin-left: 4px; }
  .section-heading h2, .why h2, .details h2, .organizers h2 { font-size: 44px; }
  .intro-copy .lead { font-size: 20px; }
  blockquote { font-size: 20px; }
  .section-top { display: block; }
  .section-top > p { margin-top: 25px; }
  .activity-grid { grid-template-columns: 1fr; }
  .activity-card { min-height: 330px; }
  .activity-card.featured { transform: none; }
  .line-icon { margin: 25px 0; }
  .infographic-grid { grid-template-columns: 1fr; gap: 12px; }
  .infographic-card figure { height: 390px; }
  .infographic-copy { min-height: 0; padding: 27px 23px 30px; }
  .infographic-copy h3 { font-size: 24px; }
  .route-animation { border-radius: 18px; }
  .route-animation figcaption { flex-direction: column; align-items: stretch; gap: 12px; }
  .route-animation figcaption > span { align-items: flex-start; }
  .route-animation-toggle { width: 100%; }
  .activity-stops { padding: 27px 18px; }
  .stop-grid { grid-template-columns: repeat(2, 1fr); }
  .stop-grid article { min-height: 115px; }
  .benefit-list p { font-size: 18px; }
  .event-card { grid-template-columns: 1fr; }
  .event-date { padding: 25px 30px; display: flex; align-items: end; gap: 18px; }
  .event-date strong { font-size: 64px; }
  .event-date span { margin: 0; }
  .event-card-body, .tips { padding: 32px 25px; }
  .logo-row { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin-top: 38px; }
  .logo-card { height: 142px; padding: 25px 12px 15px; border-radius: 14px; }
  .logo-card img, .logo-card:nth-child(2) img { height: 86px; }
  .logo-card-featured { grid-column: 1 / -1; }
  .final-cta { min-height: 570px; }
  .final-cta h2 { font-size: 68px; }
  .final-cta .button { max-width: 340px; }
  .footer-inner { flex-direction: column; gap: 18px; text-align: center; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
}
