/* RideCast 2.0 — Native Server Rendered Visual Pack
   No React. No Tailwind. No fake data.
   Drop this after the current CSS and map your existing classes/partials.
*/
:root{
  --rc-bg:#0B0D10;
  --rc-bg-2:#10151d;
  --rc-surface:#121820;
  --rc-surface-2:#161F2A;
  --rc-border:rgba(255,255,255,.10);
  --rc-text:#F5F7FA;
  --rc-muted:#9CA3AF;
  --rc-soft:#CBD5E1;
  --rc-orange:#FF6A00;
  --rc-orange-2:#FF8A2A;
  --rc-teal:#14B8A6;
  --rc-teal-2:#0D9488;
  --rc-good:#22C55E;
  --rc-warn:#F59E0B;
  --rc-risk:#EF4444;
  --rc-radius-xl:28px;
  --rc-radius-lg:20px;
  --rc-shadow:0 30px 90px rgba(0,0,0,.55);
  --rc-glow-orange:0 0 38px rgba(255,106,0,.35);
  --rc-glow-teal:0 0 34px rgba(20,184,166,.24);
}
*{box-sizing:border-box}
html{background:var(--rc-bg);color:var(--rc-text);scroll-behavior:smooth}
body{margin:0;background:
  radial-gradient(circle at 15% 0%,rgba(255,106,0,.14),transparent 34%),
  radial-gradient(circle at 90% 10%,rgba(20,184,166,.12),transparent 30%),
  linear-gradient(180deg,#07090c 0%,var(--rc-bg) 45%,#080A0E 100%);
  color:var(--rc-text);font-family:Inter,Geist,system-ui,-apple-system,Segoe UI,sans-serif;}
.rc-page{background:transparent;color:var(--rc-text)}
.rc-container{width:min(1180px,calc(100% - 32px));margin-inline:auto}
.rc-nav{position:sticky;top:0;z-index:50;background:rgba(7,9,12,.72);backdrop-filter:blur(18px);border-bottom:1px solid var(--rc-border)}
.rc-nav-inner{height:72px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.rc-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--rc-text)}
.rc-brand-mark{width:38px;height:38px;filter:drop-shadow(0 0 16px rgba(20,184,166,.32))}
.rc-brand-text{font-weight:850;letter-spacing:-.04em;font-size:22px}.rc-brand-payoff{font-size:12px;color:var(--rc-muted);letter-spacing:.08em;text-transform:lowercase}
.rc-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:12px 18px;font-weight:750;text-decoration:none;border:1px solid var(--rc-border);transition:.2s ease;color:var(--rc-text);background:rgba(255,255,255,.06)}
.rc-btn:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.22)}
.rc-btn-primary{background:linear-gradient(135deg,var(--rc-orange),var(--rc-orange-2));color:#140800;border-color:rgba(255,106,0,.45);box-shadow:var(--rc-glow-orange)}
.rc-hero{position:relative;min-height:calc(100svh - 72px);display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--rc-border)}
.rc-hero::before{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(7,9,12,.22),rgba(7,9,12,.92)),
  radial-gradient(circle at 50% 42%,rgba(255,106,0,.16),transparent 34%),
  url('/static/img/hero-bike.jpg') center/cover no-repeat;opacity:.98;}
.rc-hero::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(circle at 50% 45%,black,transparent 72%);opacity:.38}
.rc-hero-content{position:relative;z-index:2;text-align:center;padding:72px 0 48px}.rc-stars{color:var(--rc-orange);letter-spacing:.16em;text-shadow:var(--rc-glow-orange);font-size:clamp(20px,2.2vw,28px);margin-bottom:18px}.rc-kicker{color:var(--rc-teal);text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:850;margin-bottom:18px}.rc-verdict{font-size:clamp(64px,11vw,150px);line-height:.78;letter-spacing:-.08em;margin:0;text-transform:uppercase;font-weight:950}.rc-time{display:block;margin-top:22px;font-size:clamp(32px,5vw,68px);line-height:1;color:var(--rc-soft);letter-spacing:-.05em;font-weight:850}.rc-subline{margin:22px auto 0;max-width:760px;color:var(--rc-muted);font-size:clamp(16px,2vw,21px);line-height:1.5}.rc-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:28px auto 0}.rc-pill{padding:9px 13px;border:1px solid var(--rc-border);background:rgba(18,24,32,.68);backdrop-filter:blur(14px);border-radius:999px;color:var(--rc-soft);font-size:14px}.rc-pill strong{color:var(--rc-text)}
.rc-hero-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:34px}.rc-section{padding:86px 0}.rc-section-tight{padding:56px 0}.rc-section-title{font-size:clamp(34px,5vw,72px);line-height:.95;letter-spacing:-.065em;margin:0 0 14px;font-weight:950}.rc-section-lead{color:var(--rc-muted);font-size:19px;line-height:1.55;max-width:720px;margin:0 0 34px}.rc-panel{border:1px solid var(--rc-border);background:linear-gradient(180deg,rgba(22,31,42,.82),rgba(18,24,32,.62));box-shadow:var(--rc-shadow);backdrop-filter:blur(18px);border-radius:var(--rc-radius-xl);overflow:hidden}.rc-proof-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:18px;align-items:stretch}.rc-map-shell{min-height:520px;position:relative;background:#080b10}.rc-map-shell>img,.rc-map-shell>svg{width:100%;height:100%;object-fit:cover;display:block}.rc-map-overlay{position:absolute;left:22px;right:22px;bottom:22px;display:flex;justify-content:space-between;gap:16px;align-items:end}.rc-route-badge{border:1px solid rgba(255,255,255,.12);background:rgba(7,9,12,.62);backdrop-filter:blur(16px);border-radius:18px;padding:14px 16px}.rc-route-badge b{display:block;font-size:18px}.rc-route-badge span{color:var(--rc-muted);font-size:13px}.rc-metrics{display:grid;gap:14px;padding:22px}.rc-metric{padding:18px;border-radius:20px;background:rgba(255,255,255,.045);border:1px solid var(--rc-border)}.rc-metric-label{color:var(--rc-muted);font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:850}.rc-metric-value{font-size:clamp(28px,4vw,48px);letter-spacing:-.055em;font-weight:920;margin-top:6px}.rc-metric small{color:var(--rc-muted)}
.rc-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.rc-slot{position:relative;border:1px solid var(--rc-border);border-radius:24px;background:rgba(18,24,32,.74);padding:22px;overflow:hidden}.rc-slot-best{border-color:rgba(255,106,0,.6);box-shadow:var(--rc-glow-orange)}.rc-slot-best::before{content:"consigliato";position:absolute;top:16px;right:16px;color:#160800;background:var(--rc-orange);border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.rc-slot-time{font-size:18px;color:var(--rc-soft);font-weight:850}.rc-slot-score{font-size:72px;line-height:.9;letter-spacing:-.08em;font-weight:950;margin:18px 0 8px}.rc-slot-reason{color:var(--rc-muted);line-height:1.45}.rc-feature-grid,.rc-pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.rc-feature{padding:22px;border:1px solid var(--rc-border);background:rgba(18,24,32,.64);border-radius:24px}.rc-feature-icon{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,rgba(255,106,0,.22),rgba(20,184,166,.13));display:grid;place-items:center;margin-bottom:22px}.rc-feature h3{margin:0 0 10px;font-size:20px}.rc-feature p{margin:0;color:var(--rc-muted);line-height:1.5}.rc-positioning{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.rc-position-card{padding:24px;border:1px solid var(--rc-border);border-radius:24px;background:rgba(18,24,32,.56)}.rc-position-card.rc-current{border-color:rgba(20,184,166,.45);box-shadow:var(--rc-glow-teal)}.rc-position-card h3{font-size:28px;margin:0 0 10px;letter-spacing:-.04em}.rc-position-card p{color:var(--rc-muted);font-size:18px;line-height:1.45;margin:0}.rc-price-card{padding:28px;border:1px solid var(--rc-border);border-radius:28px;background:rgba(18,24,32,.68)}.rc-price-card.premium{border-color:rgba(255,106,0,.55);box-shadow:var(--rc-glow-orange)}.rc-price{font-size:56px;letter-spacing:-.07em;font-weight:950;margin:14px 0}.rc-list{padding:0;margin:20px 0 0;list-style:none;display:grid;gap:10px}.rc-list li{color:var(--rc-soft)}.rc-list li::before{content:"✓";color:var(--rc-teal);font-weight:900;margin-right:8px}.rc-final{padding:96px 0;text-align:center}.rc-final h2{font-size:clamp(44px,7vw,96px);letter-spacing:-.075em;line-height:.9;margin:0 0 22px;font-weight:950}
@media (max-width:900px){.rc-proof-grid,.rc-slots,.rc-positioning,.rc-pricing-grid{grid-template-columns:1fr}.rc-feature-grid{grid-template-columns:1fr 1fr}.rc-map-shell{min-height:420px}.rc-nav-inner{height:64px}.rc-brand-payoff{display:none}.rc-verdict{font-size:clamp(58px,17vw,96px)}.rc-time{font-size:clamp(30px,10vw,52px)}}
@media (max-width:560px){.rc-container{width:min(100% - 22px,1180px)}.rc-section{padding:62px 0}.rc-feature-grid{grid-template-columns:1fr}.rc-hero-content{padding-top:48px}.rc-subline{font-size:16px}.rc-map-shell{min-height:360px}.rc-metrics{padding:14px}.rc-slot-score{font-size:58px}.rc-btn{width:100%}.rc-hero-actions{width:100%}}

/* — Innesti per il template reale (mappa live, form beta, footer) — */
.rc-map-shell #route-map{position:absolute;inset:0;border-radius:0;height:100%;border:none}
.rc-map-overlay{pointer-events:none;z-index:500}
.rc-form{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:26px}
.rc-form input{background:rgba(255,255,255,.06);border:1px solid var(--rc-border);border-radius:999px;
  padding:12px 18px;color:var(--rc-text);font:inherit;flex:1 1 180px;max-width:260px;min-width:0}
.rc-form input:focus{outline:none;border-color:var(--rc-teal)}
.rc-form .rc-btn-primary{border:none;cursor:pointer;font:inherit}
.rc-note{color:var(--rc-muted);font-size:13px;margin-top:14px;text-align:center}
.rc-quote{color:var(--rc-muted);font-style:italic;text-align:center;padding:34px 16px 44px;border-top:1px solid var(--rc-border);margin-top:40px}
.rc-map-caption{color:var(--rc-muted);font-size:13px;margin-top:12px}
.rc-feature-grid{margin-top:8px}

/* Leaflet gestisce da solo le dimensioni dei suoi layer: mai stirarli. */
.rc-map-shell .leaflet-container img,.rc-map-shell .leaflet-container canvas,
.rc-map-shell .leaflet-container svg{width:auto;height:auto;object-fit:initial}

/* — La frase di posizionamento, gigante — */
.rc-pitch{text-align:center}
.rc-pitch-line{font-size:clamp(30px,4.6vw,62px);line-height:1.16;letter-spacing:-.045em;
  font-weight:950;margin:0 0 44px}
.rc-pitch-dim{color:var(--rc-muted);font-weight:800}
.rc-pitch-hot{color:var(--rc-orange);text-shadow:0 0 34px rgba(255,106,0,.28)}
.rc-pitch .rc-positioning{text-align:left;max-width:980px;margin-inline:auto}

/* — Sfondi fotografici (tavole AI proprie, niente stock) — */
.rc-bg-terrain{position:relative;background:url('/static/img/hero-terrain-dark.jpg') center/cover no-repeat}
.rc-bg-terrain::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--rc-bg) 0%,rgba(11,13,16,.55) 18%,rgba(11,13,16,.55) 82%,var(--rc-bg) 100%)}
.rc-bg-terrain>.rc-container{position:relative;z-index:1}
.rc-final{position:relative;overflow:hidden;background:url('/static/img/hero-trail.jpg') center/cover no-repeat}
.rc-final::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--rc-bg) 0%,rgba(7,9,12,.66) 30%,rgba(7,9,12,.78) 100%)}
.rc-final>.rc-container{position:relative;z-index:1}
