/* ==========================================================================
   Kopf & Zahl — shared design system (kopfundzahl.at)
   Used by all inner pages. Homepage keeps its own inline styles.
   Palette: Austrian red (#E10E21) primary, white/paper, Plus Jakarta Sans.
   ========================================================================== */

:root{
  --bg:#FFFFFF;--bg2:#F5F6F9;--bg3:#EEF0F4;--card:#FFFFFF;
  --ink:#14161C;--ink-2:#525762;--ink-3:#8A8F9B;
  --red:#E10E21;--red-2:#B00016;--red-soft:#FDECEE;--red-line:#F6C9CF;
  --line:#E6E8EE;--line-2:#D7DAE2;
  --shadow:0 1px 2px rgba(20,22,28,.05),0 12px 30px -10px rgba(20,22,28,.12);
  --shadow-2:0 10px 24px -8px rgba(20,22,28,.14),0 34px 64px -22px rgba(20,22,28,.24);
  --f:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --wrap:1180px;--narrow:760px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--f);line-height:1.6;font-size:16px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-weight:800;line-height:1.12;letter-spacing:-.02em}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--red);border-radius:2px}
.accent{color:var(--red)}
[id]{scroll-margin-top:90px}

/* ---- logo mark: red dice square ---- */
.brand-mark{width:38px;height:38px;border-radius:9px;background:linear-gradient(180deg,#EE1B2E,#B00016);display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);padding:8px;box-shadow:0 3px 10px rgba(225,14,33,.4);flex-shrink:0}
.brand-mark i{width:6px;height:6px;border-radius:50%;background:#fff;align-self:center;justify-self:center}
.brand-mark i:nth-child(1){grid-area:1/1}.brand-mark i:nth-child(2){grid-area:1/3}
.brand-mark i:nth-child(3){grid-area:2/2}.brand-mark i:nth-child(4){grid-area:3/1}
.brand-mark i:nth-child(5){grid-area:3/3}

/* ---- nav ---- */
.nav-wrap{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(20,22,28,.04),0 12px 34px -24px rgba(20,22,28,.55)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:12px}
.brand-text{font-weight:800;font-size:20px;letter-spacing:-.02em}
.brand-text b{color:var(--red);font-weight:800}
.nav-menu{display:flex;align-items:center;gap:28px;list-style:none}
.nav-link{font-size:14.5px;font-weight:600;color:var(--ink-2);transition:color .18s;position:relative;padding:4px 0}
.nav-link::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--red);border-radius:2px;transition:width .22s}
.nav-link:hover{color:var(--ink)}.nav-link:hover::after{width:100%}
.nav-cta{background:linear-gradient(180deg,#F5203A,#C10018);color:#fff;padding:11px 20px;border-radius:10px;font-weight:700;font-size:14px;transition:all .2s;box-shadow:0 10px 24px -6px rgba(225,14,33,.5),inset 0 1px 0 rgba(255,255,255,.28)}
.nav-cta:hover{transform:translateY(-1px)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;color:var(--ink)}
.nav-mcta{display:none}
@media(max-width:980px){
  .nav-menu,.nav>.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav-menu.open{display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;gap:0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:6px 20px 20px;box-shadow:0 22px 44px -14px rgba(20,22,28,.22);animation:navdrop .2s ease}
  .nav-menu.open li{border-bottom:1px solid var(--line)}
  .nav-menu.open .nav-link{display:block;font-size:16px;font-weight:600;padding:16px 4px;color:var(--ink)}
  .nav-menu.open .nav-link::after{display:none}
  .nav-menu.open .nav-mcta{display:block;border-bottom:0;margin-top:14px}
  .nav-menu.open .nav-mcta a{display:block;background:linear-gradient(180deg,#F5203A,#C10018);color:#fff;text-align:center;padding:15px;border-radius:12px;font-weight:700;font-size:15px;box-shadow:0 12px 26px -8px rgba(225,14,33,.55)}
}
@keyframes navdrop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 24px;border-radius:11px;font-weight:700;font-size:15px;transition:all .2s;cursor:pointer;border:0;font-family:var(--f)}
.btn-red{background:linear-gradient(180deg,#F5203A,#C10018);color:#fff;box-shadow:0 10px 24px -6px rgba(225,14,33,.5),inset 0 1px 0 rgba(255,255,255,.28)}
.btn-red:hover{transform:translateY(-2px)}
.btn-line{background:#fff;color:var(--ink);border:1.5px solid var(--line-2)}
.btn-line:hover{border-color:var(--red);color:var(--red)}

/* ---- page hero (inner pages) ---- */
.page-hero{background:linear-gradient(180deg,var(--bg2),#fff);border-bottom:1px solid var(--line);padding:34px 0 40px}
.crumb{font-size:12.5px;font-weight:600;color:var(--ink-3);margin-bottom:18px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.crumb a{color:var(--ink-3)}.crumb a:hover{color:var(--red)}
.crumb span{color:var(--line-2)}
.page-hero h1{font-size:clamp(30px,4.4vw,50px);margin-top:14px;max-width:900px}
.page-hero .lead{font-size:clamp(16px,1.4vw,19px);color:var(--ink-2);max-width:720px;margin-top:18px;line-height:1.6}
.page-meta{margin-top:20px;font-size:13px;color:var(--ink-3);display:flex;gap:8px 18px;flex-wrap:wrap;align-items:center}
.page-meta a{color:var(--red);font-weight:600}
.page-meta .dot{color:var(--line-2)}

/* ---- section scaffolding ---- */
section.sec{padding:66px 0}
.sec-head{max-width:720px;margin-bottom:40px}
.sec-head h2{font-size:clamp(26px,3.4vw,40px);margin-top:12px}
.sec-head p{color:var(--ink-2);font-size:16.5px;margin-top:14px;line-height:1.6}
.sec-head-flex{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:34px}
.sec-head-flex .sec-head{margin-bottom:0}
.sec-link{font-size:14px;font-weight:700;color:var(--red);white-space:nowrap}
.sec-link:hover{text-decoration:underline}

/* ---- cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;position:relative;overflow:hidden;transition:transform .2s,border-color .2s,box-shadow .2s;box-shadow:var(--shadow)}
.card:hover{transform:translateY(-4px);border-color:var(--red-line);box-shadow:var(--shadow-2)}
.card::before{content:"";position:absolute;left:14px;right:14px;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.95),transparent);z-index:2}

/* ---- pillar / hub grid (for hub pages listing spokes) ---- */
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.hub-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.hub-grid{grid-template-columns:1fr}}
.hub-card{display:block;padding:28px 26px}
.hub-card .hub-kicker{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.hub-card h3{font-size:20px;line-height:1.22;margin-bottom:9px}
.hub-card p{color:var(--ink-2);font-size:14px;line-height:1.55}
.hub-card .hub-link{margin-top:16px;font-size:12.5px;font-weight:700;color:var(--red);display:inline-flex;gap:6px;transition:gap .2s}
.hub-card:hover .hub-link{gap:11px}

/* ---- article / prose (spoke + legal pages) ---- */
.article{padding:52px 0 72px}
.article-grid{display:grid;grid-template-columns:1fr;gap:0;max-width:var(--narrow);margin:0 auto}
.prose{font-size:17px;line-height:1.72;color:var(--ink)}
.prose > *{max-width:var(--narrow)}
.prose h2{font-size:clamp(24px,3vw,32px);margin:44px 0 14px;letter-spacing:-.02em}
.prose h3{font-size:20px;margin:32px 0 10px}
.prose p{margin:0 0 18px;color:var(--ink)}
.prose p,.prose li{color:#24262E}
.prose a{color:var(--red);font-weight:600;text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.prose a:hover{color:var(--red-2)}
.prose ul,.prose ol{margin:0 0 20px;padding-left:22px}
.prose li{margin:0 0 9px}
.prose strong{font-weight:700}
.prose blockquote{margin:24px 0;padding:16px 22px;border-left:3px solid var(--red);background:var(--bg2);border-radius:0 10px 10px 0;color:var(--ink-2);font-size:16px}
.prose img{border-radius:12px;border:1px solid var(--line);margin:24px 0}
.prose figure{margin:26px 0}
.prose figcaption{font-size:13px;color:var(--ink-3);margin-top:9px;text-align:center}
.prose hr{border:0;border-top:1px solid var(--line);margin:36px 0}

/* ---- table of contents ---- */
.toc{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin:0 auto 34px;max-width:var(--narrow)}
.toc h2{font-size:13px!important;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin:0 0 12px!important}
.toc ol{margin:0;padding-left:20px;columns:2;column-gap:28px}
.toc li{margin:0 0 8px;font-size:14.5px}
.toc a{color:var(--ink-2);font-weight:600;text-decoration:none}
.toc a:hover{color:var(--red)}
@media(max-width:560px){.toc ol{columns:1}}

/* ---- lead figure (hero image above the TOC) ---- */
.lead-fig{max-width:var(--narrow);margin:4px auto 22px}
.lead-fig img{width:100%;border-radius:14px;border:1px solid var(--line);display:block}
.lead-fig figcaption{font-size:13px;color:var(--ink-3);margin-top:10px;text-align:center;line-height:1.5}

/* ---- callout / note boxes ---- */
.callout{border:1px solid var(--line);border-radius:14px;padding:20px 24px;margin:26px auto;max-width:var(--narrow);background:var(--bg2);font-size:15.5px;line-height:1.6}
.callout.tip{border-color:var(--red-line);background:var(--red-soft)}
.callout.warn{border-color:#F6C9CF;background:#FFF4F5}
.callout h4{font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.callout p{margin:0}
.callout p + p{margin-top:10px}

/* key-facts / spec table ---- */
.specs{width:100%;border-collapse:collapse;margin:24px auto;max-width:var(--narrow);font-size:15px}
.specs td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.specs tr td:first-child{font-weight:700;width:38%;color:var(--ink-2)}
.specs tr:last-child td{border-bottom:0}

/* ---- FAQ (native details) ---- */
.faq-list{max-width:var(--narrow);margin:34px auto 0;display:grid;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);transition:border-color .2s}
.faq-item[open]{border-color:var(--red-line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;cursor:pointer;font-weight:700;font-size:17px;list-style:none}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{content:"+";font-size:22px;color:var(--red);transition:transform .2s}
.faq-item[open] .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:0 24px 22px;color:var(--ink-2);font-size:15.5px;line-height:1.65}
.faq-a a{color:var(--red);font-weight:600}

/* ---- author box (E-E-A-T) ---- */
.author-box{display:flex;gap:18px;align-items:flex-start;max-width:var(--narrow);margin:44px auto 0;padding:24px;background:var(--bg2);border:1px solid var(--line);border-radius:16px}
.author-av{width:56px;height:56px;border-radius:12px;background:linear-gradient(180deg,#EE1B2E,#B00016);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;color:#fff;flex-shrink:0;box-shadow:0 6px 16px rgba(225,14,33,.3)}
.author-box h4{font-size:16px;margin-bottom:2px}
.author-role{font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.author-box p{font-size:14px;color:var(--ink-2);line-height:1.55;margin:0}
.author-box a{color:var(--red);font-weight:600}

/* ---- related / weiterlesen ---- */
.related{max-width:var(--narrow);margin:40px auto 0}
.related h3{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.related-list{display:grid;gap:10px}
.related-list a{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:14px 18px;background:#fff;border:1px solid var(--line);border-radius:11px;font-weight:600;font-size:15px;transition:all .18s;box-shadow:var(--shadow)}
.related-list a:hover{border-color:var(--red-line);color:var(--red);transform:translateY(-1px)}
.related-list a::after{content:"→";color:var(--red)}

/* ---- inline funnel card (editorial → bonusradar / casino-vergleich) ---- */
.funnel{max-width:var(--narrow);margin:30px auto;padding:24px 26px;border:1px solid var(--red-line);border-radius:16px;background:linear-gradient(180deg,var(--red-soft),#fff 60%)}
.funnel h4{font-size:18px;margin-bottom:8px}
.funnel p{font-size:14.5px;color:var(--ink-2);margin-bottom:16px}

/* ---- responsible-gambling box (dark, serious) ---- */
.rg{background:var(--ink);color:#fff}
.rg-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
@media(max-width:820px){.rg-inner{grid-template-columns:1fr;gap:28px}}
.rg .eyebrow{color:#FF8A96}.rg .eyebrow::before{background:#FF8A96}
.rg h2{font-size:clamp(24px,3vw,32px);color:#fff}
.rg p{color:rgba(255,255,255,.78);font-size:15.5px;margin-top:14px;line-height:1.6}
.rg-box{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:26px}
.rg-box h3{font-size:14px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#FF8A96;margin-bottom:16px}
.rg-line{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.rg-line:last-child{border-bottom:0}
.rg-line span{font-size:14px;color:rgba(255,255,255,.8)}
.rg-line b{font-size:15px;color:#fff;white-space:nowrap}

/* ---- toplist rows (casino-vergleich) ---- */
.bk-list{display:grid;gap:14px}
.bk-row{display:grid;grid-template-columns:44px 128px 1.1fr .9fr auto;align-items:center;gap:22px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 24px;transition:all .2s;position:relative;box-shadow:var(--shadow)}
.bk-row:hover{border-color:var(--red-line);transform:translateY(-2px);box-shadow:var(--shadow-2)}
.bk-row.is-top{border-color:var(--red-line);background:linear-gradient(180deg,var(--red-soft),#fff 40%)}
.bk-row.is-top::after{content:"";position:absolute;left:0;top:14px;bottom:14px;width:4px;border-radius:0 4px 4px 0;background:linear-gradient(180deg,#F5203A,#B00016)}
.bk-badge{position:absolute;top:-10px;left:22px;background:var(--red);color:#fff;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:4px 11px;border-radius:6px}
.bk-rank{font-weight:800;font-size:30px;color:var(--red);text-align:center;line-height:1}
.bk-logo{height:56px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:var(--ink);padding:6px 12px;text-align:center}
.bk-logo img{max-height:44px;max-width:100%;object-fit:contain;display:block}
.bk-info .bk-name{font-weight:800;font-size:20px}
.bk-info .bk-tag{font-size:12.5px;color:var(--ink-3);margin-top:3px}
.bk-caveat{font-size:12.5px;color:var(--ink-2);margin-top:8px;line-height:1.45}
.bk-caveat b{color:var(--red-2)}
.bk-bonus{font-size:14px;color:var(--ink-2);font-weight:600}
.bk-bonus b{display:block;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;margin-bottom:4px;color:var(--ink-3)}
.bk-right{display:flex;align-items:center;gap:20px}
.bk-score{text-align:center;background:var(--red-soft);border:1px solid var(--red-line);border-radius:12px;padding:9px 13px;min-width:66px}
.bk-score-num{font-weight:800;font-size:26px;color:var(--ink);line-height:1}
.bk-score-num small{font-size:12px;color:var(--ink-3);font-weight:500}
.bk-score-lbl{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-top:5px}
.bk-stars{display:flex;gap:2px;justify-content:center;margin-top:6px;font-size:11px;letter-spacing:1.5px;color:#F5203A;line-height:1}
.bk-stars .off{color:#E2D7D9}
.bk-cta-col{display:flex;flex-direction:column;gap:6px;min-width:150px}
.bk-cta{background:linear-gradient(180deg,#F5203A,#C10018);color:#fff;text-align:center;padding:12px 16px;border-radius:9px;font-weight:700;font-size:13px;transition:all .2s;text-transform:uppercase;letter-spacing:.03em}
.bk-cta:hover{transform:translateY(-1px)}
.bk-test{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);text-align:center}
.bk-test:hover{color:var(--red)}
@media(max-width:1000px){.bk-row{grid-template-columns:38px 100px 1fr auto;gap:14px}.bk-bonus{display:none}}
@media(max-width:680px){
  .bk-row{grid-template-columns:26px 46px 1fr auto;padding:14px 12px;gap:9px}
  .bk-logo{display:flex;height:38px;padding:4px}
  .bk-right{flex-direction:column;gap:7px;align-items:stretch}
  .bk-score{min-width:0;padding:5px 8px}
  .bk-score-num{font-size:19px}
  .bk-cta-col{min-width:104px}
  .bk-info .bk-name{font-size:15px}
}

/* ---- footer ---- */
.footer{background:var(--bg2);border-top:1px solid var(--line);padding:56px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;margin-bottom:38px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-col h4{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:16px}
.foot-col a{display:block;color:var(--ink-2);font-size:14px;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:var(--red)}
.foot-about p{color:var(--ink-3);font-size:13.5px;line-height:1.6;margin-top:14px;max-width:340px}
.foot-disclosure{border-top:1px solid var(--line);padding-top:24px;font-size:12px;color:var(--ink-3);line-height:1.7}
.foot-disclosure b{color:var(--ink-2)}
.foot-legal{margin-top:16px;display:flex;gap:18px;flex-wrap:wrap;font-size:12.5px;font-weight:600}
.foot-legal a{color:var(--ink-3)}.foot-legal a:hover{color:var(--red)}
.age-badge{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:2px solid var(--red);color:var(--red);font-weight:800;font-size:13px;margin-right:10px;vertical-align:middle}

/* ---- inline Top-3 CTA (content pages) ---- */
.kz-cta{max-width:var(--narrow);margin:38px auto;border:1px solid var(--red-line);border-radius:16px;background:linear-gradient(180deg,var(--red-soft),#fff 55%);padding:22px 24px;box-shadow:var(--shadow)}
.kz-cta-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.kz-cta-head h3{font-size:19px}
.kz-cta-head .lbl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.kz-cta-list{display:grid;gap:10px}
.kz-cta-row{display:grid;grid-template-columns:24px 88px 1fr auto;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 14px;box-shadow:var(--shadow)}
.kz-cta-rank{font-weight:800;font-size:18px;color:var(--red);text-align:center}
.kz-cta-logo{height:38px;background:var(--bg2);border:1px solid var(--line);border-radius:8px;display:flex;align-items:center;justify-content:center;padding:4px}
.kz-cta-logo img{max-height:30px;max-width:100%;object-fit:contain}
.kz-cta-name{font-weight:700;font-size:15px}
.kz-cta-name small{display:block;font-weight:500;color:var(--ink-3);font-size:12px;margin-top:1px}
.kz-cta-btn{background:linear-gradient(180deg,#F5203A,#C10018);color:#fff;padding:10px 16px;border-radius:9px;font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;box-shadow:0 8px 18px -8px rgba(225,14,33,.5)}
.kz-cta-btn:hover{filter:brightness(1.05)}
.kz-cta-foot{margin-top:14px;font-size:11.5px;color:var(--ink-3);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:center;line-height:1.5}
.kz-cta-foot a{color:var(--red);font-weight:700;white-space:nowrap}
@media(max-width:560px){.kz-cta-row{grid-template-columns:20px 40px 1fr auto;gap:9px}.kz-cta-logo{display:flex;height:30px}.kz-cta-name{font-size:14px}}

/* ---- a11y ---- */
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--red);outline-offset:3px;border-radius:8px}
