/* =====================================================================
   BuranoMurano — "La Fondamenta"
   CONCEPT: a row of Burano's painted canal-house facades, reflected in
   the Murano lagoon. Every game is a colored HOUSE with a terracotta
   roofline, a shuttered mullioned window and a monospace door-plaque.
   CONSTITUTION
   - Colors: Burano palette used as ARCHITECTURE (whole-facade planes),
     ink #17203a for outlines/lettering, paper #f4f2ec for plaster/sky.
     One deep canal band (cobalt->aqua) is the single full-bleed anchor.
   - Type: Plus Jakarta Sans, huge, for house-signs & headlines;
     Space Mono for plaques, numbers, coordinates, meta.
   - Material: hard 2px ink rules only (NO blur shadows). Signature
     motifs drawn in CSS: roof friezes of glass tesserae, louvered
     shutters, mullioned windows, a waterline + wavy reflection.
   - Layout: CENTERED container, max 90rem, margin-inline:auto, every
     block centered — never left-hugged. Interlocking house widths.
   - Signature element: the FACADE UNIT (roof frieze + shuttered window
     + mono door-plaque), repeated for every game.
   ===================================================================== */
@import url('../fonts/fonts.css');

:root{
  --white:#ffffff;
  --paper:#f4f2ec;
  --plaster:#efe9dc;
  --ink:#17203a;
  --ink-70:rgba(23,32,58,.7);
  --ink-45:rgba(23,32,58,.45);
  --line:#17203a;
  --coral:#ff6b5e;
  --sunny:#ffc42e;
  --aqua:#2ec4c4;
  --cobalt:#2b6cff;
  --pink:#ff77b7;
  --terra:#d8543f;          /* terracotta cornice / rooftiles */
  --accent:var(--coral);
  --maxw:90rem;             /* centered ~1440px, NOT left-hugged 1920 */
  --gut:1.25rem;
  --bw:2px;
  --frieze:linear-gradient(90deg,var(--coral) 0 20%,var(--sunny) 20% 40%,var(--aqua) 40% 60%,var(--cobalt) 60% 80%,var(--pink) 80% 100%);
  --disp:'Plus Jakarta Sans',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--disp);
  color:var(--ink);
  background:var(--paper);
  line-height:1.5;
  font-weight:500;
  overflow-x:hidden;
}
/* faint plaster grain — material without color */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.04;mix-blend-mode:multiply;
  background-image:radial-gradient(var(--ink) .5px,transparent .6px);background-size:4px 4px;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:800;line-height:1;letter-spacing:-.025em}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
:focus-visible{outline:3px solid var(--cobalt);outline-offset:2px}

/* ---------- layout primitives ---------- */
.bm-wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1rem,4vw,3rem);position:relative;z-index:1}
.bm-mono{font-family:var(--mono);font-weight:400;letter-spacing:.06em}
.bm-kick{
  font-family:var(--mono);font-size:.72rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;display:inline-flex;gap:.6ch;align-items:center;
}
.bm-kick::before{content:'';width:.55rem;height:.55rem;background:var(--accent);border:1.5px solid var(--ink)}

.bm-section{padding-block:clamp(3.2rem,7vw,5.5rem);border-top:var(--bw) solid var(--line)}
/* section head as a hanging enamel street-plate — centered stack */
.bm-shead{max-width:64rem;margin:0 auto clamp(2rem,4vw,3rem);text-align:center;display:grid;gap:1rem;justify-items:center}
.bm-shead__idx{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);background:var(--white);border:var(--bw) solid var(--ink);padding:.4rem .9rem;
}
.bm-shead h2{font-size:clamp(2rem,5.4vw,3.6rem);line-height:.98}
.bm-shead p{max-width:52ch;color:var(--ink-70);font-weight:500}

/* ---------- top bar (enamel canal sign) ---------- */
.bm-top{position:sticky;top:0;z-index:60;background:var(--paper);border-bottom:var(--bw) solid var(--line)}
.bm-top__in{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:4.25rem}
.bm-brand{display:flex;align-items:center;gap:.7rem;font-weight:800;font-size:1.15rem;letter-spacing:-.03em}
/* brand mark = a 2x2 Murano glass tessera */
.bm-brand__mk{width:1.9rem;height:1.9rem;border:2px solid var(--ink);display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;overflow:hidden}
.bm-brand__mk i{display:block}
.bm-brand__mk i:nth-child(1){background:var(--coral)}
.bm-brand__mk i:nth-child(2){background:var(--sunny)}
.bm-brand__mk i:nth-child(3){background:var(--aqua)}
.bm-brand__mk i:nth-child(4){background:var(--cobalt)}
.bm-brand b{color:var(--ink)}
.bm-brand span{color:var(--terra)}
.bm-nav{display:none}
.bm-nav a{font-family:var(--mono);font-size:.82rem;letter-spacing:.03em;padding:.4rem 0;position:relative}
.bm-nav a::after{content:'';position:absolute;left:0;right:100%;bottom:.1rem;height:2px;background:var(--terra);transition:right .18s ease}
.bm-nav a:hover::after{right:0}
.bm-top__cta{display:none}
.bm-burger{
  display:inline-flex;align-items:center;gap:.6ch;font-family:var(--mono);font-size:.78rem;
  letter-spacing:.12em;text-transform:uppercase;background:var(--ink);color:var(--paper);
  border:none;padding:.7rem 1rem;cursor:pointer;font-weight:700;
}
.bm-burger svg{width:1.05rem;height:1.05rem}
@media(max-width:59.99rem){
  .bm-brand{font-size:.94rem;min-width:0}
  .bm-brand__mk{width:1.5rem;height:1.5rem;flex:none}
  .bm-top__in{gap:.5rem}
  .bm-burger{padding:.6rem .7rem;font-size:.72rem}
  .bm-burger svg{width:.95rem;height:.95rem}
}
@media(min-width:60rem){
  .bm-nav{display:flex;gap:1.15rem}
  .bm-top__cta{display:inline-flex}
  .bm-burger{display:none}
}
@media(min-width:75rem){.bm-nav{gap:1.6rem}}

.bm-btn{
  display:inline-flex;align-items:center;gap:.6ch;font-family:var(--mono);font-weight:700;
  font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.85rem 1.35rem;border:var(--bw) solid var(--ink);background:var(--ink);color:var(--paper);
  cursor:pointer;transition:transform .08s ease,box-shadow .08s ease;
}
.bm-btn:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--terra)}
.bm-btn--ghost{background:transparent;color:var(--ink)}
.bm-btn--ghost:hover{box-shadow:4px 4px 0 var(--cobalt)}
.bm-btn--accent{background:var(--accent);border-color:var(--ink);color:var(--ink)}

/* =====================================================================
   HERO — the fondamenta: plaster sky + centered sign, a row of painted
   houses on the canal, reflected in the water below.
   ===================================================================== */
.bm-hero{position:relative;background:linear-gradient(180deg,#eef4f7 0%,var(--paper) 62%);border-bottom:var(--bw) solid var(--line);overflow:hidden}
.bm-hero__in{position:relative;z-index:3;padding-block:clamp(3rem,7vw,5.5rem) 0;max-width:60rem;margin-inline:auto;text-align:center;display:grid;gap:1.35rem;justify-items:center}
.bm-hero .bm-kick{background:var(--white);border:var(--bw) solid var(--ink);padding:.45rem .9rem}
.bm-hero h1{font-size:clamp(2.6rem,8vw,5.6rem);line-height:.94;letter-spacing:-.035em;max-width:15ch}
.bm-hero h1 em{font-style:normal;color:var(--terra);position:relative;white-space:nowrap}
.bm-hero h1 em::after{content:'';position:absolute;left:0;right:0;bottom:.02em;height:.12em;background:var(--sunny);z-index:-1}
.bm-hero__lede{max-width:52ch;font-size:clamp(1rem,2vw,1.18rem);color:var(--ink-70);font-weight:500}
.bm-hero__cta{display:flex;flex-wrap:wrap;justify-content:center;gap:.9rem;margin-top:.3rem}
/* meta as three brass doorplates */
.bm-hero__meta{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:.6rem;border:var(--bw) solid var(--ink);background:var(--white);max-width:34rem;width:100%}
.bm-hero__meta div{padding:.9rem 1rem;border-right:var(--bw) solid var(--ink)}
.bm-hero__meta div:last-child{border-right:none}
.bm-hero__meta b{display:block;font-size:1.5rem;font-weight:800;font-family:var(--mono)}
.bm-hero__meta span{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-45)}

/* skyline of houses on the canal */
.bm-hero__town{position:relative;z-index:2;margin-top:clamp(2.2rem,5vw,3.6rem)}
.bm-hero__row{display:flex;align-items:flex-end;justify-content:center;gap:0;max-width:82rem;margin-inline:auto;padding-inline:clamp(1rem,4vw,3rem)}
.bm-fac{position:relative;flex:1 1 0;min-width:0;border:var(--bw) solid var(--ink);border-bottom:none;background:var(--c,var(--coral));height:var(--h,9rem)}
.bm-fac + .bm-fac{border-left:none}
/* roof frieze of tesserae */
.bm-fac::before{content:'';position:absolute;left:-2px;right:-2px;top:-.7rem;height:.7rem;background:var(--frieze);border:var(--bw) solid var(--ink);background-size:1.2rem 100%}
/* lit window with mullion cross */
.bm-fac::after{content:'';position:absolute;left:50%;top:1.1rem;transform:translateX(-50%);width:46%;max-width:3.2rem;aspect-ratio:3/4;background:var(--white);border:2px solid var(--ink);
  background-image:linear-gradient(var(--ink),var(--ink)),linear-gradient(var(--ink),var(--ink));
  background-size:100% 2px,2px 100%;background-position:center,center;background-repeat:no-repeat}
.bm-fac--img{overflow:hidden}
.bm-fac__win{position:absolute;left:1rem;right:1rem;top:1.1rem;bottom:1.1rem;border:2px solid var(--ink);object-fit:cover;width:auto;height:auto}
/* the canal: a dark waterline with a wavy reflection */
.bm-hero__canal{position:relative;z-index:2;height:clamp(3.2rem,7vw,5.5rem);
  background:linear-gradient(180deg,#1c3a63 0%,#123b52 45%,#0e2f45 100%);
  border-top:3px solid var(--ink);overflow:hidden}
.bm-hero__canal::before,.bm-hero__canal::after{content:'';position:absolute;left:0;right:0;height:2px;background:rgba(255,255,255,.18)}
.bm-hero__canal::before{top:38%}
.bm-hero__canal::after{top:64%;opacity:.55}
.bm-hero__coord{position:absolute;right:1rem;bottom:.7rem;z-index:4;font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;color:rgba(255,255,255,.7);display:none}
@media(min-width:60rem){.bm-hero__coord{display:block}}
/* thin out the skyline on small screens */
@media(max-width:34rem){.bm-fac:nth-child(n+6){display:none}}

/* ---------- filter tabs (enamel street plates) ---------- */
.bm-filter{border-top:var(--bw) solid var(--line);background:var(--plaster)}
.bm-filter__in{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1rem,4vw,3rem)}
.bm-tab{
  font-family:var(--mono);font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:.75rem 1.15rem;background:var(--white);border:var(--bw) solid var(--ink);
  cursor:pointer;color:var(--ink);display:flex;align-items:center;gap:.6ch;transition:transform .08s ease,box-shadow .08s ease;
}
.bm-tab small{color:var(--ink-45);font-size:.68rem}
.bm-tab[aria-pressed="true"]{background:var(--ink);color:var(--white)}
.bm-tab[aria-pressed="true"] small{color:rgba(255,255,255,.65)}
.bm-tab:hover:not([aria-pressed="true"]){transform:translate(-2px,-2px);box-shadow:3px 3px 0 var(--accent)}

/* =====================================================================
   GAME GRID — the fondamenta: painted houses, interlocking widths,
   sitting on a shared pavement. Each is a FACADE UNIT.
   ===================================================================== */
.bm-fond{position:relative}
.bm-grid{
  display:grid;grid-template-columns:1fr;gap:clamp(.5rem,1.4vw,1rem);align-items:end;
  padding-bottom:1rem;position:relative;
}
@media(min-width:40rem){.bm-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:64rem){.bm-grid{grid-template-columns:repeat(3,1fr);grid-auto-flow:dense}}
/* a continuous canal pavement under the whole row */
.bm-fond::after{content:'';display:block;height:.7rem;background:var(--ink);
  background-image:repeating-linear-gradient(90deg,transparent 0 2.4rem,rgba(255,255,255,.14) 2.4rem calc(2.4rem + 2px))}

.bm-tile{
  position:relative;background:var(--accent);color:var(--ink);border:var(--bw) solid var(--ink);
  border-bottom:none;padding:0 0 1.2rem;display:flex;flex-direction:column;gap:.85rem;min-width:0;
  margin-top:.8rem; /* room for the roof frieze */
}
.bm-tile[hidden]{display:none}
.bm-tile--dk{color:var(--white)}
/* terracotta roofline + tessera frieze */
.bm-tile::before{content:'';position:absolute;left:-2px;right:-2px;top:-.8rem;height:.8rem;
  background:var(--frieze);background-size:1.4rem 100%;border:var(--bw) solid var(--ink)}
/* the mullioned, shuttered window that holds the icon */
.bm-tile__win{position:relative;margin:1.15rem 1.35rem .1rem;padding:.6rem 2.6rem;display:flex;justify-content:center}
.bm-tile__win::before,.bm-tile__win::after{content:'';position:absolute;top:0;bottom:0;width:1.7rem;border:2px solid var(--ink);
  background:repeating-linear-gradient(180deg,color-mix(in srgb,var(--accent) 55%,var(--ink)) 0 4px,color-mix(in srgb,var(--accent) 40%,#000) 4px 8px)}
.bm-tile__win::before{left:0}
.bm-tile__win::after{right:0}
.bm-tile--dk .bm-tile__win::before,.bm-tile--dk .bm-tile__win::after{background:repeating-linear-gradient(180deg,#20408f 0 4px,#16306e 4px 8px)}
.bm-tile__ico{width:4.4rem;height:4.4rem;border:2px solid var(--ink);background:var(--white);position:relative;z-index:1}
/* mullion cross drawn over the icon-window */
.bm-tile__win > .bm-tile__ico::after{content:''}
.bm-tile__meta{padding-inline:1.35rem;min-width:0;text-align:center}
.bm-tile__num{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;opacity:.78;display:block}
.bm-tile__name{font-size:1.35rem;font-weight:800;margin-top:.2rem;line-height:1.02}
.bm-tag{
  display:inline-block;font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;padding:.24rem .55rem;border:1.5px solid var(--ink);margin-top:.55rem;
  background:var(--white);color:var(--ink);
}
.bm-tile--dk .bm-tag{border-color:var(--white);background:transparent;color:var(--white)}
.bm-tile__blurb{opacity:.9;font-size:.92rem;padding-inline:1.35rem;text-align:center;flex:1}
.bm-tile__foot{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.6rem 1rem;
  margin:.2rem 1.1rem 0;padding:.7rem .75rem;background:var(--white);border:2px solid var(--ink);
}
.bm-tile--dk .bm-tile__foot{background:rgba(255,255,255,.08);border-color:var(--white)}
.bm-rate{font-family:var(--mono);font-size:.78rem;display:flex;align-items:center;gap:.5ch;min-width:0;flex-wrap:wrap;color:var(--ink)}
.bm-tile--dk .bm-rate{color:var(--white)}
.bm-rate b{font-size:1rem;font-weight:700}
.bm-rate .bm-stars{color:var(--terra);letter-spacing:-1px}
.bm-rate small{opacity:.7;display:block;font-size:.62rem;width:100%}
.bm-tile__link{
  font-family:var(--mono);font-weight:700;font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;
  border-bottom:2px solid var(--terra);padding-bottom:.12rem;white-space:nowrap;color:var(--ink);
}
.bm-tile--dk .bm-tile__link{color:var(--white);border-bottom-color:var(--sunny)}
.bm-tile__link:hover{color:var(--terra)}
.bm-tile--dk .bm-tile__link:hover{color:var(--sunny)}
.bm-tile__link span{margin-left:.4ch}
/* interlocking widths: wide "palazzi" break the uniform 3-up rhythm */
.bm-tile--feature .bm-tile__name{font-size:1.7rem}
.bm-tile--feature .bm-tile__ico{width:5.2rem;height:5.2rem}
.bm-tile--feature .bm-tile__blurb{font-size:1rem}
.bm-tile--compact .bm-tile__blurb{display:none}
.bm-tile--compact .bm-tile__win{margin-top:1rem}
@media(min-width:64rem){
  .bm-tile--feature{grid-column:span 2}
  .bm-tile--feature .bm-tile__win{padding-block:1rem}
}

/* =====================================================================
   TIPI DI ENIGMA — a wall of Murano glass tesserae (color panels)
   ===================================================================== */
.bm-types{display:grid;grid-template-columns:1fr;gap:var(--bw);background:var(--ink);border:var(--bw) solid var(--ink)}
@media(min-width:34rem){.bm-types{grid-template-columns:repeat(2,1fr)}}
@media(min-width:60rem){.bm-types{grid-template-columns:repeat(3,1fr)}}
.bm-type{background:var(--accent);padding:1.7rem 1.4rem 1.4rem;display:flex;flex-direction:column;gap:.85rem;position:relative;min-width:0;color:var(--ink)}
.bm-type__top{display:flex;align-items:center;gap:.85rem}
.bm-type__badge{width:2.6rem;height:2.6rem;background:var(--white);border:2px solid var(--ink);flex:none;
  background-image:linear-gradient(var(--ink),var(--ink)),linear-gradient(var(--ink),var(--ink));
  background-size:100% 2px,2px 100%;background-position:center,center;background-repeat:no-repeat}
.bm-type__idx{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;opacity:.75}
.bm-type h3{font-size:1.5rem;margin-top:.1rem}
.bm-type__desc{font-size:.9rem;opacity:.88}
.bm-type__games{display:flex;flex-wrap:wrap;gap:.4rem}
.bm-type__game{
  font-family:var(--mono);font-size:.66rem;font-weight:700;letter-spacing:.03em;
  padding:.3rem .55rem;border:1.5px solid var(--ink);background:var(--white);color:var(--ink);
}
.bm-type__link{
  margin-top:auto;align-self:flex-start;font-family:var(--mono);font-weight:700;font-size:.72rem;
  letter-spacing:.05em;text-transform:uppercase;border-bottom:2px solid var(--ink);padding-bottom:.12rem;
}
.bm-type__link:hover{opacity:.6}
.bm-type__link span{margin-left:.4ch}

/* =====================================================================
   MATRICE — three canal-houses, each with three floors (cells)
   ===================================================================== */
.bm-matrix{display:grid;grid-template-columns:1fr;gap:clamp(.5rem,1.4vw,1rem);align-items:end}
@media(min-width:34rem){.bm-matrix{grid-template-columns:repeat(2,1fr)}}
@media(min-width:56rem){.bm-matrix{grid-template-columns:repeat(3,1fr)}}
.bm-matrix__col{background:var(--white);display:flex;flex-direction:column;border:var(--bw) solid var(--ink);border-bottom:none;position:relative;margin-top:.8rem}
.bm-matrix__col::before{content:'';position:absolute;left:-2px;right:-2px;top:-.8rem;height:.8rem;background:var(--frieze);background-size:1.4rem 100%;border:var(--bw) solid var(--ink)}
.bm-matrix__hd{padding:1.4rem;border-bottom:var(--bw) solid var(--ink);position:relative;background:var(--accent);color:var(--ink)}
.bm-matrix__lv{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;opacity:.75}
.bm-matrix__hd h3{font-size:1.55rem;margin:.35rem 0 .7rem}
.bm-matrix__meter{display:flex;gap:.35rem;margin-bottom:.85rem}
.bm-matrix__meter i{width:2.2rem;height:.55rem;background:var(--white);border:2px solid var(--ink)}
.bm-matrix__meter i.on{background:var(--ink)}
.bm-matrix__hd p{font-size:.88rem;opacity:.85}
.bm-matrix__cell{padding:1.15rem 1.4rem;border-bottom:var(--bw) solid var(--ink);display:grid;gap:.3rem;background:var(--white)}
.bm-matrix__cellhd{display:flex;align-items:center;gap:.7rem;margin-bottom:.15rem}
.bm-matrix__chip{width:1rem;height:1rem;background:var(--accent);border:2px solid var(--ink);flex:none}
.bm-matrix__n{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;color:var(--ink-45)}
.bm-matrix__cell b{font-size:1.08rem;font-weight:800;line-height:1.1}
.bm-matrix__cat{font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-45)}
.bm-matrix__cell p{font-size:.86rem;color:var(--ink-70)}

/* =====================================================================
   STATS — THE CANAL. Full-bleed water band, the single anchor moment.
   ===================================================================== */
.bm-stats{border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);
  background:linear-gradient(180deg,#1c3a63 0%,#123b52 55%,#0e2f45 100%);position:relative;overflow:hidden}
.bm-stats::before,.bm-stats::after{content:'';position:absolute;left:0;right:0;height:2px;background:rgba(255,255,255,.14)}
.bm-stats::before{top:32%}.bm-stats::after{top:70%;opacity:.5}
.bm-stats__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;position:relative;z-index:1}
@media(min-width:52rem){.bm-stats__grid{grid-template-columns:repeat(4,1fr)}}
.bm-stat{padding:clamp(2.4rem,5vw,3.4rem) 1.5rem;color:var(--white);text-align:center;border-right:2px solid rgba(255,255,255,.16)}
.bm-stat:last-child{border-right:none}
.bm-stat b{display:block;font-family:var(--mono);font-size:clamp(2.1rem,5vw,3.2rem);font-weight:700;letter-spacing:-.02em}
.bm-stat span{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.bm-stat i{display:block;height:4px;width:2.6rem;margin:1rem auto 0}
.bm-stat:nth-child(1) i{background:var(--coral)}
.bm-stat:nth-child(2) i{background:var(--sunny)}
.bm-stat:nth-child(3) i{background:var(--aqua)}
.bm-stat:nth-child(4) i{background:var(--pink)}

/* ---------- rompicapo del giorno (azulejo notice) ---------- */
.bm-daily{display:grid;grid-template-columns:1fr;gap:var(--bw);background:var(--ink);border:var(--bw) solid var(--ink)}
@media(min-width:56rem){.bm-daily{grid-template-columns:1.4fr .6fr}}
.bm-daily__card{background:var(--cobalt);color:var(--white);padding:clamp(1.6rem,4vw,2.6rem);display:flex;flex-direction:column;gap:1.15rem;min-width:0}
.bm-daily__card .bm-kick{color:var(--white)}
.bm-daily__card .bm-kick::before{background:var(--sunny);border-color:var(--white)}
.bm-daily__q{font-size:clamp(1.15rem,2.6vw,1.55rem);font-weight:800;line-height:1.2;letter-spacing:-.01em;max-width:34ch}
.bm-daily__tiles{display:flex;flex-wrap:wrap;gap:.5rem}
.bm-daily__tiles span{
  width:2.7rem;height:2.7rem;display:grid;place-items:center;font-family:var(--mono);font-weight:700;
  font-size:1.15rem;color:var(--ink);border:2px solid var(--ink);
}
.bm-daily__tiles span:nth-child(6n+1){background:var(--coral)}
.bm-daily__tiles span:nth-child(6n+2){background:var(--sunny)}
.bm-daily__tiles span:nth-child(6n+3){background:var(--aqua)}
.bm-daily__tiles span:nth-child(6n+4){background:var(--pink)}
.bm-daily__tiles span:nth-child(6n+5){background:var(--white)}
.bm-daily__tiles span:nth-child(6n+6){background:var(--sunny)}
.bm-daily__reveal{border:2px solid var(--white);margin-top:auto}
.bm-daily__reveal summary{
  cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.9rem 1.1rem;font-family:var(--mono);font-weight:700;font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;
}
.bm-daily__reveal summary::-webkit-details-marker{display:none}
.bm-daily__reveal summary .s{font-size:1.4rem;line-height:1;font-weight:400}
.bm-daily__reveal[open] summary .s{transform:rotate(45deg)}
.bm-daily__ans{padding:0 1.1rem 1.1rem;font-size:.92rem;color:rgba(255,255,255,.86)}
.bm-daily__ans b{color:var(--sunny)}
.bm-daily__side{background:var(--white);padding:clamp(1.6rem,4vw,2.2rem);display:flex;flex-direction:column;gap:1.1rem;min-width:0}
.bm-daily__note{font-size:.92rem;color:var(--ink-70)}
.bm-daily__match{display:flex;align-items:center;gap:.9rem;border:var(--bw) solid var(--ink);background:var(--paper);padding:.9rem}
.bm-daily__match img{width:3.4rem;height:3.4rem;border:2px solid var(--ink);flex:none;background:var(--white)}
.bm-daily__match b{font-size:1.1rem;font-weight:800;display:block}
.bm-daily__cat{font-family:var(--mono);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-45)}
.bm-daily__side .bm-tile__link{margin-top:auto;align-self:flex-start}

/* ---------- leaderboard (regatta standings) ---------- */
.bm-board{border:var(--bw) solid var(--ink);background:var(--white)}
.bm-board__row{display:grid;grid-template-columns:3rem 1fr auto;gap:1rem;align-items:center;padding:1rem 1.2rem;border-bottom:var(--bw) solid var(--ink)}
.bm-board__row:last-child{border-bottom:none}
.bm-board__row--head{background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase}
.bm-board__rank{font-family:var(--mono);font-weight:700;font-size:1rem;width:2.2rem;height:2.2rem;display:grid;place-items:center;border:2px solid var(--ink);background:var(--accent);color:var(--ink)}
.bm-board__game{display:flex;align-items:center;gap:.9rem;min-width:0}
.bm-board__game img{width:2.6rem;height:2.6rem;border:2px solid var(--ink);flex:none}
.bm-board__game b{font-weight:800;font-size:1rem;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bm-board__game span{font-family:var(--mono);font-size:.66rem;letter-spacing:.06em;color:var(--ink-45);text-transform:uppercase}
.bm-board__stat{font-family:var(--mono);font-size:.9rem;text-align:right}
.bm-board__stat b{font-size:1.1rem;font-weight:700}
.bm-board__stat span{display:block;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-45)}
.bm-board__cols{display:none}
@media(min-width:48rem){
  .bm-board__row{grid-template-columns:3rem 1fr 8rem 8rem}
  .bm-board__cols{display:block}
  .bm-board__cat{font-family:var(--mono);font-size:.8rem;color:var(--ink-70)}
}

/* ---------- FAQ (window shutters that open) ---------- */
.bm-faq{border:var(--bw) solid var(--ink);background:var(--white)}
.bm-faq details{border-bottom:var(--bw) solid var(--ink)}
.bm-faq details:last-child{border-bottom:none}
.bm-faq summary{display:flex;gap:1rem;align-items:baseline;padding:1.3rem 1.3rem;cursor:pointer;list-style:none;font-weight:800;font-size:1.05rem}
.bm-faq summary::-webkit-details-marker{display:none}
.bm-faq summary .n{font-family:var(--mono);font-size:.8rem;color:var(--terra);font-weight:700;flex:none}
.bm-faq summary .s{margin-left:auto;font-family:var(--mono);font-weight:400;font-size:1.4rem;flex:none;color:var(--ink);line-height:1}
.bm-faq details[open] summary{background:var(--plaster)}
.bm-faq details[open] summary .s{transform:rotate(45deg)}
.bm-faq__a{padding:0 1.3rem 1.4rem 4rem;color:var(--ink-70)}

/* ---------- subscribe + contact ---------- */
.bm-connect{display:grid;grid-template-columns:1fr;gap:var(--bw);background:var(--ink);border:var(--bw) solid var(--ink)}
@media(min-width:56rem){.bm-connect{grid-template-columns:1.05fr .95fr}}
.bm-sub{background:var(--white);padding:clamp(1.6rem,4vw,2.6rem)}
.bm-sub h3{font-size:1.6rem;margin-bottom:.6rem}
.bm-sub p{color:var(--ink-70);margin-bottom:1.4rem}
.bm-field{display:grid;gap:.4rem;margin-bottom:1rem}
.bm-field label{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-70)}
.bm-field input{font-family:var(--disp);font-size:1rem;padding:.85rem .9rem;border:var(--bw) solid var(--ink);background:var(--white);color:var(--ink);width:100%}
.bm-field input:focus{outline:none;box-shadow:4px 4px 0 var(--cobalt)}
.bm-check{display:flex;gap:.7rem;align-items:flex-start;font-size:.86rem;color:var(--ink-70);margin-bottom:1.3rem}
.bm-check input{width:1.2rem;height:1.2rem;flex:none;margin-top:.15rem;accent-color:var(--cobalt)}
.bm-check a{border-bottom:2px solid var(--terra)}
#successMsg{display:none;margin-top:1rem;padding:.9rem 1rem;border:var(--bw) solid var(--ink);background:var(--aqua);font-family:var(--mono);font-size:.82rem;font-weight:700}
#successMsg.show{display:block}
.bm-contact{background:var(--cobalt);color:var(--white);padding:clamp(1.6rem,4vw,2.6rem);display:flex;flex-direction:column;gap:1.4rem}
.bm-contact h3{font-size:1.4rem}
.bm-contact .bm-kick{color:var(--white)}
.bm-contact .bm-kick::before{background:var(--sunny);border-color:var(--white)}
.bm-nap{font-family:var(--mono);font-size:.86rem;line-height:1.9;color:rgba(255,255,255,.9)}
.bm-nap a{border-bottom:1px solid rgba(255,255,255,.5)}
.bm-map{border:2px solid rgba(255,255,255,.35);position:relative;overflow:hidden;margin-top:auto}
.bm-map img{width:100%;height:160px;object-fit:cover;opacity:.55}
.bm-map__pin{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.4rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase}
.bm-map__pin b{width:1rem;height:1rem;background:var(--coral);border:2px solid var(--white)}

/* ---------- about ---------- */
.bm-about__grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start}
@media(min-width:56rem){.bm-about__grid{grid-template-columns:1fr 1fr;gap:3rem}}
.bm-about__body p{color:var(--ink-70);margin-bottom:1rem;font-size:1.02rem}
.bm-about__body p b{color:var(--ink)}
.bm-swatch{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:var(--bw) solid var(--ink);margin-top:1.5rem}
.bm-swatch div{aspect-ratio:1;position:relative;border-right:2px solid var(--ink)}
.bm-swatch div:last-child{border-right:none}
.bm-swatch div span{position:absolute;left:.4rem;bottom:.35rem;font-family:var(--mono);font-size:.58rem;color:rgba(255,255,255,.95);letter-spacing:.04em}
.bm-photos{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;border:var(--bw) solid var(--ink);padding:.5rem;background:var(--white)}
.bm-photos img{width:100%;height:auto;object-fit:cover;aspect-ratio:3/4;display:block;border:2px solid var(--ink)}
.bm-photos figure{margin:0;min-width:0}
.bm-photos figure:first-child{grid-column:1 / -1}
.bm-photos figure:first-child img{aspect-ratio:16/9}

/* ---------- footer (night canal) ---------- */
.bm-foot{background:var(--ink);color:var(--paper);border-top:3px solid var(--terra)}
.bm-foot__grid{display:grid;grid-template-columns:1fr;gap:2.4rem;padding-block:3.5rem}
@media(min-width:52rem){.bm-foot__grid{grid-template-columns:1.6fr 1fr 1fr}}
.bm-foot__brand .bm-brand{color:var(--paper);font-size:1.35rem;margin-bottom:1rem}
.bm-foot__brand p{color:rgba(244,242,236,.66);max-width:38ch;font-size:.94rem}
.bm-foot__brand .bm-nap{margin-top:1.3rem;font-size:.8rem;color:rgba(244,242,236,.72)}
.bm-foot h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sunny);margin-bottom:1.1rem;font-weight:700}
.bm-foot li{margin-bottom:.7rem}
.bm-foot li a{color:rgba(244,242,236,.8);font-size:.92rem}
.bm-foot li a:hover{color:var(--paper)}
.bm-foot__bar{border-top:var(--bw) solid rgba(244,242,236,.16);padding-block:1.4rem;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;font-family:var(--mono);font-size:.72rem;color:rgba(244,242,236,.55);letter-spacing:.05em}

/* ---------- mobile bottom sheet ---------- */
.bm-sheet{position:fixed;inset:0;z-index:100;display:none}
.bm-sheet[data-open="true"]{display:block}
.bm-sheet__ov{position:absolute;inset:0;background:rgba(23,32,58,.55)}
.bm-sheet__panel{position:absolute;left:0;right:0;bottom:0;background:var(--paper);border-top:3px solid var(--ink);transform:translateY(100%);transition:transform .28s cubic-bezier(.22,1,.36,1);padding:.75rem 1.25rem 2rem;max-height:88vh;overflow:auto}
.bm-sheet[data-open="true"] .bm-sheet__panel{transform:translateY(0)}
.bm-sheet__grab{width:3rem;height:5px;background:var(--ink);margin:.4rem auto 1.2rem}
.bm-sheet__hd{display:flex;align-items:center;justify-content:space-between;border-bottom:var(--bw) solid var(--ink);padding-bottom:1rem;margin-bottom:.4rem}
.bm-sheet__hd span{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-45)}
.bm-sheet__x{background:var(--ink);color:var(--paper);border:none;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;padding:.55rem .8rem;cursor:pointer;text-transform:uppercase;font-weight:700}
.bm-sheet__nav a{display:flex;align-items:center;justify-content:space-between;padding:1.15rem .2rem;border-bottom:var(--bw) solid var(--ink);font-weight:800;font-size:1.25rem}
.bm-sheet__nav a span{font-family:var(--mono);font-size:.72rem;font-weight:400;color:var(--ink-45)}
.bm-sheet__nav a:last-child{border-bottom:none}
.bm-sheet__cta{margin-top:1.4rem;width:100%;justify-content:center}

/* ---------- cookie banner ---------- */
.bm-cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:90;background:var(--paper);border:3px solid var(--ink);padding:1.2rem 1.3rem;display:none;grid-template-columns:1fr;gap:1rem;box-shadow:8px 8px 0 var(--ink)}
.bm-cookie[data-show="true"]{display:grid}
.bm-cookie p{font-size:.88rem;color:var(--ink-70)}
.bm-cookie p b{color:var(--ink)}
.bm-cookie a{border-bottom:2px solid var(--terra)}
.bm-cookie__btns{display:flex;gap:.7rem;flex-wrap:wrap}
.bm-cookie__btns .bm-btn{padding:.7rem 1.1rem}
@media(min-width:44rem){.bm-cookie{grid-template-columns:1fr auto;align-items:center;max-width:52rem;left:50%;right:auto;transform:translateX(-50%)}}

/* ---------- legal / generic pages ---------- */
.bm-legal{padding-block:clamp(2.5rem,6vw,4.5rem)}
.bm-legal__head{border-bottom:var(--bw) solid var(--line);padding-bottom:1.5rem;margin-bottom:2.2rem}
.bm-legal__head h1{font-size:clamp(2rem,6vw,3.2rem)}
.bm-legal__head p{font-family:var(--mono);font-size:.78rem;letter-spacing:.08em;color:var(--ink-45);margin-top:.7rem}
.bm-legal__body{max-width:62ch}
.bm-legal__body h2{font-size:1.35rem;margin:2.2rem 0 .8rem;padding-top:1.2rem;border-top:2px solid var(--line)}
.bm-legal__body h2 .n{font-family:var(--mono);font-size:.8rem;color:var(--terra);margin-right:.6ch}
.bm-legal__body p{color:var(--ink-70);margin-bottom:.9rem}
.bm-legal__body ul{margin:.4rem 0 1rem 0}
.bm-legal__body li{position:relative;padding-left:1.4rem;margin-bottom:.5rem;color:var(--ink-70)}
.bm-legal__body li::before{content:'';position:absolute;left:0;top:.55rem;width:.6rem;height:.6rem;background:var(--terra)}
.bm-legal__body a{border-bottom:2px solid var(--terra)}

/* ---------- 404 ---------- */
.bm-404{min-height:70vh;display:grid;place-items:center;text-align:center;padding:3rem 1.25rem}
.bm-404 .big{font-family:var(--mono);font-size:clamp(4rem,20vw,9rem);font-weight:700;letter-spacing:-.04em;line-height:1}
.bm-404 .big em{font-style:normal;color:var(--terra)}
.bm-404 h1{font-size:clamp(1.6rem,5vw,2.4rem);margin:.5rem 0 1rem}
.bm-404 p{color:var(--ink-70);max-width:42ch;margin:0 auto 1.6rem}

.bm-skip{position:absolute;left:-999px}
.bm-skip:focus{left:1rem;top:1rem;z-index:200;background:var(--ink);color:var(--paper);padding:.6rem 1rem;font-family:var(--mono);font-size:.8rem}
