/* =============================================================
   review-C.css — Famiglia C (online-casinos.ws)
   Canovaccio recensioni: header "hero" riassuntivo, rating stelle
   coerente, set icone inline-SVG, feature-list, striscia fatti,
   "Restricted countries" a comparsa, accento sezioni nel corpo.
   Tokenizzato (palette C), responsive, accessibile, SENZA JS.
   Da usare con casino-specs-C.css (pagamenti/valute/crypto).
   Per il rollout: confluisce in override.css.
   ============================================================= */
:root{
  --oc-primary:#9fc438; --oc-primary-dark:#7ea52e;
  --oc-cta:#bf0000; --oc-cta-dark:#9b0000;
  --oc-ink:#2e2e2e; --oc-muted:#8a8a8a;
  --oc-bg:#fff; --oc-surface:#f3f3f3; --oc-border:#e6e6e6;
  --oc-ok-bg:#f4fae6; --oc-ok-ink:#4d6f14; --oc-ok-border:#d7e8b0;
  --oc-radius:14px; --oc-radius-sm:10px; --oc-pill:999px;
}

/* --- icona inline -------------------------------------------------- */
.oc-ico{ display:inline-flex; width:1.2em; height:1.2em; flex:none; vertical-align:middle; }
.oc-ico svg{ width:100%; height:100%; display:block; }

/* --- HERO / scheda riassuntiva ------------------------------------- */
.oc-review-hero{
  background:var(--oc-bg); border:1px solid var(--oc-border);
  border-radius:var(--oc-radius); padding:18px 18px 16px;
  box-shadow:0 1px 4px rgba(0,0,0,.06); margin:0 0 24px;
}
.oc-hero-top{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.oc-hero-logo{
  flex:none; width:154px; height:66px; display:flex; align-items:center; justify-content:center;
  background:var(--oc-surface); border-radius:var(--oc-radius-sm); padding:8px;
}
.oc-hero-logo img{ max-width:100%; max-height:100%; object-fit:contain; }
.oc-hero-id{ flex:1 1 240px; min-width:0; }
.oc-hero-id h1{ margin:0; font-size:27px; line-height:1.12; color:var(--oc-ink); font-weight:800; letter-spacing:-.2px; }
.oc-hero-eyebrow{
  margin-top:6px; color:var(--oc-muted); font-size:13px; font-weight:600;
  display:flex; align-items:center; gap:7px; flex-wrap:wrap;
}
.oc-hero-eyebrow .oc-ico{ color:var(--oc-primary-dark); width:15px; height:15px; }
.oc-hero-cta{ flex:none; display:flex; flex-direction:column; align-items:stretch; gap:6px; text-align:center; }

/* rating stelle (coerente, niente sprite) */
.oc-rating{ display:inline-flex; align-items:center; gap:9px; margin-top:9px; }
.oc-stars{ position:relative; display:inline-block; font-size:21px; line-height:1; letter-spacing:2px; font-family:Arial,"Segoe UI",sans-serif; }
.oc-stars::before{ content:"\2605\2605\2605\2605\2605"; color:#dcdcdc; }
.oc-stars i{ position:absolute; left:0; top:0; width:var(--pct,100%); overflow:hidden; white-space:nowrap; }
.oc-stars i::before{ content:"\2605\2605\2605\2605\2605"; color:var(--oc-primary); }
.oc-rating__num{ font-weight:800; color:var(--oc-ink); font-size:15px; }
.oc-rating__num small{ color:var(--oc-muted); font-weight:600; font-size:12px; }

/* CTA principale */
.oc-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  background:var(--oc-cta); color:#fff; font-weight:800; font-size:15px; text-decoration:none;
  padding:13px 24px; border-radius:var(--oc-pill); box-shadow:0 2px 0 var(--oc-cta-dark);
  transition:filter .12s, transform .08s;
}
.oc-btn:hover{ filter:brightness(1.07); }
.oc-btn:active{ transform:translateY(1px); box-shadow:0 1px 0 var(--oc-cta-dark); }
.oc-btn:focus-visible{ outline:3px solid var(--oc-primary); outline-offset:2px; }
.oc-btn .oc-ico{ width:1em; height:1em; }
.oc-legal{ font-size:11px; color:var(--oc-muted); font-weight:600; }

/* striscia "fatti" reali */
.oc-facts{
  list-style:none; margin:16px 0 2px; padding:15px 0 0; border-top:1px solid var(--oc-border);
  display:grid; grid-template-columns:repeat(auto-fit,minmax(155px,1fr)); gap:13px 16px;
}
.oc-fact{ display:flex; align-items:flex-start; gap:9px; }
.oc-fact .oc-ico{ color:var(--oc-primary-dark); width:20px; height:20px; margin-top:1px; }
.oc-fact b{ display:block; font-size:10.5px; text-transform:uppercase; letter-spacing:.5px; color:var(--oc-muted); font-weight:700; }
.oc-fact span{ display:block; font-size:13.5px; color:var(--oc-ink); font-weight:600; line-height:1.3; }

/* --- feature list (sidebar) --------------------------------------- */
.oc-feature-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.oc-feature{ display:flex; align-items:flex-start; gap:11px; }
.oc-feature__ic{
  flex:none; width:34px; height:34px; border-radius:var(--oc-pill);
  background:var(--oc-ok-bg); color:var(--oc-primary-dark);
  display:flex; align-items:center; justify-content:center;
}
.oc-feature__ic .oc-ico{ width:18px; height:18px; }
.oc-feature__tx{ font-size:13.5px; color:var(--oc-ink); line-height:1.4; }
.oc-feature__tx a{ color:var(--oc-primary-dark); font-weight:600; text-decoration:none; }
.oc-feature__tx a:hover{ text-decoration:underline; }

/* "Restricted countries" a comparsa */
.oc-restricted{ border:1px solid var(--oc-border); border-radius:var(--oc-radius-sm); background:var(--oc-surface); }
.oc-restricted>summary{
  cursor:pointer; padding:10px 12px; font-weight:700; font-size:13.5px; color:var(--oc-ink);
  display:flex; align-items:center; gap:8px; list-style:none;
}
.oc-restricted>summary::-webkit-details-marker{ display:none; }
.oc-restricted>summary .oc-ico{ color:var(--oc-primary-dark); width:17px; height:17px; }
.oc-restricted>summary .oc-restricted__chev{ margin-left:auto; transition:transform .15s; }
.oc-restricted[open]>summary .oc-restricted__chev{ transform:rotate(180deg); }
.oc-restricted__body{ padding:2px 12px 12px; font-size:12px; color:var(--oc-muted); line-height:1.65; }

/* --- accento sezioni nel corpo prosa ------------------------------ */
.oc-prose h2{ position:relative; padding-left:15px; }
.oc-prose h2::before{ content:""; position:absolute; left:0; top:.14em; bottom:.14em; width:5px; border-radius:3px; background:var(--oc-primary); }

/* --- card sidebar (titoli) ---------------------------------------- */
.oc-card{ background:var(--oc-bg); border:1px solid var(--oc-border); border-radius:var(--oc-radius); padding:14px 15px; margin:0 0 16px; }
.oc-card>h3{ margin:0 0 11px; font-size:14px; text-transform:uppercase; letter-spacing:.4px; color:var(--oc-ink); font-weight:800; display:flex; align-items:center; gap:8px; }
.oc-card>h3 .oc-ico{ color:var(--oc-primary-dark); width:18px; height:18px; }

@media(max-width:680px){
  .oc-hero-cta{ width:100%; }
  .oc-hero-id h1{ font-size:22px; }
}

/* --- galleria screenshot (moderna, lightbox Magnific riusato) ------ */
.oc-shots{ list-style:none; margin:10px 0 6px; padding:0;
  display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px; }
.oc-shots li{ list-style:none; margin:0; padding:0; }
.oc-shot{ position:relative; display:block; aspect-ratio:900/527; border-radius:var(--oc-radius);
  overflow:hidden; border:1px solid var(--oc-border); background:var(--oc-surface);
  box-shadow:0 1px 4px rgba(0,0,0,.07); }
.oc-shot img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s ease; }
.oc-shot::after{ content:""; position:absolute; inset:0; background:rgba(40,46,30,0); transition:background .25s ease; }
.oc-shot__zoom{ position:absolute; right:10px; bottom:10px; width:36px; height:36px; border-radius:var(--oc-pill);
  background:var(--oc-primary); color:#fff; display:flex; align-items:center; justify-content:center;
  opacity:0; transform:translateY(8px) scale(.85); transition:opacity .25s ease, transform .25s ease;
  box-shadow:0 3px 8px rgba(0,0,0,.28); pointer-events:none; }
.oc-shot__zoom .oc-ico{ width:19px; height:19px; }
.oc-shot:hover img, .oc-shot:focus-visible img{ transform:scale(1.08); }
.oc-shot:hover::after, .oc-shot:focus-visible::after{ background:rgba(40,46,30,.22); }
.oc-shot:hover .oc-shot__zoom, .oc-shot:focus-visible .oc-shot__zoom{ opacity:1; transform:translateY(0) scale(1); }
.oc-shot:focus-visible{ outline:3px solid var(--oc-primary); outline-offset:2px; }
@media(max-width:560px){ .oc-shots{ grid-template-columns:1fr 1fr; gap:10px; } }
@media(max-width:380px){ .oc-shots{ grid-template-columns:1fr; } }

/* ---- Notice box (es. casinò chiuso) ---- */
.oc-notice{display:flex;gap:12px;align-items:flex-start;margin:0 0 22px;padding:16px 18px;border-radius:var(--oc-radius,14px);background:#fff7ed;border:1px solid #f59e0b;border-left:5px solid #f59e0b;color:#7a3b00}
.oc-notice__ico{flex:0 0 auto;color:#d97706;margin-top:2px}
.oc-notice h3{margin:0 0 5px;font-size:1.05rem;color:#b45309;line-height:1.2}
.oc-notice p{margin:0;font-size:.95rem;line-height:1.55}
.oc-notice a{color:#b45309;font-weight:700;text-decoration:underline}


/* ---- Slot pros/cons ---- */
.oc-pc{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:20px 0}
.oc-pc__col{background:var(--oc-surface,#f3f3f3);border:1px solid var(--oc-border,#e6e6e6);border-radius:12px;padding:14px 18px}
.oc-pc__col h4{margin:0 0 8px;font-size:1.05rem}
.oc-pc ul{list-style:none;margin:0;padding:0}
.oc-pc li{padding:5px 0 5px 26px;position:relative;font-size:.95rem;line-height:1.4}
.oc-pc--pro li::before{content:"\2713";position:absolute;left:2px;color:#3c9a2e;font-weight:800}
.oc-pc--con li::before{content:"\2717";position:absolute;left:2px;color:#bf0000;font-weight:800}
@media(max-width:640px){.oc-pc{grid-template-columns:1fr}}

/* Riempimento stelle senza inline (--pct via classe) */
.oc-stars.s-0{--pct:0%}
.oc-stars.s-10{--pct:10%}
.oc-stars.s-20{--pct:20%}
.oc-stars.s-30{--pct:30%}
.oc-stars.s-40{--pct:40%}
.oc-stars.s-50{--pct:50%}
.oc-stars.s-60{--pct:60%}
.oc-stars.s-70{--pct:70%}
.oc-stars.s-80{--pct:80%}
.oc-stars.s-90{--pct:90%}
.oc-stars.s-100{--pct:100%}

/* Scheda tecnica gioco/slot (griglia moderna, niente inline) */
.oc-specs{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.55rem 1.3rem;margin:1.1rem 0 1.3rem;padding:1rem 1.2rem;background:var(--oc-soft,#f5f8ee);border:1px solid #e6ecd8;border-left:4px solid var(--oc-primary,#9fc438);border-radius:var(--oc-radius,14px);}
.oc-specs .spec{display:flex;flex-direction:column;gap:.1rem;}
.oc-specs .spec b{font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;color:#8a8f7e;font-weight:700;}
.oc-specs .spec span{font-weight:600;color:var(--oc-ink,#2e2e2e);font-size:.98rem;}
