:root { --navy: #10233d; --blue: #1f67c9; --red: #ef4d47; --line: rgba(16,35,61,0.12); }
* { box-sizing: border-box; }
body { margin: 0; color: #10233d; font-family: "Arial Black", Arial, sans-serif; background: linear-gradient(135deg, rgba(31,103,201,0.08) 0 18%, transparent 18% 38%, rgba(239,77,71,0.08) 38% 48%, transparent 48% 100%), linear-gradient(180deg, #fbfdff, #edf4ff 45%, #f7f9fc); }
a { color: inherit; }
.page-header, .speed-top, .ride-strip, .parts-grid, .finish-row { width: min(1240px, calc(100% - 1rem)); margin: 0 auto; }
.page-header { padding: 1rem 0; display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.back-link, .switcher select, .headline-panel, .badge-panel, .service-panel, .copy-card, .detail-card, .contact-card, .map-card, .hero-image { border: 1px solid var(--line); border-radius: 26px; }
.back-link { text-decoration: none; padding: 0.85rem 1rem; background: rgba(255,255,255,0.84); }
.switcher { display: grid; gap: 0.35rem; justify-items: end; font-size: 0.82rem; font-family: "Trebuchet MS", Arial, sans-serif; }
.switcher span, .eyebrow, figcaption { text-transform: uppercase; letter-spacing: 0.14em; font-weight: 800; color: var(--blue); }
.switcher select { min-width: min(360px,72vw); padding: 0.9rem 1rem; background: rgba(255,255,255,0.9); }
.bike-page { display: grid; gap: 1rem; padding-bottom: 2rem; }
.speed-top { display: grid; grid-template-columns: 1.4fr 0.6fr; gap: 1rem; }
.headline-panel, .badge-panel, .service-panel, .copy-card, .detail-card, .contact-card, .map-card { background: rgba(255,255,255,0.82); padding: 1.2rem; box-shadow: 0 26px 60px rgba(16,35,61,0.12); }
h1, h2 { margin: 0 0 0.7rem; line-height: 0.92; overflow-wrap: anywhere; }
h1 { font-size: clamp(3rem, 8vw, 6rem); max-width: 8ch; }
h2 { font-size: clamp(1.8rem, 3vw, 2.9rem); }
p, li, span { line-height: 1.7; overflow-wrap: anywhere; font-family: "Trebuchet MS", Arial, sans-serif; }
.badge-panel img, .hero-image, .detail-card img { width: 100%; object-fit: cover; border-radius: 16px; background: linear-gradient(135deg, #dce8ff, #9ec1ff); }
.badge-panel img { aspect-ratio: 1 / 1; margin-top: 0.6rem; }
.ride-strip { display: grid; grid-template-columns: 0.72fr 1.28fr; gap: 1rem; }
.service-panel ul { margin: 1rem 0 0; padding-left: 1.1rem; }
.hero-image { min-height: 520px; padding: 0; }
.parts-grid { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: 1rem; }
.detail-card img { min-height: 230px; }
.detail-card.wide { grid-column: 1 / 2; }
.copy-card { grid-column: 2 / 3; grid-row: 1 / 2; align-self: start; }
.parts-grid .detail-card:nth-of-type(2) { grid-column: 1 / 2; }
.parts-grid .detail-card:nth-of-type(3) { grid-column: 2 / 3; }
.finish-row { display: grid; grid-template-columns: 1fr 0.9fr; gap: 1rem; }
.map-card { position: relative; overflow: hidden; min-height: 280px; background: linear-gradient(145deg, rgba(255,255,255,0.92), rgba(31,103,201,0.14)); }
.map-grid { position: absolute; inset: 0; background: linear-gradient(120deg, transparent 0 20%, rgba(16,35,61,0.14) 20% 24%, transparent 24% 44%, rgba(16,35,61,0.14) 44% 48%, transparent 48% 70%, rgba(16,35,61,0.14) 70% 74%, transparent 74%), linear-gradient(transparent 0 30%, rgba(239,77,71,0.12) 30% 34%, transparent 34% 65%, rgba(239,77,71,0.12) 65% 69%, transparent 69%); }
.pin { position: absolute; top: 42%; left: 58%; width: 22px; height: 22px; border-radius: 50%; background: var(--red); box-shadow: 0 0 0 10px rgba(239,77,71,0.18); }
.map-card span { position: absolute; left: 1rem; bottom: 1rem; padding: 0.6rem 0.85rem; border-radius: 999px; background: rgba(255,255,255,0.9); font-family: "Trebuchet MS", Arial, sans-serif; }
@media (max-width: 920px) { .page-header, .speed-top, .ride-strip, .parts-grid, .finish-row { grid-template-columns: 1fr; display: grid; } .switcher { justify-items: start; } .copy-card, .detail-card.wide, .parts-grid .detail-card:nth-of-type(2), .parts-grid .detail-card:nth-of-type(3) { grid-column: auto; grid-row: auto; } }
