/* TuttoLoSport — design system v6 "editoriale pulito"
   Da neo-brutalista (bordi/ombre neri) a editoriale: hairline, ombre morbide,
   liste senza cornici, griglie che tornano sempre. Mobile-first. Break 1100/700/460. */

@font-face { font-family:'Bricolage Grotesque'; font-weight:400 900; font-display:swap;
  src:url('/assets/0ac69563-abf5-4fc2-a01f-98c7703433df.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+20AC,U+2122,U+2212; }
@font-face { font-family:'Manrope'; font-weight:400 800; font-display:swap;
  src:url('/assets/9f1a5b45-e88e-4dad-97b3-00c3eee35588.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+20AC,U+2122,U+2212; }

:root {
  /* brand (invariato) */
  --azzurro:#0066CC; --navy:#0A1F44; --navy-2:#142B5A; --yellow:#FFD60A; --pink:#FF3D7F;
  /* inchiostro */
  --ink:#0F1419; --ink-2:#3A4452; --ink-3:#66707C;
  /* superfici + linee */
  --bg:#F6F5F1; --card:#FFFFFF; --line:#E6E2D8; --line-2:#F0EDE4; --wash:#EFECE3;
  /* accenti sport (contrasto AA su bianco per i tag) */
  --calcio:#0066CC; --basket:#C25A00; --tennis:#3C7A00; --pallavolo:#6E3ED6; --f1:#D11F2B; --altro:#0A1F44;
  /* tipografia */
  --disp:'Bricolage Grotesque',sans-serif; --body:'Manrope',sans-serif;
  /* elevazione morbida */
  --sh-sm:0 1px 2px rgba(15,20,25,.05), 0 2px 8px rgba(15,20,25,.05);
  --sh-md:0 8px 26px rgba(15,20,25,.10);
  --r:14px; --r-sm:10px; --r-lg:18px;
  --z-drawer-bg:80; --z-drawer:90; --z-scrolled:70; --z-header:50;
}
* { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; scroll-padding-top:70px; }
body { font-family:var(--body); color:var(--ink); background:var(--bg); line-height:1.5; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
button { font-family:inherit; cursor:pointer; }
h1,h2,h3 { text-wrap:balance; }
.wrap { max-width:1180px; margin:0 auto; padding:0 clamp(16px,4vw,32px); }

/* segnaposto immagine (niente più foto del bosco) */
.holder { width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--sc,var(--azzurro)),var(--navy)); }
.holder span { font-size:clamp(38px,7vw,72px); line-height:1; filter:drop-shadow(0 3px 8px rgba(0,0,0,.28)); }

/* ============ HEADER — masthead + navbar + topics ============ */
.masthead { background:var(--bg); }
.masthead .wrap { display:flex; align-items:center; gap:14px; padding-top:15px; padding-bottom:13px; }
.mh-date { font-size:12.5px; font-weight:700; color:var(--ink-3); text-transform:capitalize; flex:1; }
.logo { display:inline-flex; align-items:center; gap:9px; font-family:var(--disp); font-weight:900; letter-spacing:-.03em; }
.logo b { background:var(--azzurro); color:#fff; border-radius:8px; }
.masthead .logo { font-size:clamp(23px,3.6vw,32px); }
.masthead .logo b { padding:2px 11px; }
.cta { display:inline-flex; align-items:center; gap:7px; font-family:var(--disp); font-weight:800; font-size:13px;
  background:var(--ink); color:#fff; border-radius:40px; padding:9px 17px; white-space:nowrap;
  transition:background .15s, transform .12s; }
.cta:hover { background:var(--azzurro); transform:translateY(-1px); }
.masthead .wrap .logo { flex:0 0 auto; }
.masthead .wrap .cta { flex:0 0 auto; }
.masthead .wrap { justify-content:space-between; }

.navbar { background:var(--navy); }
.navbar .wrap { display:flex; align-items:center; gap:8px; height:50px; }
.burger { background:none; border:none; display:inline-flex; flex-direction:column; gap:5px; padding:10px 12px 10px 0; }
.burger span { width:22px; height:2.5px; background:#fff; border-radius:2px; }
.nav-sports { display:flex; gap:2px; overflow-x:auto; scrollbar-width:none; flex:1; }
.nav-sports::-webkit-scrollbar { display:none; }
.nav-sports a { font-family:var(--disp); font-weight:700; font-size:14.5px; color:rgba(255,255,255,.82);
  padding:7px 13px; border-radius:8px; white-space:nowrap; position:relative; transition:color .15s; }
.nav-sports a::after { content:''; position:absolute; left:13px; right:13px; bottom:4px; height:3px; border-radius:3px;
  background:var(--sc,#fff); transform:scaleX(0); transform-origin:left; transition:transform .18s ease-out; }
.nav-sports a:hover { color:#fff; }
.nav-sports a:hover::after, .nav-sports a.on::after { transform:scaleX(1); }
.nav-sports a.on { color:#fff; }
.live-badge { display:inline-flex; align-items:center; gap:7px; font-family:var(--disp); font-weight:800; font-size:12.5px;
  color:#fff; background:rgba(255,255,255,.10); border-radius:40px; padding:7px 14px; white-space:nowrap; transition:background .15s; }
.live-badge:hover { background:rgba(255,255,255,.18); }
.live-badge .dot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.45); }
.live-badge.is-live { background:rgba(255,61,127,.18); }
.live-badge.is-live .dot { background:var(--pink); animation:pulse 1.3s infinite; }
@keyframes pulse { 50%{opacity:.3} }

.topics { background:var(--bg); border-bottom:1px solid var(--line); }
.topics .wrap { display:flex; gap:8px; overflow-x:auto; scrollbar-width:none; padding-top:11px; padding-bottom:11px; }
.topics .wrap::-webkit-scrollbar { display:none; }
.chip { flex:0 0 auto; font-family:var(--disp); font-weight:700; font-size:12.5px; color:var(--ink-2);
  background:var(--card); border:1px solid var(--line); border-radius:40px; padding:5px 14px; white-space:nowrap;
  transition:border-color .15s, color .15s; }
.chip:hover { color:var(--azzurro); border-color:var(--azzurro); }

/* ============ HEADER compatto allo scroll ============ */
.scrolled { position:fixed; top:0; left:0; right:0; z-index:var(--z-scrolled); background:var(--navy);
  box-shadow:0 4px 20px rgba(10,20,30,.22); transform:translateY(-110%); transition:transform .24s ease-out; }
.scrolled.show { transform:translateY(0); }
.scrolled .wrap { display:flex; align-items:center; gap:10px; height:52px; }
.scrolled .logo { font-size:19px; color:#fff; }
.scrolled .logo b { padding:2px 8px; }
.scrolled .nav-sports { margin:0 4px; }
.scrolled .cta { font-size:12px; padding:7px 14px; background:var(--azzurro); }
@media (prefers-reduced-motion:reduce){ .scrolled{transition:none} .nav-sports a::after{transition:none} .live-badge.is-live .dot{animation:none} }

/* ============ Drawer ============ */
.drawer-bg { position:fixed; inset:0; background:rgba(10,20,30,.5); z-index:var(--z-drawer-bg); opacity:0; pointer-events:none; transition:opacity .2s; }
.drawer { position:fixed; top:0; bottom:0; left:0; width:min(340px,88vw); z-index:var(--z-drawer); background:var(--card);
  transform:translateX(-102%); transition:transform .24s ease-out; overflow-y:auto; padding:20px; box-shadow:var(--sh-md); }
body.drawer-open { overflow:hidden; }
body.drawer-open .drawer { transform:translateX(0); }
body.drawer-open .drawer-bg { opacity:1; pointer-events:auto; }
.drawer .close { float:right; background:none; border:none; font-size:24px; line-height:1; padding:4px 8px; color:var(--ink-3); }
.drawer .logo { font-size:21px; }
.drawer form { display:flex; gap:8px; margin:16px 0 20px; }
.drawer input { flex:1; border:1px solid var(--line); border-radius:10px; padding:11px 13px; font:inherit; background:var(--bg); }
.drawer input:focus { outline:2px solid var(--azzurro); outline-offset:1px; border-color:transparent; }
.drawer .go { border:none; background:var(--ink); color:#fff; border-radius:10px; font-family:var(--disp); font-weight:800; padding:0 16px; }
.drawer h4 { font-family:var(--disp); font-size:11.5px; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-3); margin:16px 0 4px; }
.drawer a.item { display:flex; align-items:center; gap:11px; font-family:var(--disp); font-weight:700; font-size:16.5px; padding:11px 8px; border-radius:10px; }
.drawer a.item:hover { background:var(--bg); }
.drawer a.item i { width:9px; height:9px; border-radius:50%; background:var(--sc,var(--ink-3)); }

/* ============ Ticker risultati ============ */
.strip { background:var(--card); border-bottom:1px solid var(--line); }
.strip[hidden] { display:none; }
.strip .wrap { display:flex; gap:8px; overflow-x:auto; scrollbar-width:none; padding-top:10px; padding-bottom:10px; scroll-snap-type:x proximity; }
.strip .wrap::-webkit-scrollbar { display:none; }
.match { flex:0 0 auto; scroll-snap-align:start; display:inline-flex; align-items:center; gap:8px; background:var(--bg);
  border:1px solid var(--line); border-radius:40px; padding:6px 13px; font-size:12.5px; }
.match .em { font-size:13px; }
.match .t { font-weight:700; }
.match .sc { font-family:var(--disp); font-weight:800; background:var(--navy); color:#fff; border-radius:20px; padding:1px 8px; font-size:12px; }
.match .st { font-size:10.5px; font-weight:800; color:var(--ink-3); text-transform:uppercase; }
.match.is-live { border-color:var(--pink); }
.match.is-live .st { color:var(--pink); }
.match.is-live .st::before { content:'●'; margin-right:3px; animation:pulse 1.3s infinite; }

/* ============ Tag / kicker sport ============ */
.tag { display:inline-block; font-family:var(--disp); font-weight:800; font-size:11px; text-transform:uppercase;
  letter-spacing:.05em; color:#fff; background:var(--sc,var(--altro)); padding:3px 10px; border-radius:5px; }
.kicker { display:inline-block; font-family:var(--disp); font-weight:900; font-size:clamp(13px,1.6vw,15px);
  text-transform:uppercase; letter-spacing:.06em; color:var(--sc,var(--azzurro)); }
.s-calcio{--sc:var(--calcio)} .s-basket{--sc:var(--basket)} .s-tennis{--sc:var(--tennis)}
.s-pallavolo{--sc:var(--pallavolo)} .s-f1{--sc:var(--f1)} .s-altro{--sc:var(--altro)}
.meta { font-size:12px; color:var(--ink-3); font-weight:600; }

/* ============ Apertura (hero + spalla) ============ */
.opening { display:grid; gap:clamp(20px,3vw,30px); padding:clamp(18px,3vw,30px) 0 0; }
@media (min-width:1100px){ .opening { grid-template-columns:1.62fr 1fr; align-items:start; } }

.hero { display:block; }
.hero .ph { aspect-ratio:16/9; border-radius:var(--r-lg); overflow:hidden; background:var(--wash); }
.hero .ph img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease-out; }
.hero:hover .ph img { transform:scale(1.03); }
.hero .body { padding:14px 2px 0; }
.hero h1 { font-family:var(--disp); font-weight:800; font-size:clamp(26px,3.8vw,40px); line-height:1.04;
  letter-spacing:-.03em; margin:8px 0 8px; }
.hero:hover h1 { color:var(--azzurro); }
.hero p { color:var(--ink-2); font-size:clamp(14.5px,1.5vw,17px); max-width:60ch; }
.hero .meta { margin-top:10px; }

/* spalla = lista pulita con filetto, niente cornici */
.shoulder { display:flex; flex-direction:column; }
.snews { display:grid; grid-template-columns:92px 1fr; gap:13px; align-items:center;
  padding:14px 0; border-top:1px solid var(--line); }
.shoulder .snews:first-child { border-top:none; padding-top:2px; }
.snews .ph { width:92px; aspect-ratio:1/1; border-radius:var(--r-sm); overflow:hidden; background:var(--wash); }
.snews .ph img { width:100%; height:100%; object-fit:cover; }
.snews .tx { min-width:0; }
.snews.no-ph { grid-template-columns:1fr; }
.snews h3 { font-family:var(--disp); font-weight:800; font-size:16px; line-height:1.2; margin-top:6px; letter-spacing:-.01em; }
.snews:hover h3 { color:var(--azzurro); }
.snews .meta { margin-top:5px; }

/* ============ Sezioni della home ============ */
.zone { margin-top:clamp(30px,5vw,48px); }
.zone-head { display:flex; align-items:baseline; gap:11px; margin-bottom:16px; padding-bottom:11px; border-bottom:2px solid var(--ink); }
.zone-head .bar { align-self:center; width:8px; height:20px; border-radius:4px; background:var(--sc,var(--azzurro)); }
.zone-head h2 { font-family:var(--disp); font-weight:800; font-size:clamp(18px,2.4vw,23px); letter-spacing:-.02em; }
.zone-head a.more { margin-left:auto; font-size:12.5px; font-weight:800; color:var(--azzurro); white-space:nowrap; }
.zone-head a.more:hover { text-decoration:underline; }

/* corpo 2 colonne */
.cols { display:grid; gap:clamp(24px,3.5vw,40px); }
@media (min-width:1100px){ .cols { grid-template-columns:1fr 320px; align-items:start; } .rail { position:sticky; top:66px; } }

/* card articolo base (leggera) */
.pcard { display:block; background:transparent; }
.pcard .ph { aspect-ratio:16/9; border-radius:var(--r); overflow:hidden; background:var(--wash); }
.pcard .ph img { width:100%; height:100%; object-fit:cover; transition:transform .35s ease-out; }
.pcard:hover .ph img { transform:scale(1.04); }
.pcard .body { padding-top:11px; }
.pcard h3 { font-family:var(--disp); font-weight:800; font-size:16.5px; line-height:1.2; margin:7px 0 5px; letter-spacing:-.01em; }
.pcard:hover h3 { color:var(--azzurro); }
.pcard.no-ph .ph { display:none; }
.pcard.no-ph { background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:15px 16px; box-shadow:var(--sh-sm); }
.pcard.no-ph .body { padding-top:0; }

/* copertina: 1 grande orizzontale + griglia che riempie sempre l'ultima riga (flex-grow) */
.vasca { display:flex; flex-wrap:wrap; gap:clamp(18px,2.4vw,24px); }
.vasca > .pcard { flex:1 1 228px; }
.vasca > .vcard.big { flex-basis:100%; }
@media (min-width:620px){
  .vcard.big { display:grid; grid-template-columns:1.3fr 1fr; gap:20px; align-items:center; }
  .vcard.big .ph { aspect-ratio:16/10; }
  .vcard.big .body { padding-top:0; }
}
.vcard.big h3 { font-size:clamp(20px,2.6vw,27px); }
.vcard.big p { font-size:14.5px; color:var(--ink-2); margin-top:8px; max-width:52ch; }
.vcard.big.no-ph { display:block; }

/* rail widget (leggero) */
.widget { background:var(--card); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--sh-sm); padding:16px 17px; margin-bottom:16px; }
.widget > h3 { font-family:var(--disp); font-weight:800; font-size:14px; text-transform:uppercase; letter-spacing:.04em;
  display:flex; align-items:center; gap:8px; margin-bottom:11px; padding-bottom:11px; border-bottom:1px solid var(--line); }
.widget > h3 .dotY { width:9px; height:9px; border-radius:50%; background:var(--pink); }
.wlist { display:grid; }
.wlist a { padding:11px 0; border-top:1px solid var(--line-2); font-size:14px; font-weight:700; line-height:1.3; display:grid; gap:3px; }
.wlist a:first-child { border-top:none; padding-top:2px; }
.wlist a:hover { color:var(--azzurro); }
.wlist a .when { font-size:11px; color:var(--ink-3); font-weight:700; }
.wtable { width:100%; border-collapse:collapse; font-size:13.5px; }
.wtable th { text-align:left; font-size:10px; text-transform:uppercase; letter-spacing:.04em; color:var(--ink-3); padding:4px 4px 8px; border-bottom:1px solid var(--line); }
.wtable td { padding:7px 4px; border-bottom:1px solid var(--line-2); font-variant-numeric:tabular-nums; }
.wtable tr:last-child td { border-bottom:none; }
.wtable .pt { font-weight:800; color:var(--azzurro); }
.wfoot { display:block; font-size:12.5px; font-weight:800; color:var(--azzurro); margin-top:12px; }
.wfoot:hover { text-decoration:underline; }
.widget.brand { background:var(--navy); border-color:var(--navy); color:#fff; }
.widget.brand h3 { color:var(--yellow); border-bottom-color:rgba(255,255,255,.16); }
.widget.brand p { font-size:13.5px; color:rgba(255,255,255,.8); line-height:1.55; }
.widget.brand .wfoot { color:var(--yellow); }

/* ============ Promo (striscia sobria) ============ */
.pushbar { display:flex; flex-wrap:wrap; align-items:center; gap:6px 20px; border-radius:var(--r);
  padding:clamp(16px,2.4vw,22px) clamp(18px,2.6vw,26px); background:var(--wash); border:1px solid var(--line); }
.pushbar .lbl { font-family:var(--disp); font-weight:800; font-size:10px; letter-spacing:.09em;
  color:var(--ink-3); background:var(--card); border:1px solid var(--line); border-radius:40px; padding:3px 11px; }
.pushbar h3 { font-family:var(--disp); font-weight:800; font-size:clamp(16px,2vw,19px); letter-spacing:-.01em; flex:1 1 240px; }
.pushbar p { font-size:13.5px; color:var(--ink-2); flex-basis:100%; }
.pushbar .cta { margin-left:auto; }
.pushbar.navy { background:var(--navy); border-color:var(--navy); color:#fff; }
.pushbar.navy .lbl { background:rgba(255,255,255,.12); border-color:transparent; color:#fff; }
.pushbar.navy p { color:rgba(255,255,255,.78); }
.pushbar.navy .cta { background:var(--yellow); color:var(--ink); }
.pushbar.navy .cta:hover { background:#fff; }

/* ============ Blocchi sport ============ */
.sblock { margin-top:clamp(28px,4.5vw,44px); }
.sgrid { display:flex; flex-wrap:wrap; gap:clamp(18px,2.4vw,26px); }
.sgrid > .pcard { flex:1 1 240px; }

/* ============ Feed cronologico (lista pulita) ============ */
.feed { display:flex; flex-direction:column; max-width:840px; }
.frow { display:grid; grid-template-columns:120px 1fr; gap:16px; align-items:center;
  padding:16px 0; border-top:1px solid var(--line); }
.feed .frow:first-child { border-top:none; }
.frow .ph { width:120px; aspect-ratio:16/11; border-radius:var(--r-sm); overflow:hidden; background:var(--wash); }
.frow .ph img { width:100%; height:100%; object-fit:cover; }
.frow.no-ph { grid-template-columns:1fr; }
.frow .tx { min-width:0; }
.frow h3 { font-family:var(--disp); font-weight:800; font-size:17px; line-height:1.2; margin:6px 0 4px; letter-spacing:-.01em; }
.frow:hover h3 { color:var(--azzurro); }
.frow.promo { background:var(--wash); border:1px solid var(--line); border-radius:var(--r); padding:16px 18px; margin:4px 0; grid-template-columns:1fr; }
.frow.promo h3 { color:var(--ink); }

/* ============ Pagina sezione ============ */
.sec-hero { background:var(--navy); color:#fff; position:relative; overflow:hidden; }
.sec-hero::before { content:''; position:absolute; inset:0; opacity:.9;
  background:linear-gradient(120deg,var(--sc,var(--azzurro)) 0%, transparent 62%); }
.sec-hero .wrap { position:relative; padding-top:clamp(26px,4.5vw,42px); padding-bottom:clamp(22px,4vw,34px); }
.sec-hero h1 { font-family:var(--disp); font-weight:900; font-size:clamp(30px,5.5vw,50px); letter-spacing:-.03em; line-height:1; }
.sec-hero p { margin-top:9px; opacity:.9; font-size:clamp(14px,1.8vw,17px); max-width:58ch; }
.tabs { display:flex; gap:8px; overflow-x:auto; scrollbar-width:none; border-bottom:1px solid var(--line); background:var(--bg);
  position:sticky; top:0; z-index:5; padding:11px clamp(16px,4vw,32px); }
.tabs::-webkit-scrollbar { display:none; }
.tabbtn { flex:0 0 auto; font-family:var(--disp); font-weight:800; font-size:13.5px; border:1px solid var(--line);
  background:var(--card); color:var(--ink-2); border-radius:40px; padding:8px 18px; transition:.15s; }
.tabbtn:hover { border-color:var(--ink-3); color:var(--ink); }
.tabbtn.on { background:var(--ink); color:#fff; border-color:var(--ink); }
.tabpane[hidden] { display:none; }
.srow { display:flex; justify-content:space-between; gap:10px; padding:12px 0; border-top:1px solid var(--line-2); font-size:14.5px; align-items:center; }
.srow:first-child { border-top:none; }
.srow .sc { font-family:var(--disp); font-weight:800; background:var(--navy); color:#fff; border-radius:20px; padding:1px 9px; font-size:13px; }

/* ============ Articolo ============ */
.art-wrap { max-width:720px; margin:0 auto; padding:clamp(22px,4vw,38px) clamp(16px,4vw,32px) 44px; }
.art-wrap h1 { font-family:var(--disp); font-weight:800; font-size:clamp(28px,5vw,44px); line-height:1.04; letter-spacing:-.03em; margin:12px 0 12px; }
.art-som { font-size:clamp(16px,2vw,20px); color:var(--ink-2); line-height:1.5; }
.art-meta { display:flex; gap:9px; align-items:center; font-size:13px; color:var(--ink-3); font-weight:700; margin:16px 0 20px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.art-cover { border-radius:var(--r-lg); overflow:hidden; margin-bottom:24px; background:var(--wash); }
.art-body { font-size:18px; line-height:1.75; color:#1c232c; }
.art-body p { margin:0 0 18px; }
.art-body h2 { font-family:var(--disp); font-weight:800; font-size:25px; margin:30px 0 12px; letter-spacing:-.02em; }
.art-body blockquote { border-left:3px solid var(--azzurro); background:var(--card); border-radius:0 var(--r-sm) var(--r-sm) 0; padding:12px 18px; margin:20px 0; font-style:italic; color:var(--ink-2); }
.art-body a { color:var(--azzurro); font-weight:700; text-decoration:underline; }
.art-body ul, .art-body ol { margin:0 0 18px 22px; }
.art-body img { border-radius:var(--r); margin:8px 0 20px; }

/* ============ Footer ============ */
footer { background:var(--navy); color:#fff; margin-top:clamp(40px,6vw,68px); }
footer .wrap { padding-top:clamp(34px,5vw,50px); padding-bottom:24px; }
.foot-top { display:flex; flex-wrap:wrap; gap:32px 48px; justify-content:space-between; }
.foot-brand { max-width:360px; }
.foot-brand .logo { color:#fff; font-size:22px; }
.foot-brand p { margin-top:13px; color:rgba(255,255,255,.66); font-size:14px; line-height:1.6; }
.foot-cols { display:flex; gap:clamp(36px,7vw,68px); }
.foot-col { display:flex; flex-direction:column; gap:2px; }
.foot-col h4 { font-family:var(--disp); font-weight:800; font-size:12px; text-transform:uppercase; letter-spacing:.07em; color:var(--yellow); margin-bottom:8px; }
.foot-col a { color:rgba(255,255,255,.82); font-size:14.5px; padding:6px 0; transition:color .15s; }
.foot-col a:hover { color:#fff; }
.foot-bottom { display:flex; flex-wrap:wrap; gap:8px 20px; justify-content:space-between; align-items:center;
  margin-top:34px; padding-top:20px; border-top:1px solid rgba(255,255,255,.14); color:rgba(255,255,255,.6); font-size:12.5px; }
@media (max-width:700px){ .foot-top { flex-direction:column; gap:28px; } }

/* ============ Welcome (0 articoli) ============ */
.welcome { position:relative; overflow:hidden; background:var(--navy); color:#fff; border-radius:var(--r-lg);
  padding:clamp(34px,7vw,64px) clamp(22px,5vw,48px); text-align:center; margin-top:clamp(20px,3vw,30px); }
.welcome::before { content:''; position:absolute; inset:0; opacity:.85;
  background:radial-gradient(120% 120% at 15% 0%, var(--azzurro) 0%, transparent 55%); }
.welcome > * { position:relative; }
.welcome h1 { font-family:var(--disp); font-weight:900; font-size:clamp(28px,6vw,52px); line-height:1.02; letter-spacing:-.03em; }
.welcome p { margin-top:14px; font-size:clamp(15px,2vw,19px); color:rgba(255,255,255,.9); max-width:52ch; margin-inline:auto; }
.welcome .badge { display:inline-block; background:var(--yellow); color:var(--ink); font-family:var(--disp);
  font-weight:800; font-size:12.5px; padding:5px 15px; border-radius:40px; margin-bottom:18px; }

/* ============ Responsive ============ */
@media (max-width:700px){
  .frow { grid-template-columns:104px 1fr; gap:13px; }
  .frow .ph { width:104px; }
}
@media (max-width:460px){
  .mh-date { display:none; }
  .masthead .logo { font-size:21px; }
  .hide-460, .hide-420 { display:none; }
  .cta { font-size:12px; padding:8px 13px; }
  .hero h1 { font-size:24px; }
  .snews { grid-template-columns:78px 1fr; gap:11px; }
  .snews .ph { width:78px; }
}
