/* ===== Viking Casino — front page + review ===== */
:root{
  --bg:#0a0a0a;
  --panel:#121110;
  --panel-2:#1a1714;
  --line:#2a241c;
  --gold:#d4a23c;
  --gold-2:#f7e08a;
  --green:#3aa55a;
  --green-2:#54d27e;
  --text:#e8e2d6;
  --muted:#9b9486;
  --sidebar-w:200px;
  --header-h:70px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ---------- Header ---------- */
.header{
  position:sticky;top:0;z-index:50;
  height:var(--header-h);
  display:flex;align-items:center;gap:18px;
  padding:0 24px;
  background:linear-gradient(180deg,#15110c,#0c0a08);
  border-bottom:1px solid var(--line);
}
.burger{display:flex;flex-direction:column;gap:4px;cursor:pointer;padding:6px}
.burger span{width:20px;height:2px;background:var(--gold)}
.logo img{height:46px}
.search{
  flex:1;max-width:560px;margin-left:8px;
  display:flex;align-items:center;gap:10px;
  background:#0c0a08;border:1px solid var(--line);
  border-radius:6px;padding:9px 14px;color:var(--muted);
}
.search input{
  flex:1;background:transparent;border:0;outline:0;
  color:var(--text);font-size:14px;
}
.header-actions{display:flex;gap:12px;margin-left:auto}
.btn{
  display:inline-block;cursor:pointer;border:0;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;font-size:13px;border-radius:6px;
  padding:11px 20px;transition:.15s;
}
.btn-ghost{
  background:transparent;color:var(--gold-2);
  border:1px solid var(--gold);
}
.btn-ghost:hover{background:rgba(212,162,60,.12)}
.btn-gold{
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  color:#2a1d08;border:1px solid #7a531a;
}
.btn-gold:hover{filter:brightness(1.08)}

/* ---------- Layout ---------- */
.layout{display:flex;min-height:calc(100vh - var(--header-h))}
.sidebar{
  width:var(--sidebar-w);flex:0 0 var(--sidebar-w);
  background:linear-gradient(180deg,#100d09,#0a0807);
  border-right:1px solid var(--line);
  padding:18px 0;
}
.nav-group{padding:6px 0}
.nav-item{
  display:flex;align-items:center;gap:14px;
  padding:13px 22px;color:var(--muted);
  font-size:14px;font-weight:600;letter-spacing:.4px;
  text-transform:uppercase;cursor:pointer;
  border-left:3px solid transparent;transition:.15s;
}
.nav-item .ico{width:20px;text-align:center;font-size:16px;color:var(--gold)}
.nav-item:hover{color:var(--text);background:rgba(255,255,255,.02)}
.nav-item.active{
  color:#fff;background:linear-gradient(90deg,rgba(178,40,40,.45),transparent);
  border-left-color:#c43f36;
}
.nav-sep{height:1px;background:var(--line);margin:8px 22px}

.main{flex:1;min-width:0;padding:24px 28px 60px}

/* ---------- Hero ---------- */
.hero{
  position:relative;border-radius:12px;overflow:hidden;
  border:1px solid var(--line);
  background:#0a0a0a;
}
.hero img{width:100%;height:auto;display:block}
.hero-content{
  position:absolute;left:6%;top:50%;transform:translateY(-50%);
  max-width:340px;
}
.hero-kicker{
  color:var(--gold);font-size:12px;letter-spacing:3px;
  text-transform:uppercase;font-weight:700;margin-bottom:6px;
}
.hero-title{
  font-family:Georgia,serif;font-weight:800;
  font-size:clamp(22px,3vw,38px);line-height:1.05;
  color:var(--gold-2);
  text-shadow:0 2px 12px rgba(0,0,0,.6);
  margin-bottom:20px;
}
.hero-cta{
  display:inline-block;
  background:linear-gradient(180deg,var(--green-2),var(--green));
  color:#06250f;font-weight:800;text-transform:uppercase;
  letter-spacing:1px;font-size:15px;
  padding:14px 46px;border-radius:8px;
  border:2px solid #1d5e32;
  box-shadow:0 6px 18px rgba(0,0,0,.4);
}
.hero-cta:hover{filter:brightness(1.07)}
.hero-terms{display:block;margin-top:14px;color:var(--gold);font-size:12px;text-decoration:underline}
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  font-size:30px;color:var(--gold);opacity:.6;cursor:pointer;user-select:none;
}
.hero-arrow.left{left:14px}
.hero-arrow.right{right:14px}
.hero-dots{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%);
  display:flex;gap:9px;
}
.hero-dots i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.3)}
.hero-dots i.on{background:var(--gold)}

/* ---------- Category pills ---------- */
.pills{
  display:flex;flex-wrap:wrap;gap:10px;justify-content:center;
  margin:26px 0 30px;
}
.pill{
  display:flex;align-items:center;gap:8px;
  background:linear-gradient(180deg,#17130d,#0e0b08);
  border:1px solid var(--line);border-radius:6px;
  padding:10px 16px;font-size:12px;font-weight:700;
  letter-spacing:.6px;text-transform:uppercase;color:var(--text);
  cursor:pointer;transition:.15s;
}
.pill:hover{border-color:var(--gold);color:var(--gold-2)}
.pill .ico{font-size:14px}

/* ---------- Games ---------- */
.section-head{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;
}
.section-head h2{font-family:Georgia,serif;font-size:22px;color:var(--text)}
.section-tools{display:flex;align-items:center;gap:14px}
.see-all{color:var(--gold);font-size:12px;letter-spacing:1px;text-transform:uppercase;font-weight:700}
.arrow-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:6px;border:1px solid var(--line);
  background:var(--panel);color:var(--gold);cursor:pointer;font-size:16px;
}
.arrow-btn:hover{border-color:var(--gold)}
.games{
  display:grid;grid-template-columns:repeat(7,1fr);gap:16px;
}
.game{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;transition:.18s}
.game img{width:100%;height:auto;border-radius:8px;border:1px solid var(--line)}
.game:hover{transform:translateY(-6px)}
.game .rank{
  position:absolute;left:6px;bottom:-6px;
  font-family:Georgia,serif;font-weight:800;font-size:54px;line-height:1;
  color:#cdbf9a;text-shadow:0 2px 6px rgba(0,0,0,.7);
}
.game .play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.45);opacity:0;transition:.18s;
}
.game:hover .play{opacity:1}
.game .play span{
  background:linear-gradient(180deg,var(--green-2),var(--green));
  color:#06250f;font-weight:800;text-transform:uppercase;font-size:11px;
  padding:9px 16px;border-radius:6px;
}

/* ---------- Review article ---------- */
.review{
  max-width:920px;margin:56px auto 0;
}
.review .eyebrow{
  color:var(--gold);text-transform:uppercase;letter-spacing:3px;font-size:12px;font-weight:700;
}
.review h1{
  font-family:Georgia,serif;font-size:34px;line-height:1.15;margin:8px 0 6px;color:#fff;
}
.review .meta{color:var(--muted);font-size:13px;margin-bottom:8px}
.rating{display:flex;align-items:center;gap:10px;margin:14px 0 26px}
.stars{color:var(--gold);font-size:20px;letter-spacing:2px}
.rating .score{
  font-weight:800;color:var(--gold-2);background:#1a140a;
  border:1px solid var(--gold);border-radius:6px;padding:3px 10px;font-size:14px;
}
.review h2{
  font-family:Georgia,serif;font-size:24px;margin:34px 0 12px;color:#fff;
  padding-bottom:8px;border-bottom:1px solid var(--line);
}
.review p{margin:0 0 16px;color:#cfc8ba}
.review ul{margin:0 0 18px;padding-left:0;list-style:none}
.review li{padding:8px 0 8px 30px;position:relative;color:#cfc8ba;border-bottom:1px dashed var(--line)}
.review li::before{content:"⚔";position:absolute;left:4px;color:var(--gold)}

.proscons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0}
.pc{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px 20px}
.pc h3{font-size:15px;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}
.pc.pros h3{color:var(--green-2)}
.pc.cons h3{color:#e07a6a}
.pc ul li{padding-left:26px;border-bottom:1px solid var(--line)}
.pc.pros li::before{content:"✓";color:var(--green-2)}
.pc.cons li::before{content:"✕";color:#e07a6a}

.facts{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0 6px;
}
.fact{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:16px;text-align:center}
.fact .k{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:1px}
.fact .v{color:var(--gold-2);font-weight:800;font-size:18px;margin-top:6px;font-family:Georgia,serif}

/* ---------- Final CTA ---------- */
.cta{
  max-width:920px;margin:50px auto 0;
  position:relative;overflow:hidden;border-radius:16px;
  border:1px solid var(--gold);
  background:
    radial-gradient(120% 140% at 80% 10%,rgba(196,63,54,.35),transparent 60%),
    linear-gradient(180deg,#1a130b,#0c0907);
  padding:46px 40px;text-align:center;
}
.cta h2{font-family:Georgia,serif;font-size:30px;color:var(--gold-2);margin-bottom:10px}
.cta p{color:#d8cfbf;max-width:560px;margin:0 auto 26px}
.cta .big-offer{
  display:inline-block;font-family:Georgia,serif;font-weight:800;
  font-size:40px;color:#fff;text-shadow:0 0 24px rgba(212,162,60,.5);margin-bottom:8px;
}
.cta .cta-btn{
  display:inline-block;margin-top:8px;
  background:linear-gradient(180deg,var(--green-2),var(--green));
  color:#06250f;font-weight:800;text-transform:uppercase;letter-spacing:1px;
  font-size:17px;padding:16px 56px;border-radius:10px;border:2px solid #1d5e32;
  box-shadow:0 8px 26px rgba(0,0,0,.5);
}
.cta .cta-btn:hover{filter:brightness(1.08)}
.cta .fineprint{margin-top:18px;color:var(--muted);font-size:11px;max-width:620px;margin-left:auto;margin-right:auto}

/* ---------- Footer ---------- */
.footer{
  margin-top:60px;border-top:1px solid var(--line);
  padding:26px;text-align:center;color:var(--muted);font-size:12px;
}
.footer .age{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;border:2px solid var(--muted);
  font-weight:800;margin-bottom:10px;
}

/* ---------- Responsive ---------- */
@media(max-width:1100px){
  .games{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:880px){
  .sidebar{display:none}
  .search{display:none}
  .games{grid-template-columns:repeat(3,1fr)}
  .proscons,.facts{grid-template-columns:1fr}
  .facts{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .games{grid-template-columns:repeat(2,1fr)}
  .hero-content{max-width:60%}
  .header-actions .btn{padding:10px 12px}
}
