:root{
  --blue:#1b5e91;
  --blue-dark:#12476f;
  --yellow:#f4b51c;
  --ink:#16202b;
  --muted:#5b6670;
  --bg:#ffffff;
  --bg-soft:#f4f7fa;
  --line:#e4eaf0;
  --radius:16px;
  --shadow:0 10px 40px rgba(18,71,111,.10);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3{line-height:1.15;font-weight:800;letter-spacing:-.02em}
.btn{display:inline-block;padding:14px 28px;border-radius:999px;font-weight:700;font-size:15px;transition:.2s;cursor:pointer;border:2px solid transparent}
.btn-primary{background:var(--yellow);color:var(--ink)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(244,181,28,.4)}
.btn-ghost{border-color:rgba(255,255,255,.6);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-dark);transform:translateY(-2px)}

/* HEADER */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.nav .logo img{height:40px}
.nav nav{display:flex;gap:26px;align-items:center}
.nav nav a{font-weight:600;font-size:15px;color:var(--ink);opacity:.85;transition:.2s}
.nav nav a:hover,.nav nav a.active{opacity:1;color:var(--blue)}
.nav .phone{font-weight:700;color:var(--blue);white-space:nowrap}
.menu-toggle{display:none;font-size:26px;background:none;border:none;cursor:pointer}
@media(max-width:920px){
  .nav nav{position:absolute;top:74px;left:0;right:0;background:#fff;flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--line);box-shadow:var(--shadow);display:none}
  .nav nav.open{display:flex}
  .nav nav a{padding:12px 24px;width:100%}
  .menu-toggle{display:block}
}

/* HERO (home) */
.hero{position:relative;color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  linear-gradient(120deg,rgba(18,71,111,.92),rgba(18,71,111,.55) 60%,rgba(18,71,111,.2)),
  url('images/groupbike-header-2024-1280x630.jpg') center/cover;}
.hero-inner{position:relative;padding:110px 0 120px;max-width:680px}
.badge{display:inline-block;background:var(--yellow);color:var(--ink);font-weight:800;font-size:13px;letter-spacing:.04em;text-transform:uppercase;padding:7px 16px;border-radius:999px;margin-bottom:22px}
.hero h1{font-size:clamp(34px,5.2vw,58px);margin-bottom:18px}
.hero p{font-size:19px;opacity:.95;margin-bottom:32px;max-width:560px}
.hero .btns{display:flex;gap:14px;flex-wrap:wrap}

/* PAGE HERO (subpages) */
.pagehero{position:relative;color:#fff;overflow:hidden;background:linear-gradient(120deg,var(--blue),var(--blue-dark))}
.pagehero .wrap{position:relative;padding:64px 24px 60px}
.pagehero h1{font-size:clamp(30px,4.4vw,46px);margin-bottom:10px}
.pagehero p{opacity:.92;font-size:18px;max-width:640px}
.crumb{font-size:13px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--yellow);margin-bottom:14px}

/* TRUST STRIP */
.trust{background:var(--blue-dark);color:#fff}
.trust .wrap{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between;padding:22px 24px;align-items:center}
.trust span{font-weight:600;opacity:.9;font-size:15px}
.trust b{color:var(--yellow)}

/* SECTIONS */
section{padding:84px 0}
section.tight{padding:60px 0}
.eyebrow{color:var(--blue);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:13px;margin-bottom:12px}
.section-head{max-width:720px;margin-bottom:48px}
.section-head h2{font-size:clamp(28px,3.6vw,40px);margin-bottom:14px}
.section-head p{color:var(--muted);font-size:18px}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* SPLIT */
.split{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow)}
.split h2{font-size:clamp(26px,3.4vw,38px);margin-bottom:18px}
.split p{color:var(--muted);margin-bottom:16px;font-size:17px}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:32px}}

/* STATS */
.stats{background:var(--bg-soft)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .num{font-size:clamp(32px,4vw,46px);font-weight:800;color:var(--blue)}
.stat .lbl{color:var(--muted);font-weight:600;font-size:15px;margin-top:4px}
@media(max-width:820px){.stats .grid{grid-template-columns:repeat(2,1fr);gap:32px}}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;transition:.25s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .ic{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;margin-bottom:18px}
.card h3{font-size:20px;margin-bottom:10px}
.card p{color:var(--muted);font-size:15px}
@media(max-width:820px){.cards{grid-template-columns:1fr}}

/* SPECS LIST */
.specs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 30px;margin-top:8px}
.specs li{list-style:none;padding:14px 0;border-bottom:1px solid var(--line);font-weight:600;display:flex;align-items:center;gap:10px}
.specs li::before{content:"✓";color:var(--yellow);font-weight:900}
@media(max-width:820px){.specs{grid-template-columns:1fr}}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery img{border-radius:12px;height:240px;object-fit:cover;width:100%;cursor:pointer;transition:.25s}
.gallery img:hover{opacity:.92;transform:scale(1.01)}
@media(max-width:820px){.gallery{grid-template-columns:repeat(2,1fr)}.gallery img{height:180px}}

/* USED BIKES CTA */
.usedcta{background:linear-gradient(120deg,var(--blue),var(--blue-dark));color:#fff;border-radius:24px;padding:56px;display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center}
.usedcta h2{font-size:clamp(26px,3.2vw,36px);margin-bottom:14px}
.usedcta p{opacity:.92;font-size:17px;margin-bottom:24px}
@media(max-width:820px){.usedcta{grid-template-columns:1fr;padding:36px}}

/* PARTNERS */
.partners{background:var(--bg-soft)}
.logos{display:flex;flex-wrap:wrap;gap:40px;align-items:center;justify-content:center;opacity:.8}
.logos img{height:54px;width:auto;filter:grayscale(1);transition:.25s}
.logos img:hover{filter:none}

/* BIKE LISTINGS (used bikes) */
.bike{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:40px;border:1px solid var(--line);border-radius:24px;margin-bottom:36px;position:relative;overflow:hidden;background:#fff}
.bike:nth-child(even){grid-template-columns:1fr 1fr}
.bike:nth-child(even) .bike-media{order:2}
.bike-info h3{font-size:26px;margin-bottom:6px}
.bike-info .price{font-size:24px;font-weight:800;color:var(--blue);margin:10px 0 16px}
.bike-info ul{list-style:none;margin-bottom:20px}
.bike-info li{padding:8px 0;border-bottom:1px solid var(--line);font-size:15px;display:flex;gap:10px;align-items:flex-start}
.bike-info li::before{content:"›";color:var(--yellow);font-weight:900}
.bike-media{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bike-media img{border-radius:12px;height:160px;width:100%;object-fit:cover;cursor:pointer;transition:.2s}
.bike-media img:hover{opacity:.92}
.bike-media .main{grid-column:1 / -1;height:230px}
.bike-media .more-wrap{position:relative;cursor:pointer}
.bike-media .more-wrap img{height:160px;width:100%;object-fit:cover;border-radius:12px}
.more-badge{position:absolute;inset:0;background:rgba(18,71,111,.66);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px;letter-spacing:.02em;pointer-events:none}
.more-badge small{font-weight:600;font-size:12px;margin-left:6px;opacity:.9}
.bike-nophoto{display:flex;align-items:center;justify-content:center;background:var(--bg-soft);border-radius:12px;color:var(--muted);font-weight:600;min-height:200px}
@media(max-width:820px){.bike,.bike:nth-child(even){grid-template-columns:1fr}.bike:nth-child(even) .bike-media{order:0}}

/* CORNER RIBBON (fixed-size, always clipped) */
.corner{position:absolute;top:0;right:0;width:150px;height:150px;overflow:hidden;z-index:3;pointer-events:none}
.rib{position:absolute;left:-34px;top:34px;width:210px;transform:rotate(45deg);text-align:center;background:var(--yellow);color:var(--ink);font-weight:800;font-size:12px;letter-spacing:.03em;text-transform:uppercase;padding:8px 0;box-shadow:0 3px 10px rgba(0,0,0,.2)}
.rib.sold{background:#c0392b;color:#fff}
.rib.soon{background:var(--blue);color:#fff}
.tag{display:inline-block;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.05em;padding:5px 12px;border-radius:999px;margin-bottom:10px}
.tag.forsale{background:#e7f5ec;color:#1e7e44}
.tag.sold{background:#fbe9e7;color:#c0392b}
.tag.soon{background:#e8f0f7;color:var(--blue)}

/* TESTIMONIALS */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;display:flex;flex-direction:column}
.tcard .quote{font-size:15px;color:var(--ink);margin-bottom:18px;flex:1}
.tcard .who{font-weight:800;color:var(--blue)}
.tcard .stars{color:var(--yellow);margin-bottom:14px;font-size:15px}
@media(max-width:820px){.tcards{grid-template-columns:1fr}}

/* CONTACT */
.contact{background:var(--ink);color:#fff}
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.contact h2{font-size:clamp(28px,3.4vw,40px);margin-bottom:16px}
.contact p{opacity:.8;margin-bottom:10px}
.contact a{color:var(--yellow)}
.contact .made{margin-top:24px}
.contact .made img{height:80px}
form.cf{display:grid;gap:14px}
form.cf input,form.cf textarea,form.cf select{padding:14px 16px;border-radius:10px;border:none;font-size:15px;font-family:inherit;width:100%}
.formnote{font-size:13px;opacity:.7;margin-top:4px}
@media(max-width:820px){.contact .grid{grid-template-columns:1fr;gap:28px}}

.mapwrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);line-height:0}
.mapwrap iframe{width:100%;height:380px;border:0}

/* FOOTER */
footer{background:#0d1620;color:rgba(255,255,255,.6);padding:40px 0 28px;font-size:14px}
footer .grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;margin-bottom:28px}
footer h4{color:#fff;font-size:15px;margin-bottom:12px}
footer a{display:block;padding:4px 0;color:rgba(255,255,255,.6)}
footer a:hover{color:var(--yellow)}
footer .bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center}
@media(max-width:820px){footer .grid{grid-template-columns:1fr;gap:20px}}

/* LIGHTBOX */
.lb{position:fixed;inset:0;background:rgba(8,14,20,.93);display:none;align-items:center;justify-content:center;z-index:200;padding:30px;cursor:zoom-out}
.lb.open{display:flex}
.lb img{max-width:88vw;max-height:88vh;border-radius:8px;cursor:pointer}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.14);color:#fff;border:none;font-size:38px;line-height:1;width:58px;height:84px;cursor:pointer;border-radius:12px;z-index:201;transition:.2s}
.lb-nav:hover{background:rgba(255,255,255,.3)}
.lb-prev{left:20px}.lb-next{right:20px}
.lb-count{position:fixed;bottom:22px;left:0;right:0;text-align:center;color:#fff;font-weight:600;font-size:14px;letter-spacing:.04em}
.lb-close{position:fixed;top:18px;right:22px;background:none;border:none;color:#fff;font-size:34px;cursor:pointer;z-index:201;line-height:1}
@media(max-width:620px){.lb-nav{width:44px;height:64px;font-size:28px}}

/* PRESS / ARTICLES */
.press-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.article{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.article .thumb{background:var(--bg-soft);text-align:center;cursor:zoom-in;padding:18px}
.article .thumb img{max-height:340px;width:auto;margin:0 auto;border-radius:6px;box-shadow:0 6px 20px rgba(0,0,0,.12)}
.article .body{padding:26px;display:flex;flex-direction:column;flex:1}
.article h3{font-size:21px;margin-bottom:6px}
.article .src{font-size:13px;color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}
.article p{color:var(--muted);font-size:15px;margin-bottom:18px;flex:1}
@media(max-width:820px){.press-grid{grid-template-columns:1fr}}

/* MODAL */
.modal{position:fixed;inset:0;background:rgba(8,14,20,.6);backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;z-index:210;padding:40px 20px;overflow-y:auto}
.modal.open{display:flex}
.modal-box{background:#fff;max-width:760px;width:100%;border-radius:var(--radius);padding:40px;position:relative;box-shadow:0 30px 80px rgba(0,0,0,.4);margin:auto}
.modal-close{position:absolute;top:14px;right:18px;background:none;border:none;font-size:30px;cursor:pointer;color:var(--muted);line-height:1}
.modal-body h3{font-size:24px;margin-bottom:6px}
.modal-body .src{font-size:13px;color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:18px}
.modal-body img{border-radius:8px;margin:8px 0 20px;width:100%}
.modal-body p{margin-bottom:14px;color:var(--ink);font-size:15px;line-height:1.7}
.modal-body .caption{font-size:13px;color:var(--muted);font-style:italic}

.fade{opacity:0;transform:translateY(20px);transition:.7s}
.fade.in{opacity:1;transform:none}
