/* ===== Holyluck Casino — holy-luck-casinos.nl ===== */
:root{
  --bg:#07150e; --bg2:#0a1f15; --panel:#0f2a1d; --panel2:#143524;
  --line:rgba(243,211,94,.16); --line2:rgba(255,255,255,.07);
  --green:#3fbf6a; --green2:#2ea157; --glow:#5fe08a;
  --gold:#f3d35e; --gold2:#e0b441;
  --text:#eaf6ee; --muted:#9fb6a8; --head:#ffffff;
  --radius:16px; --maxw:1200px;
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --grad-gold:linear-gradient(135deg,#f8e07a,#e0b441 60%,#c79b34);
  --grad-green:linear-gradient(135deg,#56d985,#2ea157);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:"Manrope",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100%;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--gold);text-decoration:none;transition:.2s}
a:hover{color:var(--glow)}
.skip{position:absolute;left:-999px;top:0;z-index:200;background:var(--gold);color:#1a1205;
  padding:10px 18px;border-radius:0 0 10px 0;font-weight:800}
.skip:focus{left:0;color:#1a1205}
:focus-visible{outline:3px solid var(--glow);outline-offset:2px;border-radius:4px}
h1,h2,h3,h4{font-family:"Cinzel",Georgia,serif;color:var(--head);line-height:1.18;margin:0 0 .5em;font-weight:700}
h1{font-size:clamp(2rem,4.6vw,3.4rem);letter-spacing:.5px}
h2{font-size:clamp(1.5rem,3vw,2.3rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin:0 0 1.1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{padding:62px 0;position:relative}
.muted{color:var(--muted)}
.gold{color:var(--gold)}
.center{text-align:center}
.eyebrow{font-family:"Cinzel",serif;letter-spacing:3px;text-transform:uppercase;font-size:.78rem;color:var(--gold);font-weight:700;margin-bottom:10px}
.lead{font-size:1.12rem;color:#cfe3d6;max-width:760px}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.55em;justify-content:center;
  font-family:"Manrope",sans-serif;font-weight:800;font-size:1rem;cursor:pointer;
  padding:14px 30px;border-radius:50px;border:0;text-align:center;transition:.22s;white-space:nowrap}
.btn-cta{background:var(--grad-green);color:#06210f;box-shadow:0 10px 26px rgba(63,191,106,.35)}
.btn-cta:hover{color:#06210f;transform:translateY(-2px);box-shadow:0 14px 34px rgba(95,224,138,.5)}
.btn-gold{background:var(--grad-gold);color:#221603;box-shadow:0 10px 26px rgba(224,180,65,.32)}
.btn-gold:hover{color:#221603;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-lg{padding:17px 40px;font-size:1.08rem}
.btn-block{display:flex;width:100%}

/* ---- header ---- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(7,21,14,.92);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.head-row{display:flex;align-items:center;gap:18px;height:74px}
.brand img{height:46px;width:auto}
.nav{display:flex;align-items:center;gap:6px;margin-left:auto}
.nav a{color:var(--text);font-weight:700;font-size:.96rem;padding:9px 13px;border-radius:9px}
.nav a:hover,.nav a.active{color:var(--gold);background:rgba(243,211,94,.08)}
.head-cta{display:flex;align-items:center;gap:10px;margin-left:8px}
.head-cta .btn{padding:10px 20px;font-size:.92rem}
.burger{display:none;margin-left:auto;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.burger span{width:26px;height:3px;background:var(--gold);border-radius:3px;transition:.25s}
.mobile-cta{display:none}

/* ---- mobile drawer ---- */
.drawer{position:fixed;inset:0 0 0 auto;width:min(86vw,340px);background:var(--bg2);
  border-left:1px solid var(--line);transform:translateX(100%);transition:.3s;z-index:60;
  padding:22px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}
.drawer.open{transform:none}
.drawer a{color:var(--text);font-weight:700;padding:13px 12px;border-radius:10px;border-bottom:1px solid var(--line2)}
.drawer a:hover{color:var(--gold)}
.drawer .btn{margin-top:8px}
.drawer-close{align-self:flex-end;background:none;border:0;color:var(--gold);font-size:1.7rem;cursor:pointer;line-height:1}
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);opacity:0;visibility:hidden;transition:.3s;z-index:55}
.backdrop.show{opacity:1;visibility:visible}

/* ---- hero (hero-main bg on all main pages) ---- */
.hero{position:relative;min-height:496px;display:grid;align-items:center;padding:34px 0;overflow:hidden;
  background:
   linear-gradient(90deg,rgba(6,18,12,.95) 0%,rgba(6,18,12,.9) 30%,rgba(6,18,12,.5) 52%,rgba(6,18,12,.1) 72%,rgba(6,18,12,0) 100%),
   url("/images/holyluck-casino-hero-olympische-goden.webp") center right/cover no-repeat;
  border-bottom:1px solid var(--line)}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 64%,rgba(6,18,12,.8) 100%)}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-inner>*{max-width:560px}
.hero h1{font-size:clamp(1.8rem,3.1vw,2.45rem);line-height:1.15;margin-bottom:.4em}
.hero .lead{font-size:1.04rem;max-width:520px}
.hero .pill-row{margin:16px 0 20px;display:flex;flex-wrap:nowrap;gap:8px;max-width:none}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.pill{display:inline-flex;align-items:center;gap:6px;background:rgba(15,42,29,.7);white-space:nowrap;flex:none;
  border:1px solid var(--line);padding:7px 13px;border-radius:50px;font-size:.82rem;font-weight:700;margin:0}
.pill b{color:var(--gold)}

/* ---- bonus sport cards (like screenshot) ---- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card-bonus{background:var(--panel);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  display:flex;flex-direction:column;transition:.25s}
.card-bonus:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:var(--shadow)}
.card-bonus .ph{aspect-ratio:1/1;overflow:hidden;position:relative}
.card-bonus .ph img{width:100%;height:100%;object-fit:cover}
.card-bonus .body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:4px;flex:1}
.card-bonus h3{font-size:1.18rem;margin:0}
.card-bonus .sub{color:var(--muted);font-size:.95rem;margin-bottom:auto}
.card-bonus .btn{margin-top:14px}
.card-bonus .info{position:absolute;top:12px;right:12px;width:26px;height:26px;border-radius:50%;
  border:2px solid var(--green);color:var(--green);display:grid;place-items:center;font-size:.8rem;font-weight:800;font-family:serif;background:rgba(7,21,14,.5)}

/* ---- wide promo banner (full art shown, text overlaid in empty zone) ---- */
.promo{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line)}
.promo img{display:block;width:100%;height:auto}
.promo .ov{position:absolute;top:0;bottom:0;left:0;width:min(58%,560px);z-index:2;
  display:flex;flex-direction:column;justify-content:center;gap:9px;padding:0 clamp(22px,3vw,46px);
  background:linear-gradient(90deg,rgba(6,18,12,.9) 0%,rgba(6,18,12,.66) 52%,rgba(6,18,12,0) 100%)}
.promo.right .ov{left:auto;right:0;text-align:right;align-items:flex-end;
  background:linear-gradient(270deg,rgba(6,18,12,.9) 0%,rgba(6,18,12,.66) 52%,rgba(6,18,12,0) 100%)}
.promo .ov h2,.promo .ov h3{margin:0}
.promo .ov .big{font-size:clamp(1.5rem,2.7vw,2.4rem);color:var(--gold);font-family:"Cinzel",serif;font-weight:700;line-height:1.1;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.promo .ov p{text-shadow:0 1px 8px rgba(0,0,0,.6)}

/* ---- game/slot tiles ---- */
.games{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.game{border-radius:16px;overflow:hidden;border:1px solid var(--line);position:relative;transition:.25s;background:var(--panel)}
.game:hover{transform:translateY(-5px);border-color:var(--green);box-shadow:var(--shadow)}
.game img{aspect-ratio:1/1;object-fit:cover;width:100%}
.game .gname{position:absolute;left:0;right:0;bottom:0;padding:24px 12px 10px;font-weight:800;font-size:.9rem;
  background:linear-gradient(transparent,rgba(7,21,14,.92));z-index:2}
.game .play{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:.25s;z-index:3;background:rgba(7,21,14,.45)}
.game:hover .play{opacity:1}
.game .play .btn{padding:11px 22px}

/* ---- generic grids & feature cards ---- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
/* let grid/split children shrink so wide content (tables) can't blow out the column */
.grid-2>*,.grid-3>*,.grid-4>*,.split>*,.cards>*,.games>*,.stat-row>*{min-width:0}
.box{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.box.soft{background:linear-gradient(160deg,var(--panel),var(--bg2))}
.feature{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:.22s}
.feature:hover{border-color:var(--gold);transform:translateY(-4px)}
.feature .ic{width:50px;height:50px;border-radius:12px;display:grid;place-items:center;font-size:1.5rem;
  background:rgba(243,211,94,.12);border:1px solid var(--line);margin-bottom:14px}
.feature h3{font-size:1.18rem}
.feature p{margin:0;color:var(--muted);font-size:.97rem}
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.split img{border-radius:var(--radius);border:1px solid var(--line)}

/* ---- tables ---- */
.tbl-wrap{overflow-x:auto;max-width:100%;border-radius:var(--radius);border:1px solid var(--line)}
table.t{width:100%;border-collapse:collapse;min-width:520px;background:var(--panel);font-size:.97rem}
table.t th,table.t td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line2)}
table.t thead th{background:rgba(243,211,94,.1);color:var(--gold);font-family:"Cinzel",serif;font-size:.9rem;letter-spacing:.4px}
table.t tbody tr:hover{background:rgba(255,255,255,.03)}
table.t td b,table.t td strong{color:var(--text)}

/* ---- CSS diagrams ---- */
.bars{display:flex;flex-direction:column;gap:14px}
.bar-row{display:grid;grid-template-columns:140px 1fr 56px;align-items:center;gap:14px;font-size:.92rem}
.bar-track{height:13px;border-radius:7px;background:rgba(255,255,255,.07);overflow:hidden}
.bar-fill{height:100%;border-radius:7px;background:var(--grad-green)}
.bar-fill.gold{background:var(--grad-gold)}

.donut-wrap{display:flex;gap:30px;align-items:center;flex-wrap:wrap}
.donut{width:190px;height:190px;border-radius:50%;flex:none}
.legend{display:flex;flex-direction:column;gap:10px}
.legend .li{display:flex;align-items:center;gap:10px;font-size:.95rem}
.legend .dot{width:14px;height:14px;border-radius:4px;flex:none}

.timeline{position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:3px;background:linear-gradient(var(--gold),var(--green))}
.tl-step{position:relative;margin-bottom:24px}
.tl-step::before{content:"";position:absolute;left:-30px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(243,211,94,.18)}
.tl-step h3{margin:0 0 4px;font-family:"Manrope",sans-serif;color:var(--gold);font-size:1.05rem}
.tl-step p{margin:0;color:var(--muted);font-size:.96rem}

.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{background:linear-gradient(160deg,var(--panel2),var(--bg2));border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center}
.stat .n{font-family:"Cinzel",serif;font-size:2rem;color:var(--gold);font-weight:700;line-height:1}
.stat .l{color:var(--muted);font-size:.88rem;margin-top:6px}

.steps{counter-reset:s;display:grid;gap:16px}
.step{display:flex;gap:16px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px 22px}
.step::before{counter-increment:s;content:counter(s);font-family:"Cinzel",serif;font-weight:700;
  min-width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:var(--grad-gold);color:#221603;font-size:1.15rem}
.step h3{margin:0 0 3px;font-size:1.12rem}
.step p{margin:0;color:var(--muted)}

.checklist{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.checklist li{display:flex;gap:12px;align-items:flex-start}
.checklist li::before{content:"✦";color:var(--green);font-size:1.05rem;margin-top:2px}
ul.pros,ul.cons{list-style:none;padding:0;margin:0;display:grid;gap:10px}
ul.pros li::before{content:"✓ ";color:var(--green);font-weight:800}
ul.cons li::before{content:"– ";color:var(--gold);font-weight:800}

/* ---- FAQ ---- */
.faq{display:grid;gap:12px;max-width:880px;margin:0 auto}
.faq details{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:4px 22px;transition:.2s}
.faq details[open]{border-color:var(--gold)}
.faq summary{cursor:pointer;list-style:none;font-weight:800;padding:16px 0;font-size:1.05rem;
  display:flex;justify-content:space-between;gap:14px;align-items:center;color:var(--head)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold);font-size:1.5rem;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:0 0 16px;color:var(--muted)}

/* ---- author block ---- */
.author-box{display:flex;gap:22px;align-items:center;background:linear-gradient(160deg,var(--panel2),var(--bg2));
  border:1px solid var(--line);border-radius:18px;padding:26px 28px;flex-wrap:wrap}
.author-box .ava{width:92px;height:92px;border-radius:50%;flex:none;object-fit:cover;border:2px solid var(--gold);background:var(--panel)}
.author-box .meta{flex:1;min-width:240px}
.author-box .meta .nm{font-family:"Cinzel",serif;font-size:1.2rem;color:var(--head)}
.author-box .meta .role{color:var(--gold);font-size:.9rem;font-weight:700;margin-bottom:6px}
.author-box .meta p{margin:0;color:var(--muted);font-size:.96rem}
.ava-mono{display:grid;place-items:center;font-family:"Cinzel",serif;font-weight:700;color:var(--gold);font-size:2rem}

/* ---- breadcrumb ---- */
.crumb{font-size:.86rem;color:var(--muted);padding:16px 0 0}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--gold)}

/* ---- footer ---- */
.site-foot{background:#050f0a;border-top:1px solid var(--line);padding:54px 0 30px;margin-top:20px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px}
.foot-grid img{height:42px;margin-bottom:14px}
.foot-grid h3{font-family:"Cinzel",serif;font-size:1rem;color:var(--gold);margin-bottom:14px}
.foot-grid a{display:block;color:var(--muted);padding:5px 0;font-size:.95rem}
.foot-grid a:hover{color:var(--gold)}
.foot-grid p{color:var(--muted);font-size:.93rem}
.pay-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.pay-row span{background:var(--panel);border:1px solid var(--line);border-radius:7px;padding:5px 11px;font-size:.78rem;font-weight:700;color:#cfe3d6}
.foot-bottom{border-top:1px solid var(--line2);margin-top:34px;padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center;color:var(--muted);font-size:.84rem}
.age{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:50%;border:2px solid var(--gold);color:var(--gold);font-weight:800;font-family:"Cinzel",serif;flex:none}
.foot-disc{color:#7d958a;font-size:.8rem;line-height:1.6;margin-top:18px}

/* ---- sticky bonus banner (bottom-right, tall, logo top / text+btn bottom) ---- */
.sticky-bonus{position:fixed;right:22px;bottom:22px;z-index:70;width:300px;
  border-radius:20px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.6);
  border:1.5px solid var(--gold);background:#0a1f15;
  transform:translateY(140%);opacity:0;transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .5s}
.sticky-bonus.show{transform:none;opacity:1}
.sticky-bonus .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.sticky-bonus::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(rgba(7,21,14,.55) 0%,rgba(7,21,14,0) 26%,rgba(7,21,14,.1) 55%,rgba(7,21,14,.92) 100%)}
.sticky-bonus .inner{position:relative;z-index:2;display:flex;flex-direction:column;
  align-items:center;justify-content:space-between;height:430px;padding:16px 16px 18px;text-align:center}
.sticky-bonus .sb-logo{height:34px;width:auto;margin:2px auto 0;filter:drop-shadow(0 2px 8px rgba(0,0,0,.6))}
.sticky-bonus .sb-foot{display:flex;flex-direction:column;align-items:center;gap:9px;width:100%}
.sticky-bonus .sb-foot .t{font-family:"Cinzel",serif;font-weight:700;font-size:1.42rem;color:#fff;line-height:1.05;text-shadow:0 2px 10px rgba(0,0,0,.7)}
.sticky-bonus .sb-foot .t b{color:var(--gold)}
.sticky-bonus .sb-foot .s{font-size:.82rem;color:#dcefe1;font-weight:700}
.sticky-bonus .sb-foot .btn{width:100%;padding:13px}
.sb-close{position:absolute;top:8px;right:9px;z-index:4;width:28px;height:28px;border-radius:50%;
  background:rgba(7,21,14,.7);border:1px solid var(--line);color:#fff;cursor:pointer;font-size:1rem;line-height:1;display:grid;place-items:center}
.sb-close:hover{color:var(--gold)}
body.drawer-open .sticky-bonus{opacity:0 !important;visibility:hidden;pointer-events:none}

/* ---- misc ---- */
.note{background:rgba(243,211,94,.08);border:1px solid var(--line);border-left:4px solid var(--gold);
  border-radius:10px;padding:16px 20px;color:#dfeee4;font-size:.96rem;margin:22px 0}
.tag{display:inline-block;background:rgba(63,191,106,.16);color:var(--glow);border:1px solid rgba(63,191,106,.3);
  border-radius:50px;padding:4px 14px;font-size:.8rem;font-weight:800;letter-spacing:.4px}
.divider{height:1px;background:var(--line);margin:8px 0}
.toc{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px 26px;margin:0 0 30px}
.toc h3{margin:0 0 10px;font-size:1.1rem}
.toc ol{margin:0;padding-left:20px;columns:2;gap:30px}
.toc a{color:#cfe3d6}
.bg-alt{background:var(--bg2)}
.prose p,.prose li{color:#d5e6db}
.prose h2{margin-top:1.2em}

/* ---- promo: stack image + text panel on smaller screens ---- */
@media(max-width:760px){
  .promo .ov{position:relative;top:auto;bottom:auto;left:auto;right:auto;width:100%;
    text-align:left;align-items:flex-start;padding:22px 20px;
    background:linear-gradient(180deg,rgba(16,42,29,.96),rgba(10,31,21,.96))}
  .promo.right .ov{text-align:left;align-items:flex-start;
    background:linear-gradient(180deg,rgba(16,42,29,.96),rgba(10,31,21,.96))}
}

/* ---- responsive ---- */
@media(max-width:980px){
  .nav,.head-cta{display:none}
  .burger{display:flex}
  .mobile-cta{display:inline-flex}
  .cards{grid-template-columns:repeat(2,1fr)}
  .games{grid-template-columns:repeat(3,1fr)}
  .grid-4,.stat-row{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .toc ol{columns:1}
}
@media(max-width:620px){
  body{font-size:16px}
  section{padding:46px 0}
  .hero{min-height:auto;padding:42px 0 38px;background-position:70% center}
  .hero::before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(90deg,rgba(6,18,12,.92),rgba(6,18,12,.55) 70%,rgba(6,18,12,.25))}
  .hero-inner>*{max-width:100%}
  .hero h1{font-size:clamp(1.5rem,5.6vw,2.1rem);overflow-wrap:break-word;word-break:break-word}
  .hero .lead{max-width:100%}
  .hero .pill-row{flex-wrap:wrap;max-width:100%}
  .hero-cta{width:100%}
  .hero-cta .btn{white-space:normal;flex:1 1 46%}
  .hero .btn-lg{padding:15px 18px;font-size:1rem}
  .cards,.games,.grid-3,.grid-4,.stat-row{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .bar-row{grid-template-columns:96px 1fr 44px;font-size:.82rem}
  .foot-grid{grid-template-columns:1fr}
  .sticky-bonus{width:240px;right:12px;bottom:12px}
  .sticky-bonus .inner{height:360px}
  .author-box{flex-direction:column;text-align:center}
}
@media(max-width:430px){
  .cards,.games,.grid-3,.grid-4,.stat-row{grid-template-columns:1fr}
}
