/* ============================================================
   SOLANGELES — STREAMING THEME (design system condiviso)
   Netflix × Cartoon Network × late-night broadcast.
   Usato da tutte le pagine del sito ridisegnato.
   ============================================================ */
:root{
  --black:#08080a; --panel:#101014; --card:#16161c;
  --white:#f4f4f0; --grey:#9b9ba6; --line:#23232a;
  --phos:#19fb9b; --purple:#9945ff; --red:#e50914; --amber:#ffb02e;
  --font-disp:'Archivo Black',sans-serif;
  --font-body:'Space Grotesk',sans-serif;
  --font-vhs:'VT323',monospace;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{ scroll-behavior:smooth; }
body{ font-family:var(--font-body); background:var(--black); color:var(--white);
  overflow-x:hidden; -webkit-font-smoothing:antialiased; }
/* scanline late-night, leggerissima */
body::after{ content:""; position:fixed; inset:0; pointer-events:none; z-index:90;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.1) 0 1px, transparent 1px 4px); }
img{ max-width:100%; }
a{ color:inherit; }

.disp{ font-family:var(--font-disp); }
.vhs{ font-family:var(--font-vhs); }

/* divisore "signal line" — sottile, neon, con bagliore */
.checker{ position:relative; height:2px; border:none;
  background:linear-gradient(90deg, transparent 0%, var(--purple) 18%, var(--phos) 50%, var(--purple) 82%, transparent 100%); }
.checker::after{ content:""; position:absolute; left:10%; right:10%; top:-5px; height:12px;
  background:inherit; filter:blur(10px); opacity:.55; pointer-events:none; }

/* ---------- NAV ---------- */
nav.main{ position:fixed; top:0; left:0; right:0; z-index:80;
  display:flex; align-items:center; gap:20px; padding:14px clamp(16px,4vw,48px);
  background:linear-gradient(180deg, rgba(8,8,10,.94) 40%, transparent); }
nav.main .brand img{ height:34px; display:block; }
nav.main .links{ display:flex; gap:2px; }
nav.main .links a{ color:var(--grey); text-decoration:none; font-size:13px; font-weight:700;
  letter-spacing:.06em; padding:9px 13px; border-radius:6px; transition:.15s; }
nav.main .links a:hover{ color:var(--white); background:rgba(255,255,255,.07); }
nav.main .links a.active{ color:var(--phos); }
nav.main .socials{ margin-left:auto; display:flex; gap:8px; }
nav.main .ca{ background:var(--phos); color:#04130c; border:none; border-radius:6px;
  padding:10px 18px; font-weight:700; font-size:12px; letter-spacing:.08em; cursor:pointer;
  box-shadow:0 0 18px rgba(25,251,155,.3); transition:.15s; }
nav.main .ca.copied{ background:var(--amber); }

.soc{ width:38px; height:38px; border-radius:8px; display:flex; align-items:center;
  justify-content:center; background:rgba(255,255,255,.08); border:1px solid var(--line);
  transition:.15s; }
.soc:hover{ border-color:var(--phos); box-shadow:0 0 14px rgba(25,251,155,.3); }
.soc svg{ width:17px; height:17px; fill:var(--white); }

/* hamburger + menu mobile */
.hamb{ display:none; flex-direction:column; gap:5px; padding:11px 10px;
  background:rgba(255,255,255,.08); border:1px solid var(--line); border-radius:8px;
  cursor:pointer; }
.hamb span{ width:21px; height:2px; background:var(--white); border-radius:1px; display:block; }
.t-menu{ display:none; position:fixed; inset:0; z-index:200; background:rgba(8,8,10,.97);
  backdrop-filter:blur(18px); padding:84px 26px 30px; flex-direction:column; gap:4px; }
.t-menu.open{ display:flex; }
.t-menu .close{ position:absolute; top:18px; right:18px; width:44px; height:44px;
  border-radius:50%; background:rgba(255,255,255,.08); border:1px solid var(--line);
  color:var(--white); font-size:25px; line-height:1; cursor:pointer; }
.t-menu a.mlink{ color:var(--white); font-family:var(--font-disp); font-size:29px;
  text-transform:uppercase; letter-spacing:.02em; padding:10px 0; text-decoration:none; }
.t-menu a.mlink:hover{ color:var(--phos); }
.t-menu .mca{ width:100%; padding:14px 16px; background:rgba(255,255,255,.06);
  border:1px solid var(--line); border-radius:10px; display:flex; align-items:center;
  justify-content:space-between; gap:12px; color:var(--white); font-size:13px;
  font-weight:800; letter-spacing:.04em; margin-bottom:18px; cursor:pointer;
  text-transform:uppercase; }
.t-menu .mca .copy{ background:var(--phos); color:#04130c; font-size:11px; font-weight:900;
  letter-spacing:.1em; padding:7px 13px; border-radius:100px; }
.t-menu .mca.copied .copy{ background:var(--amber); }
.t-menu .msoc{ display:flex; gap:12px; margin-top:auto; padding-top:18px; }
.t-menu .msoc .soc{ width:50px; height:50px; }
@media (max-width:900px){
  nav.main .links{ display:none; }
  .hamb{ display:flex; }
}
@media (max-width:560px){ nav.main .socials{ display:none; } }

/* ---------- MUSICA ---------- */
.music{ position:fixed; right:18px; bottom:18px; z-index:95; width:52px; height:52px;
  border-radius:50%; border:2px solid var(--phos); background:rgba(8,8,10,.9);
  color:var(--phos); cursor:pointer; display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 20px rgba(25,251,155,.25); transition:.15s; }
.music:hover{ box-shadow:0 0 32px rgba(25,251,155,.5); }
.music svg{ width:22px; height:22px; fill:currentColor; }
.music .on{ display:none; }
.music.playing{ background:var(--phos); color:#04130c; }
.music.playing .on{ display:block; } .music.playing .off{ display:none; }

/* ---------- BOTTONI ---------- */
.cta-main{ display:inline-flex; align-items:center; gap:11px; background:var(--white);
  color:var(--black); border:none; border-radius:8px; padding:15px 32px;
  font-family:var(--font-disp); font-size:15px; letter-spacing:.04em;
  text-transform:uppercase; text-decoration:none; cursor:pointer; transition:.15s; }
.cta-main:hover{ background:var(--phos); box-shadow:0 0 30px rgba(25,251,155,.45); }
.cta-main svg{ width:17px; height:17px; fill:currentColor; }
.btn-ghost{ display:inline-flex; align-items:center; gap:9px;
  background:rgba(255,255,255,.1); color:var(--white); border:none; border-radius:8px;
  padding:15px 26px; font-weight:700; font-size:13.5px; text-decoration:none; cursor:pointer;
  backdrop-filter:blur(6px); transition:.15s; }
.btn-ghost:hover{ background:rgba(255,255,255,.2); }

/* ---------- ROW / STRIP / TILE ---------- */
.row-sec{ padding:clamp(30px,5vh,52px) 0 0; }
.row-head{ display:flex; align-items:baseline; gap:14px;
  padding:0 clamp(16px,4vw,48px) 14px; }
.row-head h2{ font-family:var(--font-disp); font-size:clamp(18px,2.6vw,26px);
  text-transform:uppercase; letter-spacing:.03em; }
.row-head .tag{ font-family:var(--font-vhs); font-size:18px; color:var(--amber); }
.row-head a.all{ margin-left:auto; color:var(--grey); font-size:12.5px; font-weight:700;
  text-decoration:none; letter-spacing:.08em; }
.row-head a.all:hover{ color:var(--phos); }
.strip{ display:flex; gap:14px; overflow-x:auto; padding:6px clamp(16px,4vw,48px) 22px;
  scroll-snap-type:x mandatory; scrollbar-width:thin; scrollbar-color:#2c2c33 transparent; }
.strip::-webkit-scrollbar{ height:8px; }
.strip::-webkit-scrollbar-thumb{ background:#2c2c33; border-radius:4px; }
.strip.center{ justify-content:safe center; }
@media (max-width:1080px){ .strip.center{ justify-content:flex-start; } }

.tile{ flex:0 0 min(320px,72vw); scroll-snap-align:start; background:var(--card);
  border-radius:10px; overflow:hidden; border:1px solid var(--line);
  cursor:pointer; transition:transform .22s ease, box-shadow .22s ease, border-color .22s;
  position:relative; text-decoration:none; color:var(--white); }
.tile:hover{ transform:scale(1.05); z-index:5; border-color:var(--phos);
  box-shadow:0 14px 44px rgba(0,0,0,.7), 0 0 24px rgba(25,251,155,.18); }
.tile .th{ position:relative; aspect-ratio:16/9; background:#000; }
.tile .th img{ width:100%; height:100%; object-fit:cover; display:block; }
.tile .th .dur{ position:absolute; right:8px; bottom:8px; font-family:var(--font-vhs);
  font-size:16px; background:rgba(0,0,0,.75); padding:2px 8px; border-radius:4px; }
.tile .th .newtag{ position:absolute; left:8px; top:8px; background:var(--red); color:#fff;
  font-weight:700; font-size:10px; letter-spacing:.12em; padding:4px 9px; border-radius:4px; }
.tile .th .playov{ position:absolute; inset:0; display:flex; align-items:center;
  justify-content:center; opacity:0; transition:.2s; background:rgba(0,0,0,.35); }
.tile:hover .playov{ opacity:1; }
.tile .playov i{ width:54px; height:54px; border-radius:50%; background:var(--white);
  display:flex; align-items:center; justify-content:center; }
.tile .playov svg{ width:22px; height:22px; fill:var(--black); margin-left:3px; }
.tile .info{ padding:13px 15px 15px; display:block; }
.tile .info b{ font-family:var(--font-disp); font-size:15.5px; text-transform:uppercase; }
.tile .info p{ font-size:12.5px; color:var(--grey); margin-top:4px; }
.tile .prog{ height:3px; background:#26262c; display:block; }
.tile .prog i{ display:block; height:100%; background:var(--phos); }

/* top-rank tiles */
.top-tile{ flex:0 0 auto; display:flex; align-items:flex-end; scroll-snap-align:start;
  cursor:pointer; text-decoration:none; color:var(--white); }
.top-tile .rank{ font-family:var(--font-disp); font-size:clamp(96px,13vw,170px);
  line-height:.78; color:transparent; -webkit-text-stroke:3px var(--purple);
  margin-right:-18px; position:relative; z-index:1; transition:.2s; }
.top-tile:hover .rank{ -webkit-text-stroke-color:var(--phos); }
.top-tile .pc{ position:relative; z-index:2; width:138px; border-radius:10px;
  overflow:hidden; border:1.5px solid var(--line); transition:.2s; background:var(--card); }
.top-tile:hover .pc{ transform:scale(1.06); border-color:var(--phos);
  box-shadow:0 12px 36px rgba(0,0,0,.7); }
.top-tile .pc img{ width:100%; aspect-ratio:3/4; object-fit:cover; display:block; }
.top-tile .pc b{ display:block; font-family:var(--font-vhs); font-size:17px;
  color:var(--phos); padding:8px 10px; background:#0c0c10; }
.top-tile .pc b small{ float:right; color:var(--grey); font-size:15px; }

/* ---------- CARD GENERICA ---------- */
.dcard{ position:relative; border-radius:14px; overflow:hidden;
  border:1.5px solid var(--line); background:var(--card); transition:.2s; }
.dcard:hover{ border-color:var(--phos); }
.dcard .pad{ padding:clamp(20px,3vw,34px); display:flex; flex-direction:column;
  justify-content:center; gap:10px; }
.dcard .k{ font-family:var(--font-vhs); font-size:18px; color:var(--amber); }
.dcard h3{ font-family:var(--font-disp); font-size:clamp(22px,3vw,34px);
  text-transform:uppercase; line-height:1.02; }
.dcard p{ font-size:13.5px; color:var(--grey); line-height:1.55; }
.dcard .lnk{ display:inline-flex; margin-top:8px; color:var(--phos); font-weight:700;
  font-size:13px; letter-spacing:.08em; text-decoration:none; }
.dcard .lnk:hover{ text-shadow:0 0 12px rgba(25,251,155,.6); }

/* ---------- CN BAND ---------- */
.cn-band{ padding:clamp(34px,6vh,60px) clamp(16px,4vw,48px); background:var(--purple);
  position:relative; overflow:hidden; }
.cn-band::before{ content:""; position:absolute; inset:0; opacity:.13;
  background:radial-gradient(circle, #fff 2px, transparent 3px); background-size:26px 26px; }
.cn-inner{ position:relative; display:flex; align-items:center; gap:26px; flex-wrap:wrap;
  max-width:1140px; margin:0 auto; }
.cn-logo{ flex:none; display:grid; grid-template-columns:repeat(2,46px);
  grid-auto-rows:46px; border:4px solid var(--black); transform:rotate(-4deg);
  box-shadow:6px 7px 0 rgba(0,0,0,.4); }
.cn-logo i{ display:flex; align-items:center; justify-content:center;
  font-family:var(--font-disp); font-size:24px; font-style:normal; }
.cn-logo i:nth-child(1),.cn-logo i:nth-child(4){ background:var(--black); color:var(--white); }
.cn-logo i:nth-child(2),.cn-logo i:nth-child(3){ background:var(--white); color:var(--black); }
.cn-inner h2{ font-family:var(--font-disp); font-size:clamp(24px,4vw,42px);
  text-transform:uppercase; line-height:1.04; }
.cn-inner p{ color:#eadfff; font-size:14.5px; margin-top:6px; max-width:480px; }
.cn-inner .cta-main{ margin-left:auto; }
@media (max-width:760px){ .cn-inner .cta-main{ margin-left:0; } }

/* ---------- COMMUNITY CARDS ---------- */
.comm-grid{ margin-top:24px; display:grid; gap:14px;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); }
.comm{ display:flex; align-items:center; gap:14px; padding:20px;
  background:var(--card); border:1.5px solid var(--line); border-radius:12px;
  text-decoration:none; color:var(--white); transition:.18s; }
.comm:hover{ border-color:var(--phos); transform:translateY(-4px);
  box-shadow:0 12px 34px rgba(0,0,0,.6); }
.comm .ic{ width:46px; height:46px; border-radius:10px; display:flex; align-items:center;
  justify-content:center; flex-shrink:0; }
.comm .ic svg{ width:21px; height:21px; fill:#fff; }
.comm .ic.yt{ background:#c4302b; }
.comm .ic.tw{ background:#16161a; border:1px solid var(--line); }
.comm .ic.tk{ background:#0f0f12; border:1px solid var(--line); }
.comm .ic.dx{ background:var(--purple); }
.comm b{ font-family:var(--font-disp); font-size:15px; text-transform:uppercase; }
.comm p{ font-size:12px; color:var(--grey); margin-top:2px; }

/* ---------- VIDEO LIGHTBOX ---------- */
.vlb{ position:fixed; inset:0; z-index:130; display:none; align-items:center;
  justify-content:center; background:rgba(4,4,6,.95); padding:4vw; }
.vlb.open{ display:flex; }
.vlb .box{ width:100%; max-width:1000px; aspect-ratio:16/9; max-height:84vh;
  border:1.5px solid var(--line); border-radius:12px; background:#000; overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.8), 0 0 40px rgba(153,69,255,.18); }
.vlb iframe, .vlb video{ width:100%; height:100%; border:0; display:block; background:#000; }
.vlb .close{ position:absolute; top:20px; right:22px; width:46px; height:46px;
  border-radius:10px; border:1px solid var(--line); background:var(--panel);
  color:var(--white); font-size:19px; font-weight:800; cursor:pointer; transition:.15s; }
.vlb .close:hover{ border-color:var(--phos); color:var(--phos); }

/* ---------- HEADER DI PAGINA (sottopagine) ---------- */
.page-head{ padding:clamp(110px,16vh,150px) clamp(16px,4vw,48px) clamp(20px,3vh,30px);
  max-width:1140px; margin:0 auto; }
.page-head .tag{ font-family:var(--font-vhs); font-size:19px; color:var(--amber); }
.page-head h1{ font-family:var(--font-disp); font-size:clamp(34px,6vw,64px);
  text-transform:uppercase; line-height:.96; margin-top:10px; }
.page-head p.sub{ color:var(--grey); font-size:14.5px; margin-top:12px; max-width:560px; }

/* ---------- FOOTER ---------- */
footer.main{ border-top:1px solid var(--line); padding:36px clamp(16px,4vw,48px) 46px;
  text-align:center; }
footer.main .socials{ display:flex; gap:10px; justify-content:center; margin-bottom:18px; }
footer.main .soc{ width:46px; height:46px; }
footer.main .soc svg{ width:20px; height:20px; }
footer.main .off{ font-family:var(--font-vhs); font-size:21px; color:var(--grey);
  letter-spacing:.18em; }
footer.main .off b{ color:var(--white); }
footer.main p.fine{ margin-top:10px; font-size:11px; color:#54545e; letter-spacing:.14em;
  text-transform:uppercase; }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001s !important; transition-duration:.001s !important; }
}
