/*
Theme Name:  MBItalia — Registro
Description: Tema custom per matchedbettingitalia.it. Colonna unica di lettura,
             testo continuo, link affiliato nel flusso. Regola semantica:
             il verde compare SOLO su valori monetari/positivi e CTA,
             il rosso solo su perdite/contro. Nessun JavaScript.
Version:     1.1
Author:      Roberto Mazzanti
*/

/* ============ 1. TOKEN ============ */
:root{
  --carta:      #F6F7F3;
  --riga:       #E3E6DD;
  --inchiostro: #1B2420;
  --grigio:     #5B665F;
  --petrolio:   #0D4A42;
  --profitto:   #0E8A4F;
  --profitto-bg:#E8F4EC;
  --perdita:    #B6402F;
  --bianco:     #FFFFFF;

  --f-display: "Bricolage Grotesque", system-ui, sans-serif;
  --f-testo:   "Source Serif 4", Georgia, serif;
  --f-dati:    "Spline Sans Mono", "Courier New", monospace;

  --colonna: 910px;   /* unica colonna di lettura */
}

/* ============ 2. BASE ============ */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ transition:none !important; animation:none !important; }
}
body{
  margin:0;
  background:var(--carta);
  color:var(--inchiostro);
  font-family:var(--f-testo);
  font-size:1.1rem;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--petrolio); text-decoration-thickness:1px; text-underline-offset:3px; }
a:hover{ text-decoration-thickness:2px; }
:focus-visible{ outline:3px solid var(--petrolio); outline-offset:2px; border-radius:2px; }

h1,h2,h3{
  font-family:var(--f-display);
  line-height:1.15;
  letter-spacing:-0.015em;
  text-wrap:balance;
}
h1{ font-size:clamp(1.9rem, 4.5vw, 2.8rem); font-weight:800; margin:.4em 0 .35em; }
h2{ font-size:clamp(1.4rem, 2.8vw, 1.8rem); font-weight:700; margin:2.1em 0 .55em; }
h3{ font-size:1.18rem; font-weight:700; margin:1.7em 0 .45em; }
p{ margin:0 0 1.15em; }
ul,ol{ padding-left:1.3em; margin:0 0 1.15em; }
li{ margin-bottom:.45em; }

/* Valori monetari */
.eur{ font-family:var(--f-dati); font-weight:600; white-space:nowrap; font-size:.95em; }
.eur.pos{ color:var(--profitto); }
.eur.neg{ color:var(--perdita); }

/* Link affiliato nel testo: si distingue ma resta nel flusso */
a.aff{
  color:var(--profitto); font-weight:600;
  text-decoration-color:var(--profitto);
}

/* ============ 3. BARRA CONFORMITÀ ============ */
.conformita{
  background:var(--inchiostro); color:#D8DED9;
  font-family:var(--f-dati); font-size:.72rem;
  text-align:center; padding:.45rem .8rem; letter-spacing:.02em;
}
.conformita a{ color:#fff; }
.conformita .b18{
  display:inline-block; border:1.5px solid #fff; border-radius:50%;
  width:1.45em; height:1.45em; line-height:1.45em; font-weight:700;
  margin-right:.5em; vertical-align:-15%;
}

/* ============ 4. HEADER ============ */
.testata{
  background:var(--bianco); border-bottom:1px solid var(--riga);
  position:sticky; top:0; z-index:50;
}
.testata-int{
  max-width:1080px; margin:0 auto; padding:.7rem 1.2rem;
  display:flex; align-items:center; gap:1.4rem;
}
.marchio{
  font-family:var(--f-display); font-weight:800; font-size:1.22rem;
  color:var(--inchiostro); text-decoration:none; letter-spacing:-0.02em;
}
.marchio em{ font-style:normal; color:var(--petrolio); }
.marchio small{
  display:block; font-family:var(--f-dati); font-weight:400;
  font-size:.6rem; color:var(--grigio); letter-spacing:.14em; text-transform:uppercase;
}
.nav-principale{ margin-left:auto; display:flex; align-items:center; gap:1.3rem; }
.nav-principale a{
  font-family:var(--f-display); font-weight:600; font-size:.93rem;
  text-decoration:none; color:var(--inchiostro);
}
.nav-principale a:hover{ color:var(--petrolio); }
.cta{
  display:inline-block; background:var(--profitto); color:#fff !important;
  font-family:var(--f-display); font-weight:700; text-decoration:none;
  padding:.6rem 1.2rem; border-radius:999px; font-size:.95rem;
  border:2px solid var(--profitto); transition:background .15s;
}
.cta:hover{ background:#0B6E40; border-color:#0B6E40; }
.nav-toggle, .nav-burger{ display:none; }

/* ============ 5. COLONNA UNICA ============ */
.articolo{
  max-width:var(--colonna); margin:0 auto; padding:2rem 1.2rem 4rem;
}
.briciole{
  font-family:var(--f-dati); font-size:.75rem; color:var(--grigio); margin-bottom:.5rem;
}
.briciole a{ color:var(--grigio); }
.occhiello{
  font-family:var(--f-dati); font-size:.72rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--petrolio); font-weight:600;
}
.meta-articolo{
  display:flex; flex-wrap:wrap; align-items:center; gap:.4rem 1.3rem;
  font-family:var(--f-dati); font-size:.78rem; color:var(--grigio);
  padding:.8rem 0; border-top:1px solid var(--riga); border-bottom:1px solid var(--riga);
  margin-bottom:2rem;
}
.meta-articolo strong{ color:var(--inchiostro); }
.timbro-test{
  background:var(--inchiostro); color:#fff; border-radius:4px;
  padding:.2rem .55rem; font-weight:600;
}


/* Featured image in apertura articolo/pagina */
.evidenza{ margin:0 0 2rem; }
.evidenza img{ width:100%; height:auto; border-radius:10px; display:block; }

/* ============ 6. "IN BREVE" — apertura, non scheda ============ */
.in-breve{
  font-size:1.15rem; line-height:1.7;
  border-bottom:1px solid var(--riga);
  padding-bottom:1.4rem; margin-bottom:2rem;
}
.in-breve p:last-child{ margin-bottom:0; }

/* ============ 7. CTA NEL FLUSSO DEL TESTO ============ */
.cta-flusso{
  text-align:center; margin:2.2rem 0;
}
.cta-flusso .cta{ font-size:1.05rem; padding:.85rem 1.8rem; }
.cta-flusso small{
  display:block; margin-top:.55rem;
  font-family:var(--f-dati); font-size:.7rem; color:var(--grigio);
}

/* ============ 8. RICEVUTA DI VERIFICA (unico elemento "oggetto") ============ */
.ricevuta{
  background:var(--bianco); border:1px solid var(--riga);
  box-shadow:0 10px 24px rgba(27,36,32,.07);
  max-width:480px; margin:2.4rem auto; position:relative;
  font-family:var(--f-dati); border-radius:3px 3px 0 0;
}
.ricevuta::after{
  content:""; position:absolute; left:0; right:0; bottom:-11px; height:12px;
  background:
    linear-gradient(45deg, var(--bianco) 25%, transparent 25%) 0 0/16px 16px,
    linear-gradient(-45deg, var(--bianco) 25%, transparent 25%) 8px 0/16px 16px;
  background-repeat:repeat-x;
}
.ricevuta-testa{
  text-align:center; padding:1.3rem 1.4rem .9rem;
  border-bottom:1px dashed var(--riga);
}
.ricevuta-testa .insegna{
  font-weight:700; letter-spacing:.22em; text-transform:uppercase; font-size:.78rem;
}
.ricevuta-testa .sotto{ font-size:.68rem; color:var(--grigio); margin-top:.3rem; }
.ricevuta-corpo{ padding:1rem 1.4rem .4rem; font-size:.86rem; margin:0; }
.ricevuta-riga{
  display:flex; justify-content:space-between; gap:1rem;
  padding:.5rem 0; border-bottom:1px dashed var(--riga);
}
.ricevuta-riga dt{ color:var(--grigio); }
.ricevuta-riga dd{ margin:0; font-weight:600; text-align:right; }
.ricevuta-totale{
  display:flex; justify-content:space-between; padding:.9rem 1.4rem 1.3rem;
  font-size:1.02rem; font-weight:700; background:var(--profitto-bg);
}
.ricevuta-totale .eur{ font-size:1.25rem; }
.ricevuta-voto{ font-family:var(--f-display); font-size:1.9rem; font-weight:800; color:var(--petrolio); }

/* ============ 9. TABELLE ============ */
.tab-scroll{ overflow-x:auto; margin:1.4rem 0 1.8rem; }
table.registro{
  border-collapse:collapse; width:100%; min-width:520px;
  background:var(--bianco); border:1px solid var(--riga);
  font-size:.92rem; font-family:var(--f-testo);
}
table.registro caption{
  caption-side:top; text-align:left; font-family:var(--f-display);
  font-weight:700; padding:.5rem 0; font-size:1rem;
}
table.registro th{
  font-family:var(--f-display); font-weight:700; text-align:left;
  background:var(--inchiostro); color:#fff; padding:.6rem .9rem; font-size:.85rem;
}
table.registro td{ padding:.6rem .9rem; border-bottom:1px solid var(--riga); vertical-align:top; }
table.registro tr:nth-child(even) td{ background:#FBFCF9; }
table.registro td.num{ font-family:var(--f-dati); font-size:.85rem; }
table.registro tr.verdetto td{ background:var(--profitto-bg); font-weight:700; font-family:var(--f-display); }
.si{ color:var(--profitto); font-weight:700; }
.no{ color:var(--perdita); font-weight:700; }

/* ============ 10. FAQ — solo righe, niente schede ============ */
.faq{ margin:1rem 0 2rem; border-top:1px solid var(--riga); }
.faq details{ border-bottom:1px solid var(--riga); }
.faq summary{
  cursor:pointer; list-style:none; padding:.95rem .2rem;
  font-family:var(--f-display); font-weight:600; font-size:1.02rem;
  display:flex; justify-content:space-between; gap:1rem; align-items:center;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--f-dati); font-size:1.2rem; color:var(--petrolio); }
.faq details[open] summary::after{ content:"–"; }
.faq details > div{ padding:0 .2rem 1rem; font-size:.98rem; }

/* ============ 11. FIRMA AUTORE in coda ============ */
.autore{
  display:flex; gap:1.1rem; align-items:flex-start;
  border-top:1px solid var(--riga); padding-top:1.6rem; margin-top:2.6rem;
}
.autore .pallino{
  flex:none; width:56px; height:56px; border-radius:50%; background:var(--petrolio);
  color:#fff; display:grid; place-items:center; font-family:var(--f-display);
  font-weight:800; font-size:1.3rem;
}
.autore h2{ margin:0 0 .25rem; font-size:1.05rem; }
.autore p{ font-size:.93rem; margin:0 0 .35em; }
.autore .credenziali{ font-family:var(--f-dati); font-size:.72rem; color:var(--grigio); }

/* Nota trasparenza e aggiornamenti: righe di testo, non box */
.nota-trasparenza, .registro-aggiornamenti{
  font-family:var(--f-dati); font-size:.74rem; color:var(--grigio);
  line-height:1.7; margin:1.4rem 0 0;
}
.registro-aggiornamenti time{ color:var(--inchiostro); }

/* ============ 12. PIÈ DI PAGINA ============ */
.pie{ background:var(--inchiostro); color:#C9D2CC; margin-top:3rem; font-size:.9rem; }
.pie a{ color:#fff; }
.pie-int{
  max-width:1080px; margin:0 auto; padding:2.5rem 1.2rem 1.5rem;
  display:grid; grid-template-columns:2fr 1fr 1fr; gap:2.5rem;
}
.pie h2{ color:#fff; font-size:.95rem; margin:0 0 .8rem; font-family:var(--f-display); }
.pie ul{ list-style:none; margin:0; padding:0; }
.pie li{ margin-bottom:.45rem; }
.pie .gioco-responsabile{
  border-top:1px solid #32413A; padding:1.1rem 1.2rem; text-align:center;
  font-family:var(--f-dati); font-size:.72rem; line-height:1.7;
}
.pie .gioco-responsabile .b18{
  display:inline-block; border:1.5px solid #fff; border-radius:50%; color:#fff;
  width:1.6em; height:1.6em; line-height:1.6em; font-weight:700; margin-right:.5em;
}

/* ============ 13. RESPONSIVE ============ */
@media (max-width: 760px){
  .nav-burger{
    display:block; margin-left:auto; cursor:pointer;
    font-family:var(--f-display); font-weight:700; font-size:1rem;
    border:1.5px solid var(--inchiostro); border-radius:6px; padding:.35rem .7rem;
  }
  .nav-principale{
    display:none; position:absolute; top:100%; left:0; right:0;
    background:var(--bianco); border-bottom:1px solid var(--riga);
    flex-direction:column; align-items:flex-start; padding:1rem 1.2rem; gap:.9rem;
  }
  .nav-toggle:checked ~ .nav-principale{ display:flex; }
  .pie-int{ grid-template-columns:1fr; gap:1.6rem; }
}

/* ============ 14. WORDPRESS: liste articoli, paginazione, commenti ============ */
.lista-articoli .anteprima{
  border-bottom:1px solid var(--riga); padding:1.6rem 0;
}
.lista-articoli .anteprima h2{ margin:.15em 0 .3em; }
.lista-articoli .anteprima h2 a{ text-decoration:none; color:var(--inchiostro); }
.lista-articoli .anteprima h2 a:hover{ color:var(--petrolio); }
.anteprima-meta{ font-family:var(--f-dati); font-size:.75rem; color:var(--grigio); margin-bottom:.6em; }
.paginazione{ margin:2rem 0; font-family:var(--f-display); }
.paginazione .nav-links{ display:flex; gap:1rem; flex-wrap:wrap; }
.paginazione .page-numbers{ text-decoration:none; padding:.3rem .7rem; border:1px solid var(--riga); border-radius:6px; background:var(--bianco); }
.paginazione .page-numbers.current{ background:var(--inchiostro); color:#fff; border-color:var(--inchiostro); }

.commenti{ border-top:1px solid var(--riga); margin-top:2.5rem; padding-top:1.5rem; }
.lista-commenti{ list-style:none; padding:0; margin:0 0 1.5rem; }
.lista-commenti .comment{ border-bottom:1px dashed var(--riga); padding:1rem 0; }
.lista-commenti .children{ list-style:none; padding-left:1.6rem; border-left:2px solid var(--riga); margin-top:1rem; }
.comment-author{ font-family:var(--f-display); font-weight:700; display:flex; align-items:center; gap:.6rem; }
.comment-author .avatar{ border-radius:50%; }
.comment-metadata{ font-family:var(--f-dati); font-size:.72rem; }
.comment-metadata a{ color:var(--grigio); }
.comment-reply-link{ font-family:var(--f-dati); font-size:.78rem; }
.comment-form label{ display:block; font-family:var(--f-display); font-weight:600; font-size:.9rem; margin-bottom:.25rem; }
.comment-form input[type="text"], .comment-form input[type="email"],
.comment-form input[type="url"], .comment-form textarea, .ricerca input[type="search"]{
  width:100%; padding:.6rem .8rem; border:1px solid var(--riga); border-radius:6px;
  font-family:var(--f-testo); font-size:1rem; background:var(--bianco); margin-bottom:1rem;
}
.comment-form .submit{ cursor:pointer; }
.ricerca{ display:flex; gap:.6rem; max-width:420px; }
.ricerca input{ margin:0 !important; }
.ricerca .cta{ cursor:pointer; }

/* Allineamenti e blocchi Gutenberg */
.articolo img, .wp-block-image img{ border-radius:6px; }
.wp-block-image figcaption, .wp-element-caption{
  font-family:var(--f-dati); font-size:.74rem; color:var(--grigio); text-align:center;
}
.wp-block-table table{ border-collapse:collapse; width:100%; background:var(--bianco); border:1px solid var(--riga); font-size:.92rem; }
.wp-block-table th{ font-family:var(--f-display); background:var(--inchiostro); color:#fff; padding:.6rem .9rem; text-align:left; }
.wp-block-table td{ padding:.6rem .9rem; border-bottom:1px solid var(--riga); }
.wp-block-quote{ border-left:4px solid var(--petrolio); margin:1.5em 0; padding:.2em 0 .2em 1.2em; font-style:italic; }
.screen-reader-text{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
