*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f4f7f5;
  --ink:#1e3a5f;
  --surface:#ffffff;
  --surface-alt:#e8f0ec;
  --emerald:#059669;
  --emerald-light:#10b981;
  --gold:#c9a227;
  --gold-light:#dbb84a;
  --text:#334155;
  --text-muted:#64748b;
  --border:rgba(5,150,105,.2);
  --radius:.75rem;
  --header-h:3.75rem;
  --mobile-cta-h:3.75rem;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
body{
  font-family:"Nunito Sans",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  font-size:1rem;
  line-height:1.65;
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
  min-height:100vh;
}
body.has-mobile-cta{padding-bottom:var(--mobile-cta-h)}
img{max-width:100%;height:auto;display:block}
a{color:var(--emerald);text-decoration:none;transition:color .2s}
a:hover{color:var(--ink)}
.container{width:min(100% - 2rem,72rem);margin-inline:auto}
h1,h2,.section-title,.page-hero h1{font-family:"Source Serif 4",Georgia,serif}

.update-bar{
  background:var(--ink);
  color:rgba(255,255,255,.8);
  text-align:center;
  padding:.5rem 1rem;
  font-size:.8125rem;
}
.update-bar strong{color:var(--gold-light)}

.header{
  position:sticky;
  top:0;
  z-index:200;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 rgba(30,58,95,.05);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.75rem 0;
  min-height:var(--header-h);
}
.logo{
  font-family:"Source Serif 4",Georgia,serif;
  font-size:clamp(.8rem,2.5vw,1rem);
  font-weight:700;
  color:var(--ink);
  letter-spacing:-.02em;
  line-height:1.2;
}
.logo em{font-style:normal;color:var(--emerald)}
.nav-toggle{display:none}
.nav-toggle-label{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem}
.nav-toggle-label span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .25s}
.nav__list{display:flex;gap:.25rem 1.25rem;list-style:none}
.nav__list a{
  color:var(--text-muted);
  font-weight:600;
  font-size:.9375rem;
  padding:.25rem 0;
  border-bottom:2px solid transparent;
  transition:border-color .2s,color .2s;
}
.nav__list a:hover,.nav__list a.is-active{color:var(--ink);border-bottom-color:var(--emerald)}

.hero{
  padding:2rem 0 2.5rem;
  background:linear-gradient(180deg,var(--surface-alt) 0%,var(--bg) 100%);
  border-bottom:3px solid var(--emerald);
}
.hero__grid{display:grid;gap:1.5rem;align-items:center}
.hero__badge{
  display:inline-block;
  background:rgba(5,150,105,.12);
  border:1px solid var(--emerald);
  color:var(--emerald);
  font-size:.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  padding:.35rem .85rem;
  border-radius:999px;
  margin-bottom:.85rem;
}
.hero h1{
  font-size:clamp(1.625rem,5vw,2.5rem);
  font-weight:700;
  color:var(--ink);
  letter-spacing:-.03em;
  line-height:1.15;
  margin-bottom:.85rem;
}
.hero__lead{color:var(--text-muted);font-size:clamp(.9375rem,2.5vw,1.0625rem);max-width:36rem}
.hero__visual{border-radius:var(--radius);overflow:hidden;border:2px solid var(--border);box-shadow:0 12px 40px rgba(30,58,95,.1)}
.hero__visual img{width:100%;height:auto;object-fit:cover}

.trust-bar{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:.75rem 1.5rem;
  padding:1rem;
  background:var(--surface);
  border-bottom:1px solid var(--border);
}
.trust-bar__item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--ink)}
.trust-bar__icon{font-size:1.125rem}

/* Layout #4 – table ranking (light trust theme) */
.rankings{padding:2rem 0 2.5rem}
.section-title{
  font-size:clamp(1.375rem,3.5vw,1.75rem);
  font-weight:700;
  letter-spacing:-.02em;
  margin-bottom:1.5rem;
  color:var(--ink);
}
.section-title span{color:var(--emerald)}
.rank-table{display:flex;flex-direction:column;gap:.875rem}
.rank-table__head{display:none}
.rank-row{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1rem;
  display:grid;
  gap:.75rem;
  box-shadow:0 2px 8px rgba(30,58,95,.04);
  transition:border-color .2s,box-shadow .2s;
}
.rank-row:hover{border-color:var(--emerald);box-shadow:0 4px 16px rgba(5,150,105,.1)}
.rank-row--top{border-color:var(--emerald);box-shadow:0 0 0 1px rgba(5,150,105,.2),0 8px 24px rgba(5,150,105,.12)}
.rank-row__ribbon{
  position:absolute;
  top:-.5rem;
  left:1rem;
  background:linear-gradient(135deg,var(--emerald),var(--emerald-light));
  color:#fff;
  font-size:.6875rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:.25rem .65rem;
  border-radius:999px;
}
.rank-row__rank{display:flex;align-items:center;gap:.5rem}
.rank-row__num{
  display:flex;
  align-items:center;
  justify-content:center;
  width:2rem;
  height:2rem;
  background:var(--surface-alt);
  border:1px solid var(--border);
  border-radius:50%;
  font-weight:800;
  font-size:.875rem;
  color:var(--emerald);
  flex-shrink:0;
}
.rank-row--top .rank-row__num{background:var(--emerald);color:#fff;border-color:var(--emerald)}
.rank-row__casino{display:flex;align-items:center;gap:.875rem}
.casino-logo{
  width:110px;
  height:110px;
  border-radius:var(--radius);
  border:2px solid var(--border);
  overflow:hidden;
  flex-shrink:0;
  background:var(--surface-alt);
  transition:border-color .2s;
}
.casino-logo:hover{border-color:var(--emerald)}
.casino-logo img{width:100%;height:100%;object-fit:cover}
.rank-row__info h2{font-family:"Source Serif 4",Georgia,serif;font-size:1.125rem;font-weight:700;color:var(--ink);margin-bottom:.2rem}
.rank-row__rating{font-size:.8125rem;color:var(--text-muted)}
.rank-row__stars{color:var(--gold);letter-spacing:.05em}
.rank-row__bonus-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.25rem}
.rank-row__bonus-value{font-size:1rem;font-weight:700;color:var(--emerald)}
.rank-row__features{list-style:none;display:grid;gap:.35rem}
.rank-row__features li{font-size:.8125rem;color:var(--text-muted);padding-left:1rem;position:relative}
.rank-row__features li::before{content:"✓";position:absolute;left:0;color:var(--emerald);font-weight:700;font-size:.75rem}
.rank-row__cell{display:flex;flex-direction:column}
.rank-row__cell[data-label]::before{
  content:attr(data-label);
  font-size:.6875rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--text-muted);
  margin-bottom:.35rem;
}
.rank-row__action{display:flex;flex-direction:column;align-items:stretch;gap:.5rem}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.35rem;
  background:linear-gradient(135deg,var(--emerald),var(--emerald-light));
  color:#fff;
  font-weight:700;
  font-size:.9375rem;
  padding:.75rem 1.25rem;
  border-radius:var(--radius);
  border:none;
  cursor:pointer;
  font-family:inherit;
  transition:transform .15s,box-shadow .15s;
  text-align:center;
}
.btn:hover{color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px rgba(5,150,105,.35)}
.rank-row--top .btn{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--ink)}
.rank-row--top .btn:hover{color:var(--ink);box-shadow:0 4px 16px rgba(201,162,39,.35)}
.rank-row__verified{font-size:.6875rem;color:var(--text-muted);text-align:center}

.seo{padding:2.5rem 0;background:var(--surface);border-top:1px solid var(--border)}
.seo h2{font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700;margin-bottom:1rem;color:var(--ink)}
.seo__text{display:grid;gap:1rem;color:var(--text-muted)}

.faq-section{padding:2.5rem 0}
.faq-teaser{display:grid;gap:.75rem;margin-bottom:1.25rem}
.faq__item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.faq__item h3{
  padding:1rem 1.25rem;
  font-size:1rem;
  font-weight:600;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  user-select:none;
  color:var(--ink);
}
.faq__item h3::after{content:"+";font-size:1.25rem;color:var(--emerald);flex-shrink:0;transition:transform .2s}
.faq__item.is-open h3::after{transform:rotate(45deg)}
.faq__answer{display:none;padding:0 1.25rem 1rem;color:var(--text-muted);font-size:.9375rem}
.faq__item.is-open .faq__answer{display:block}
.faq__more{display:inline-flex;font-weight:700;color:var(--emerald)}

.responsible{padding:1.5rem 0 2rem}
.responsible__badge{
  text-align:center;
  padding:1rem 1.25rem;
  background:var(--surface);
  border:1px solid rgba(5,150,105,.25);
  border-radius:var(--radius);
  font-size:.9375rem;
  color:var(--text-muted);
}
.responsible__badge strong{color:var(--emerald);font-size:1.125rem;margin-right:.35rem}

.footer{background:var(--ink);color:rgba(255,255,255,.75);padding:2rem 0}
.footer__nav{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 1.5rem;list-style:none;margin-bottom:1.25rem}
.footer__nav a{color:rgba(255,255,255,.8);font-weight:600;font-size:.9375rem}
.footer__nav a:hover{color:var(--gold-light)}
.footer__disclaimer,.footer__copy{text-align:center;font-size:.8125rem;max-width:40rem;margin-inline:auto}
.footer__disclaimer{margin-bottom:.75rem}

.mobile-cta{
  display:none;
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:300;
  padding:.75rem 1rem;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(8px);
  border-top:1px solid var(--border);
  box-shadow:0 -4px 20px rgba(30,58,95,.08);
}
.mobile-cta .btn{max-width:none;width:100%}
@media (max-width:768px){body.has-mobile-cta .mobile-cta{display:block}}

.page-hero{padding:2.5rem 0 2rem;background:var(--surface);border-bottom:1px solid var(--border);text-align:center}
.page-hero h1{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;margin-bottom:.5rem;color:var(--ink)}
.page-hero p{color:var(--text-muted)}
.content-section{padding:2.5rem 0}
.content-section h2{font-family:"Source Serif 4",Georgia,serif;font-size:1.25rem;font-weight:700;margin:2rem 0 .75rem;color:var(--ink)}
.content-section h2:first-child{margin-top:0}
.content-section p,.content-section li{color:var(--text-muted);margin-bottom:.75rem}
.content-section ul{padding-left:1.25rem;margin-bottom:1rem}

.contact-form{max-width:28rem;margin-top:1.5rem}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.35rem;color:var(--ink)}
.form-group input,.form-group select,.form-group textarea{
  width:100%;
  padding:.75rem 1rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:.5rem;
  color:var(--text);
  font-family:inherit;
  font-size:1rem;
}
.form-group textarea{min-height:8rem;resize:vertical}
.form-success{
  display:none;
  margin-top:1rem;
  padding:1rem;
  background:rgba(5,150,105,.1);
  border:1px solid var(--border);
  border-radius:.5rem;
  color:var(--emerald);
  font-size:.9375rem;
}
.form-success.is-visible{display:block}

.rankings--compact .rank-row__features{display:none}
.rankings--compact .rank-row__verified{display:none}

@media (min-width:480px){.hero__grid{grid-template-columns:1fr 1fr}}
@media (min-width:768px){
  .nav-toggle-label{display:none}
  .nav__list{display:flex}
  .rank-table__head{
    display:grid;
    grid-template-columns:3rem 1.6fr 1.1fr 1.4fr 9rem;
    gap:1rem;
    padding:.75rem 1rem;
    background:var(--surface-alt);
    border:1px solid var(--border);
    border-radius:var(--radius);
    font-size:.6875rem;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.06em;
    color:var(--text-muted);
    position:sticky;
    top:var(--header-h);
    z-index:50;
  }
  .rank-row{
    grid-template-columns:3rem 1.6fr 1.1fr 1.4fr 9rem;
    gap:1rem;
    align-items:center;
    padding:1rem;
  }
  .rank-row__cell[data-label]::before{display:none}
  .rank-row__action{align-items:stretch}
}
@media (max-width:767px){
  .hero__grid{grid-template-columns:1fr}
  .hero__visual{order:-1}
  .nav-toggle-label{display:flex}
  .nav{
    position:fixed;
    top:var(--header-h);
    left:0;
    right:0;
    background:var(--surface);
    border-bottom:1px solid var(--border);
    padding:1rem;
    transform:translateY(-120%);
    opacity:0;
    pointer-events:none;
    transition:transform .25s,opacity .25s;
    z-index:199;
    box-shadow:0 8px 24px rgba(30,58,95,.1);
  }
  .nav-toggle:checked ~ .nav{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-toggle:checked + .nav-toggle-label span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked + .nav-toggle-label span:nth-child(2){opacity:0}
  .nav-toggle:checked + .nav-toggle-label span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav__list{flex-direction:column;gap:.5rem}
  .nav__list a{display:block;padding:.65rem .5rem}
}
