/* BarraCassino — theme & components. Palette: indigo #393a8a · green #10A100 · text #070812 · Lato. */
:root{
  --bg:#ffffff; --surface:#f6f6fb; --surface-2:#eef0f8; --border:#e2e3ef;
  --primary:#393a8a; --primary-dark:#2a2b6b; --primary-tint:#eef0fb;
  --green:#10A100; --green-dark:#0c8400; --green-tint:#eafbe7;
  --gold:#b8860b; --text:#070812; --muted:#5b5d70;
  --bonus-bg:#FEF3C7; --bonus-tx:#92400E; --footer-bg:#F0FFF0;
  --radius:9px; --maxw:1140px;
  --font:'Lato',system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.65;
  font-size:17px;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.1rem}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-dark);text-decoration:underline}
img{max-width:100%;height:auto}
h1,h2,h3,h4{line-height:1.25;color:var(--text);font-weight:800}
h1{font-size:2.05rem;margin:.2rem 0 .6rem}
h2{font-size:1.5rem;margin:2rem 0 .8rem;color:var(--primary)}
h3{font-size:1.18rem;margin:1.4rem 0 .5rem}
p{margin:.7rem 0}
ul,ol{margin:.7rem 0 .7rem 1.2rem;padding:0}
li{margin:.35rem 0}

/* top 18+ strip */
.age-strip{background:var(--primary);color:#eef0fb;font-size:.78rem;text-align:center;
  padding:.35rem 1rem;letter-spacing:.02em}
.age-strip strong{color:#fff}

/* header band: logo + site search */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}
.site-head{background:#fff;border-bottom:1px solid var(--border)}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.9rem 1.1rem}
.site-head .logo{display:flex;align-items:center;gap:.4rem;font-weight:900;font-size:1.7rem;
  color:var(--primary);letter-spacing:-.02em;white-space:nowrap}
.site-head .logo:hover{text-decoration:none}
.site-head .logo .brand-mark{color:var(--green)}
.head-search{display:flex;align-items:center;gap:.5rem;flex:1;max-width:420px}
.head-search #search{flex:1;min-width:0;padding:.6rem .9rem;font-size:.95rem;color:var(--text);
  background:#fff;border:1px solid var(--border);border-radius:7px;
  box-shadow:1px 1px 6px rgba(0,0,0,.15)}
.head-search #search:focus{outline:0;border-color:var(--primary);box-shadow:1px 1px 6px rgba(57,58,138,.25)}
.head-search .btn{white-space:nowrap}
@media(max-width:680px){
  .head-inner{flex-direction:column;align-items:stretch;gap:.7rem;text-align:center}
  .site-head .logo{justify-content:center;font-size:1.5rem}
  .head-search{max-width:none}
}

/* Navbar (canonical) — light, indigo brand */
.navbar{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--border);
  box-shadow:0 1px 6px rgba(7,8,18,.06)}
.navbar-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;padding:.55rem 1.1rem;gap:1rem;min-height:62px}
.brand{display:flex;align-items:center;gap:.4rem;font-weight:900;font-size:1.3rem;
  color:var(--primary);letter-spacing:-.02em}
.brand:hover{text-decoration:none;color:var(--primary)}
.brand .brand-mark{color:var(--green)}
.brand .nav-logo{height:42px;width:auto;display:block}
@media(max-width:880px){.brand .nav-logo{height:34px}}
.nav-links{display:flex;align-items:center;gap:1.2rem;list-style:none;margin:0}
.nav-links a{color:var(--text);font-size:.95rem;font-weight:700}
.nav-links a:hover{color:var(--primary);text-decoration:none}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--primary);margin:5px 0}
#nav-check{display:none}
@media(max-width:880px){
  .nav-toggle{display:block}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:#fff;
    border-bottom:1px solid var(--border);max-height:0;overflow:hidden;transition:max-height .25s ease;
    box-shadow:0 8px 16px rgba(7,8,18,.08)}
  .nav-links li{width:100%;border-top:1px solid var(--border)}
  .nav-links a{display:block;padding:.85rem 1.2rem}
  #nav-check:checked~.navbar .nav-links{max-height:560px}
}

/* Hero — light, soft indigo wash */
.hero{background:linear-gradient(180deg,var(--primary-tint),#fff);border-bottom:1px solid var(--border);
  padding:1.6rem 0 1.9rem}
.hero .wrap{max-width:880px;text-align:center}
.hero h1{color:var(--text)}
.breadcrumb{font-size:.82rem;color:var(--muted);margin-bottom:.5rem}
.breadcrumb a{color:var(--primary)}
.hero-subtitle{font-size:1.08rem;color:var(--muted);margin:.4rem auto .2rem;max-width:680px}
.byline{font-size:.84rem;color:var(--muted);margin-top:.6rem}
.byline strong{color:var(--text)}
.byline-author{display:inline-flex;align-items:center;gap:.4rem;color:inherit;text-decoration:none;vertical-align:middle}
.byline-author:hover{text-decoration:none}
.byline-author:hover strong{color:var(--primary)}
.byline-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:2px solid var(--primary-tint)}
.hero-more-toggle{position:absolute;left:-9999px}
.hero-more-summary{display:none}.hero-more{display:block}
@media(max-width:768px){
  .hero-more-summary{display:inline-block;cursor:pointer;color:var(--primary);font-size:.875rem;
    margin-top:.5rem;font-weight:700;user-select:none}
  .hero-more-summary::after{content:" \25B8"}
  .hero-more{display:none}
  .hero-more-toggle:checked~.hero-more-summary::after{content:" \25BE"}
  .hero-more-toggle:checked~.hero-more{display:block}
  h1{font-size:1.6rem}
}

/* Hero featured mini-card (#1 operator) — MOBILE ONLY, distinct from toplist cards */
.hero-featured{display:none}
@media(max-width:768px){
  .hero-featured{display:block;max-width:430px;margin:1.2rem auto 0;text-align:left;
    background:linear-gradient(150deg,#3a3c92,#23244e);border:1px solid #4a4ca0;border-radius:16px;
    padding:.9rem .95rem 1rem;box-shadow:0 10px 26px rgba(35,36,78,.4);color:#fff;text-decoration:none}
  .hero-featured:hover{text-decoration:none}
  .hf-ribbon{display:inline-block;background:linear-gradient(180deg,#FFE9A8,#FBD24E);color:#5a3d00;
    font-weight:900;font-size:.74rem;text-transform:uppercase;letter-spacing:.03em;padding:.3rem .75rem;border-radius:20px}
  .hf-body{display:flex;align-items:center;gap:.85rem;margin:.75rem 0}
  .hf-logo{width:104px;height:56px;object-fit:contain;background:#fff;border-radius:8px;padding:5px 7px;flex:0 0 auto}
  .hf-info{display:flex;flex-direction:column;line-height:1.25}
  .hf-name{font-size:1.2rem;font-weight:900;color:#fff}
  .hf-rating{color:#FBD24E;font-weight:800;font-size:.95rem}
  .hf-bonus{display:block;background:linear-gradient(180deg,#FFE9A8,#FBD24E);color:#7c2d12;font-weight:900;
    font-size:1.05rem;text-align:center;padding:.55rem;border-radius:8px;margin:.1rem 0 .75rem}
  .hf-cta{display:block;width:100%;text-align:center}
}

/* Buttons / CTA */
.btn{display:inline-block;border:0;border-radius:7px;font-weight:800;cursor:pointer;text-align:center;
  line-height:1.1;transition:filter .15s,transform .08s}
.btn:hover{text-decoration:none;filter:brightness(1.06)}
.btn:active{transform:translateY(1px)}
.btn-primary,a.btn-primary{background:linear-gradient(180deg,#19c41d 0%,var(--green) 55%,var(--green-dark) 100%);
  color:#fff;box-shadow:0 3px 0 #0a6e00,0 6px 16px rgba(12,132,0,.32)}
.btn-primary:hover{filter:brightness(1.05);color:#fff;box-shadow:0 4px 0 #0a6e00,0 9px 22px rgba(12,132,0,.4)}
.btn-primary:active{transform:translateY(2px);box-shadow:0 1px 0 #0a6e00,0 3px 8px rgba(12,132,0,.3)}
.btn-sm{padding:.6rem 1rem;font-size:.92rem}
.btn-lg{padding:.85rem 1.5rem;font-size:1.05rem}
/* prominent toplist/review CTA */
.btn-cta{padding:.85rem 1.5rem;font-size:1.02rem;font-weight:900;text-transform:uppercase;
  letter-spacing:.03em;border-radius:9px}
.head-badges{display:flex;gap:.5rem;flex-wrap:wrap}
.head-badges span{border:1px solid var(--primary);color:var(--primary);border-radius:20px;
  padding:.28rem .7rem;font-size:.8rem;font-weight:800}
@media(max-width:680px){.head-badges{justify-content:center}}

/* Content */
.content{padding:1.4rem 0 2.4rem}
.content .wrap{max-width:var(--maxw)}
.lead{font-size:1.06rem;color:#26283a}
.section{margin:1.1rem 0}
.note{background:var(--primary-tint);border-left:4px solid var(--primary);border-radius:8px;
  padding:.8rem 1rem;margin:1rem 0;color:#26283a;font-size:.96rem}

/* Toplist table */
.toplist-section .table-wrapper{overflow-x:auto}
.toplist-lead{color:var(--muted);max-width:760px}
.toplist-table{width:100%;border-collapse:separate;border-spacing:0;margin:1rem 0;background:#fff;
  border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.toplist-table thead th{text-align:left;padding:.8rem 1rem;background:var(--surface-2);color:var(--primary);
  font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  border-bottom:1px solid var(--border)}
.toplist-table tbody td{padding:.9rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}
.toplist-table tbody tr:last-child td{border-bottom:0}
.toplist-row.highlight-row{background:var(--primary-tint);box-shadow:inset 4px 0 0 var(--gold)}
.toplist-table .col-rank{width:46px;font-weight:800;font-size:1.05rem;color:var(--primary)}
.toplist-table .col-logo{display:flex;align-items:center;gap:.9rem;min-width:255px}
.toplist-logo{width:124px;height:64px;object-fit:contain;background:#fff;padding:5px 8px;border-radius:8px;
  border:1px solid var(--border)}
.toplist-brand{display:flex;flex-direction:column;line-height:1.25}
.toplist-descriptor{font-size:.78rem;color:var(--muted);max-width:16ch}
.toplist-bonus{display:inline-block;background:linear-gradient(180deg,#FFE9A8,#FBD24E);color:#7c2d12;
  font-weight:900;font-size:1.05rem;padding:.42rem .85rem;border-radius:7px;border:1px solid #f0b429;
  box-shadow:0 1px 3px rgba(0,0,0,.12)}
.toplist-rating{color:var(--gold);font-weight:800}
.toplist-table .col-cta{width:200px;text-align:right}
.toplist-table .col-cta .btn{white-space:nowrap}
@media(max-width:768px){
  .toplist-table thead{display:none}
  /* the table is reflowed to cards on mobile — drop the horizontal-scroll clip so the
     negative-top rank badge isn't cropped */
  .toplist-section .table-wrapper{overflow:visible}
  .toplist-table{background:transparent;border:0;overflow:visible}
  .toplist-table,.toplist-table tbody,.toplist-table tr,.toplist-table td{display:block;width:100%}
  .toplist-table tr{position:relative;border:1.5px solid var(--border);border-radius:16px;
    margin-bottom:1.1rem;padding:1.3rem .9rem .95rem;background:#fff;text-align:center;
    box-shadow:0 2px 12px rgba(7,8,18,.07)}
  .toplist-row.highlight-row{border:2px solid var(--gold);box-shadow:0 6px 20px rgba(240,192,64,.28)}
  .toplist-table td{border:none;padding:.25rem 0;text-align:center}
  /* rank → circular badge pinned to the card top */
  .toplist-table .col-rank{position:absolute;top:-16px;left:50%;transform:translateX(-50%);
    width:32px;height:32px;line-height:32px;padding:0;border-radius:50%;background:var(--primary);
    color:#fff;font-size:.98rem;box-shadow:0 2px 7px rgba(57,58,138,.45)}
  .toplist-table .col-rank strong{color:#fff}
  .toplist-row.highlight-row .col-rank{background:var(--gold);color:#1a1500}
  .toplist-row.highlight-row .col-rank strong{color:#1a1500}
  .toplist-table .col-logo{flex-direction:column;min-width:0;gap:.5rem;align-items:center;margin-top:.5rem}
  .toplist-logo{width:172px;height:86px}
  .toplist-descriptor{max-width:none;font-size:.85rem}
  .toplist-table .col-bonus{margin:.6rem 0}
  .toplist-bonus{font-size:1.18rem;padding:.5rem 1rem}
  /* Jogos + Nota side by side, with labels */
  .toplist-table .col-metric,.toplist-table .col-rating{display:inline-block;width:48%;
    vertical-align:top;color:var(--text);font-size:1.05rem;font-weight:800;margin:.3rem 0}
  .toplist-table td[data-label]::before{content:attr(data-label);display:block;color:var(--muted);
    font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.1rem}
  .toplist-table .col-bonus[data-label]::before{margin-bottom:.25rem}
  .toplist-rating{font-size:1.05rem}
  .toplist-table .col-cta{width:100%;text-align:center;margin-top:.7rem}
  .toplist-table .col-cta .btn{display:block;width:100%;padding:.95rem;font-size:1.08rem}
}

/* Generic data / comparison tables */
.data-table{width:100%;border-collapse:collapse;margin:1rem 0;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;font-size:.95rem}
.data-table th,.data-table td{padding:.7rem .9rem;border-bottom:1px solid var(--border);text-align:left}
.data-table thead th{background:var(--surface-2);color:var(--primary);font-size:.78rem;
  text-transform:uppercase;letter-spacing:.03em}
.data-table tbody tr:nth-child(even){background:var(--surface)}
.data-table tbody tr:last-child td{border-bottom:0}
.table-wrapper{overflow-x:auto}
/* Mobile: stack each .data-table row into a labelled card (labels injected by footer JS) */
@media(max-width:768px){
  .data-table.rtable thead{display:none}
  .data-table.rtable,.data-table.rtable tbody,.data-table.rtable tr,.data-table.rtable td{display:block;width:100%}
  .data-table.rtable tr{border:1px solid var(--border);border-radius:10px;margin-bottom:.7rem;
    background:#fff!important;overflow:hidden}
  .data-table.rtable td{display:flex;justify-content:space-between;gap:1rem;text-align:right;
    padding:.55rem .8rem;border-bottom:1px solid var(--border)}
  .data-table.rtable td:last-child{border-bottom:0}
  .data-table.rtable td::before{content:attr(data-label);font-weight:700;color:var(--muted);
    text-align:left;flex:0 0 40%}
  .data-table.rtable td:empty{display:none}
}

/* Operator review: small horizontal (16:9) offer thumbnail under the ranking, top-anchored */
.op-offer{display:block;width:100%;aspect-ratio:16/9;margin:.5rem 0 1rem;
  border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff;
  box-shadow:0 1px 6px rgba(7,8,18,.06)}
.op-offer img{display:block;width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .3s}
.op-offer:hover img{transform:scale(1.04)}

/* Operator review blocks */
.op-review{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.1rem 1.2rem;margin:1.2rem 0;box-shadow:0 1px 6px rgba(7,8,18,.05)}
.op-review-head{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.op-review-head img{width:124px;height:66px;object-fit:contain;background:#fff;padding:5px 8px;
  border-radius:8px;border:1px solid var(--border)}
.op-review-head h3{color:var(--text)}
.op-rating-badge{margin-left:auto;background:var(--primary);color:#fff;font-weight:800;
  padding:.35rem .7rem;border-radius:8px;font-size:.95rem}
.op-spec{width:100%;border-collapse:collapse;margin:.8rem 0;font-size:.92rem}
.op-spec th{text-align:left;color:var(--muted);font-weight:700;padding:.45rem .6rem;width:38%;
  border-bottom:1px solid var(--border);vertical-align:top}
.op-spec td{padding:.45rem .6rem;border-bottom:1px solid var(--border)}
.op-verdict{font-size:.92rem;color:#26283a;border-left:3px solid var(--green);padding-left:.8rem;margin:.7rem 0}

/* FAQ accordion */
.faq details{background:#fff;border:1px solid var(--border);border-radius:8px;margin:.55rem 0}
.faq summary{cursor:pointer;font-weight:700;color:var(--text);padding:.85rem 1rem;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--primary);font-weight:800}
.faq details[open] summary::after{content:"\2212"}
.faq details[open] summary{color:var(--primary)}
.faq details p{padding:0 1rem 1rem;margin:0;color:#26283a}

/* Pros / cons */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0}
.proscons>div{border:1px solid var(--border);border-radius:10px;padding:1rem}
.pros{background:var(--green-tint)}.cons{background:#fdeeee}
.proscons h4{margin:.1rem 0 .5rem}
.pros h4{color:var(--green-dark)}.cons h4{color:#a12626}
.proscons ul{list-style:none;margin:.3rem 0 0}
.pros li::before{content:"\2713 ";color:var(--green-dark);font-weight:800}
.cons li::before{content:"\2715 ";color:#a12626;font-weight:800}
@media(max-width:680px){.proscons{grid-template-columns:1fr}}

/* Footer */
.site-footer{background:var(--footer-bg);border-top:1px solid var(--border);margin-top:2.5rem;
  padding:2rem 0 1.4rem;color:#3a4a3f;font-size:.9rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1.6rem}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-grid h4{color:var(--primary);font-size:1rem;margin:0 0 .6rem}
.footer-grid ul{list-style:none;margin:0}
.footer-grid a{color:#3a4a3f}
.footer-grid a:hover{color:var(--primary)}
.footer-badges{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center;margin:.6rem 0}
.footer-badges span{border:1px solid var(--primary);border-radius:6px;padding:.25rem .55rem;
  font-weight:800;color:var(--primary)}
.footer-legal{border-top:1px solid #cfe6cf;margin-top:1.5rem;padding-top:1.1rem;font-size:.82rem;line-height:1.6}
@media(max-width:680px){.footer-grid{grid-template-columns:1fr;gap:1.1rem}}

/* Authors */
.author-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;margin:1.4rem 0}
.author-card{display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);padding:1.1rem;box-shadow:0 1px 6px rgba(7,8,18,.05)}
.author-card img,.author-hero img{border-radius:50%;object-fit:cover;background:var(--surface-2)}
.author-card img{width:72px;height:72px;flex:0 0 72px}
.author-card h3{margin:.1rem 0 .2rem;font-size:1.1rem}
.author-card .role{color:var(--primary);font-weight:700;font-size:.9rem}
.author-card .loc{color:var(--muted);font-size:.85rem}
.author-card a.profile{display:inline-block;margin-top:.4rem;font-weight:700;font-size:.9rem}
.author-hero{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap;margin:.5rem 0 1rem}
.author-hero img{width:140px;height:140px;border:3px solid var(--primary-tint)}
.author-hero .role{color:var(--primary);font-weight:700}
.author-hero .meta{color:var(--muted);font-size:.92rem}
.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:.6rem 0;padding:0}
.tag-list li{background:var(--primary-tint);color:var(--primary-dark);border-radius:20px;
  padding:.3rem .8rem;font-size:.85rem;font-weight:700;margin:0}
.stats-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.8rem;margin:1rem 0}
.stats-panel .stat{background:var(--surface);border:1px solid var(--border);border-radius:10px;
  padding:.9rem;text-align:center}
.stats-panel .stat b{display:block;font-size:1.5rem;color:var(--primary)}
.stats-panel .stat span{font-size:.82rem;color:var(--muted)}

:target{scroll-margin-top:80px}
