:root{
  /* chrome dello strumento = mondo "Randagi 24.7" blu acciaio (iced-out). NON arancione. */
  --c:#2F88C2;--c-bri:#46A6DE;--c-deep:#1C6FA6;--bone:#F2F0EA;
  /* arancione = identita' della SOLA piattaforma "Sito" (il sito pubblico e' arancione) */
  --o:#FE5A1D;
  --ink:#1B2926;--ink2:#16201E;--ink3:#233331;--line:rgba(255,255,255,.14);
  --green:#1DB954;--red:#FF4444;--ig:#E1306C;--tk:#25F4EE;
  --display:'Anton','Archivo',sans-serif;--ui:'Archivo','Helvetica Neue',Arial,sans-serif;--mono:'IBM Plex Mono',ui-monospace,monospace}
*{box-sizing:border-box}
body{margin:0;background:var(--ink);color:#fff;font:15px/1.45 'Archivo',-apple-system,Arial,sans-serif}
a{color:inherit}
/* header come il pannello /admin: logo + tag + nav a sinistra, utente/esci a destra (mood acciaio) */
.bar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:22px;background:var(--c-deep);
  color:var(--bone);padding:0 22px;height:64px;font-weight:700}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;padding-right:18px;
  border-right:2px solid rgba(255,255,255,.22)}
.brand-logo{height:22px;filter:brightness(0) invert(1)}  /* wordmark nero -> bianco sull'header scuro */
.brand-tag{border:2px solid var(--bone);color:var(--bone);font-weight:800;font-size:10px;
  letter-spacing:.1em;text-transform:uppercase;padding:2px 7px}
.nav{display:flex;gap:20px}
.nav a{color:var(--bone);text-decoration:none;font-weight:700;font-size:12px;letter-spacing:.05em;
  text-transform:uppercase;opacity:.72;padding:2px 0;border-bottom:2px solid transparent}
.nav a:hover{opacity:1}
.nav a.active{opacity:1;border-bottom-color:var(--bone)}
.right{margin-left:auto;display:flex;align-items:center;gap:12px}
.who{font-size:.85em;opacity:.8}
.ghost{border:2px solid var(--bone);color:var(--bone);padding:5px 12px;text-decoration:none;font-weight:700;
  font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.ghost:hover{background:var(--bone);color:var(--c-deep)}
/* sistema bottoni (acciaio) allineato al /admin */
.btn,.btn-ghost{display:inline-flex;align-items:center;gap:8px;font-family:var(--ui);font-weight:700;
  text-transform:uppercase;letter-spacing:.03em;font-size:14px;padding:11px 20px;border:2px solid transparent;
  cursor:pointer;text-decoration:none;transition:background .14s,border-color .14s}
.btn{background:var(--c);color:#fff}
.btn:hover{background:var(--c-bri)}
.btn-ghost{background:transparent;border-color:var(--line);color:#fff}
.btn-ghost:hover{border-color:#fff}
.btn-sm{padding:7px 12px;font-size:12px}
.badge{display:inline-block;padding:3px 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.badge.gen{background:var(--ink2);color:rgba(255,255,255,.6);border:1px solid var(--line)}
tr.gen td{opacity:.6}
.warn{color:#F5C518}
code{background:var(--ink2);padding:1px 5px;font-size:.9em}
.assign{display:flex;gap:6px;align-items:center;margin:0}
.assign input[type=number]{width:62px;background:var(--ink2);border:1px solid var(--line);color:#fff;padding:5px 7px;font:inherit}
.assign button{background:var(--c);color:#fff;border:0;padding:6px 12px;font-weight:700;cursor:pointer;font-size:.82em;text-transform:uppercase;letter-spacing:.03em}
.assign button:hover{filter:brightness(1.12)}
main{max-width:1180px;margin:22px auto;padding:0 18px}
h1{font-family:'Anton','Archivo',sans-serif;font-weight:400;font-size:34px;line-height:1;letter-spacing:.01em;text-transform:uppercase;margin:.15em 0 .35em}
h2.sec{font-size:18px;margin:28px 0 12px;color:#fff;text-transform:uppercase;letter-spacing:.03em;font-weight:700;
  border-left:3px solid var(--c);padding-left:10px}
h3{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:rgba(255,255,255,.6);margin:0 0 10px;font-weight:700}
.muted{color:rgba(255,255,255,.6)}.sm{font-size:12px}

/* momentum verdict */
.verdict{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  border:2px solid var(--line);padding:16px 20px;margin:14px 0 12px;background:var(--ink3)}
.verdict .vlabel{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.5)}
.verdict .vbig{font-size:26px;font-weight:800;margin-top:2px}
.verdict .vbig b{text-transform:uppercase}
.verdict .vsub{font-size:13px;color:rgba(255,255,255,.6)}
.v-increscita{border-color:var(--green)} .v-increscita .vbig b{color:var(--green)}
.v-incalo{border-color:var(--red)} .v-incalo .vbig b{color:var(--red)}
.v-stabile{border-color:var(--c)} .v-stabile .vbig b{color:var(--c)}
.v-inripresa{border-color:#F5C518} .v-inripresa .vbig b{color:#F5C518}

.momgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:12px}
@media(max-width:520px){.momgrid{grid-template-columns:repeat(2,1fr)}}
.mcard{background:var(--ink3);border:2px solid var(--line);padding:13px}
.mcard .l{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:rgba(255,255,255,.55)}
.mcard .v{font-size:24px;font-weight:800;font-variant-numeric:tabular-nums;margin-top:3px}
.mcard .d{font-size:12px;margin-top:4px;font-variant-numeric:tabular-nums}
.mcard .d.up{color:var(--green)} .mcard .d.down{color:var(--red)}

/* KPI 3 piattaforme */
.kpis3{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:980px){.kpis3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.kpis3{grid-template-columns:1fr}}
.kpi3{background:var(--ink3);border:2px solid var(--line);border-top-width:4px;padding:16px}
.kpi3.sp{border-top-color:var(--green)} .kpi3.yt{border-top-color:var(--red)} .kpi3.si{border-top-color:var(--o)} .kpi3.ig{border-top-color:var(--ig)}
.kpi3 .pl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.85}
.kpi3 .v{font-size:32px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1.1;margin-top:4px}
.kpi3 .l{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:rgba(255,255,255,.55)}
.kpi3 .sub{font-size:12px;color:rgba(255,255,255,.6);margin-top:6px}

.toggles{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px;color:rgba(255,255,255,.55);margin-bottom:8px}
.tg{background:var(--ink2);border:1px solid var(--line);color:rgba(255,255,255,.7);padding:4px 11px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;cursor:pointer}
.tg.on{background:var(--c);color:#fff;border-color:var(--c)}
.exc{margin-left:auto;display:flex;align-items:center;gap:5px;cursor:pointer;text-transform:none;font-weight:400}
.card{background:var(--ink3);border:2px solid var(--line);padding:14px;margin-bottom:14px}
.cbox{position:relative;height:260px}
.cbox.sm{height:200px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
@media(max-width:980px){.grid2{grid-template-columns:1fr}}
/* tabelle dentro le card (scorecard, salute pubblico): non forzare la larghezza piena */
.card .wrap{border-width:0;margin:0}
.card .wrap table{min-width:0}
.scorecell{white-space:nowrap}
.scorebar{display:inline-block;width:64px;height:8px;background:var(--ink);border:1px solid var(--line);margin-right:7px;vertical-align:middle}
.scorebar span{display:block;height:100%;background:var(--c)}
table.mini{min-width:0;margin-top:10px}
.card.pick{border-left:4px solid var(--c)}
.card.pick .pl{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.6)}
.vbigpick{font-family:'Anton',sans-serif;font-size:30px;line-height:1.1;text-transform:uppercase;letter-spacing:.01em;margin-top:3px}
tr.pickrow td{background:rgba(254,90,29,.14)}
.subh{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.75);margin:18px 0 8px;font-weight:700}
.demo-row{display:flex;align-items:center;gap:10px;margin:6px 0}
.demo-row .dl{flex:0 0 140px;font-size:13px;color:rgba(255,255,255,.82);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.demo-row .db{flex:1;height:10px;background:var(--ink);border:1px solid var(--line)}
.demo-row .db i{display:block;height:100%;background:var(--ig)}
.demo-row .dp{flex:0 0 50px;text-align:right;font-variant-numeric:tabular-nums;font-size:13px;color:rgba(255,255,255,.7)}

/* tabella */
.wrap{overflow-x:auto;border:2px solid var(--line);-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;background:var(--ink2);min-width:1180px}
th,td{padding:9px 11px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}
th{background:var(--ink3);text-transform:uppercase;font-size:11px;letter-spacing:.04em;color:rgba(255,255,255,.6)}
tbody tr:hover td{background:var(--ink3)}
tr.blk td{background:rgba(255,68,68,.06)}
.r{text-align:right}.num{font-variant-numeric:tabular-nums}.str{color:var(--green);font-weight:700}
.flag{font-size:9px;text-transform:uppercase;letter-spacing:.04em;color:var(--red);border:1px solid var(--red);padding:1px 4px;margin-left:4px;vertical-align:middle}
.tag{display:inline-block;padding:2px 6px;font-size:10px;font-weight:700;text-transform:uppercase;border:1px solid var(--line);margin-right:3px}
.tag.spotify{color:var(--green)}.tag.youtube{color:var(--red)}.tag.site{color:var(--o)}.tag.ig{color:var(--ig)}.tag.tiktok{color:var(--tk)}
td.ig{color:var(--ig)}td.tk{color:var(--tk)}td.yt{color:var(--red)}

/* form TikTok manuale */
.tkform{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}
.tkform label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:rgba(255,255,255,.6)}
.tkform input{background:var(--ink2);border:1px solid var(--line);color:#fff;padding:8px 10px;font:inherit;min-width:150px}
.tkform button{background:var(--c);color:#fff;border:0;padding:10px 20px;font-weight:700;text-transform:uppercase;cursor:pointer;letter-spacing:.03em}
.tkform button:hover{filter:brightness(1.12)}

/* matrice correlazioni */
table.cmx{min-width:740px}
table.cmx th{font-size:10px;letter-spacing:.02em}
table.cmx tbody th{text-align:left;white-space:nowrap;font-size:11px;color:rgba(255,255,255,.75)}
table.cmx td{font-weight:700;font-variant-numeric:tabular-nums;border-color:rgba(0,0,0,.3);color:#fff}

/* badge di confidenza statistica */
.conf{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:2px 7px;border:1px solid;vertical-align:middle}
.conf.ok{color:var(--green);border-color:var(--green)}
.conf.weak{color:#F5C518;border-color:#F5C518}
.conf.none{color:var(--red);border-color:var(--red)}

/* insights "cosa dicono i dati" */
.insights{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:6px 0 4px}
.ins{background:var(--ink3);border:2px solid var(--line);padding:14px 16px}
.ins.win{border-color:var(--c);grid-column:1/-1}
.ins .ik{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.55);font-weight:700;margin-bottom:5px}
.ins .iv{font-size:22px;font-weight:800;margin-bottom:3px}
.ins .is{font-size:14px;line-height:1.55;color:rgba(255,255,255,.9)}
@media(max-width:760px){.insights{grid-template-columns:1fr}}

/* readout */
.readout{list-style:none;padding:0;margin:6px 0 4px}
.readout li{padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}
.readout li:last-child{border-bottom:0}

/* pannello verifica dati */
.vsum{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin:6px 0 14px}
.vs{background:var(--ink3);border:2px solid var(--line);padding:10px 12px}
.vs.bad{border-color:#F5C518}
.vsn{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums}
.vsl{font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:rgba(255,255,255,.55)}
table.vtab{min-width:1040px}
table.vtab td{vertical-align:top;line-height:1.4}
.vlink{text-decoration:none;font-weight:700}
.vlink.yt{color:var(--red)}.vlink.ig{color:var(--ig)}.vlink.tk{color:var(--tk)}
.vlink:hover{text-decoration:underline}
tr.flagrow td{background:rgba(245,197,24,.06)}
@media(max-width:760px){.vsum{grid-template-columns:repeat(3,1fr)}}

/* dettaglio traccia */
.kvgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:0 26px}
.kv{display:flex;justify-content:space-between;gap:12px;align-items:baseline;padding:10px 0;border-bottom:1px solid var(--line)}
.kv>span{color:rgba(255,255,255,.55);text-transform:uppercase;font-size:11px;letter-spacing:.04em;font-weight:700}
.kv b{font-family:var(--mono);font-variant-numeric:tabular-nums}
@media(max-width:760px){.kvgrid{grid-template-columns:1fr}}

/* ---- mobile ---- */
@media(max-width:680px){
  main{margin:14px auto;padding:0 12px}
  h1{font-size:21px}
  h2.sec{font-size:16px;margin:22px 0 10px}
  .bar{height:50px;padding:0 12px;gap:8px}
  .verdict{padding:13px 15px}
  .verdict .vbig{font-size:21px}
  .kpi3 .v{font-size:26px}
  .mcard .v{font-size:20px}
  .cbox{height:230px}
  .card{padding:11px}
  th,td{padding:8px 9px;font-size:13px}
  .who{display:none}
  .brand-tag{display:none}
  .brand{padding-right:10px}
  .nav{gap:12px}
  .nav a{font-size:10px}
  .bar{height:auto;flex-wrap:wrap;padding:8px 12px;gap:10px}
}
