/* Self-hosted fonts */
@font-face{font-family:"Space Grotesk";font-weight:400;font-display:swap;src:url("/assets/fonts/space-grotesk-latin-400-normal.woff2") format("woff2")}
@font-face{font-family:"Space Grotesk";font-weight:500;font-display:swap;src:url("/assets/fonts/space-grotesk-latin-500-normal.woff2") format("woff2")}
@font-face{font-family:"Space Grotesk";font-weight:700;font-display:swap;src:url("/assets/fonts/space-grotesk-latin-700-normal.woff2") format("woff2")}
@font-face{font-family:"Manrope";font-weight:400;font-display:swap;src:url("/assets/fonts/manrope-latin-400-normal.woff2") format("woff2")}
@font-face{font-family:"Manrope";font-weight:600;font-display:swap;src:url("/assets/fonts/manrope-latin-600-normal.woff2") format("woff2")}
@font-face{font-family:"Manrope";font-weight:700;font-display:swap;src:url("/assets/fonts/manrope-latin-700-normal.woff2") format("woff2")}
@font-face{font-family:"Manrope";font-weight:800;font-display:swap;src:url("/assets/fonts/manrope-latin-800-normal.woff2") format("woff2")}
@font-face{font-family:"Roboto Mono";font-weight:400;font-display:swap;src:url("/assets/fonts/roboto-mono-latin-400-normal.woff2") format("woff2")}
@font-face{font-family:"Roboto Mono";font-weight:500;font-display:swap;src:url("/assets/fonts/roboto-mono-latin-500-normal.woff2") format("woff2")}

/* ============================================================
   Girandola — giri gratis (free spins) non AAMS
   light · teal petrolio · corallo · Space Grotesk
   ============================================================ */
:root{
  --bg:#F4F8F7;
  --surface:#FFFFFF;
  --panel:#EAF3F1;
  --ink:#16211F;
  --ink-2:#4C5B58;
  --ink-3:#7E8D8A;
  --line:#E3ECEA;
  --line-2:#D2DFDC;
  --teal:#0E9488;
  --teal-d:#0B7A70;
  --teal-t:#E0F2F0;
  --coral:#F1556A;
  --coral-d:#DC3F55;
  --coral-t:#FDE7EB;
  --gold:#E7A928;
  --maxw:1140px;
  --disp:"Space Grotesk",system-ui,-apple-system,"Segoe UI",sans-serif;
  --body:"Manrope",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:"Roboto Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--body);font-size:17px;line-height:1.68;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--teal-d)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

h1,h2,h3,h4{font-family:var(--disp);font-weight:700;line-height:1.15;color:var(--ink);letter-spacing:-.4px;margin:0}
h1{font-size:clamp(2.25rem,5.2vw,3.5rem)}
h2{font-size:clamp(1.5rem,3.1vw,2.05rem);margin:2.1em 0 .5em}
h3{font-size:clamp(1.18rem,2.2vw,1.42rem);margin:1.4em 0 .35em}
p{margin:0 0 1.05em}
strong{font-weight:700;color:var(--ink)}

.eyebrow{font-family:var(--mono);font-weight:500;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:var(--teal);margin-bottom:.7em}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(244,248,247,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;gap:18px;height:66px}
.brand{font-family:var(--disp);font-weight:700;font-size:1.35rem;color:var(--ink);letter-spacing:-.5px;white-space:nowrap;display:flex;align-items:center;gap:10px}
.brand .mark{position:relative;width:26px;height:26px;flex:none;border-radius:50%;background:conic-gradient(var(--teal) 0 25%,var(--coral) 0 50%,var(--teal) 0 75%,var(--coral) 0 100%)}
.brand .mark::after{content:"";position:absolute;inset:9px;background:var(--bg);border-radius:50%}
.nav{display:flex;gap:24px;margin-left:auto}
.nav a{color:var(--ink-2);font-weight:600;font-size:.92rem}
.nav a:hover{color:var(--teal)}
.btn{display:inline-flex;align-items:center;gap:.5em;background:var(--teal);color:#fff;font-weight:700;font-size:.92rem;padding:11px 19px;border-radius:12px;border:none;transition:.15s;white-space:nowrap;font-family:var(--body)}
.btn:hover{background:var(--teal-d);color:#fff;transform:translateY(-1px)}
.btn.coral{background:var(--coral)}
.btn.coral:hover{background:var(--coral-d)}

/* ---------- Hero (centrato) ---------- */
.hero{padding:56px 0 20px;text-align:center}
.hero h1{margin:.05em 0 .5em}
.hero h1 em{color:var(--coral);font-style:normal}
.hero .lede{font-size:1.32rem;line-height:1.6;color:var(--ink-2);max-width:58ch;margin:0 auto}
.trust{display:flex;flex-wrap:wrap;gap:11px;margin:28px 0 4px;justify-content:center}
.chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line-2);border-radius:999px;padding:8px 15px;font-size:.85rem;color:var(--ink-2);font-weight:600}
.chip b{color:var(--ink);font-family:var(--disp)}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--coral)}
.author{display:flex;align-items:center;gap:11px;margin-top:22px;font-size:.86rem;color:var(--ink-3);justify-content:center}
.author .ava{width:36px;height:36px;border-radius:50%;background:var(--coral-t);border:1px solid var(--coral);display:flex;align-items:center;justify-content:center;color:var(--coral-d);font-weight:800;font-family:var(--disp)}
.author b{color:var(--ink-2)}
.author .v{color:var(--teal);font-weight:700}

/* ---------- Sum nav (spin counts) ---------- */
.sumnav{display:flex;flex-wrap:wrap;gap:8px;margin:28px 0 4px;justify-content:center}
.sumnav a{border:1px solid var(--line-2);background:var(--surface);color:var(--ink);padding:8px 14px;border-radius:10px;font-weight:700;font-size:.88rem;transition:.15s;font-family:var(--disp)}
.sumnav a:hover{border-color:var(--teal);color:var(--teal)}
.sumnav a.active{background:var(--teal);border-color:var(--teal);color:#fff}

/* ---------- Section head ---------- */
.shead{display:flex;align-items:baseline;justify-content:space-between;gap:14px;flex-wrap:wrap;margin:44px 0 16px}
.shead h2{margin:0}
.shead .meta{font-family:var(--mono);font-size:.74rem;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em}

/* ---------- Comparison table ---------- */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:0 1px 2px rgba(20,40,38,.04)}
table.compare{width:100%;border-collapse:collapse;min-width:680px;font-size:.94rem}
table.compare th{background:var(--panel);text-align:left;font-family:var(--mono);font-weight:500;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);padding:13px 16px;border-bottom:1px solid var(--line)}
table.compare td{padding:14px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
table.compare tr:last-child td{border-bottom:none}
table.compare tr:hover td{background:var(--panel)}
.c-rank{font-family:var(--disp);font-weight:700;color:var(--coral);width:34px}
.c-name{font-weight:700;color:var(--ink);white-space:nowrap}
.c-giri{font-family:var(--disp);font-weight:700;color:var(--teal);white-space:nowrap}
.c-giri span{font-family:var(--body);font-weight:600;color:var(--ink-3);font-size:.82rem}
.c-type{color:var(--ink-2);font-size:.88rem}
.c-cta a{display:inline-block;background:var(--teal);color:#fff;font-weight:700;font-size:.84rem;padding:8px 14px;border-radius:9px;white-space:nowrap}
.c-cta a:hover{background:var(--teal-d)}

/* ---------- Offer card (signature: badge giri circolare) ---------- */
.offers{display:flex;flex-direction:column;gap:14px;margin:16px 0}
.offer{position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:22px 24px;transition:.18s;box-shadow:0 1px 2px rgba(20,40,38,.04)}
.offer:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 8px 24px rgba(14,148,136,.1)}
.offer.top{border-color:var(--coral)}
.ribbon{position:absolute;top:-11px;left:22px;background:var(--coral);color:#fff;font-size:.68rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase;padding:4px 11px;border-radius:7px;font-family:var(--body)}
.o-badge{position:relative;width:96px;height:96px;flex:none;border-radius:50%;background:var(--teal-t);border:3px solid var(--teal);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.o-badge .n{font-family:var(--disp);font-weight:700;font-size:1.9rem;color:var(--teal-d);line-height:.95}
.o-badge .n small{font-size:1rem;font-weight:500}
.o-badge .l{font-family:var(--mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.1em;color:var(--teal-d);margin-top:2px}
.o-rank{position:absolute;top:14px;left:16px;font-family:var(--disp);font-weight:700;font-size:.9rem;color:var(--ink-3)}
.o-main .o-brand{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.plate{display:inline-flex;align-items:center;font-family:var(--disp);font-weight:700;color:#fff;padding:6px 13px;border-radius:9px;font-size:.98rem}
.o-lic{font-family:var(--mono);font-size:.72rem;color:var(--ink-3)}
.o-tags{display:flex;flex-wrap:wrap;gap:7px;margin:8px 0 10px}
.otag{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:.75rem;background:var(--panel);border:1px solid var(--line-2);border-radius:7px;padding:4px 9px;color:var(--ink-2)}
.otag.nd{color:var(--teal-d);border-color:rgba(14,148,136,.3);background:var(--teal-t)}
.otag.co{color:var(--coral-d);border-color:rgba(241,85,106,.3);background:var(--coral-t)}
.o-verdict{font-weight:700;color:var(--ink);margin:0 0 8px}
.pros{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px 18px}
.pros li{font-size:.87rem;color:var(--ink-2);padding-left:19px;position:relative}
.pros li::before{content:"✦";position:absolute;left:0;color:var(--coral);font-weight:700}
.o-act{display:flex;flex-direction:column;gap:9px;align-items:stretch;min-width:150px}
.o-act .btn{justify-content:center}
.codepill{font-family:var(--mono);font-size:.78rem;background:var(--panel);border:1px dashed var(--line-2);border-radius:9px;padding:7px 10px;color:var(--ink-2);text-align:center}
.codepill b{color:var(--coral-d);font-weight:500}

/* ---------- Prose ---------- */
.prose{max-width:72ch}
.note{background:var(--coral-t);border:1px solid rgba(241,85,106,.28);border-left:3px solid var(--coral);border-radius:0 12px 12px 0;padding:15px 18px;margin:22px 0;color:var(--ink)}
.note b{color:var(--coral-d)}

/* ---------- Review (H2) ---------- */
.rev{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px 24px;margin:14px 0;box-shadow:0 1px 2px rgba(20,40,38,.04)}
.rev-h{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:4px}
.rev-h h2{margin:0;font-size:1.4rem}
.rev-h .rank{font-family:var(--mono);font-size:.85rem;color:var(--coral-d);font-weight:500}
.rev-h .gbadge{margin-left:auto;font-family:var(--disp);font-weight:700;font-size:.95rem;color:var(--teal-d);background:var(--teal-t);border:1px solid var(--teal);border-radius:999px;padding:3px 12px}
.rev-sub{display:flex;flex-wrap:wrap;gap:7px;margin:9px 0 12px}
.tag{display:inline-flex;align-items:center;font-family:var(--mono);font-size:.75rem;background:var(--panel);border:1px solid var(--line-2);border-radius:7px;padding:4px 9px;color:var(--ink-2)}
.rev p{margin-bottom:.7em;color:var(--ink-2)}
.rev .rbtn{margin-top:6px}

/* ---------- Sum grid ---------- */
.sumgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px;margin:16px 0}
.sumcard{display:block;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px;transition:.18s}
.sumcard:hover{border-color:var(--coral);transform:translateY(-2px)}
.sumcard .big{font-family:var(--disp);font-weight:700;font-size:2rem;color:var(--teal-d);line-height:1}
.sumcard h3{margin:.1em 0 .3em;font-size:1.08rem}
.sumcard p{margin:0;font-size:.88rem;color:var(--ink-2)}
.sumcard .go{display:inline-block;margin-top:10px;color:var(--teal);font-weight:700;font-size:.85rem}

/* ---------- FAQ ---------- */
.faq details{border:1px solid var(--line);border-radius:12px;margin-bottom:9px;background:var(--surface)}
.faq summary{cursor:pointer;padding:15px 18px;font-weight:700;color:var(--ink);list-style:none;display:flex;justify-content:space-between;gap:14px;font-family:var(--disp)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--coral);font-size:1.3rem;line-height:1;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 18px 15px;color:var(--ink-2)}

/* ---------- Breadcrumb ---------- */
.crumb{font-family:var(--mono);font-size:.8rem;color:var(--ink-3);padding-top:6px}
.crumb a{color:var(--ink-2)}
.crumb a:hover{color:var(--teal)}

/* ---------- Author box ---------- */
.authorbox{margin:48px 0 0;padding:24px 26px;background:var(--surface);border:1px solid var(--line);border-radius:18px;display:flex;gap:16px;align-items:flex-start;box-shadow:0 1px 2px rgba(20,40,38,.04)}
.authorbox .ava-lg{flex:none;width:54px;height:54px;border-radius:50%;background:var(--coral-t);border:1px solid var(--coral);display:flex;align-items:center;justify-content:center;color:var(--coral-d);font-family:var(--disp);font-weight:700;font-size:1.55rem}
.authorbox .aname{font-family:var(--disp);font-weight:700;font-size:1.26rem;color:var(--ink);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.vbadge{display:inline-flex;align-items:center;gap:5px;font-family:var(--body);font-weight:700;font-size:.84rem;color:var(--teal)}
.vbadge .tick{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;border-radius:50%;background:var(--teal);color:#fff;font-size:.72rem;font-weight:700}
.abio{margin:.45em 0 0;font-size:.93rem;color:var(--ink-2);line-height:1.65;max-width:70ch}

/* ---------- CTA band + footer ---------- */
.cta-band{background:linear-gradient(135deg,var(--teal),#0c8b7f);border-radius:20px;padding:42px;text-align:center;margin:60px 0 0;color:#fff}
.cta-band h2{margin:0 0 .3em;color:#fff}
.cta-band h2 em{color:#ffe0b0;font-style:normal}
.cta-band p{color:rgba(255,255,255,.9);max-width:56ch;margin:0 auto 20px}
.cta-band .btn{background:#fff;color:var(--teal-d)}
.cta-band .btn:hover{background:#f0f0f0;color:var(--teal-d)}
.age{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:2px solid rgba(255,255,255,.6);color:#fff;border-radius:50%;font-weight:700;margin-bottom:14px;font-family:var(--disp)}
.site-footer{margin-top:52px;border-top:1px solid var(--line);padding:40px 0 34px;color:var(--ink-3);font-size:.86rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:30px;margin-bottom:24px}
.foot-grid h4{font-family:var(--disp);font-size:1rem;color:var(--ink);margin:0 0 12px}
.foot-grid a{display:block;color:var(--ink-2);margin-bottom:7px}
.foot-grid a:hover{color:var(--teal)}
.disclaimer{border-top:1px solid var(--line);padding-top:16px;line-height:1.6}
.disclaimer b{color:var(--coral-d)}

/* ---------- Responsive ---------- */
@media(max-width:820px){
  .offer{grid-template-columns:auto 1fr;gap:16px}
  .o-act{grid-column:1/-1;flex-direction:row;flex-wrap:wrap}
  .o-act .btn{flex:1}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  body{font-size:16px}
  .nav{display:none}
  .offer{grid-template-columns:1fr;text-align:center}
  .o-badge{margin:0 auto}
  .o-main .o-brand,.o-tags,.pros{justify-content:center}
  .o-rank{position:static;margin-bottom:6px}
  .foot-grid{grid-template-columns:1fr}
  .cta-band{padding:28px 20px}
}
a:focus-visible,summary:focus-visible,.btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
