*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font-family:'Montserrat',sans-serif;
  background:#f5f5f5;
  color:#111;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none}
main{max-width:1200px;margin:0 auto;padding:20px}
p{font-size:1.08rem;line-height:1.6;margin:16px 4px;color:#222}
h1,h2,h3{color:#111}
h2{margin:18px 0 10px}
h3{margin:14px 0 8px}

.section-title{
  max-width:1200px;
  margin:26px auto 12px;
  padding:0 20px;
  font-size:1.5rem;
  font-weight:700;
  color:#111;
}

/* Header */
.custom-header{
  background:#111;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 20px;
  position:sticky;
  top:0;
  z-index:1200;
  border-bottom:1px solid rgba(255,255,255,0.08);
}

.logo-container{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.logo-image{
  width:40px;
  height:40px;
  object-fit:cover;
  border-radius:10px;
}

.site-name{
  font-size:1.05rem;
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.main-nav ul{
  list-style:none;
  display:flex;
  gap:20px;
  align-items:center;
}

.main-nav li a{
  color:#fff;
  font-weight:500;
  font-size:0.95rem;
  opacity:0.92;
}

.main-nav li a:hover{
  opacity:1;
  color:#d80027;
}

@media (min-width:769px){
  .main-nav{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
  }
}

@media (max-width:768px){
  .main-nav{position:static}
}

/* Burger */
.menu-button{display:none;cursor:pointer}
.hamburger-icon{width:25px;height:3px;background:#fff;position:relative}
.hamburger-icon::before,
.hamburger-icon::after{
  content:"";
  position:absolute;
  width:25px;
  height:3px;
  background:#fff;
  left:0;
}
.hamburger-icon::before{top:-8px}
.hamburger-icon::after{top:8px}

@media (max-width:768px){
  .main-nav ul{
    display:none;
    flex-direction:column;
    background:#111;
    position:absolute;
    top:60px;
    left:0;
    width:100%;
    padding:12px 0;
    z-index:1300;
    align-items:center;
    text-align:center;
    border-bottom:1px solid rgba(255,255,255,0.08);
  }
  .main-nav ul.active{display:flex}
  .main-nav li{margin:10px 0}
  .menu-button{display:block}
}

/* Hero */
.hero-section{
  background:
    radial-gradient(1200px 600px at 20% 0%, rgba(216,0,39,0.22), rgba(0,0,0,0) 60%),
    linear-gradient(180deg, #111 0%, #151515 100%);
  color:#fff;
  padding:44px 20px;
}
.hero-content{max-width:1200px;margin:0 auto}
.hero-content h1{color:#fff;font-size:2rem;line-height:1.2;margin-bottom:12px}
.hero-content p{color:rgba(255,255,255,0.9);margin:0;max-width:980px;font-size:1.05rem}
@media (max-width:768px){
  .hero-content h1{font-size:1.55rem}
  .hero-section{padding:34px 16px}
}

/* Casino list cards */
.casino-list{
  max-width:1200px;
  margin:0 auto;
  padding:0 20px 10px;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.casino-card{
  background:#fff;
  border-radius:14px;
  box-shadow:0 10px 24px rgba(0,0,0,0.08);
  border:1px solid rgba(0,0,0,0.06);
  display:grid;
  grid-template-columns:56px 120px 1fr;
  gap:14px;
  padding:14px;
  align-items:center;
}

.casino-card .rank{
  width:42px;
  height:42px;
  border-radius:12px;
  background:#d80027;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:1.05rem;
  justify-self:center;
}

.casino-card .card-image img{
  width:110px;
  height:70px;
  object-fit:contain;
  border-radius:12px;
  background:#f7f7f7;
  padding:8px;
  border:1px solid rgba(0,0,0,0.06);
}

.card-content{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  min-width:0;
}

.casino-info{min-width:0}
.casino-title{font-size:1.15rem;margin:0 0 6px}

.rating{display:flex;gap:3px;line-height:1}
.rating .star{color:#d80027;font-size:14px}

.offers{
  display:flex;
  gap:10px;
  align-items:stretch;
  flex-wrap:wrap;
}

.bonus,.freespins{
  background:#111;
  color:#fff;
  border-radius:12px;
  padding:10px 12px;
  min-width:140px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border:1px solid rgba(0,0,0,0.10);
}

.bonus::before,.freespins::before{
  content:attr(data-label);
  font-size:11px;
  opacity:0.8;
  margin-bottom:4px;
  letter-spacing:0.4px;
  text-transform:uppercase;
}

.amount{font-weight:700;font-size:14px}

.actions{
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-end;
}

.btn-primary,.btn-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:12px;
  font-weight:700;
  font-size:14px;
  width:140px;
  cursor:pointer;
  transition:transform .08s ease, opacity .12s ease;
}

.btn-primary{background:#d80027;color:#fff}
.btn-secondary{background:#f3f3f3;color:#111;border:1px solid rgba(0,0,0,0.10)}

.btn-primary:hover,.btn-secondary:hover{transform:translateY(-1px)}

.disclaimer{
  font-size:11.5px;
  color:#444;
  max-width:220px;
  text-align:right;
  line-height:1.35;
}

@media (max-width:900px){
  .casino-card{
    grid-template-columns:56px 1fr;
    grid-template-rows:auto auto;
    align-items:start;
  }
  .casino-card .card-image{grid-column:2}
  .casino-card .card-content{
    grid-column:2;
    flex-direction:column;
    align-items:stretch;
  }
  .actions{align-items:flex-start}
  .disclaimer{text-align:left;max-width:none}
  .bonus,.freespins{min-width:0;flex:1}
  .btn-primary,.btn-secondary{width:100%}
}

/* Content images */
.content-image{
  display:block;
  margin:18px auto;
  width:100%;
  max-width:900px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,0.08);
  box-shadow:0 12px 26px rgba(0,0,0,0.10);
}

/* Bullet blocks */
.bullet-list-section{
  margin:18px 4px;
  padding:16px 16px;
  background:#fff;
  border-left:5px solid #d80027;
  box-shadow:0 2px 10px rgba(0,0,0,0.06);
  border-radius:10px;
}

.custom-bullet-list{list-style:none;padding-left:0;margin:0}
.custom-bullet-list li{
  position:relative;
  padding-left:22px;
  margin:10px 0;
  font-size:0.98rem;
  line-height:1.55;
  color:#222;
}
.custom-bullet-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:0.62em;
  transform:translateY(-50%);
  width:9px;
  height:9px;
  background:#d80027;
  border-radius:50%;
}

/* Table */
.table-section{margin:22px 4px}
.table-responsive{width:100%;overflow-x:auto}
.review-table{
  width:100%;
  border-collapse:collapse;
  background:#fff;
  border:1px solid rgba(0,0,0,0.12);
  border-radius:12px;
  overflow:hidden;
}
.review-table th,.review-table td{
  border-bottom:1px solid rgba(0,0,0,0.10);
  padding:12px;
  text-align:left;
  vertical-align:top;
  font-size:0.95rem;
}
.review-table th{
  background:#d80027;
  color:#fff;
  border-bottom:none;
  font-weight:700;
}
.review-table tbody tr:nth-child(even){background:#fafafa}
.review-table tbody tr:last-child td{border-bottom:none}

/* How-to */
.howto-block{
  margin:18px 4px 10px;
  padding:18px;
  background:#fff;
  border-radius:14px;
  border:1px solid rgba(0,0,0,0.08);
  box-shadow:0 10px 24px rgba(0,0,0,0.08);
}
.howto-steps{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.howto-step{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:12px;
  border-radius:12px;
  background:linear-gradient(180deg, #ffffff 0%, #fbfbfb 100%);
  border:1px solid rgba(0,0,0,0.06);
}
.howto-num{
  width:38px;
  height:38px;
  flex:0 0 38px;
  border-radius:12px;
  background:#d80027;
  color:#fff;
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:center;
}
.howto-title{margin:0 0 4px;font-size:1.05rem}
.howto-text p{margin:0;font-size:0.95rem;color:#333}

/* FAQ */
.faq-section{
  margin:18px 4px 6px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.faq-item{
  background:#fff;
  border-radius:12px;
  border:1px solid rgba(0,0,0,0.08);
  box-shadow:0 8px 18px rgba(0,0,0,0.06);
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer;
  padding:14px 14px;
  font-weight:700;
  color:#111;
  list-style:none;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-content{padding:0 14px 14px}
.faq-content p{margin:10px 0 0;color:#222;font-size:0.98rem}

/* Footer */
.custom-footer{
  padding:22px 20px;
  background:#0b0b0b;
  border-top:1px solid rgba(255,255,255,0.08);
}
.custom-footer .footer-inner{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns:260px 1fr 420px;
  gap:18px 24px;
  align-items:start;
}
.custom-footer .footer-brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.custom-footer .footer-logo-img{
  width:34px;
  height:34px;
  border-radius:50%;
  flex:0 0 34px;
  object-fit:cover;
}
.custom-footer .footer-name{
  color:#fff;
  font-weight:700;
  font-size:16px;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.custom-footer .footer-nav{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
  margin-top:6px;
}
.custom-footer .footer-nav a,
.custom-footer .footer-nav a:visited{
  color:rgba(255,255,255,0.90);
  font-weight:500;
  font-size:14px;
  line-height:1.2;
}
.custom-footer .footer-nav a:hover{
  color:#fff;
  text-decoration:underline;
  text-underline-offset:3px;
}
.custom-footer .footer-meta{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:0;
}
.custom-footer .footer-contact,
.custom-footer .footer-disclaimer,
.custom-footer .footer-copy{
  margin:0;
  color:rgba(255,255,255,0.86);
  font-size:13px;
  line-height:1.45;
}
.custom-footer .footer-contact a,
.custom-footer .footer-contact a:visited{
  color:#fff;
  text-decoration:underline;
  text-underline-offset:2px;
}
.custom-footer .footer-contact a:hover{opacity:0.9}

@media (max-width:1000px){
  .custom-footer .footer-inner{grid-template-columns:1fr}
  .custom-footer .footer-nav{margin-top:0}
}

/* To top button */
.to-top{
  position:fixed;
  right:18px;
  bottom:18px;
  width:46px;
  height:46px;
  border-radius:50%;
  border:none;
  background:#d80027;
  color:#fff;
  font-size:18px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 12px 24px rgba(0,0,0,0.22);
  z-index:1400;
}
.to-top:hover{transform:translateY(-1px)}

/* Small screens */
@media (max-width:768px){
  p{font-size:1.02rem}
  .bullet-list-section{padding:14px}
  .review-table th,.review-table td{padding:10px}
  .howto-block{padding:14px}
}
