/* ============================================================
   Tarantlinchetto — tavola.css
   CONCEPT: "La Gazzetta del Tavolo" — the weekend games section
   of a printed broadsheet newspaper, read at a cozy board-game
   cafe. Warm newsprint over faint tabletop-wood grain, ink
   hairline rules, a nameplate masthead, folios, editorial
   columns, drop caps, dice/meeple marginalia.
   CONSTITUTION
   - Colours: newsprint #f4ecdd + ink #1b2333; indigo #3b3f8f
     as printed-ink headings; coral #ef6f5e as the ONE rubber
     stamp accent; wood/kraft derived tones for cafe warmth.
     (mandated skin tokens base/ink/indigo/coral all kept.)
   - Type: Outfit = broadsheet nameplate/headline (heavy, caps,
     tight). Red Hat Text = body columns + wide-tracked folios.
   - Surface: newsprint + 5% grain; cards = thin ink hairline
     rules, NOT soft shadows; one hard-offset tactile shadow
     reserved for tickets/coupons. Radii 3-6px only.
   - Layout: CENTERED 90rem max, margin-inline:auto everywhere.
     Visible column rules + coral section numbers N.0X, varied
     section heights, one full-bleed wood anchor band.
   - Signature: coral N.0X stamp + ink hairline under every
     section head; die-face brand mark (no card suits).
   ============================================================ */
@import url('./fonts.css');

/* ---- tokens ---- */
:root{
  --base:#f3f5f9;
  --paper:#f4ecdd;          /* warm newsprint page */
  --paper-2:#efe3cf;        /* deeper newsprint */
  --card:#fbf6ec;           /* warm printed card */
  --kraft:#e7d7b7;          /* coupon / stamp panels */
  --ink:#1b2333;
  --ink-soft:#5d5747;       /* warm sepia-grey body */
  --ink-faint:#8a8371;
  --indigo:#3b3f8f;
  --indigo-deep:#2c2f6b;
  --coral:#ef6f5e;
  --coral-deep:#c9432f;
  --wood:#785334;
  --wood-2:#6c4a2d;
  --wood-deep:#4f3620;
  --rule:#1b2333;                       /* strong ink hairline */
  --rule-soft:rgba(27,35,51,.16);       /* faint column rule   */
  --tint-indigo:#e7e8f6;
  --tint-coral:#fbe4de;
  --gold:#c98a2b;
  --shadow-hard:5px 5px 0 rgba(27,35,51,.92);
  --shadow-hard-sm:3px 3px 0 rgba(27,35,51,.9);
  --r-sm:3px;
  --r-md:4px;
  --r-lg:6px;
  --pad:clamp(1rem,4vw,3rem);
  --wrap:90rem;             /* 1440px centered container */
  --col:64rem;              /* narrow reading column */
  --hdr-h:4.1rem;
  --ff-display:'Outfit',system-ui,sans-serif;
  --ff-body:'Red Hat Text',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:calc(var(--hdr-h) + .6rem)}
body{
  margin:0;color:var(--ink);
  font-family:var(--ff-body);font-size:1.02rem;line-height:1.66;
  font-weight:400;overflow-x:hidden;position:relative;
  background:var(--paper);
  background-image:
    /* faint tabletop wood grain under the newsprint */
    repeating-linear-gradient(91deg,rgba(120,83,52,.05) 0 3px,rgba(120,83,52,0) 3px 9px),
    radial-gradient(120% 80% at 50% -10%,rgba(59,63,143,.06) 0%,transparent 55%);
}
/* newsprint grain overlay */
.tl-grain{position:fixed;inset:0;pointer-events:none;z-index:2;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

img{max-width:100%;display:block}
a{color:var(--indigo);text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-display);line-height:1.06;margin:0;color:var(--ink);font-weight:800;letter-spacing:-.015em}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--coral);outline-offset:2px;border-radius:2px}
::selection{background:var(--coral);color:#fff}

/* shared centering helper */
.tl-shell{display:block}
.tl-main{display:block}

/* ============================================================
   STICKY TOP HEADER — a newspaper folio bar
   ============================================================ */
.tl-hdr{position:sticky;top:0;z-index:50;background:rgba(244,236,221,.94);
  backdrop-filter:saturate(1.2) blur(8px);-webkit-backdrop-filter:saturate(1.2) blur(8px);
  border-bottom:2px solid var(--ink)}
.tl-hdr-inner{max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;gap:1rem;
  min-height:var(--hdr-h);padding:.5rem var(--pad)}
.tl-brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink);flex:none}
.tl-brand-mark{width:2.15rem;height:2.15rem;flex:none;border-radius:5px;border:1.5px solid var(--ink)}
.tl-brand-name{font-family:var(--ff-display);font-weight:800;font-size:1.14rem;line-height:1;letter-spacing:-.03em;color:var(--ink);text-transform:uppercase}
.tl-brand-name span{display:block;font-family:var(--ff-body);font-size:.54rem;font-weight:700;letter-spacing:.34em;
  text-transform:uppercase;color:var(--coral-deep);margin-top:.28rem}
.tl-nav{display:flex;align-items:center;gap:.05rem;margin-left:auto}
.tl-nav a{font-family:var(--ff-body);font-weight:600;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);padding:.5rem .62rem;transition:color .15s;position:relative;white-space:nowrap}
.tl-nav a:hover{color:var(--indigo)}
.tl-nav a.is-active{color:var(--ink)}
.tl-nav a.is-active::after,.tl-nav a:hover::after{content:"";position:absolute;left:.62rem;right:.62rem;bottom:.34rem;height:2px;background:var(--coral)}
.tl-hdr-cta{display:flex;align-items:center;gap:.55rem;margin-left:.5rem;flex:none}

.tl-burger{display:none;flex-direction:column;gap:.32rem;background:var(--card);border:1.5px solid var(--ink);
  border-radius:4px;padding:.6rem;cursor:pointer;width:2.7rem;height:2.7rem;align-items:center;justify-content:center}
.tl-burger span{display:block;width:1.25rem;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s,opacity .2s}
.tl-burger[aria-expanded=true] span:nth-child(1){transform:translateY(.44rem) rotate(45deg)}
.tl-burger[aria-expanded=true] span:nth-child(2){opacity:0}
.tl-burger[aria-expanded=true] span:nth-child(3){transform:translateY(-.44rem) rotate(-45deg)}
.tl-drawer{display:none;overflow:hidden;max-height:0;transition:max-height .28s ease;border-top:1px solid var(--rule-soft);background:var(--card)}
.tl-drawer.open{max-height:34rem}
.tl-drawer nav{display:flex;flex-direction:column;padding:.4rem var(--pad) 1rem;max-width:var(--wrap);margin:0 auto}
.tl-drawer nav a{color:var(--ink);padding:.8rem .2rem;border-bottom:1px solid var(--rule-soft);
  font-family:var(--ff-body);font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
.tl-drawer nav a:last-child{border-bottom:none}
.tl-drawer .tl-btn{margin-top:.9rem;justify-content:center}

/* ============================================================
   BUTTONS — inked tickets, tactile hard shadow
   ============================================================ */
.tl-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-display);font-weight:800;
  font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;padding:.8rem 1.3rem;border-radius:var(--r-sm);
  border:1.5px solid var(--ink);cursor:pointer;line-height:1;background:var(--card);color:var(--ink);
  box-shadow:var(--shadow-hard-sm);transition:transform .1s,box-shadow .1s,background .15s,color .15s}
.tl-btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 rgba(27,35,51,.92)}
.tl-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 rgba(27,35,51,.92)}
.tl-btn--primary{background:var(--coral);color:#3a140d;border-color:var(--ink)}
.tl-btn--primary:hover{background:#f2836f}
.tl-btn--ghost{background:var(--card);color:var(--ink)}
.tl-btn--ghost:hover{background:#fff}
.tl-btn--play{background:var(--indigo);color:#fff}
.tl-btn--play:hover{background:var(--indigo-deep)}
.tl-btn--sm{padding:.55rem .95rem;font-size:.72rem;box-shadow:var(--shadow-hard-sm)}

/* ============================================================
   SHARED SECTION SHELL + EDITORIAL SECTION HEAD (signature)
   ============================================================ */
.tl-section{padding:clamp(2.4rem,5vw,4rem) var(--pad);max-width:var(--wrap);width:100%;margin-inline:auto}
.tl-section--tight{padding-top:clamp(1.4rem,3vw,2rem)}

.tl-sechead{max-width:52rem;margin:0 auto 2rem;text-align:center;
  padding-top:1.1rem;border-top:2px solid var(--ink);position:relative}
.tl-secnum{position:absolute;top:-.95rem;left:50%;transform:translateX(-50%);
  font-family:var(--ff-display);font-weight:800;font-size:.72rem;letter-spacing:.14em;color:#fff;
  background:var(--coral-deep);border:1.5px solid var(--ink);padding:.2rem .6rem;border-radius:2px}
.tl-eyebrow{display:inline-block;font-family:var(--ff-body);font-weight:700;
  font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--coral-deep);margin-bottom:.7rem}
.tl-h2{font-size:clamp(1.75rem,4vw,2.9rem);letter-spacing:-.025em;text-transform:uppercase;line-height:1.02}
.tl-lead{color:var(--ink-soft);font-size:clamp(1.02rem,1.5vw,1.16rem);max-width:44rem;margin:.7rem auto 0}
/* left-aligned variant used by some spreads */
.tl-sechead--left{text-align:left;margin-inline:0;max-width:56rem}
.tl-sechead--left .tl-secnum{left:0;transform:none}
.tl-sechead--left .tl-lead{margin-inline:0}

/* ============================================================
   MASTHEAD HERO — broadsheet nameplate
   ============================================================ */
.tl-hero{padding:clamp(1.2rem,2.5vw,2rem) var(--pad) clamp(2rem,4vw,3rem);
  border-bottom:3px double var(--ink)}
.tl-hero-inner{max-width:var(--wrap);margin:0 auto}

.tl-folio{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  font-family:var(--ff-body);font-weight:700;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-soft);border-bottom:1px solid var(--ink);padding-bottom:.55rem}
.tl-folio .mid{color:var(--coral-deep)}
.tl-nameplate{text-align:center;padding:.9rem 0 .5rem;border-bottom:2px solid var(--ink);position:relative}
.tl-nameplate .np-word{font-family:var(--ff-display);font-weight:900;text-transform:uppercase;
  font-size:clamp(1.5rem,8.5vw,8.2rem);letter-spacing:-.045em;line-height:.9;color:var(--ink);
  display:block;white-space:nowrap}
.tl-nameplate .np-sub{display:flex;justify-content:center;align-items:center;gap:.7rem;flex-wrap:wrap;
  margin-top:.65rem;font-family:var(--ff-body);font-weight:700;font-size:clamp(.66rem,1.3vw,.82rem);
  letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft)}
.tl-nameplate .np-sub b{color:var(--coral-deep)}
.tl-nameplate .np-sub .sq{width:.42rem;height:.42rem;background:var(--coral);display:inline-block}

/* hero editorial spread: lead column + boxed contents */
.tl-lead-spread{display:grid;grid-template-columns:1.55fr .95fr;gap:clamp(1.4rem,3vw,2.6rem);
  margin-top:clamp(1.4rem,3vw,2.2rem);align-items:start}
.tl-lead-main{min-width:0}
.tl-dash-hi{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--ff-body);font-weight:700;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--coral-deep);margin-bottom:.5rem}
.tl-dash-hi .dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--coral)}
.tl-lead-main h1{font-family:var(--ff-display);font-weight:800;font-size:clamp(1.9rem,4.4vw,3.35rem);
  letter-spacing:-.03em;line-height:1;max-width:16ch;text-transform:none}
.tl-lead-main h1 .mark{color:var(--indigo);position:relative;white-space:nowrap}
.tl-lead-main h1 .mark::after{content:"";position:absolute;left:0;right:0;bottom:-.04em;height:.14em;
  background:var(--coral);border-radius:2px}
.tl-hero-lead{margin-top:1rem;font-size:1.08rem;color:var(--ink);max-width:38rem;column-count:1}
.tl-hero-lead::first-letter{font-family:var(--ff-display);font-weight:800;font-size:3.4em;float:left;
  line-height:.72;padding:.06em .12em .02em 0;color:var(--coral-deep)}
.tl-dash-cta{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.3rem}

/* boxed "In questo numero" contents */
.tl-index{border:2px solid var(--ink);background:var(--card);box-shadow:var(--shadow-hard);border-radius:var(--r-md)}
.tl-index-h{font-family:var(--ff-display);font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  font-size:1rem;padding:.7rem 1rem;border-bottom:2px solid var(--ink);background:var(--kraft);
  display:flex;align-items:center;justify-content:space-between}
.tl-index-h span{font-family:var(--ff-body);font-weight:700;font-size:.66rem;letter-spacing:.16em;color:var(--ink-soft)}
.tl-index ol{list-style:none;margin:0;padding:.3rem .3rem}
.tl-index li{margin:0}
.tl-index a{display:flex;align-items:baseline;gap:.7rem;padding:.5rem .7rem;color:var(--ink);
  font-family:var(--ff-body);font-weight:600;font-size:.92rem;border-bottom:1px dotted var(--rule-soft)}
.tl-index li:last-child a{border-bottom:none}
.tl-index a .n{font-family:var(--ff-display);font-weight:800;color:var(--coral-deep);font-size:.82rem;min-width:1.9rem}
.tl-index a .dots{flex:1;border-bottom:1px dotted var(--ink-faint);transform:translateY(-.16em)}
.tl-index a:hover{color:var(--indigo)}
.tl-index a:hover .n{color:var(--indigo)}

/* stat gauge ledger under hero */
.tl-gauge{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:clamp(1.4rem,3vw,2.2rem);
  border:2px solid var(--ink);background:var(--card);border-radius:var(--r-md);overflow:hidden}
.tl-gauge div{padding:1rem 1.1rem;border-left:1px solid var(--rule-soft);text-align:center}
.tl-gauge div:first-child{border-left:none}
.tl-gauge .n{font-family:var(--ff-display);font-weight:900;font-size:clamp(1.7rem,3.2vw,2.4rem);color:var(--indigo);
  line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.tl-gauge .n em{color:var(--coral-deep);font-style:normal}
.tl-gauge .l{font-family:var(--ff-body);font-weight:700;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);margin-top:.45rem}

/* ============================================================
   FEATURED — full-bleed WOOD band "Gioco della settimana"
   ============================================================ */
.tl-editor{width:100%;padding:clamp(2.4rem,5vw,4rem) var(--pad);
  background-color:var(--wood);
  background-image:
    repeating-linear-gradient(90deg,rgba(0,0,0,.08) 0 1px,rgba(0,0,0,0) 1px 4px),
    repeating-linear-gradient(90deg,var(--wood-2) 0 78px,var(--wood) 78px 156px,var(--wood-deep) 156px 158px,var(--wood) 158px 236px),
    linear-gradient(180deg,rgba(0,0,0,.14),rgba(0,0,0,0) 30%);
  border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);color:#f4ecdd}
.tl-editor-inner{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1fr 20rem;
  gap:clamp(1.4rem,3vw,2.6rem);align-items:center}
.tl-editor-tag{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-display);font-weight:800;
  text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:#3a140d;background:var(--coral);
  border:1.5px solid var(--ink);padding:.3rem .7rem;border-radius:2px;box-shadow:var(--shadow-hard-sm)}
.tl-editor h3{color:#fff;font-size:clamp(2.1rem,5.5vw,4rem);text-transform:uppercase;letter-spacing:-.03em;
  line-height:.92;margin:.9rem 0 .35rem}
.tl-editor .seller{font-family:var(--ff-body);font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  font-size:.78rem;color:#e8c9a3}
.tl-editor-body{margin-top:1rem;max-width:40rem;color:#f3e6d2;font-size:1.06rem;line-height:1.62}
.tl-editor-body::first-letter{font-family:var(--ff-display);font-weight:800;font-size:3.1em;float:left;
  line-height:.72;padding:.05em .14em 0 0;color:var(--coral)}
.tl-editor-meta{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin:.4rem 0 1.3rem}
.tl-editor-meta .tl-pill{color:#f3e6d2;background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.25)}
.tl-editor .tl-btn{background:var(--coral);color:#3a140d}
.tl-editor .tl-btn:hover{background:#f2836f}
/* framed newspaper plate for the pick */
.tl-plate{background:var(--card);border:2px solid var(--ink);border-radius:var(--r-md);
  box-shadow:var(--shadow-hard);padding:.8rem;text-align:center;justify-self:end;max-width:20rem;width:100%}
.tl-plate img{width:9rem;height:9rem;margin:.4rem auto .7rem;border-radius:var(--r-md);border:1.5px solid var(--ink)}
.tl-plate .cap{font-family:var(--ff-body);font-weight:700;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);border-top:1px solid var(--rule-soft);padding-top:.6rem}

/* pills + stars (shared) */
.tl-pill{font-family:var(--ff-body);font-size:.72rem;font-weight:700;letter-spacing:.05em;color:var(--ink-soft);
  background:var(--paper);border:1px solid var(--ink);border-radius:2px;padding:.26rem .6rem}
.tl-stars{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:inherit}
.tl-stars .bar{position:relative;width:5.4rem;height:.95rem;display:inline-block}
.tl-stars .bar i{position:absolute;inset:0;color:rgba(27,35,51,.22);letter-spacing:.1em;font-style:normal;font-size:1rem;line-height:.95rem}
.tl-stars .bar b{position:absolute;inset:0;overflow:hidden;color:var(--gold);letter-spacing:.1em;font-style:normal;font-weight:400;font-size:1rem;line-height:.95rem;white-space:nowrap}
.tl-stars .rv{font-weight:800;font-family:var(--ff-display);color:currentColor}
.tl-editor-meta .tl-stars .bar i{color:rgba(255,255,255,.3)}

/* ============================================================
   CATALOG — broadsheet classified listing with column rules
   ============================================================ */
.tl-tiles{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;
  border-top:2px solid var(--ink);border-left:2px solid var(--ink)}
.tl-tile{border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);
  padding:1.15rem 1.15rem 1.25rem;display:flex;flex-direction:column;gap:.7rem;background:var(--card);
  position:relative;transition:background .15s}
.tl-tile:hover{background:#fff}
.tl-tile-head{display:flex;gap:.8rem;align-items:center}
.tl-tile-icon{width:3.3rem;height:3.3rem;flex:none;border-radius:var(--r-sm);border:1.5px solid var(--ink)}
.tl-tile-head h3{font-size:1.06rem;line-height:1.1;margin-bottom:.15rem;text-transform:uppercase;letter-spacing:-.01em}
.tl-tile-head .seller{font-family:var(--ff-body);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:9rem}
.tl-tile-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap;
  border-top:1px solid var(--rule-soft);border-bottom:1px solid var(--rule-soft);padding:.5rem 0}
.tl-genre{font-family:var(--ff-display);font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:var(--indigo);padding:.24rem .55rem;border-radius:2px}
.tl-tile p{font-size:.9rem;color:var(--ink-soft);margin:0;flex:1}
.tl-tile .tl-btn--play{margin-top:.2rem;justify-content:center;width:100%;font-size:.72rem}

/* ============================================================
   NUMERI — printed ledger strip
   ============================================================ */
.tl-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;
  border:2px solid var(--ink);border-radius:var(--r-md);background:var(--card);overflow:hidden}
.tl-metric{padding:1.4rem 1.2rem;border-left:1px solid var(--rule-soft);text-align:center}
.tl-metric:first-child{border-left:none}
.tl-metric .n{font-family:var(--ff-display);font-weight:900;font-size:clamp(2rem,4vw,2.9rem);color:var(--indigo);
  line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.03em}
.tl-metric:nth-child(2) .n,.tl-metric:nth-child(4) .n{color:var(--coral-deep)}
.tl-metric .n em{font-style:normal;color:var(--gold)}
.tl-metric .l{font-family:var(--ff-display);font-weight:800;font-size:.9rem;margin-top:.6rem;color:var(--ink);text-transform:uppercase;letter-spacing:.02em}
.tl-metric .c{font-family:var(--ff-body);font-size:.76rem;color:var(--ink-soft);margin-top:.25rem;line-height:1.4}

/* ============================================================
   REGOLE — "Il manuale" printed instruction sheet
   ============================================================ */
.tl-howto{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border-top:2px solid var(--ink);border-left:2px solid var(--ink)}
.tl-howto-card{border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);
  padding:1.3rem 1.4rem;display:flex;flex-direction:column;gap:.75rem;background:var(--card)}
.tl-howto-top{display:flex;align-items:baseline;gap:.7rem}
.tl-howto-num{font-family:var(--ff-display);font-weight:900;font-size:2rem;line-height:.8;color:var(--coral-deep);
  font-variant-numeric:tabular-nums}
.tl-howto-top h3{font-size:1.2rem;text-transform:uppercase;letter-spacing:-.01em}
.tl-howto-goal{font-family:var(--ff-body);font-size:.86rem;color:var(--ink);background:var(--kraft);
  border:1.5px solid var(--ink);border-radius:2px;padding:.55rem .8rem;margin:0}
.tl-howto-goal b{font-family:var(--ff-display);font-weight:800;text-transform:uppercase;font-size:.72rem;letter-spacing:.08em;color:var(--coral-deep)}
.tl-howto-steps{list-style:none;margin:0;padding:0;display:grid;gap:.6rem;counter-reset:step}
.tl-howto-steps li{position:relative;padding-left:2.1rem;font-size:.9rem;color:var(--ink-soft);line-height:1.5;counter-increment:step}
.tl-howto-steps li::before{content:counter(step);position:absolute;left:0;top:.02rem;width:1.5rem;height:1.5rem;
  border:1.5px solid var(--ink);background:var(--paper);color:var(--indigo);font-family:var(--ff-display);
  font-weight:800;font-size:.78rem;display:grid;place-items:center;border-radius:2px}

/* ============================================================
   SERATA — printed table plan (matrix)
   ============================================================ */
.tl-plan{display:grid;grid-template-columns:minmax(7rem,auto) repeat(3,1fr);gap:0;
  border:2px solid var(--ink);border-radius:var(--r-md);overflow:hidden;background:var(--card)}
.tl-plan>*{border-right:1px solid var(--rule-soft);border-bottom:1px solid var(--rule-soft);padding:.8rem .9rem}
.tl-plan-corner{display:flex;align-items:center;font-family:var(--ff-display);font-weight:800;font-size:.76rem;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);background:var(--kraft)}
.tl-plan-col{background:var(--indigo);color:#fff;text-align:center}
.tl-plan-col b{font-family:var(--ff-display);font-size:1rem;text-transform:uppercase;display:block;line-height:1.1}
.tl-plan-col span{font-family:var(--ff-body);font-size:.72rem;color:#cdd0f0}
.tl-plan-rowh{background:var(--kraft);display:flex;flex-direction:column;justify-content:center}
.tl-plan-rowh b{font-family:var(--ff-display);font-size:1rem;text-transform:uppercase;color:var(--indigo);line-height:1.1}
.tl-plan-rowh span{font-family:var(--ff-body);font-size:.72rem;color:var(--ink-soft);margin-top:.15rem}
.tl-plan-cell{display:flex;flex-direction:column;gap:.4rem}
.tl-plan-cell-lbl{display:none;font-family:var(--ff-display);font-weight:800;font-size:.68rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--indigo)}
.tl-pick{display:inline-flex;align-items:center;align-self:flex-start;font-family:var(--ff-display);font-weight:700;
  font-size:.82rem;color:var(--ink);background:var(--paper);border:1.5px solid var(--ink);border-radius:2px;padding:.28rem .6rem}
.tl-plan-note{font-family:var(--ff-body);font-size:.75rem;color:var(--ink-soft);margin-top:auto}
.tl-plan-solo{display:flex;gap:.85rem;align-items:flex-start;margin-top:1.1rem;max-width:var(--wrap);
  background:var(--card);border:2px solid var(--ink);border-left:6px solid var(--coral);
  border-radius:var(--r-md);box-shadow:var(--shadow-hard-sm);padding:1rem 1.2rem}
.tl-plan-solo b{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.03em}
.tl-plan-solo div{font-family:var(--ff-body);font-size:.92rem;color:var(--ink-soft)}
.tl-plan-solo a{font-weight:700;text-decoration:underline;text-decoration-style:dotted}

/* ============================================================
   FAQ — narrow single column "Lettere & risposte"
   ============================================================ */
.tl-faq{display:grid;gap:0;max-width:var(--col);margin-inline:auto;border-top:2px solid var(--ink)}
.tl-faq details{border-bottom:1px solid var(--ink);background:transparent}
.tl-faq summary{list-style:none;cursor:pointer;padding:1.05rem .4rem;font-family:var(--ff-display);font-weight:800;
  font-size:1.06rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;color:var(--ink);text-transform:none}
.tl-faq summary::-webkit-details-marker{display:none}
.tl-faq summary::before{content:"D.";font-family:var(--ff-display);font-weight:900;color:var(--coral-deep);margin-right:.6rem}
.tl-faq summary .ic{flex:none;width:1.5rem;height:1.5rem;border:1.5px solid var(--ink);color:var(--ink);
  display:grid;place-items:center;font-size:1rem;transition:transform .2s,background .2s;font-family:var(--ff-body);border-radius:2px}
.tl-faq details[open] summary .ic{transform:rotate(45deg);background:var(--coral);color:#fff}
.tl-faq details p{margin:0;padding:0 .4rem 1.15rem 1.9rem;color:var(--ink-soft);font-size:.96rem;position:relative}
.tl-faq details p::before{content:"R.";position:absolute;left:.4rem;top:0;font-family:var(--ff-display);font-weight:900;color:var(--indigo)}

/* ============================================================
   CLASSIFICA — printed league table
   ============================================================ */
.tl-lead-wrap{max-width:var(--wrap);margin-inline:auto;border:2px solid var(--ink);border-radius:var(--r-md);
  background:var(--card);overflow:hidden}
.tl-lead-row{display:grid;grid-template-columns:2.6rem 1fr auto;gap:.9rem;align-items:center;padding:.8rem 1.15rem;border-bottom:1px solid var(--rule-soft)}
.tl-lead-row:last-child{border-bottom:none}
.tl-lead-head{background:var(--ink);color:var(--paper);font-family:var(--ff-body);font-weight:700;font-size:.68rem;
  letter-spacing:.16em;text-transform:uppercase}
.tl-rank{font-family:var(--ff-display);font-weight:900;font-size:1.2rem;color:var(--ink-faint);text-align:center;font-variant-numeric:tabular-nums}
.tl-lead-row.top{background:#fff}
.tl-lead-row.top .tl-rank{color:var(--coral-deep)}
.tl-lead-game{display:flex;align-items:center;gap:.75rem;min-width:0}
.tl-lead-game img{width:2.5rem;height:2.5rem;border-radius:2px;border:1.5px solid var(--ink);flex:none}
.tl-lead-game .gn{font-family:var(--ff-display);font-weight:800;font-size:.98rem;text-transform:uppercase;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-lead-game .gg{font-family:var(--ff-body);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.tl-lead-score{text-align:right}
.tl-lead-score .s{font-family:var(--ff-display);font-weight:900;color:var(--indigo);font-size:1.15rem;font-variant-numeric:tabular-nums}
.tl-lead-score .t{font-family:var(--ff-body);font-size:.7rem;color:var(--ink-soft)}

/* ============================================================
   CURIOSITA — "Almanacco" dateline entries
   ============================================================ */
.tl-trivia{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border-top:2px solid var(--ink);border-left:2px solid var(--ink)}
.tl-trivia-card{border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);
  padding:1.4rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;background:var(--card)}
.tl-trivia-tag{align-self:flex-start;font-family:var(--ff-body);font-weight:700;font-size:.68rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--coral-deep);border-bottom:1.5px solid var(--coral);padding-bottom:.2rem}
.tl-trivia-year{font-family:var(--ff-display);font-weight:900;font-size:clamp(1.7rem,3.4vw,2.3rem);
  color:var(--indigo);line-height:1;letter-spacing:-.02em;text-transform:uppercase}
.tl-trivia-card:nth-child(even) .tl-trivia-year{color:var(--ink)}
.tl-trivia-card h3{font-size:1.1rem;line-height:1.15;text-transform:uppercase;letter-spacing:-.01em}
.tl-trivia-card p{font-family:var(--ff-body);font-size:.9rem;color:var(--ink-soft);margin:0;line-height:1.6}
.tl-trivia-card p::first-letter{font-family:var(--ff-display);font-weight:800;font-size:2.3em;float:left;
  line-height:.7;padding:.05em .12em 0 0;color:var(--ink)}

/* ============================================================
   ISCRIVITI — subscription coupon
   ============================================================ */
.tl-sub{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:var(--wrap);margin-inline:auto;
  border:2px solid var(--ink);border-radius:var(--r-md);box-shadow:var(--shadow-hard);overflow:hidden;background:var(--card)}
.tl-sub-side{background:var(--indigo);color:#eef0fb;padding:clamp(1.5rem,3vw,2.4rem);position:relative;border-right:2px dashed rgba(255,255,255,.4)}
.tl-sub-side h2{color:#fff;font-size:clamp(1.4rem,2.8vw,2rem);text-transform:uppercase;letter-spacing:-.02em;margin-bottom:.6rem}
.tl-sub-side p{color:#cdd0f0;font-size:.95rem}
.tl-sub-side ul{list-style:none;padding:0;margin:1.1rem 0 0;display:grid;gap:.6rem}
.tl-sub-side li{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;color:#e6e8f8}
.tl-sub-side li svg{width:1.15rem;height:1.15rem;flex:none;margin-top:.12rem;color:var(--coral)}
.tl-sub-contact{margin-top:1.3rem;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.2);font-size:.86rem;color:#cdd0f0;line-height:1.7}
.tl-sub-contact strong{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.04em;color:#fff}
.tl-sub-contact a{color:#fff;text-decoration:underline;text-decoration-style:dotted}
.tl-sub-form{padding:clamp(1.5rem,3vw,2.4rem);background:var(--kraft)}
.tl-field{margin-bottom:.9rem}
.tl-field label{display:block;font-family:var(--ff-display);font-weight:800;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.35rem;color:var(--ink)}
.tl-field input[type=text],.tl-field input[type=tel],.tl-field input[type=email]{
  width:100%;padding:.7rem .85rem;border:1.5px solid var(--ink);border-radius:2px;
  font-family:var(--ff-body);font-size:.95rem;background:var(--paper);color:var(--ink);transition:box-shadow .15s}
.tl-field input:focus{outline:none;box-shadow:var(--shadow-hard-sm)}
.tl-consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.84rem;color:var(--ink-soft);margin:.3rem 0 1rem}
.tl-consent input{margin-top:.2rem;width:1.05rem;height:1.05rem;flex:none;accent-color:var(--indigo)}
.tl-consent a{font-weight:700;text-decoration:underline;text-decoration-style:dotted}
.tl-sub-form .tl-btn{width:100%;justify-content:center}
#successMsg{display:none;margin-top:.9rem;background:var(--card);border:1.5px solid var(--ink);color:var(--coral-deep);
  border-radius:2px;padding:.75rem .9rem;font-size:.9rem;font-weight:700;box-shadow:var(--shadow-hard-sm)}
#successMsg.show{display:block}

/* ============================================================
   CHI SIAMO — "La redazione" colophon
   ============================================================ */
.tl-about{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.6rem,3vw,2.6rem);align-items:center;max-width:var(--wrap);margin-inline:auto}
.tl-about h2{text-transform:uppercase;letter-spacing:-.02em}
.tl-about p{color:var(--ink-soft)}
.tl-about-media{border:2px solid var(--ink);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-hard);
  position:relative;background:var(--card);padding:.7rem;max-width:32rem;margin-inline:auto;width:100%}
.tl-about-media img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;border:1.5px solid var(--ink);border-radius:2px;filter:saturate(.92) contrast(1.02)}
.tl-about-media figcaption{font-family:var(--ff-body);font-weight:700;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);padding:.6rem .2rem .1rem}
.tl-about-facts{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:1.4rem;border-top:2px solid var(--ink);border-left:2px solid var(--ink)}
.tl-fact{border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:.9rem 1rem;background:var(--card)}
.tl-fact .k{font-family:var(--ff-display);font-weight:900;color:var(--indigo);font-size:1.1rem;text-transform:uppercase;letter-spacing:-.01em}
.tl-fact .v{font-family:var(--ff-body);font-size:.78rem;color:var(--ink-soft);margin-top:.2rem}

/* ============================================================
   FOOTER — editorial colophon
   ============================================================ */
.tl-footer{background:var(--ink);color:#cbc6b6;padding:clamp(2.4rem,4vw,3.4rem) var(--pad) 1.6rem;margin-top:0;border-top:3px solid var(--coral)}
.tl-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:1.8rem;max-width:var(--wrap);margin:0 auto}
.tl-footer-brand{display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem}
.tl-footer-brand img{width:2.4rem;height:2.4rem;border-radius:4px;border:1.5px solid #cbc6b6}
.tl-footer-brand b{font-family:var(--ff-display);font-weight:800;font-size:1.14rem;color:#fff;text-transform:uppercase;letter-spacing:-.02em}
.tl-footer p{font-family:var(--ff-body);font-size:.9rem;line-height:1.7;color:#a29c8b}
.tl-footer h4{color:#fff;font-family:var(--ff-body);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:.85rem;font-weight:700}
.tl-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}
.tl-footer ul a{color:#bdb8a7;font-size:.9rem}
.tl-footer ul a:hover{color:#fff}
.tl-footer address{font-style:normal;font-size:.9rem;line-height:1.7;color:#a29c8b}
.tl-footer address a{color:#bdb8a7}
.tl-footer-bottom{max-width:var(--wrap);margin:1.8rem auto 0;padding-top:1.3rem;border-top:1px solid rgba(255,255,255,.14);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-family:var(--ff-body);font-size:.78rem;letter-spacing:.04em;color:#8f8a79}

/* ============================================================
   COOKIE
   ============================================================ */
.tl-cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:60;max-width:38rem;margin-left:auto;
  background:var(--card);border:2px solid var(--ink);border-radius:var(--r-md);box-shadow:var(--shadow-hard);
  padding:1.1rem 1.2rem;display:none;gap:.9rem;align-items:center;flex-wrap:wrap}
.tl-cookie.show{display:flex}
.tl-cookie p{margin:0;font-size:.88rem;color:var(--ink-soft);flex:1;min-width:14rem}
.tl-cookie p a{font-weight:700;text-decoration:underline;text-decoration-style:dotted}
.tl-cookie-btns{display:flex;gap:.55rem;flex-wrap:wrap}
.tl-cookie .tl-btn{padding:.6rem 1.05rem;font-size:.72rem}

/* ============================================================
   LEGAL / GENERIC PAGES (shared, kept working)
   ============================================================ */
.tl-page-head{border-bottom:3px double var(--ink);padding:clamp(1.6rem,4vw,2.6rem) var(--pad) clamp(1.4rem,3vw,2rem)}
.tl-page-head>*{max-width:var(--wrap);margin-inline:auto}
.tl-page-head h1{font-family:var(--ff-display);font-size:clamp(1.9rem,4.4vw,3rem);max-width:60rem;text-transform:uppercase;letter-spacing:-.025em;line-height:1}
.tl-page-head .tl-lead{margin-top:.8rem;margin-inline:0}
.tl-crumbs{font-family:var(--ff-body);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.9rem}
.tl-crumbs a{color:var(--coral-deep)}
.tl-hero-cta{display:flex;flex-wrap:wrap;gap:.7rem;max-width:var(--wrap);margin-inline:auto}
.tl-prose{max-width:var(--col);margin-inline:auto}
.tl-prose h2{font-family:var(--ff-display);font-size:1.4rem;margin:2rem 0 .7rem;color:var(--ink);text-transform:uppercase;letter-spacing:-.01em;border-bottom:1.5px solid var(--ink);padding-bottom:.3rem}
.tl-prose h3{font-size:1.08rem;margin:1.3rem 0 .4rem;color:var(--indigo)}
.tl-prose p,.tl-prose li{color:var(--ink-soft);font-size:.98rem}
.tl-prose ul{padding-left:1.2rem;margin:0 0 1rem}
.tl-prose li{margin-bottom:.4rem}
.tl-card-note{background:var(--card);border:2px solid var(--ink);border-left:6px solid var(--coral);border-radius:var(--r-md);
  padding:1rem 1.2rem;box-shadow:var(--shadow-hard-sm);margin:1.4rem 0}
.tl-card-note p:last-child{margin-bottom:0}
.tl-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:var(--wrap);margin-inline:auto;border-top:2px solid var(--ink);border-left:2px solid var(--ink)}
.tl-contact-card{border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:1.4rem;background:var(--card)}
.tl-contact-card h3{font-size:1.08rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:-.01em}
.tl-contact-card h3 svg{width:1.2rem;height:1.2rem;color:var(--coral-deep)}
.tl-contact-card p{font-family:var(--ff-body);font-size:.94rem;color:var(--ink-soft);margin-bottom:.3rem}
.tl-contact-card a{font-weight:700;color:var(--indigo);text-decoration:underline;text-decoration-style:dotted}

/* 404 */
.tl-404{min-height:70vh;display:grid;place-items:center;text-align:center;padding:2rem var(--pad)}
.tl-404 .big{font-family:var(--ff-display);font-weight:900;font-size:clamp(4rem,14vw,8rem);color:var(--indigo);line-height:1;letter-spacing:-.04em}
.tl-404 .big span{color:var(--coral)}
.tl-404 h1{font-size:clamp(1.4rem,3vw,2rem);margin:.6rem 0;text-transform:uppercase}
.tl-404 p{color:var(--ink-soft);max-width:34rem;margin:0 auto 1.4rem}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .tl-tiles{grid-template-columns:repeat(2,minmax(0,1fr))}
  .tl-gauge,.tl-metrics{grid-template-columns:repeat(2,1fr)}
  .tl-gauge div:nth-child(3),.tl-metric:nth-child(3){border-left:none}
  .tl-lead-spread{grid-template-columns:1fr}
  .tl-index{max-width:36rem}
  .tl-editor-inner{grid-template-columns:1fr}
  .tl-plate{justify-self:center;margin-top:.4rem}
}
@media (max-width:900px){
  .tl-nav,.tl-hdr-cta .tl-btn{display:none}
  .tl-burger{display:inline-flex}
  .tl-drawer{display:block}
  .tl-hdr-cta{margin-left:auto}
  .tl-about{grid-template-columns:1fr}
  .tl-footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .tl-howto,.tl-trivia{grid-template-columns:1fr}
  .tl-tiles{grid-template-columns:repeat(2,minmax(0,1fr))}
  .tl-plan{grid-template-columns:1fr}
  .tl-plan-corner,.tl-plan-col{display:none}
  .tl-plan>*{border-right:none}
  .tl-plan-rowh{margin-top:0;border-top:2px solid var(--ink)}
  .tl-plan-rowh:first-of-type{border-top:none}
  .tl-plan-cell-lbl{display:inline-block}
  .tl-sub{grid-template-columns:1fr}
  .tl-sub-side{border-right:none;border-bottom:2px dashed rgba(255,255,255,.4)}
  .tl-contact-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  body{font-size:.99rem}
  .tl-gauge,.tl-metrics{grid-template-columns:1fr}
  .tl-gauge div,.tl-metric{border-left:none;border-top:1px solid var(--rule-soft)}
  .tl-gauge div:first-child,.tl-metric:first-child{border-top:none}
  .tl-tiles{grid-template-columns:1fr}
  .tl-about-facts{grid-template-columns:1fr}
  .tl-footer-grid{grid-template-columns:1fr}
  .tl-footer-bottom{flex-direction:column}
  .tl-lead-row{grid-template-columns:2rem 1fr auto;padding:.7rem .85rem;gap:.6rem}
  .tl-cookie{left:.6rem;right:.6rem;bottom:.6rem}
}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}
