*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0a1210;
  --surface:#142420;
  --surface-light:#1c332c;
  --emerald:#34d399;
  --emerald-light:#6ee7b7;
  --gold:#c9a227;
  --gold-light:#e8c547;
  --text:#ecfdf5;
  --text-muted:#8fa89a;
  --border:rgba(52,211,153,.22);
  --border-gold:rgba(201,162,39,.35);
  --radius:.75rem;
  --header-h:3.75rem;
  --mobile-cta-h:3.75rem;
  --sidebar-w:15rem;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  font-size:1rem;
  line-height:1.65;
  color:var(--text);
  background:var(--ink);
  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-light);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold-light)}
a:focus-visible{outline:2px solid var(--emerald);outline-offset:2px;border-radius:2px}
.container{width:min(100% - 2rem,72rem);margin-inline:auto}

/* Update bar */
.update-bar{
  background:var(--surface);
  color:var(--text-muted);
  text-align:center;
  padding:.5rem 1rem;
  font-size:.8125rem;
  border-bottom:1px solid var(--border);
}
.update-bar strong{color:var(--gold)}

/* Header */
.header{
  position:sticky;
  top:0;
  z-index:200;
  background:rgba(10,18,16,.93);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.75rem 0;
  min-height:var(--header-h);
}
.logo{
  font-size:clamp(.9375rem,2.5vw,1.125rem);
  font-weight:800;
  color:var(--text);
  letter-spacing:-.02em;
}
.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(--text);
  border-radius:2px;
  transition:transform .2s,opacity .2s;
}
.nav__list{display:flex;gap:1.25rem;list-style:none}
.nav__list a{
  color:var(--text-muted);
  font-weight:600;
  font-size:.9375rem;
}
.nav__list a:hover,.nav__list a.is-active{color:var(--emerald)}

/* Hero */
.hero{
  position:relative;
  min-height:clamp(16rem,42vw,22rem);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:2.5rem 1rem;
  overflow:hidden;
}
.hero__bg{
  position:absolute;
  inset:0;
  background:url("/images/hero.webp") center/cover no-repeat;
  z-index:0;
}
.hero__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(10,18,16,.9) 0%,rgba(20,36,32,.72) 50%,rgba(10,18,16,.88) 100%);
  z-index:1;
}
.hero .container{position:relative;z-index:2}
.hero__badge{
  display:inline-block;
  background:var(--gold);
  color:var(--ink);
  font-size:.75rem;
  font-weight:800;
  padding:.25rem .75rem;
  border-radius:999px;
  margin-bottom:1rem;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.hero h1{
  font-size:clamp(1.625rem,5.5vw,2.5rem);
  font-weight:800;
  line-height:1.15;
  margin-bottom:1rem;
  letter-spacing:-.02em;
}
.hero__lead{
  max-width:38rem;
  margin:0 auto;
  font-size:clamp(.9375rem,2.5vw,1.0625rem);
  color:var(--text-muted);
  line-height:1.7;
}

/* Trust bar */
.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:.8125rem;
  font-weight:600;
  color:var(--text-muted);
}
.trust-bar__icon{color:var(--emerald);font-size:1rem}

/* Layout 6 – sidebar + cards */
.casinos{padding:2rem 0 2.5rem}
.casinos__layout{display:flex;flex-direction:column;gap:1.25rem}
.section-title{
  font-size:clamp(1.25rem,3.5vw,1.625rem);
  font-weight:800;
  margin-bottom:0;
  letter-spacing:-.02em;
}
.section-title span{color:var(--emerald)}

/* Mobile rank pills */
.casinos__pills{
  display:flex;
  gap:.5rem;
  overflow-x:auto;
  padding-bottom:.25rem;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.casinos__pills::-webkit-scrollbar{display:none}
.casinos__pill{
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  gap:.375rem;
  padding:.5rem .875rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:999px;
  font-size:.8125rem;
  font-weight:700;
  color:var(--text-muted);
  transition:border-color .2s,color .2s,background .2s;
}
.casinos__pill:hover{color:var(--emerald);border-color:var(--emerald)}
.casinos__pill.is-active{
  background:var(--surface-light);
  border-color:var(--gold);
  color:var(--gold-light);
}
.casinos__pill-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:1.375rem;
  height:1.375rem;
  border-radius:50%;
  background:var(--ink);
  font-size:.6875rem;
  color:var(--emerald);
}

/* Sidebar (desktop) */
.casinos__sidebar{display:none}
.casinos__sidebar-title{
  font-size:.6875rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--text-muted);
  margin-bottom:.75rem;
}
.casinos__nav{list-style:none;display:flex;flex-direction:column;gap:.375rem}
.casinos__nav a{
  display:flex;
  align-items:center;
  gap:.625rem;
  padding:.625rem .75rem;
  border-radius:.5rem;
  border:1px solid transparent;
  color:var(--text-muted);
  font-size:.875rem;
  font-weight:600;
  transition:background .2s,border-color .2s,color .2s;
}
.casinos__nav a:hover{
  background:var(--surface-light);
  color:var(--emerald);
  border-color:var(--border);
}
.casinos__nav a.is-active{
  background:var(--surface-light);
  border-color:var(--border-gold);
  color:var(--gold-light);
}
.casinos__nav-rank{
  flex-shrink:0;
  width:1.5rem;
  height:1.5rem;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:.375rem;
  background:var(--ink);
  font-size:.75rem;
  font-weight:800;
  color:var(--emerald);
}
.casinos__nav a.is-active .casinos__nav-rank{background:var(--gold);color:var(--ink)}
.casinos__sidebar-trust{
  margin-top:1.5rem;
  padding-top:1.25rem;
  border-top:1px solid var(--border);
}
.casinos__sidebar-trust li{
  font-size:.75rem;
  color:var(--text-muted);
  padding:.375rem 0 .375rem 1.125rem;
  position:relative;
  list-style:none;
}
.casinos__sidebar-trust li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--emerald);
  font-weight:700;
  font-size:.6875rem;
}

/* Casino cards */
.casinos__main{display:flex;flex-direction:column;gap:1.25rem;flex:1;min-width:0}
.casino-card{
  background:var(--surface);
  border:2px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  scroll-margin-top:calc(var(--header-h) + 1rem);
  transition:border-color .25s,box-shadow .25s;
}
.casino-card:hover{
  border-color:var(--emerald);
  box-shadow:0 8px 32px rgba(52,211,153,.1);
}
.casino-card--rank-1{
  border-color:var(--border-gold);
  box-shadow:0 4px 24px rgba(201,162,39,.12);
}
.casino-card__ribbon{
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  color:var(--ink);
  font-size:.6875rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:.375rem 1rem;
  text-align:center;
}
.casino-card__inner{
  display:flex;
  flex-direction:column;
  gap:1rem;
  padding:1.25rem;
}
.casino-card__main{display:flex;gap:1rem;align-items:flex-start}
.casino-card__logo{
  flex-shrink:0;
  border-radius:.625rem;
  overflow:hidden;
  border:2px solid var(--border);
  transition:border-color .2s;
}
.casino-card__logo:hover{border-color:var(--gold)}
.casino-card__logo img{width:110px;height:110px;object-fit:cover}
.casino-card__info{flex:1;min-width:0}
.casino-card__rank{
  font-size:.75rem;
  font-weight:700;
  color:var(--emerald);
  text-transform:uppercase;
  letter-spacing:.05em;
  margin-bottom:.25rem;
}
.casino-card__info h2{
  font-size:clamp(1.125rem,3vw,1.375rem);
  font-weight:800;
  margin-bottom:.375rem;
}
.casino-card__rating{font-size:.8125rem;color:var(--text-muted);margin-bottom:.5rem}
.casino-card__stars{color:var(--gold);letter-spacing:1px}
.casino-card__bonus-block{
  background:var(--surface-light);
  border:1px solid var(--border);
  border-radius:.5rem;
  padding:.875rem 1rem;
  text-align:center;
}
.casino-card__bonus-label{
  font-size:.6875rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--text-muted);
  margin-bottom:.25rem;
}
.casino-card__bonus-value{
  font-size:clamp(.9375rem,2.5vw,1.125rem);
  font-weight:800;
  color:var(--gold-light);
}
.casino-card__features{
  list-style:none;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.375rem .75rem;
}
.casino-card__features li{
  font-size:.8125rem;
  color:var(--text-muted);
  padding-left:1.125rem;
  position:relative;
}
.casino-card__features li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--emerald);
  font-weight:700;
  font-size:.75rem;
}
.casino-card__cta-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.5rem;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.375rem;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--ink);
  font-weight:800;
  font-size:.9375rem;
  padding:.75rem 1.5rem;
  border-radius:.5rem;
  border:none;
  cursor:pointer;
  text-align:center;
  transition:transform .15s,box-shadow .15s;
  width:100%;
  max-width:20rem;
}
.btn:hover{
  color:var(--ink);
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(201,162,39,.35);
}
.casino-card__verified{font-size:.6875rem;color:var(--text-muted);font-weight:600}

@media(min-width:640px){
  .casino-card__inner{
    flex-direction:row;
    align-items:center;
    flex-wrap:wrap;
  }
  .casino-card__main{flex:1 1 14rem}
  .casino-card__bonus-block{
    flex:0 0 11rem;
    align-self:stretch;
    display:flex;
    flex-direction:column;
    justify-content:center;
  }
  .casino-card__features{flex:1 1 100%;grid-template-columns:repeat(4,1fr)}
  .casino-card__cta-wrap{flex:0 0 auto;min-width:10rem}
  .btn{width:auto;min-width:10rem}
}

@media(min-width:768px){
  .casinos__pills{display:none}
  .casinos__layout{
    flex-direction:row;
    align-items:flex-start;
    gap:1.75rem;
  }
  .casinos__sidebar{
    display:block;
    flex:0 0 var(--sidebar-w);
    position:sticky;
    top:calc(var(--header-h) + 1rem);
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:1.25rem;
  }
}

@media(min-width:960px){
  .casino-card__inner{flex-wrap:nowrap;gap:1.5rem}
  .casino-card__main{flex:1}
  .casino-card__features{flex:1;grid-template-columns:1fr 1fr}
  .casino-card__bonus-block{flex:0 0 12rem}
}

/* SEO */
.seo{
  padding:2rem 0;
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.seo h2{
  font-size:clamp(1.125rem,3vw,1.5rem);
  font-weight:800;
  margin-bottom:1rem;
}
.seo__text p{
  color:var(--text-muted);
  margin-bottom:1rem;
  font-size:.9375rem;
  line-height:1.75;
}
.seo__text p:last-child{margin-bottom:0}

/* FAQ */
.faq-section{padding:2rem 0}
.faq-teaser{margin-bottom:1.5rem}
.faq__item{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  margin-bottom:.75rem;
  overflow:hidden;
}
.faq__item h3{
  font-size:.9375rem;
  font-weight:700;
  padding:1rem 2.5rem 1rem 1rem;
  cursor:pointer;
  position:relative;
  user-select:none;
}
.faq__item h3::after{
  content:"+";
  position:absolute;
  right:1rem;
  top:50%;
  transform:translateY(-50%);
  font-size:1.25rem;
  color:var(--emerald);
  transition:transform .2s;
}
.faq__item.is-open h3::after{content:"−"}
.faq__answer{
  display:none;
  padding:0 1rem 1rem;
  color:var(--text-muted);
  font-size:.875rem;
  line-height:1.7;
}
.faq__item.is-open .faq__answer{display:block}
.faq__more{
  display:inline-flex;
  align-items:center;
  gap:.375rem;
  font-weight:700;
  font-size:.9375rem;
  margin-top:.5rem;
}

/* Responsible gambling */
.responsible{padding:1.5rem 0 2rem;text-align:center}
.responsible__badge{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  flex-wrap:wrap;
  justify-content:center;
  background:var(--surface);
  border:1px solid var(--emerald);
  border-radius:var(--radius);
  padding:.75rem 1.25rem;
  font-size:.8125rem;
  color:var(--text-muted);
}
.responsible__badge strong{color:var(--emerald)}

/* Footer */
.footer{
  background:var(--surface);
  border-top:1px solid var(--border);
  padding:2rem 0 1.5rem;
}
.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:var(--text-muted);font-size:.875rem;font-weight:600}
.footer__disclaimer{
  font-size:.75rem;
  color:var(--text-muted);
  line-height:1.7;
  max-width:48rem;
  margin:0 auto 1rem;
  text-align:center;
}
.footer__copy{
  text-align:center;
  font-size:.75rem;
  color:var(--text-muted);
  opacity:.7;
}

/* Mobile CTA */
.mobile-cta{
  display:none;
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:300;
  background:var(--surface);
  border-top:2px solid var(--gold);
  padding:.625rem 1rem;
  padding-bottom:max(.625rem,env(safe-area-inset-bottom));
  box-shadow:0 -4px 20px rgba(0,0,0,.3);
}
.mobile-cta .btn{max-width:none;width:100%}
@media(max-width:639px){
  body.has-mobile-cta .mobile-cta{display:block}
}

/* Subpages */
.page-hero{
  padding:2rem 0 1.5rem;
  text-align:center;
  border-bottom:1px solid var(--border);
}
.page-hero h1{
  font-size:clamp(1.375rem,4vw,2rem);
  font-weight:800;
  margin-bottom:.5rem;
}
.page-hero p{color:var(--text-muted);font-size:.9375rem}
.content-section{padding:2rem 0 3rem}
.content-section h2{
  font-size:1.125rem;
  font-weight:800;
  margin:1.75rem 0 .75rem;
  color:var(--emerald);
}
.content-section h2:first-child{margin-top:0}
.content-section p,.content-section li{
  color:var(--text-muted);
  font-size:.9375rem;
  line-height:1.75;
  margin-bottom:.75rem;
}
.content-section ul{padding-left:1.25rem;margin-bottom:1rem}

/* Contact form */
.contact-form{max-width:28rem;margin:1.5rem auto 0}
.form-group{margin-bottom:1rem}
.form-group label{
  display:block;
  font-size:.8125rem;
  font-weight:700;
  margin-bottom:.375rem;
  color:var(--text);
}
.form-group input,.form-group textarea{
  width:100%;
  padding:.625rem .875rem;
  background:var(--surface-light);
  border:1px solid var(--border);
  border-radius:.5rem;
  color:var(--text);
  font-family:inherit;
  font-size:.9375rem;
}
.form-group input:focus,.form-group textarea:focus{
  outline:none;
  border-color:var(--emerald);
}
.form-group textarea{min-height:7rem;resize:vertical}
.form-success{
  display:none;
  background:rgba(52,211,153,.1);
  border:1px solid var(--emerald);
  border-radius:var(--radius);
  padding:1rem;
  text-align:center;
  color:var(--emerald);
  font-weight:600;
  margin-top:1rem;
}
.form-success.is-visible{display:block}

/* Mobile nav */
@media(max-width:639px){
  .nav-toggle-label{display:flex}
  .header__inner{position:relative}
  .nav{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--surface);
    border-bottom:1px solid var(--border);
    max-height:0;
    overflow:hidden;
    transition:max-height .3s;
  }
  .nav-toggle:checked ~ .nav{max-height:16rem}
  .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;padding:1rem;gap:.75rem}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition:none!important;animation:none!important}
}
