/* ============================================================
   DurlinVela — onda.css
   CONCEPT: an official printed RACE-DAY PROGRAM / timing sheet.
   Ink on race-paper, bold sports broadsheet, checkered + signal
   flags, printed circuit diagrams, diagonal speed rules, race-bib
   numbers, a ticker of race modes.
   CONSTITUTION
   - Colors: navy #0c2033 = ink · foam = paper · teal #17a2b8 =
     live/timing accent · sand #e6c98a = program-gold (sparing).
   - Type: Baloo 2 heavy/uppercase race labels + huge masthead;
     Rubik body/data with tabular numerals.
   - Surface: printed panels, ink hairline/double rules, checkered
     edges, 0-4px corners. No floating glass cards, no soft shadows,
     no translateY hovers.
   - Layout: centered 90rem program grid; full-width bib+rule+folio
     section heads; full-bleed diagonal bands; vertical bib banners.
   - Signature: checkered start-line tick + black N deg bib number +
     diagonal speed rule prefixing every section.
   ============================================================ */

:root{
  --navy:#0c2033;
  --navy-2:#123049;
  --teal:#17a2b8;
  --teal-deep:#0e7f92;
  --foam:#eef6f8;
  --foam-2:#dcecef;
  --ink:#0b1620;
  --sand:#e6c98a;
  --sand-deep:#d3ad61;
  --white:#ffffff;
  --paper:#f2f8f9;
  --line:rgba(12,32,51,.12);
  --hair:rgba(12,32,51,.18);
  --rule:rgba(12,32,51,.9);

  --shadow-sm:0 2px 0 rgba(11,22,32,.12);
  --shadow-md:8px 8px 0 rgba(12,32,51,.14);
  --shadow-lg:12px 12px 0 rgba(9,25,40,.22);

  --r-sm:4px;
  --r-md:5px;
  --r-lg:6px;
  --r-xl:8px;

  --wrap:90rem;                 /* centered ~1440px */
  --pad:clamp(1rem,4vw,3rem);
  --gap:clamp(1rem,2.2vw,1.6rem);

  --ff-display:"Baloo 2",system-ui,sans-serif;
  --ff-body:"Rubik",system-ui,sans-serif;

  /* signature checkered flag pattern */
  --checker:repeating-conic-gradient(var(--navy) 0 25%,#fff 0 50%);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--foam);
  background-image:
    linear-gradient(0deg,rgba(12,32,51,.015) 1px,transparent 1px);
  background-size:100% 6px;
  line-height:1.62;
  font-size:clamp(1rem,.96rem + .2vw,1.06rem);
  font-variant-numeric:tabular-nums;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-display);line-height:1.02;margin:0;font-weight:800;letter-spacing:-.015em}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit;cursor:pointer}

.vela-wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}

/* ---------- signature: checkered tick + bib + rule ---------- */
.vela-flag{display:inline-block;width:26px;height:16px;flex:0 0 auto;
  background:var(--checker);background-size:8px 8px;
  border:1px solid var(--navy);vertical-align:middle}

.vela-eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--ff-display);font-weight:800;
  text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;
  color:var(--teal-deep);
}
.vela-eyebrow::before{content:"";width:22px;height:13px;
  background:var(--checker);background-size:6.5px 6.5px;border:1px solid var(--navy)}
.vela-eyebrow.is-light{color:var(--sand)}
.vela-eyebrow.is-light::before{border-color:var(--sand);
  background:repeating-conic-gradient(var(--sand) 0 25%,var(--navy) 0 50%);background-size:6.5px 6.5px}

.vela-bib{display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--ff-display);font-weight:800;font-size:1.02rem;line-height:1;
  min-width:2.8rem;padding:.45rem .55rem;letter-spacing:.02em;
  background:var(--navy);color:#fff;border-radius:3px;
  box-shadow:3px 3px 0 var(--sand)}
.vela-bib::before{content:"N\00b0 ";font-size:.62rem;opacity:.7;margin-right:.15rem;transform:translateY(-.35em)}
.is-light .vela-bib,.vela-bib.is-light{background:var(--sand);color:var(--navy);box-shadow:3px 3px 0 rgba(0,0,0,.35)}

/* full-width section head: bib + label + double rule + folio */
.vela-section__head{margin-bottom:clamp(1.9rem,4vw,3.1rem)}
.vela-rulehead{display:flex;align-items:center;gap:1rem;margin-bottom:1.15rem}
.vela-rulehead__line{flex:1 1 auto;height:0;border-top:3px double var(--rule);min-width:2rem}
.vela-rulehead__folio{font-family:var(--ff-display);font-weight:700;font-size:.7rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--teal-deep);white-space:nowrap}
.is-light .vela-rulehead__line{border-top-color:rgba(255,255,255,.5)}
.is-light .vela-rulehead__folio{color:var(--sand)}
.vela-headrow{display:grid;grid-template-columns:1.35fr .85fr;gap:clamp(1rem,3vw,2.8rem);align-items:end}
.vela-headrow h2{font-size:clamp(2rem,1rem + 4.2vw,3.7rem);font-weight:800;
  text-transform:uppercase;letter-spacing:-.02em;line-height:.96}
.vela-headrow p{color:#3a4f60;font-size:1.04rem;padding-bottom:.3rem}
.is-light .vela-headrow h2{color:#fff}
.is-light .vela-headrow p{color:#cfe1e8}
@media (max-width:760px){.vela-headrow{grid-template-columns:1fr;gap:.9rem}}
@media (max-width:720px){.vela-rulehead__folio{display:none}.vela-rulehead{gap:.7rem}}

.vela-section{padding-block:clamp(3rem,7vw,6rem)}

:focus-visible{outline:3px solid var(--teal);outline-offset:3px;border-radius:2px}

/* ---------- buttons (printed press-plate style) ---------- */
.vela-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--ff-display);font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
  padding:.8rem 1.5rem;border-radius:3px;border:2px solid var(--navy);
  font-size:.92rem;transition:background .16s ease,color .16s ease,box-shadow .16s ease,transform .16s ease;
  line-height:1;text-align:center;
}
.vela-btn--primary{background:var(--teal);color:#fff;border-color:var(--navy);box-shadow:4px 4px 0 var(--navy)}
.vela-btn--primary:hover{background:var(--navy);box-shadow:0 0 0 var(--navy);transform:translate(4px,4px)}
.vela-btn--sand{background:var(--sand);color:var(--navy);border-color:var(--navy);box-shadow:4px 4px 0 var(--navy)}
.vela-btn--sand:hover{background:var(--navy);color:#fff;box-shadow:0 0 0 var(--navy);transform:translate(4px,4px)}
.vela-btn--ghost{background:transparent;color:#fff;border-color:#fff}
.vela-btn--ghost:hover{background:#fff;color:var(--navy)}
.vela-btn--outline{background:transparent;color:var(--navy);border-color:var(--navy)}
.vela-btn--outline:hover{background:var(--navy);color:#fff}
.vela-btn svg{width:1.05em;height:1.05em}

/* ============================================================
   HEADER — masthead nameplate
   ============================================================ */
.vela-header{
  position:sticky;top:0;z-index:60;
  background:var(--paper);
  border-bottom:3px solid var(--navy);
}
.vela-header__bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.6rem}
.vela-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--ff-display);
  font-weight:800;font-size:1.32rem;color:var(--navy);text-transform:uppercase;letter-spacing:-.01em}
.vela-brand__mark{width:38px;height:38px;border-radius:3px;border:2px solid var(--navy)}
.vela-brand span b{color:var(--teal-deep)}
.vela-nav{display:flex;align-items:center;gap:.15rem}
.vela-nav a{
  font-family:var(--ff-display);font-weight:700;font-size:.82rem;color:var(--navy);
  text-transform:uppercase;letter-spacing:.05em;
  padding:.5rem .7rem;border-radius:2px;transition:background .15s,color .15s;
}
.vela-nav a:hover{background:var(--navy);color:#fff}
.vela-nav .vela-btn{padding:.55rem 1.05rem;margin-left:.5rem;font-size:.78rem}
.vela-burger{display:none;flex-direction:column;gap:5px;width:46px;height:46px;
  border:2px solid var(--navy);border-radius:3px;background:var(--white);align-items:center;justify-content:center}
.vela-burger span{display:block;width:22px;height:2.5px;border-radius:0;background:var(--navy);transition:transform .25s,opacity .2s}

/* drawer */
.vela-drawer{position:fixed;inset:0;z-index:90;visibility:hidden;pointer-events:none}
.vela-drawer__scrim{position:absolute;inset:0;background:rgba(8,20,32,.6);opacity:0;transition:opacity .3s}
.vela-drawer__panel{
  position:absolute;top:0;left:0;height:100%;width:min(86vw,21rem);
  background:var(--navy);
  color:var(--foam);
  transform:translateX(-100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  padding:1.4rem 1.2rem;display:flex;flex-direction:column;gap:.35rem;
  border-right:4px solid var(--sand);
}
.vela-drawer__panel::before{content:"";position:absolute;top:0;left:0;right:0;height:10px;
  background:var(--checker);background-size:10px 10px}
.vela-drawer.is-open{visibility:visible;pointer-events:auto}
.vela-drawer.is-open .vela-drawer__scrim{opacity:1}
.vela-drawer.is-open .vela-drawer__panel{transform:translateX(0)}
.vela-drawer__top{display:flex;align-items:center;justify-content:space-between;margin:.4rem 0 1rem}
.vela-drawer__close{width:42px;height:42px;border-radius:3px;border:2px solid rgba(255,255,255,.4);
  background:transparent;color:#fff;font-size:1.4rem;line-height:1}
.vela-drawer__panel a{
  font-family:var(--ff-display);font-weight:700;font-size:1.02rem;color:var(--foam);
  text-transform:uppercase;letter-spacing:.04em;
  padding:.8rem .9rem;border-radius:2px;
  border-bottom:1px solid rgba(255,255,255,.14);transition:background .15s,padding-left .15s}
.vela-drawer__panel a:hover{background:rgba(255,255,255,.1);padding-left:1.3rem}
.vela-drawer__panel .vela-btn{margin-top:.7rem;border-color:var(--sand)}
.vela-drawer__nap{margin-top:auto;font-size:.84rem;color:rgba(238,246,248,.8);line-height:1.55}
.vela-drawer__nap a{background:none;border:none;padding:0;font-family:var(--ff-body);
  font-size:.84rem;text-transform:none;letter-spacing:0;text-decoration:underline}

/* ============================================================
   HERO — race-day start sheet
   ============================================================ */
.vela-hero{position:relative;isolation:isolate;overflow:hidden;color:var(--foam);
  border-bottom:4px solid var(--navy)}
.vela-hero__bg{position:absolute;inset:0;z-index:-2}
.vela-hero__bg img{width:100%;height:100%;object-fit:cover}
.vela-hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(9,20,33,.96) 34%,rgba(12,32,51,.86) 60%,rgba(14,127,146,.55) 100%)}

/* masthead folio strip */
.vela-folio{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;
  padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.28);
  font-family:var(--ff-display);font-weight:700;font-size:.7rem;
  letter-spacing:.2em;text-transform:uppercase;color:#bcd6df}
.vela-folio b{color:var(--sand)}
.vela-folio .vela-folio__sp{flex:1 1 auto;height:0;border-top:1px solid rgba(255,255,255,.2);min-width:1rem}

.vela-hero__grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.6rem,4vw,3.4rem);
  align-items:center;padding-block:clamp(2.4rem,6vw,4.6rem);
}
.vela-hero__badge{display:inline-flex;align-items:center;gap:.5rem;
  background:var(--sand);border:2px solid var(--navy);color:var(--navy);
  padding:.35rem .8rem;border-radius:3px;font-size:.76rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;font-family:var(--ff-display);
  box-shadow:3px 3px 0 rgba(0,0,0,.35)}
.vela-hero__badge b{color:var(--teal-deep)}
.vela-hero h1{
  font-size:clamp(2.5rem,1rem + 6.4vw,5.4rem);font-weight:800;margin-top:1.1rem;
  text-transform:uppercase;letter-spacing:-.025em;line-height:.92;
  text-shadow:4px 4px 0 rgba(0,0,0,.28);
}
.vela-hero h1 em{font-style:italic;color:var(--sand)}
.vela-hero__lead{margin-top:1.3rem;font-size:1.12rem;max-width:34rem;color:#dbe9ee}
.vela-hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.vela-hero__cta .vela-btn--sand{box-shadow:5px 5px 0 rgba(0,0,0,.4)}

.vela-hero__meta{display:flex;flex-wrap:wrap;margin-top:2rem;border:2px solid rgba(255,255,255,.35)}
.vela-hero__meta div{display:flex;flex-direction:column;padding:.8rem 1.15rem;flex:1 1 6rem;
  border-right:1px solid rgba(255,255,255,.22)}
.vela-hero__meta div:last-child{border-right:0}
.vela-hero__meta b{font-family:var(--ff-display);font-size:1.7rem;font-weight:800;color:#fff;line-height:1}
.vela-hero__meta span{font-size:.68rem;color:#bcd0d8;text-transform:uppercase;letter-spacing:.12em;margin-top:.3rem}

/* hero right: start-line photo plate + timing board */
.vela-startline{display:flex;flex-direction:column;gap:1rem}
.vela-lights{display:flex;gap:.55rem;justify-content:flex-end}
.vela-lights i{display:block;width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#ff6a5a,#c1231a);border:2px solid rgba(0,0,0,.35)}
.vela-plate{margin:0;position:relative;border:3px solid #fff;background:#fff;
  box-shadow:10px 10px 0 rgba(0,0,0,.35)}
.vela-plate img{width:100%;height:clamp(9rem,20vw,13rem);object-fit:cover;display:block}
.vela-plate figcaption{display:flex;align-items:center;gap:.5rem;
  background:var(--navy);color:#fff;font-family:var(--ff-display);font-weight:700;
  font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:.5rem .7rem}
.vela-plate figcaption b{margin-left:auto;color:var(--sand);font-size:.92rem;letter-spacing:.04em}
.vela-plate::before{content:"";position:absolute;top:.5rem;left:.5rem;z-index:2;
  width:14px;height:14px;background:var(--checker);background-size:7px 7px;border:1px solid #fff}

.vela-board{background:var(--paper);border:2px solid var(--navy);box-shadow:8px 8px 0 rgba(0,0,0,.3)}
.vela-board__t{display:flex;align-items:center;gap:.5rem;background:var(--navy);color:#fff;
  font-family:var(--ff-display);font-weight:800;font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;padding:.5rem .75rem}
.vela-board__t::after{content:"LIVE";margin-left:auto;color:var(--navy);background:var(--teal);
  font-size:.6rem;padding:.12rem .4rem;border-radius:2px;letter-spacing:.1em}
.vela-board__r{display:grid;grid-template-columns:2rem 1fr auto;gap:.7rem;align-items:center;
  padding:.5rem .75rem;border-top:1px solid var(--hair);color:var(--navy)}
.vela-board__r b{font-family:var(--ff-display);font-weight:800;color:var(--navy)}
.vela-board__pos{font-family:var(--ff-display);font-weight:800;font-size:.9rem;color:#fff;
  background:var(--teal-deep);width:1.9rem;height:1.9rem;display:grid;place-items:center;border-radius:2px}
.vela-board__r:first-of-type .vela-board__pos{background:var(--sand);color:var(--navy)}
.vela-board__nm{font-family:var(--ff-display);font-weight:700;font-size:.9rem;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.vela-board__sc{font-family:var(--ff-display);font-weight:800;font-size:1rem;color:var(--teal-deep)}

/* checkered start-line divider replacing the wave */
.vela-startdiv{height:16px;background:var(--checker);background-size:16px 16px;
  border-top:3px solid var(--navy);border-bottom:3px solid var(--navy)}

/* ============================================================
   MODES TICKER — scrolling race-mode marquee
   ============================================================ */
.vela-ticker{background:var(--navy);color:#fff;overflow:hidden;border-bottom:3px solid var(--sand);
  padding-block:.6rem}
.vela-ticker__track{display:inline-flex;white-space:nowrap;gap:2.5rem;padding-left:2.5rem;
  font-family:var(--ff-display);font-weight:800;font-size:.86rem;letter-spacing:.14em;
  text-transform:uppercase;will-change:transform;animation:vela-marq 26s linear infinite}
.vela-ticker__track span{display:inline-flex;align-items:center;gap:2.5rem}
.vela-ticker__track span::after{content:"";width:9px;height:9px;background:var(--sand);
  transform:rotate(45deg)}
.vela-ticker__track b{color:var(--sand);font-weight:800}
@keyframes vela-marq{to{transform:translateX(-50%)}}

/* ============================================================
   FEATURED — cover-story spreads
   ============================================================ */
.vela-featured{padding-block:clamp(3rem,7vw,5.5rem);background:var(--foam)}
.vela-feat{
  display:grid;grid-template-columns:1.05fr .95fr;gap:0;
  margin-bottom:clamp(2.2rem,5vw,3.4rem);border:3px solid var(--navy);
  background:var(--white);box-shadow:var(--shadow-lg);
}
.vela-feat:last-child{margin-bottom:0}
.vela-feat>*{min-width:0}
.vela-feat--flip .vela-feat__media{order:2}
.vela-feat__media{position:relative;overflow:hidden;aspect-ratio:16/11;
  border-right:3px solid var(--navy)}
.vela-feat--flip .vela-feat__media{border-right:0;border-left:3px solid var(--navy)}
.vela-feat__media img{width:100%;height:100%;object-fit:cover}
.vela-feat__media::after{content:"";position:absolute;left:0;right:0;bottom:0;height:40%;
  background:linear-gradient(180deg,transparent,rgba(12,32,51,.5))}
.vela-feat__badge{
  position:absolute;left:0;top:1rem;z-index:2;display:flex;align-items:center;gap:.55rem;
  background:var(--navy);border:0;padding:.45rem .75rem .45rem .5rem;
  font-family:var(--ff-display);font-weight:800;font-size:.8rem;color:#fff;
  text-transform:uppercase;letter-spacing:.04em;box-shadow:4px 4px 0 var(--sand)}
.vela-feat__badge img{width:30px;height:30px;border-radius:3px;border:1px solid rgba(255,255,255,.4)}
.vela-feat__rank{
  position:absolute;right:1rem;bottom:1rem;z-index:2;color:var(--navy);background:var(--sand);
  font-family:var(--ff-display);font-weight:800;font-size:.86rem;padding:.3rem .6rem;border-radius:2px;
  display:flex;align-items:center;gap:.35rem;border:2px solid var(--navy)}
.vela-feat__body{padding:clamp(1.4rem,3vw,2.4rem)}
.vela-feat__body h3{font-size:clamp(1.7rem,1rem + 2.6vw,2.6rem);font-weight:800;
  text-transform:uppercase;letter-spacing:-.02em;line-height:.98;margin-top:.5rem}
.vela-feat__seller{color:var(--teal-deep);font-weight:700;font-family:var(--ff-display);
  text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;margin-top:.4rem;display:block}
.vela-feat__body p{margin-top:1rem;color:#3a4f60}
.vela-feat__stats{display:flex;flex-wrap:wrap;gap:0;margin-top:1.4rem;border:2px solid var(--navy)}
.vela-feat__stats div{display:flex;flex-direction:column;line-height:1.2;padding:.65rem .9rem;
  flex:1 1 0;min-width:0;border-right:1px solid var(--hair)}
.vela-feat__stats div:last-child{border-right:0}
.vela-feat__stats b{font-family:var(--ff-display);font-weight:800;font-size:1.35rem;color:var(--navy)}
.vela-feat__stats span{font-size:.68rem;color:#5a6f7e;text-transform:uppercase;letter-spacing:.1em;margin-top:.15rem}
.vela-feat__cta{margin-top:1.5rem}
.vela-stars{color:var(--sand-deep);letter-spacing:.05em}
.vela-chip{display:inline-flex;font-family:var(--ff-display);font-weight:800;
  font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:#fff;
  background:var(--teal-deep);padding:.28rem .6rem;border-radius:2px}

/* ============================================================
   STARTING GRID — griglia di partenza (timing sheet)
   ============================================================ */
.vela-games{background:var(--foam-2)}
.vela-startgrid{
  background:var(--white);overflow:hidden;
  border:3px solid var(--navy);box-shadow:var(--shadow-lg);
}
.vela-startgrid__flag{height:16px;background:var(--checker);background-size:16px 16px;
  border-bottom:3px solid var(--navy)}
.vela-startgrid__head{
  display:grid;grid-template-columns:4.4rem minmax(0,1fr) 11rem 7rem 8.6rem;
  gap:1.1rem;align-items:center;padding:.7rem 1.5rem;
  background:var(--navy);color:var(--sand);
  font-family:var(--ff-display);font-weight:800;font-size:.68rem;
  text-transform:uppercase;letter-spacing:.18em;
}
.vela-startgrid__head span:nth-child(4){justify-self:center}
.vela-startgrid__head span:nth-child(5){justify-self:end}

.vela-row{
  display:grid;grid-template-columns:4.4rem minmax(0,1fr) 11rem 7rem 8.6rem;
  grid-template-areas:"pos id genre rate cta";
  gap:1.1rem;align-items:center;padding:.95rem 1.5rem;
  border-top:1px solid var(--hair);transition:background .16s ease;
}
.vela-row:nth-of-type(even){background:rgba(12,32,51,.035)}
.vela-row:hover{background:var(--sand);color:var(--navy)}

.vela-row__pos{
  grid-area:pos;display:flex;align-items:center;justify-content:center;
  width:3.3rem;height:3.3rem;border-radius:3px;
  font-family:var(--ff-display);font-weight:800;font-size:1.16rem;color:#fff;letter-spacing:-.02em;
  background:var(--navy);border:2px solid var(--navy);
}
.vela-row__pos--gold{background:var(--sand);color:var(--navy);box-shadow:3px 3px 0 var(--navy)}
.vela-row__pos--silver{background:#cdd8de;color:var(--navy)}
.vela-row__pos--bronze{background:#cf9668;color:#fff}

.vela-row__id{grid-area:id;display:flex;align-items:center;gap:.95rem;min-width:0}
.vela-row__icon{width:56px;height:56px;border-radius:4px;border:2px solid var(--navy);flex:0 0 auto}
.vela-row__name{min-width:0}
.vela-row__name h3{font-size:1.12rem;font-weight:800;color:var(--navy);text-transform:uppercase;letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vela-row:hover .vela-row__name h3{color:var(--navy)}
.vela-row__name span{font-size:.78rem;color:#5a6f7e;display:block;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.vela-row__genre{grid-area:genre;justify-self:start;
  font-family:var(--ff-display);font-weight:800;font-size:.68rem;
  text-transform:uppercase;letter-spacing:.08em;color:var(--teal-deep);
  border:1.5px solid var(--teal-deep);padding:.28rem .6rem;border-radius:2px;white-space:nowrap}
.vela-row:hover .vela-row__genre{border-color:var(--navy);color:var(--navy)}

.vela-row__rate{grid-area:rate;display:flex;flex-direction:column;align-items:center;
  justify-self:center;line-height:1.15;text-align:center}
.vela-row__rate b{font-family:var(--ff-display);font-weight:800;font-size:1.34rem;color:var(--navy)}
.vela-row__rate .vela-stars{font-size:.66rem}
.vela-row__rate small{font-size:.66rem;color:#5a6f7e}

.vela-row__cta{grid-area:cta;justify-self:stretch}
.vela-row__cta .vela-btn{width:100%;padding:.6rem 1rem;font-size:.82rem;box-shadow:3px 3px 0 var(--navy)}
.vela-row__cta .vela-btn:hover{transform:translate(3px,3px);box-shadow:0 0 0 var(--navy)}

@media (max-width:860px){
  .vela-startgrid__head{display:none}
  .vela-row{
    grid-template-columns:3.4rem minmax(0,1fr) auto;
    grid-template-areas:"pos id rate" "pos genre cta";
    row-gap:.7rem;padding:1rem 1.1rem;
  }
  .vela-row__pos{width:2.9rem;height:2.9rem;font-size:1.02rem}
  .vela-row__rate{justify-self:end;flex-direction:row;align-items:baseline;gap:.4rem}
  .vela-row__rate small{display:none}
  .vela-row__cta{justify-self:end}
  .vela-row__cta .vela-btn{width:auto}
}
@media (max-width:460px){
  .vela-row{
    grid-template-columns:2.8rem minmax(0,1fr);
    grid-template-areas:"pos id" "pos rate" "cta cta";
  }
  .vela-row__genre{display:none}
  .vela-row__rate{justify-self:start}
  .vela-row__cta{justify-self:stretch;margin-top:.2rem}
  .vela-row__cta .vela-btn{width:100%}
}

/* ============================================================
   REVIEWS — press clippings
   ============================================================ */
.vela-reviews{background:var(--navy);color:var(--foam);position:relative;overflow:hidden}
.vela-reviews__scroll{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:var(--gap);
}
.vela-quote{
  background:var(--paper);color:var(--ink);
  border:2px solid #000;box-shadow:6px 6px 0 rgba(0,0,0,.35);
  padding:1.3rem 1.35rem;position:relative;
  display:flex;flex-direction:column;gap:.75rem;
}
.vela-quote::before{content:"";position:absolute;top:0;left:0;right:0;height:7px;
  background:var(--checker);background-size:7px 7px}
.vela-quote__stars{color:var(--sand-deep);font-size:.95rem;letter-spacing:.08em;margin-top:.4rem}
.vela-quote p{color:#22333f;font-size:.98rem}
.vela-quote__who{display:flex;align-items:center;gap:.75rem;margin-top:auto;
  padding-top:.7rem;border-top:1px solid var(--hair)}
.vela-quote__av{width:42px;height:42px;border-radius:2px;display:grid;place-items:center;
  font-family:var(--ff-display);font-weight:800;color:#fff;background:var(--navy);flex:0 0 auto}
.vela-quote__who b{font-family:var(--ff-display);font-weight:800;font-size:.96rem;color:var(--navy);display:block}
.vela-quote__who span{font-size:.78rem;color:#5a6f7e}

/* ============================================================
   STATS BAND — big timing figures
   ============================================================ */
.vela-stats{position:relative;overflow:hidden;color:#fff;isolation:isolate;
  border-block:4px solid var(--navy)}
.vela-stats__bg{position:absolute;inset:0;z-index:-2}
.vela-stats__bg img{width:100%;height:100%;object-fit:cover}
.vela-stats__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(9,25,40,.94),rgba(12,32,51,.9))}
.vela-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  padding-block:clamp(2.6rem,6vw,4.4rem);text-align:center}
.vela-stat{padding:.5rem 1rem}
.vela-stat b{display:block;font-family:var(--ff-display);font-weight:800;
  font-size:clamp(2.2rem,1.2rem + 3.4vw,3.6rem);color:#fff;line-height:1}
.vela-stat span{display:block;margin-top:.4rem;font-size:.78rem;color:var(--sand);
  text-transform:uppercase;letter-spacing:.14em}
.vela-stat + .vela-stat{border-left:2px solid rgba(255,255,255,.2)}

/* ============================================================
   MODES — race-mode ledger over a photo band
   ============================================================ */
.vela-modes{position:relative;overflow:hidden;color:var(--foam);isolation:isolate;
  padding-block:clamp(3rem,7vw,6rem);border-block:4px solid var(--navy)}
.vela-modes__bg{position:absolute;inset:0;z-index:-2}
.vela-modes__bg img{width:100%;height:100%;object-fit:cover}
.vela-modes__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(9,20,33,.96) 40%,rgba(12,32,51,.9) 70%,rgba(14,127,146,.62))}
.vela-modes__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border:2px solid rgba(255,255,255,.4)}
.vela-mode{position:relative;display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:start;
  padding:1.5rem 1.5rem;border:1px solid rgba(255,255,255,.22);
  transition:background .18s ease}
.vela-mode:hover{background:rgba(230,201,138,.14)}
.vela-mode__num{font-family:var(--ff-display);font-weight:800;font-size:2.6rem;
  color:var(--sand);line-height:.8;letter-spacing:-.03em}
.vela-mode__ic{display:none}
.vela-mode h3{font-family:var(--ff-display);font-weight:800;font-size:1.32rem;color:#fff;
  text-transform:uppercase;letter-spacing:-.01em}
.vela-mode p{color:#dbe9ee;font-size:.95rem;line-height:1.55;margin-top:.35rem;grid-column:2}

/* ============================================================
   PADDOCK — classi di veicoli (spec-plate cards)
   ============================================================ */
.vela-paddock{background:var(--foam);padding-block:clamp(3rem,7vw,6rem)}
.vela-paddock__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap)}
.vela-class{position:relative;display:flex;flex-direction:column;gap:.7rem;overflow:hidden;
  background:var(--white);border:2px solid var(--navy);
  padding:1.5rem 1.35rem 1.25rem;box-shadow:var(--shadow-md);
  transition:box-shadow .18s ease,transform .18s ease}
.vela-class::before{content:"";position:absolute;top:0;left:0;right:0;height:8px;
  background:var(--checker);background-size:8px 8px;border-bottom:2px solid var(--navy)}
.vela-class:hover{box-shadow:0 0 0 rgba(0,0,0,0);transform:translate(4px,4px)}
.vela-class__top{display:flex;align-items:center;gap:.9rem;margin-top:.5rem}
.vela-class__ic{width:54px;height:54px;border-radius:3px;flex:0 0 auto;display:grid;place-items:center;
  background:var(--navy);border:2px solid var(--navy)}
.vela-class__ic svg{width:30px;height:30px;stroke:var(--sand);fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round}
.vela-class__plate{margin-left:auto;font-family:var(--ff-display);font-weight:800;
  font-size:.74rem;letter-spacing:.14em;color:#fff;
  background:var(--teal-deep);border-radius:2px;padding:.22rem .55rem}
.vela-class h3{font-size:1.28rem;font-weight:800;color:var(--navy);text-transform:uppercase;
  letter-spacing:-.01em;margin-top:.2rem}
.vela-class p{color:#3a4f60;font-size:.94rem}
.vela-class__games{margin-top:auto;display:flex;flex-wrap:wrap;gap:.45rem;padding-top:.6rem;
  border-top:1px solid var(--hair)}
.vela-class__game{display:inline-flex;align-items:center;gap:.42rem;
  background:var(--foam);border:1.5px solid var(--navy);border-radius:2px;
  padding:.26rem .6rem .26rem .3rem;font-family:var(--ff-display);font-weight:700;
  font-size:.74rem;color:var(--navy)}
.vela-class__game img{width:22px;height:22px;border-radius:2px;flex:0 0 auto}

/* ============================================================
   CIRCUITS — printed circuit diagrams
   ============================================================ */
.vela-circuits{background:var(--foam-2);padding-block:clamp(3rem,7vw,6rem)}
.vela-circuits__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap)}
.vela-circuit{position:relative;display:flex;flex-direction:column;gap:.6rem;overflow:hidden;
  background:var(--navy);color:var(--foam);
  border:3px solid var(--navy);box-shadow:var(--shadow-md);
  transition:box-shadow .18s ease,transform .18s ease}
.vela-circuit:hover{transform:translate(4px,4px);box-shadow:0 0 0}
.vela-circuit__map{display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  padding:1rem 1.25rem .4rem;background:rgba(255,255,255,.04)}
.vela-circuit__map svg{width:120px;height:40px;overflow:visible;flex:0 0 auto}
.vela-circuit__no{width:38px;height:38px;border-radius:3px;flex:0 0 auto;display:grid;place-items:center;
  font-family:var(--ff-display);font-weight:800;font-size:1.05rem;color:var(--navy);
  background:var(--sand);border:2px solid #000}
.vela-circuit__loc,.vela-circuit h3,.vela-circuit p{margin-inline:1.25rem}
.vela-circuit__loc{font-family:var(--ff-display);font-weight:800;font-size:.72rem;color:var(--sand);
  text-transform:uppercase;letter-spacing:.12em;margin-top:.3rem}
.vela-circuit h3{color:#fff;font-size:1.24rem;font-weight:800;text-transform:uppercase;letter-spacing:-.01em}
.vela-circuit p{color:#cddbe2;font-size:.92rem;line-height:1.55}
.vela-circuit__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;
  gap:.6rem;padding:.85rem 1.25rem;border-top:1px dashed rgba(255,255,255,.28)}
.vela-diff{display:flex;align-items:center;gap:.5rem;font-family:var(--ff-display);font-weight:800;
  font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#dbe9ee}
.vela-diff__bars{display:flex;gap:3px}
.vela-diff__bars i{display:block;width:7px;height:15px;background:rgba(255,255,255,.22)}
.vela-diff--1 .vela-diff__bars i:nth-child(-n+1),
.vela-diff--2 .vela-diff__bars i:nth-child(-n+2),
.vela-diff--3 .vela-diff__bars i:nth-child(-n+3){background:var(--sand)}
.vela-circuit__len{font-family:var(--ff-display);font-weight:800;font-size:.78rem;color:var(--sand)}

@media (max-width:960px){
  .vela-paddock__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vela-circuits__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vela-reviews__scroll{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vela-modes__grid{grid-template-columns:1fr}
}
@media (max-width:600px){
  .vela-paddock__grid{grid-template-columns:1fr}
  .vela-circuits__grid{grid-template-columns:1fr}
  .vela-reviews__scroll{grid-template-columns:1fr}
}

/* ============================================================
   NEWSLETTER + CONTACT — race entry form
   ============================================================ */
.vela-news{position:relative;overflow:hidden;color:#fff;isolation:isolate;border-block:4px solid var(--navy)}
.vela-news__bg{position:absolute;inset:0;z-index:-2}
.vela-news__bg img{width:100%;height:100%;object-fit:cover}
.vela-news__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(9,20,33,.96),rgba(14,127,146,.72))}
.vela-news__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3.2rem);
  align-items:start;padding-block:clamp(3rem,7vw,5rem)}
.vela-news__intro h2{font-size:clamp(2rem,1.2rem + 3.4vw,3.2rem);font-weight:800;color:#fff;
  text-transform:uppercase;letter-spacing:-.02em;margin-top:.6rem;line-height:.98}
.vela-news__intro p{margin-top:1rem;color:#dbe9ee;max-width:32rem}
.vela-contacts{display:grid;gap:0;margin-top:1.8rem;border:2px solid rgba(255,255,255,.4)}
.vela-contact{display:flex;gap:.9rem;align-items:center;padding:.85rem 1rem;
  border-bottom:1px solid rgba(255,255,255,.2)}
.vela-contact:last-child{border-bottom:0}
.vela-contact__ic{width:42px;height:42px;border-radius:3px;flex:0 0 auto;display:grid;place-items:center;
  background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.35)}
.vela-contact__ic svg{width:20px;height:20px;stroke:var(--sand)}
.vela-contact b{font-family:var(--ff-display);display:block;color:#fff;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.1em}
.vela-contact span,.vela-contact a{color:#cfe1e8;font-size:.94rem}
.vela-contact a:hover{color:#fff;text-decoration:underline}

.vela-form{background:var(--paper);border:3px solid var(--navy);padding:clamp(1.4rem,3vw,2.2rem);
  box-shadow:var(--shadow-lg);color:var(--ink);position:relative}
.vela-form::before{content:"";position:absolute;top:0;left:0;right:0;height:9px;
  background:var(--checker);background-size:9px 9px;border-bottom:2px solid var(--navy)}
.vela-form h3{color:var(--navy);font-size:1.5rem;font-weight:800;text-transform:uppercase;
  letter-spacing:-.01em;margin-top:.6rem}
.vela-form p.vela-form__sub{color:#5a6f7e;font-size:.94rem;margin-top:.35rem;margin-bottom:1.2rem}
.vela-field{margin-bottom:1rem}
.vela-field label{display:block;font-family:var(--ff-display);font-weight:800;font-size:.78rem;
  color:var(--navy);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.08em}
.vela-field input{width:100%;padding:.85rem 1rem;border-radius:2px;border:2px solid var(--navy);
  background:#fff;font-family:inherit;font-size:1rem;color:var(--ink);transition:box-shadow .15s}
.vela-field input:focus{outline:none;box-shadow:3px 3px 0 var(--teal)}
.vela-consent{display:flex;gap:.65rem;align-items:flex-start;margin-bottom:1.1rem;font-size:.86rem;color:#3a4f60}
.vela-consent input{width:20px;height:20px;flex:0 0 auto;margin-top:.15rem;accent-color:var(--teal)}
.vela-consent a{color:var(--teal-deep);text-decoration:underline}
.vela-form button[type=submit]{width:100%}
.vela-success{display:none;margin-top:1rem;padding:.9rem 1.1rem;border-radius:2px;
  background:var(--navy);border:2px solid var(--navy);color:#fff;
  font-family:var(--ff-display);font-weight:700;font-size:.94rem}
.vela-success.show{display:block}

/* ============================================================
   ABOUT — editorial colophon
   ============================================================ */
.vela-about{background:var(--foam)}
.vela-about__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.vela-about__body h2{font-size:clamp(2rem,1.2rem + 3.4vw,3.2rem);font-weight:800;
  text-transform:uppercase;letter-spacing:-.02em;margin-top:.5rem;line-height:.98}
.vela-about__body p{margin-top:1rem;color:#3a4f60}
.vela-about__points{display:grid;gap:0;margin-top:1.5rem;border:2px solid var(--navy)}
.vela-about__points li{display:flex;gap:.7rem;align-items:flex-start;color:#22333f;
  padding:.75rem .9rem;border-bottom:1px solid var(--hair)}
.vela-about__points li:last-child{border-bottom:0}
.vela-about__points svg{width:22px;height:22px;flex:0 0 auto;margin-top:.1rem;stroke:var(--teal-deep)}
.vela-about__media{position:relative}
.vela-about__media img{border:3px solid var(--navy);box-shadow:var(--shadow-lg);width:100%}
.vela-about__nap{margin-top:1.4rem;background:var(--white);border:2px solid var(--navy);
  padding:1.1rem 1.2rem}
.vela-about__nap b{font-family:var(--ff-display);color:var(--navy);display:block;margin-bottom:.3rem;
  text-transform:uppercase;letter-spacing:.06em}
.vela-about__nap p{color:#3a4f60;font-size:.94rem;margin:0}
.vela-about__nap a{color:var(--teal-deep)}

/* ============================================================
   FOOTER — colophon
   ============================================================ */
.vela-footer{background:var(--navy);color:#c6d6de;padding-block:clamp(2.8rem,6vw,4rem) 2rem;
  border-top:6px solid var(--sand)}
.vela-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem}
.vela-footer__brand{display:flex;align-items:center;gap:.6rem;font-family:var(--ff-display);
  font-weight:800;font-size:1.32rem;color:#fff;text-transform:uppercase}
.vela-footer__brand img{width:40px;height:40px;border-radius:3px;border:2px solid rgba(255,255,255,.4)}
.vela-footer p.vela-footer__blurb{margin-top:1rem;font-size:.9rem;max-width:26rem;color:#9db2bc}
.vela-footer h4{font-family:var(--ff-display);color:var(--sand);font-size:.82rem;margin-bottom:.9rem;
  text-transform:uppercase;letter-spacing:.14em}
.vela-footer__col a,.vela-footer__col span{display:block;font-size:.9rem;color:#a9bec8;padding:.22rem 0}
.vela-footer__col a{text-transform:uppercase;letter-spacing:.03em;font-size:.82rem;font-family:var(--ff-display);font-weight:600}
.vela-footer__col a:hover{color:var(--sand)}
.vela-footer__nap{font-size:.88rem;color:#a9bec8;line-height:1.7}
.vela-footer__nap a:hover{color:var(--sand)}
.vela-footer__bar{border-top:1px solid rgba(255,255,255,.14);margin-top:2.4rem;padding-top:1.4rem;
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;font-size:.82rem;color:#8ba3ae}
.vela-footer__bar a:hover{color:var(--sand)}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.vela-cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:80;max-width:44rem;margin-inline:auto;
  background:var(--navy);color:var(--foam);border:2px solid var(--sand);
  border-radius:3px;padding:1.1rem 1.3rem;box-shadow:var(--shadow-lg);
  display:none;gap:1rem;align-items:center;flex-wrap:wrap}
.vela-cookie.show{display:flex}
.vela-cookie p{flex:1 1 16rem;font-size:.88rem;color:#d6e5ea}
.vela-cookie a{color:var(--sand);text-decoration:underline}
.vela-cookie__btns{display:flex;gap:.6rem;flex-wrap:wrap}
.vela-cookie .vela-btn{padding:.6rem 1.1rem;font-size:.82rem}

/* ============================================================
   LEGAL / GENERIC PAGE
   ============================================================ */
.vela-page-hero{background:var(--navy);color:#fff;border-bottom:4px solid var(--sand);
  padding-block:clamp(3rem,7vw,4.6rem)}
.vela-page-hero h1{font-size:clamp(2rem,1.3rem + 3vw,3.2rem);font-weight:800;text-transform:uppercase;letter-spacing:-.02em}
.vela-page-hero p{margin-top:.8rem;color:#d4e6ec;max-width:40rem}
.vela-prose{max-width:52rem;padding-block:clamp(2.6rem,6vw,4rem)}
.vela-prose h2{font-size:1.5rem;font-weight:800;color:var(--navy);margin-top:2.2rem;margin-bottom:.6rem;text-transform:uppercase}
.vela-prose h2:first-child{margin-top:0}
.vela-prose h3{font-size:1.15rem;color:var(--navy);margin-top:1.4rem;margin-bottom:.4rem}
.vela-prose p{margin-top:.7rem;color:#3a4f60}
.vela-prose ul{margin-top:.7rem;display:grid;gap:.45rem}
.vela-prose ul li{padding-left:1.3rem;position:relative;color:#3a4f60}
.vela-prose ul li::before{content:"";position:absolute;left:0;top:.55rem;width:8px;height:8px;
  background:var(--teal);transform:rotate(45deg)}
.vela-prose a{color:var(--teal-deep);text-decoration:underline}
.vela-prose__nap{background:var(--foam);border-left:4px solid var(--teal);
  padding:1.1rem 1.3rem;margin-top:1rem}
.vela-prose__meta{color:#5a6f7e;font-size:.9rem;margin-bottom:.5rem}

/* 404 */
.vela-404{min-height:70vh;display:grid;place-items:center;text-align:center;
  background:var(--navy);color:#fff;padding:3rem 1.5rem}
.vela-404 h1{font-size:clamp(4rem,10vw,7rem);font-weight:800;color:var(--sand);text-transform:uppercase}
.vela-404 p{margin:1rem auto 2rem;max-width:32rem;color:#d4e6ec;font-size:1.1rem}
.vela-404 .vela-btn{margin:.3rem}

.vela-skip{position:absolute;left:-999px;top:0;background:var(--teal);color:#fff;padding:.6rem 1rem;
  border-radius:0 0 3px 0;z-index:100}
.vela-skip:focus{left:0}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .vela-nav{display:none}
  .vela-burger{display:flex}
  .vela-hero__grid{grid-template-columns:1fr;gap:2rem}
  .vela-feat{grid-template-columns:1fr}
  .vela-feat__media{border-right:0;border-bottom:3px solid var(--navy);aspect-ratio:16/9}
  .vela-feat--flip .vela-feat__media{order:0;border-left:0;border-bottom:3px solid var(--navy)}
  .vela-stats__grid{grid-template-columns:repeat(2,1fr);gap:0}
  .vela-stat:nth-child(3){border-left:0}
  .vela-stat:nth-child(n+3){border-top:2px solid rgba(255,255,255,.2)}
  .vela-news__grid{grid-template-columns:1fr}
  .vela-about__grid{grid-template-columns:1fr}
  .vela-about__media{order:-1}
  .vela-footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .vela-footer__grid{grid-template-columns:1fr}
  .vela-hero__meta{border:0;flex-direction:column;gap:0}
  .vela-hero__meta div{border-right:0;border:2px solid rgba(255,255,255,.35);border-bottom:0;flex-basis:auto}
  .vela-hero__meta div:last-child{border-bottom:2px solid rgba(255,255,255,.35)}
  .vela-cookie{flex-direction:column;align-items:stretch}
  .vela-cookie__btns .vela-btn{flex:1}
}
@media (max-width:360px){
  .vela-hero__meta b{font-size:1.4rem}
  .vela-brand{font-size:1.12rem}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important}
  .vela-ticker__track{animation:none!important}
}
