/* ============ Energy Casino Polska – affiliate review – stylesheet ============ */
:root{
  --bg:#0b0e1a;
  --bg-alt:#11162a;
  --bg-card:#171c33;
  --bg-card-2:#1d2440;
  --line:#2a3253;
  --text:#e8ebf5;
  --text-dim:#a8aec5;
  --gold:#f5c518;
  --gold-2:#ffd84d;
  --gold-deep:#c69500;
  --accent:#ff5252;
  --green:#34c759;
  --red:#ff4d4d;
  --shadow:0 6px 24px rgba(0,0,0,.35);
  --radius:10px;
  --maxw:1180px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold);text-decoration:none;transition:color .15s}
a:hover{color:var(--gold-2);text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
h1,h2,h3,h4{font-family:'Manrope',sans-serif;font-weight:800;line-height:1.25;color:#fff;margin:1.5em 0 .6em}
h1{font-size:clamp(28px,4vw,42px);margin-top:0}
h2{font-size:clamp(22px,2.6vw,30px);border-left:4px solid var(--gold);padding-left:14px}
h3{font-size:clamp(18px,2vw,22px);color:var(--gold-2)}
h4{font-size:17px;color:#fff}
p{margin:0 0 1em}
ul,ol{margin:0 0 1em;padding-left:22px}
li{margin-bottom:.4em}
strong{color:#fff}
hr{border:0;border-top:1px solid var(--line);margin:32px 0}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,#0b0e1a 0%,#0e1226 100%);
  border-bottom:1px solid var(--line);
  box-shadow:0 2px 12px rgba(0,0,0,.4);
}
.header-inner{
  display:flex;align-items:center;gap:18px;
  padding:14px 20px;
  max-width:var(--maxw);margin:0 auto;
}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo img{height:38px;width:auto}
.logo-text{font-weight:800;font-size:20px;color:#fff;letter-spacing:.3px}
.logo-text span{color:var(--gold)}
nav.main-nav{flex:1;display:flex;justify-content:center}
nav.main-nav ul{list-style:none;display:flex;flex-wrap:nowrap;gap:6px;margin:0;padding:0}
nav.main-nav a{
  color:#e8ebf5;font-weight:600;font-size:14px;
  padding:8px 12px;border-radius:6px;
  white-space:nowrap;
  transition:background .15s,color .15s;
}
nav.main-nav a:hover{background:rgba(245,197,24,.1);color:var(--gold);text-decoration:none}
nav.main-nav a.active{color:var(--gold)}
.cta-header{
  background:linear-gradient(180deg,var(--gold-2) 0%,var(--gold) 50%,var(--gold-deep) 100%);
  color:#0b0e1a !important;
  font-weight:800;
  padding:10px 20px;
  border-radius:6px;
  font-size:14px;
  letter-spacing:.4px;
  text-transform:uppercase;
  white-space:nowrap;
  box-shadow:0 2px 0 #8a6700,0 4px 14px rgba(245,197,24,.3);
  transition:transform .12s;
}
.cta-header:hover{transform:translateY(-1px);text-decoration:none;color:#0b0e1a !important}
.menu-toggle{
  display:none;background:transparent;border:0;color:#fff;
  font-size:26px;cursor:pointer;padding:6px 10px;
}
@media (max-width:960px){
  nav.main-nav{
    position:fixed;top:0;left:-100%;width:280px;height:100vh;
    background:#0e1226;flex-direction:column;justify-content:flex-start;
    padding:80px 20px 20px;transition:left .25s;border-right:1px solid var(--line);
    box-shadow:4px 0 20px rgba(0,0,0,.5);
  }
  nav.main-nav.open{left:0}
  nav.main-nav ul{flex-direction:column;gap:4px;width:100%}
  nav.main-nav a{display:block;padding:12px 14px;font-size:15px}
  .menu-toggle{display:block;order:-1}
  .cta-header{padding:9px 14px;font-size:12px}
  .logo-text{display:none}
  .header-inner{gap:10px}
}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:40}
.nav-overlay.show{display:block}

/* ===== Hero ===== */
.hero{
  background:radial-gradient(ellipse at top,rgba(245,197,24,.12) 0%,transparent 60%),linear-gradient(180deg,#0e1226 0%,#0b0e1a 100%);
  padding:48px 0 36px;
  border-bottom:1px solid var(--line);
}
.hero-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:center}
@media (max-width:860px){.hero-inner{grid-template-columns:1fr;gap:24px}}
.hero h1{margin-bottom:.4em}
.hero p.lead{font-size:18px;color:var(--text-dim);max-width:560px}
.rating-row{display:flex;align-items:center;gap:14px;margin:18px 0}
.stars{color:var(--gold);font-size:22px;letter-spacing:2px}
.score-box{
  background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);
  padding:6px 14px;font-weight:800;color:#fff;
}
.score-box span{color:var(--gold);font-size:20px}

/* ===== Verdict / cards ===== */
.verdict-card{
  background:linear-gradient(180deg,var(--bg-card) 0%,var(--bg-card-2) 100%);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
  box-shadow:var(--shadow);
}
.verdict-card h3{margin-top:0}
.bonus-headline{
  font-size:22px;font-weight:800;color:var(--gold-2);
  text-align:center;margin:6px 0 14px;line-height:1.3;
}
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:20px 0}
@media (max-width:600px){.proscons{grid-template-columns:1fr}}
.proscons ul{list-style:none;padding:0;margin:0}
.proscons li{padding:6px 0 6px 24px;position:relative;font-size:14.5px}
.pros li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}
.cons li::before{content:"✕";position:absolute;left:0;color:var(--red);font-weight:800}
.pros h4,.cons h4{margin-top:0;margin-bottom:8px}

/* ===== Buttons / CTAs ===== */
.btn{
  display:inline-block;font-weight:800;text-align:center;
  padding:14px 28px;border-radius:8px;cursor:pointer;border:0;
  text-transform:uppercase;letter-spacing:.5px;font-size:15px;
  transition:transform .12s,box-shadow .12s;text-decoration:none;
}
.btn-primary{
  background:linear-gradient(180deg,var(--gold-2) 0%,var(--gold) 50%,var(--gold-deep) 100%);
  color:#0b0e1a !important;
  box-shadow:0 3px 0 #8a6700,0 6px 18px rgba(245,197,24,.35);
}
.btn-primary:hover{transform:translateY(-2px);text-decoration:none;color:#0b0e1a !important}
.btn-block{display:block;width:100%}
.btn-large{padding:18px 36px;font-size:17px}
.cta-block{
  background:linear-gradient(135deg,#1d2440 0%,#11162a 100%);
  border:1px solid var(--gold);
  border-radius:var(--radius);
  padding:28px;text-align:center;margin:32px 0;
}
.cta-block h3{margin-top:0;color:#fff}
.cta-block p{color:var(--text-dim);margin-bottom:18px}

/* ===== Tables ===== */
table{
  width:100%;border-collapse:collapse;margin:18px 0 26px;
  background:var(--bg-card);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);font-size:15px;
}
th,td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
th{background:#1d2440;color:var(--gold-2);font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.4px}
tr:last-child td{border-bottom:0}
tr:hover td{background:rgba(245,197,24,.04)}

/* ===== Info box / callouts ===== */
.callout{
  background:linear-gradient(135deg,rgba(245,197,24,.08) 0%,rgba(245,197,24,.02) 100%);
  border-left:4px solid var(--gold);
  padding:16px 20px;border-radius:6px;margin:20px 0;
}
.callout-warn{
  background:rgba(255,82,82,.07);border-left-color:var(--accent);
}
.callout strong{color:var(--gold-2)}

/* ===== Promo code box ===== */
.promo-box{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg-card-2);border:2px dashed var(--gold);
  border-radius:var(--radius);padding:14px 20px;margin:18px 0;gap:14px;
  flex-wrap:wrap;
}
.promo-code{
  font-family:'Courier New',monospace;font-weight:800;font-size:22px;
  color:var(--gold);letter-spacing:2px;
}
.copy-btn{
  background:#0b0e1a;color:var(--gold);border:1px solid var(--gold);
  padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:700;
  font-size:13px;text-transform:uppercase;
}
.copy-btn:hover{background:var(--gold);color:#0b0e1a}
.copy-btn.copied{background:var(--green);color:#fff;border-color:var(--green)}

/* ===== Figures / images ===== */
figure{margin:24px auto;text-align:center;max-width:100%}
figure img{
  width:90%;height:auto;
  border-radius:8px;
  box-shadow:0 8px 28px rgba(0,0,0,.4);
  margin:0 auto;
}
figcaption{font-size:13.5px;color:var(--text-dim);margin-top:10px;font-style:italic}
@media (max-width:700px){figure img{width:100%}}

/* ===== FAQ ===== */
.faq{margin:28px 0}
.faq details{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:8px;
  margin-bottom:10px;
  overflow:hidden;
}
.faq summary{
  cursor:pointer;padding:16px 20px;font-weight:700;color:#fff;
  list-style:none;display:flex;justify-content:space-between;align-items:center;
  font-size:16px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold);font-size:22px;font-weight:300}
.faq details[open] summary::after{content:"−"}
.faq details[open] summary{border-bottom:1px solid var(--line);background:#1d2440}
.faq details > *:not(summary){padding:16px 20px;color:var(--text-dim)}
.faq details p:last-child{margin-bottom:0}

/* ===== Layout: two-col content + sidebar (homepage) ===== */
.content{padding:36px 0 60px}
.content-grid{display:grid;grid-template-columns:1fr;gap:40px}
article > p:first-of-type{font-size:17px;color:var(--text)}
article ul li, article ol li{color:var(--text)}

/* ===== Footer ===== */
footer{
  background:#070914;border-top:1px solid var(--line);
  padding:40px 0 20px;margin-top:40px;color:var(--text-dim);font-size:14px;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px;
  max-width:var(--maxw);margin:0 auto;padding:0 20px;
}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{color:#fff;margin-top:0;font-size:15px;text-transform:uppercase;letter-spacing:.5px}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:6px}
.footer-grid a{color:var(--text-dim)}
.footer-grid a:hover{color:var(--gold)}
.badge-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:14px 0}
.badge{
  background:#1d2440;border:1px solid var(--line);
  color:#fff;font-weight:700;font-size:12px;padding:5px 10px;border-radius:4px;
}
.badge-18{background:var(--red);border-color:var(--red);color:#fff}
.legal{
  text-align:center;padding-top:20px;margin-top:24px;
  border-top:1px solid var(--line);color:#6f748a;font-size:12.5px;
  max-width:var(--maxw);margin-left:auto;margin-right:auto;padding-left:20px;padding-right:20px;
}
.legal a{color:#9aa0b8}

/* ===== Breadcrumbs ===== */
.crumbs{padding:14px 0;font-size:13.5px;color:var(--text-dim)}
.crumbs a{color:var(--text-dim)}
.crumbs a:hover{color:var(--gold)}
.crumbs span.sep{margin:0 8px;color:#4a5072}

/* ===== Quick fact list ===== */
.facts{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;
  margin:18px 0 28px;
}
.fact{
  background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 16px;
}
.fact .label{font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}
.fact .val{font-size:16px;font-weight:700;color:#fff;margin-top:4px}

/* ===== Steps list ===== */
.steps{counter-reset:s;list-style:none;padding:0;margin:20px 0}
.steps li{
  counter-increment:s;
  position:relative;padding:14px 18px 14px 60px;
  background:var(--bg-card);border:1px solid var(--line);border-radius:8px;
  margin-bottom:10px;
}
.steps li::before{
  content:counter(s);
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:32px;height:32px;border-radius:50%;
  background:var(--gold);color:#0b0e1a;font-weight:800;
  display:flex;align-items:center;justify-content:center;font-size:15px;
}

/* ===== Disclaimer ===== */
.disclaimer{
  margin-top:36px;padding:14px 18px;background:#0e1226;
  border:1px dashed var(--line);border-radius:6px;
  font-size:13.5px;color:var(--text-dim);
}

/* skip-to-content for a11y */
.skip{position:absolute;left:-9999px}
.skip:focus{left:10px;top:10px;background:var(--gold);color:#000;padding:8px 12px;border-radius:4px;z-index:100}
