*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:rgba(34,211,238,.12)}
body{font-family:"DM Sans",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;font-size:1rem;line-height:1.6;color:#e2e8f0;background:linear-gradient(180deg,#0b1220 0%,#111b2e 50%,#0b1220 100%);overflow-x:hidden;padding-bottom:env(safe-area-inset-bottom,0);min-height:100vh}
img{max-width:100%;height:auto;display:block}
a{color:#22d3ee;text-decoration:none}
a:hover{color:#67e8f9}
.container{width:min(100% - 2rem,72rem);margin-inline:auto}
.section{padding:3.5rem 0}
.section h2{font-size:clamp(1.5rem,4vw,2rem);color:#f8fafc;text-align:center;margin-bottom:.75rem;font-weight:700;letter-spacing:-.02em}
.section__lead{text-align:center;color:#94a3b8;max-width:48rem;margin:0 auto 2rem;font-size:clamp(.95rem,2.5vw,1.05rem)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.875rem 1.75rem;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#0b1220;background:linear-gradient(135deg,#22d3ee,#0ea5e9);border:none;border-radius:.75rem;box-shadow:0 4px 24px rgba(34,211,238,.35);transition:transform .2s,box-shadow .2s,filter .2s;min-height:52px;cursor:pointer;text-align:center;touch-action:manipulation;-webkit-user-select:none;user-select:none}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(34,211,238,.5);filter:brightness(1.06);color:#0b1220}
.btn:active{transform:scale(.98);filter:brightness(.95)}
.btn--xl{font-size:clamp(1rem,2.5vw,1.125rem);padding:1rem 2.5rem;width:100%;max-width:22rem}
.btn--card{width:100%;font-size:1.05rem;padding:1rem 1.5rem;margin-top:auto;border-radius:.625rem}
.header{position:sticky;top:0;z-index:200;background:rgba(11,18,32,.96);backdrop-filter:blur(12px);border-bottom:1px solid rgba(34,211,238,.15);padding-top:env(safe-area-inset-top,0)}
.header__inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:.875rem 0}
.logo{font-size:clamp(1.05rem,2.5vw,1.35rem);font-weight:800;color:#f8fafc;line-height:1.2;cursor:default;user-select:none;justify-self:start;letter-spacing:-.03em}
.logo em{font-style:normal;color:#22d3ee;font-weight:700}
.nav-toggle{display:none}
.nav-toggle-label{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;min-width:48px;min-height:48px;align-items:center;justify-content:center;touch-action:manipulation;border-radius:.5rem}
.nav-toggle-label span{width:22px;height:2px;background:#22d3ee;border-radius:2px;pointer-events:none;transition:transform .2s,opacity .2s}
.nav{justify-self:center}
.nav__list{display:flex;gap:clamp(.75rem,2vw,1.5rem);list-style:none;flex-wrap:wrap;justify-content:center}
.nav__list a{color:#cbd5e1;font-weight:500;font-size:.9rem;padding:.25rem 0;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.nav__list a:hover{color:#22d3ee;border-bottom-color:rgba(34,211,238,.5)}
.btn--header{justify-self:end;flex-shrink:0;font-size:.85rem;padding:.7rem 1.35rem;white-space:nowrap;border-radius:.625rem}
.hero{position:relative;min-height:clamp(280px,42vh,460px);display:flex;align-items:center;padding:3rem 0;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,18,32,.82) 0%,rgba(17,27,46,.88) 55%,rgba(11,18,32,.92) 100%),url("images/hero.webp") center/cover no-repeat;z-index:0}
.hero__content{position:relative;z-index:1;text-align:center;max-width:52rem;margin-inline:auto}
.hero h2{font-size:clamp(1.65rem,5vw,2.5rem);line-height:1.15;color:#f8fafc;margin-bottom:1rem;text-shadow:0 2px 20px rgba(0,0,0,.5);font-weight:700;letter-spacing:-.02em}
.hero__subtitle{font-size:clamp(1rem,2.5vw,1.12rem);color:#94a3b8;margin-bottom:2rem;max-width:40rem;margin-inline:auto}
.hero__badges{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:1.75rem}
.hero__badge{background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.28);color:#67e8f9;padding:.35rem .85rem;border-radius:999px;font-size:.78rem;font-weight:600;letter-spacing:.03em}
.casinos{background:linear-gradient(180deg,#0b1220 0%,#0f1729 100%)}
.casinos--first{padding-top:1rem;padding-bottom:2rem}
.casinos__head{margin-bottom:1.25rem;text-align:center}
.casinos--first h1{font-size:clamp(1.35rem,4vw,1.9rem);color:#f8fafc;margin-bottom:.5rem;line-height:1.2;font-weight:800;letter-spacing:-.02em}
.casinos__lead{margin-bottom:0;font-size:clamp(.85rem,2.5vw,.95rem);max-width:36rem;margin-inline:auto;color:#94a3b8}
.casinos__scroll-wrap{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scroll-padding-inline:1rem;overscroll-behavior-x:contain;scrollbar-width:thin;scrollbar-color:rgba(34,211,238,.35) transparent;padding:.25rem 0 1rem}
.casinos__scroll-wrap::-webkit-scrollbar{height:5px}
.casinos__scroll-wrap::-webkit-scrollbar-thumb{background:rgba(34,211,238,.4);border-radius:4px}
.casinos__grid{display:flex;flex-direction:row;gap:1rem;padding:0 max(1rem,calc((100% - 72rem)/2 + 1rem));width:max-content;min-width:100%}
.casino-card{flex:0 0 clamp(268px,78vw,310px);scroll-snap-align:center;scroll-snap-stop:always;display:flex;flex-direction:column;background:linear-gradient(160deg,#141e33 0%,#1a2744 100%);border-radius:1.25rem;overflow:hidden;border:1px solid rgba(34,211,238,.18);box-shadow:0 12px 40px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.04);transition:transform .2s,box-shadow .2s,border-color .2s}
.casino-card:hover{transform:translateY(-4px);box-shadow:0 18px 48px rgba(14,165,233,.15);border-color:rgba(34,211,238,.35)}
.casino-card--featured{border-color:rgba(34,211,238,.4);box-shadow:0 14px 44px rgba(34,211,238,.12)}
.casino-card__rank{position:absolute;top:.75rem;left:.75rem;background:linear-gradient(135deg,#22d3ee,#0ea5e9);color:#0b1220;font-weight:800;font-size:.8rem;padding:.3rem .7rem;border-radius:.5rem;z-index:2;pointer-events:none;letter-spacing:.02em}
.casino-card__img-wrap{position:relative;flex-shrink:0;overflow:hidden;background:#0b1220;aspect-ratio:16/10}
.casino-card__img-link{display:block;line-height:0;cursor:pointer;touch-action:manipulation;height:100%}
.casino-card__img-link:focus-visible{outline:2px solid #22d3ee;outline-offset:2px}
.casino-card__img-link:hover .casino-card__img{transform:scale(1.03)}
.casino-card__img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .25s ease}
.casino-card__body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.65rem;flex:1}
.casino-card__header{display:flex;flex-direction:column;gap:.3rem}
.casino-card__name{font-size:1.12rem;color:#f8fafc;font-weight:800;line-height:1.2}
.casino-card__bonus{font-size:.92rem;color:#22d3ee;font-weight:700;line-height:1.35}
.casino-card__features{list-style:none;display:flex;flex-direction:column;gap:.4rem;flex:1}
.casino-card__features li{color:#94a3b8;font-size:.82rem;padding-left:1.15rem;position:relative;line-height:1.4}
.casino-card__features li::before{content:"";position:absolute;left:0;top:.45em;width:.45rem;height:.45rem;border-radius:50%;background:#22d3ee;opacity:.85}
.casinos__hint{text-align:center;color:#64748b;font-size:.75rem;margin-top:.35rem;padding:0 1rem}
.vergleich{background:linear-gradient(180deg,#0f1729 0%,#0b1220 100%)}
.vergleich__text{max-width:48rem;margin:0 auto;color:#94a3b8;font-size:clamp(.95rem,2.5vw,1.05rem)}
.vergleich__text p{margin-bottom:1rem}
.vergleich__text strong{color:#e2e8f0;font-weight:600}
.vorteile{background:#0f1729}
.vorteile__grid{display:grid;grid-template-columns:1fr;gap:1.25rem;list-style:none}
.vorteil{text-align:center;padding:1.75rem 1.25rem;background:linear-gradient(145deg,#141e33,#1a2744);border-radius:1rem;border:1px solid rgba(34,211,238,.12);transition:border-color .2s}
.vorteil:hover{border-color:rgba(34,211,238,.28)}
.vorteil__icon{font-size:2rem;display:block;margin-bottom:.65rem;line-height:1}
.vorteil h3{font-size:1.05rem;color:#f8fafc;margin-bottom:.45rem;font-weight:700}
.vorteil p{color:#94a3b8;font-size:.9rem}
.faq{background:#0b1220}
.faq__list{max-width:48rem;margin:0 auto;display:flex;flex-direction:column;gap:1rem}
.faq__item{padding:1.25rem 1.5rem;background:#141e33;border-radius:.875rem;border:1px solid rgba(34,211,238,.1);border-left:3px solid #22d3ee}
.faq__item h3{font-size:1.05rem;color:#22d3ee;margin-bottom:.5rem;line-height:1.35;font-weight:700}
.faq__item p{color:#94a3b8;font-size:.95rem}
.responsible{background:#0f1729;border-top:1px solid rgba(34,211,238,.1);border-bottom:1px solid rgba(34,211,238,.1)}
.responsible__inner{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;max-width:42rem;margin:0 auto;padding:2.5rem 0}
.responsible__badge{display:inline-flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;border-radius:50%;background:rgba(34,211,238,.12);border:2px solid #22d3ee;color:#22d3ee;font-weight:800;font-size:1.1rem;flex-shrink:0}
.responsible__text{color:#94a3b8;font-size:.95rem;padding:0 1rem}
.responsible__links{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 1.5rem;font-size:.9rem}
.responsible__links a{padding:.35rem .5rem;min-height:48px;display:inline-flex;align-items:center}
.footer{background:#080f1a;border-top:1px solid rgba(34,211,238,.12);padding:2.5rem 0 5rem;text-align:center}
.footer__inner{display:flex;flex-direction:column;align-items:center;gap:.85rem;padding:0 1rem}
.footer__copy,.footer__domain,.footer__disclaimer,.footer__age{color:#64748b;font-size:.85rem;max-width:40rem}
.footer__domain{color:#22d3ee;font-weight:600;word-break:break-word}
.footer__disclaimer{font-style:italic;color:#64748b}
.footer__age strong{color:#67e8f9}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:300;padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0));padding-left:max(1rem,env(safe-area-inset-left,0));padding-right:max(1rem,env(safe-area-inset-right,0));background:rgba(11,18,32,.97);backdrop-filter:blur(12px);border-top:1px solid rgba(34,211,238,.2);transform:translateY(100%);transition:transform .3s ease;box-shadow:0 -8px 32px rgba(0,0,0,.45)}
.sticky-cta.is-visible{transform:translateY(0)}
.sticky-cta .btn{width:100%;max-width:28rem;margin:0 auto;font-size:1.05rem;min-height:56px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

@media(min-width:640px){
  .vorteile__grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:768px){
  .casino-card{flex:0 0 clamp(248px,32vw,288px);scroll-snap-align:start}
}
@media(min-width:960px){
  .vorteile__grid{grid-template-columns:repeat(4,1fr)}
}
@media(min-width:1024px){
  .sticky-cta{display:none}
}
@media(min-width:1200px){
  .casinos__scroll-wrap{overflow-x:visible}
  .casinos__grid{width:100%;max-width:72rem;margin:0 auto;padding:0 1rem;justify-content:center;flex-wrap:nowrap}
  .casino-card{flex:1 1 0;min-width:0;max-width:none}
  .casinos__hint{display:none}
}

@media(max-width:1023px){
  .header__inner{display:flex;flex-wrap:wrap;position:relative}
  .logo{order:1;flex:1}
  .nav-toggle-label{display:flex;order:2;margin-left:auto}
  .btn--header{order:4;width:100%;min-height:48px}
  .nav{order:3;width:100%;justify-self:stretch}
  .nav__list{flex-direction:column;padding:.5rem 0 1rem;gap:0;width:100%}
  .nav__list a{display:flex;align-items:center;min-height:48px;padding:.5rem 0;font-size:1rem;border-bottom:none}
  .nav{position:absolute;top:100%;left:0;right:0;background:rgba(11,18,32,.98);border-bottom:1px solid rgba(34,211,238,.12);max-height:0;overflow:hidden;transition:max-height .3s ease}
  .nav-toggle:checked~.nav{max-height:20rem}
  .nav-toggle:checked+.nav-toggle-label span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked+.nav-toggle-label span:nth-child(2){opacity:0}
  .nav-toggle:checked+.nav-toggle-label span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

@media(max-width:767px){
  .container{width:min(100% - 1.25rem,72rem)}
  .section{padding:2rem 0}
  .section__lead{margin-bottom:1.5rem}
  .header__inner{padding:.5rem 0;gap:.5rem}
  .casinos--first{padding-top:.5rem;padding-bottom:1.5rem}
  .casinos__head{margin-bottom:1rem;padding:0 .25rem}
  .casinos--first h1{font-size:1.25rem}
  .casinos__lead{font-size:.8125rem;line-height:1.45}
  .casinos__scroll-wrap{scroll-padding-inline:max(.625rem,env(safe-area-inset-left,0))}
  .casinos__grid{gap:.875rem;padding-inline:max(.625rem,env(safe-area-inset-left,0)) max(.625rem,env(safe-area-inset-right,0))}
  .casino-card{flex:0 0 min(88vw,320px)}
  .casino-card__body{padding:1rem}
  .btn--card{min-height:56px;font-size:1.0625rem;padding:1.125rem 1rem}
  .hero{min-height:auto;padding:2rem 0}
  .hero h2{font-size:1.375rem}
  .hero__subtitle{font-size:.9375rem;margin-bottom:1.5rem}
  .btn--xl{max-width:none;min-height:56px}
  .footer{padding-bottom:calc(5.75rem + env(safe-area-inset-bottom,0))}
  .sticky-cta{transform:translateY(0)}
  .sticky-cta .btn{max-width:none}
  .sticky-cta.is-visible{transform:translateY(0)}
}

@media(hover:none){
  .casino-card:hover{transform:none;box-shadow:0 12px 40px rgba(0,0,0,.35)}
  .btn:hover{transform:none}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .casino-card,.btn,.casino-card__img{transition:none}
}
