@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@600;700;800;900&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#06070d;--bg-2:#0a0c16;--bg-3:#0f1322;
  --cyan:#22f0ff;--cyan-deep:#00d6e6;--magenta:#ff3ddb;--violet:#7b5cff;
  --ink:#f0f3ff;--ink-2:#c7cef0;--ink-3:#9aa2c6;
  --line:rgba(120,200,255,.16);--line-2:rgba(255,255,255,.07);
  --surface:rgba(16,20,34,.7);--surface-2:rgba(20,25,42,.55);
  --d:'Orbitron',sans-serif;--b:'Inter',system-ui,sans-serif;
  --maxw:1240px;--ease:cubic-bezier(.22,1,.36,1);--ease-expo:cubic-bezier(.16,1,.3,1);
  --z-bg:-1;--z-sticky:80;--z-nav:100;--z-menu:120;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:88px;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{background:var(--bg);color:var(--ink);font-family:var(--b);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;cursor:pointer}
h1,h2,h3,h4,.ctitle,.h2{overflow-wrap:break-word;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto}
::selection{background:rgba(34,240,255,.28);color:#fff}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,40px)}
.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--cyan);color:#04050a;padding:12px 20px;font-weight:700;border-radius:0 0 8px 0}
.skip:focus{left:0}

/* ambient */
.amb{position:fixed;inset:0;z-index:var(--z-bg);pointer-events:none;overflow:hidden}
.amb .glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5}
.amb .g1{top:-12%;left:50%;width:780px;height:560px;transform:translateX(-50%);background:radial-gradient(circle,rgba(123,92,255,.5),transparent 65%)}
.amb .g2{bottom:-10%;right:-6%;width:620px;height:520px;background:radial-gradient(circle,rgba(255,61,219,.32),transparent 65%)}
.amb .g3{bottom:6%;left:-8%;width:600px;height:500px;background:radial-gradient(circle,rgba(34,240,255,.28),transparent 65%)}
.grain{position:fixed;inset:0;z-index:var(--z-bg);pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E")}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,4vw,40px);transition:padding .4s var(--ease),background .4s,border-color .4s;border-bottom:1px solid transparent}
nav.solid{border-color:var(--line);padding-top:12px;padding-bottom:12px}
/* Blur auf Pseudo-Element statt auf nav selbst -> nav wird KEIN Containing-Block fürs fixe Menü-Panel (verhindert das ruckartige Aufklappen) */
nav.solid::before{content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;background:rgba(6,7,13,.72);-webkit-backdrop-filter:blur(18px) saturate(1.2);backdrop-filter:blur(18px) saturate(1.2)}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--d);font-weight:800;font-size:18px;letter-spacing:2px}
.brand .mark{height:26px;width:auto;filter:drop-shadow(0 0 8px rgba(34,240,255,.55))}
.brand i{font-style:normal;color:var(--cyan)}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{position:relative;font-size:13px;color:var(--ink-2);font-weight:600;letter-spacing:.6px;text-transform:uppercase;padding:9px 14px;border-radius:8px;transition:color .25s}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;left:14px;right:14px;bottom:5px;height:1.5px;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);box-shadow:0 0 8px var(--cyan)}
.nav-links a:not(.nav-cta):hover{color:var(--ink)}
.nav-links a:not(.nav-cta):hover::after{transform:scaleX(1)}
.nav-cta{margin-left:10px;padding:11px 20px!important;border-radius:9px;color:#04060c!important;font-weight:700;background:linear-gradient(118deg,var(--cyan),#9bf6ff);box-shadow:0 0 22px rgba(34,240,255,.4);transition:transform .3s var(--ease),box-shadow .3s}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(34,240,255,.65)}
.menu-btn{display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:10px;min-width:44px;min-height:44px;background:none;border:0;z-index:var(--z-menu)}
.menu-btn span{width:24px;height:2px;background:var(--cyan);border-radius:2px;transition:transform .35s var(--ease),opacity .25s}
.menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0}
.menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 30px;border-radius:11px;font-family:var(--d);font-weight:700;font-size:13.5px;letter-spacing:1px;text-transform:uppercase;border:1px solid transparent;
  transition:transform .35s var(--ease),box-shadow .35s,background .35s,border-color .35s,color .35s}
.btn svg{width:17px;height:17px}
.btn-primary{color:#04060c;background:linear-gradient(118deg,var(--cyan),#9bf6ff);box-shadow:0 0 30px rgba(34,240,255,.42)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 46px -6px rgba(34,240,255,.75)}
.btn-ghost{color:var(--ink);background:rgba(255,255,255,.03);border-color:var(--line)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--cyan);background:rgba(34,240,255,.06)}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* glitch helper */
.g{position:relative;display:inline-block}
.g::before,.g::after{content:attr(data-t);position:absolute;inset:0}
.g::before{color:var(--magenta);animation:gl1 4.2s infinite steps(1)}
.g::after{color:var(--cyan);animation:gl2 3.6s infinite steps(1)}
@keyframes gl1{0%,94%,100%{transform:translate(0);clip-path:inset(0);opacity:0}95%{transform:translate(-3px,1px);clip-path:inset(0 0 62% 0);opacity:.9}97%{transform:translate(2px,-2px);clip-path:inset(40% 0 20% 0);opacity:.85}99%{transform:translate(-1px,1px);clip-path:inset(70% 0 0 0);opacity:.8}}
@keyframes gl2{0%,93%,100%{transform:translate(0);clip-path:inset(0);opacity:0}94%{transform:translate(3px,-1px);clip-path:inset(0 0 55% 0);opacity:.9}96%{transform:translate(-2px,2px);clip-path:inset(55% 0 18% 0);opacity:.85}98%{transform:translate(1px,-1px);clip-path:inset(80% 0 0 0);opacity:.8}}

/* section bits */
section{position:relative}
.sec{padding:clamp(72px,11vw,128px) 0}
.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--d);font-weight:700;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--cyan)}
.kicker::before{content:'';width:26px;height:2px;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.h2{font-family:var(--d);font-weight:800;font-size:clamp(30px,5.2vw,58px);line-height:1.04;letter-spacing:.5px;text-wrap:balance}
.h2 em{font-style:normal;color:var(--cyan)}
.lead{color:var(--ink-2);font-size:clamp(15px,1.7vw,18.5px);max-width:60ch;margin-top:18px;text-wrap:pretty}
.sec-head{max-width:760px}

/* ============ category hero ============ */
.chero{position:relative;min-height:90vh;display:flex;align-items:flex-end;overflow:hidden;padding:140px 0 64px}
.chero-bg{position:absolute;inset:0;z-index:-2}
.chero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.05)}
.chero::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(6,7,13,.5) 0%,rgba(6,7,13,.4) 38%,rgba(6,7,13,.97) 100%)}
.chero .wrap{width:100%}
.back{display:inline-flex;align-items:center;gap:9px;font-family:var(--d);font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--cyan);margin-bottom:24px}
.back svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.back:hover svg{transform:translateX(-4px)}
.chero .label{display:inline-flex;align-items:center;gap:10px;font-family:var(--d);font-weight:700;font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--cyan);margin-bottom:16px}
.chero .label::before{content:'';width:26px;height:2px;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.ctitle{font-family:var(--d);font-weight:900;font-size:clamp(58px,14vw,158px);line-height:.88;letter-spacing:1px;color:var(--ink);position:relative;display:inline-block;text-shadow:0 0 34px rgba(34,240,255,.22)}
.chero p{color:var(--ink-2);font-size:clamp(16px,2vw,20px);max-width:62ch;margin-top:22px;line-height:1.6;text-shadow:0 1px 12px rgba(0,0,0,.5)}
.specs{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.specs span{font-family:var(--d);font-size:11.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan);padding:9px 15px;border:1px solid var(--line);border-radius:100px;background:rgba(34,240,255,.06);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.chero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}

/* marquee */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);overflow:hidden;white-space:nowrap;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.track{display:inline-flex;padding:16px 0;animation:mq 30s linear infinite;font-family:var(--d);font-weight:700;font-size:13.5px;letter-spacing:2px;color:var(--ink-3);text-transform:uppercase}
.track span{display:inline-flex;align-items:center;gap:34px;padding-right:34px}
.track b{color:var(--cyan)}
@keyframes mq{to{transform:translateX(-50%)}}

/* ============ game feature rows ============ */
.games{margin-top:clamp(48px,7vw,80px);display:flex;flex-direction:column;gap:clamp(56px,9vw,112px)}
.game{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.game.flip .game-media{order:2}
.game-media{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;box-shadow:0 30px 70px -36px rgba(0,0,0,.95);isolation:isolate}
.game-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);transition:transform 1.1s var(--ease)}
.game:hover .game-media img{transform:scale(1.1)}
/* Diashow: direkte <img> in .game-media werden durchgeblendet */
.game-media > img{position:absolute;inset:0;z-index:1;opacity:0;transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.game-media > img.is-active{opacity:1}
.game:hover .game-media > img.is-active{transform:scale(1.1)}
.game-media::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,rgba(34,240,255,.12),transparent 46%,rgba(255,61,219,.14));pointer-events:none}
.game-media .num{position:absolute;top:18px;left:18px;z-index:2;font-family:var(--d);font-weight:900;font-size:17px;color:var(--ink);background:rgba(6,7,13,.6);border:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:46px;height:46px;border-radius:12px;display:grid;place-items:center}
.game-tag{font-family:var(--d);font-weight:600;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan)}
.game h3{font-family:var(--d);font-weight:900;font-size:clamp(30px,4.4vw,52px);letter-spacing:.5px;margin:10px 0 0;line-height:1;position:relative;display:inline-block}
.game:hover h3 .g::before{animation:hj1 2.6s infinite linear alternate-reverse}
.game:hover h3 .g::after{animation:hj2 2s infinite linear alternate-reverse}
@keyframes hj1{0%,92%{transform:translate(0);opacity:.55;clip-path:inset(0 0 55% 0)}94%{transform:translate(-3px,1px);opacity:.55}97%{transform:translate(2px,-1px);opacity:.55}100%{transform:translate(0);opacity:.55}}
@keyframes hj2{0%,92%{transform:translate(0);opacity:.55;clip-path:inset(55% 0 0 0)}94%{transform:translate(3px,-1px);opacity:.55}97%{transform:translate(-2px,1px);opacity:.55}100%{transform:translate(0);opacity:.55}}
.game p{color:var(--ink-2);font-size:clamp(15px,1.7vw,17px);line-height:1.65;margin-top:16px;max-width:52ch}
.feats{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px}
.feats b{font-family:var(--d);font-weight:600;font-size:12px;letter-spacing:.5px;color:var(--ink-2);padding:9px 14px;border:1px solid var(--line-2);border-radius:8px;background:var(--surface-2)}

/* placeholder / coming-soon game media */
.game-media.soon,.game-media.ph{display:grid;place-items:center;background:radial-gradient(120% 100% at 50% 0,rgba(34,240,255,.13),transparent 58%),linear-gradient(160deg,#0c1124,#070910)}
.game-media .soon-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(34,240,255,.09) 1px,transparent 1px),linear-gradient(90deg,rgba(34,240,255,.09) 1px,transparent 1px);background-size:40px 40px;-webkit-mask:radial-gradient(110% 82% at 50% 42%,#000,transparent 72%);mask:radial-gradient(110% 82% at 50% 42%,#000,transparent 72%)}
.game-media .soon-inner{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;padding:20px}
.game-media .soon-mark{width:clamp(86px,16vw,120px);height:auto;filter:drop-shadow(0 0 24px rgba(34,240,255,.55));opacity:.92;animation:floaty 5s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.game-media .soon-label{font-family:var(--d);font-weight:700;font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--ink-2)}
.soon-badge{position:absolute;top:18px;right:18px;z-index:2;font-family:var(--d);font-weight:700;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#04060c;background:linear-gradient(118deg,var(--cyan),#9bf6ff);padding:8px 13px;border-radius:100px;box-shadow:0 0 18px rgba(34,240,255,.45)}

/* ============ cta band ============ */
.cta-band{position:relative;border-radius:24px;overflow:hidden;padding:clamp(46px,7vw,80px) clamp(28px,7vw,8%);text-align:center;border:1px solid var(--line);
  background:radial-gradient(700px 360px at 50% -25%,rgba(34,240,255,.16),transparent 60%),linear-gradient(120deg,rgba(34,240,255,.08),rgba(123,92,255,.1),rgba(255,61,219,.08))}
.cta-band h2{font-family:var(--d);font-weight:900;font-size:clamp(28px,5vw,52px);line-height:1.04}
.cta-band h2 em{font-style:normal;color:var(--cyan)}
.cta-band p{color:var(--ink-2);font-size:clamp(15px,1.7vw,18px);max-width:52ch;margin:18px auto 32px}
.cta-band .phone{display:flex;justify-content:center;align-items:center;gap:9px;margin-top:26px;font-size:14px;color:var(--ink-3)}
.cta-band .phone a{color:var(--ink-2);font-weight:600}
.cta-band .phone a:hover{color:var(--cyan)}

/* footer */
footer{padding:clamp(60px,8vw,90px) 0 40px;border-top:1px solid var(--line);background:var(--bg-2)}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.foot .brand{font-size:20px;margin-bottom:16px}
.foot .addr{color:var(--ink-2);font-size:14.5px;line-height:1.8}
.foot .addr a:hover{color:var(--cyan)}
.foot-col h5{font-family:var(--d);font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--cyan);margin-bottom:16px}
.foot-col a{display:block;color:var(--ink-2);font-size:14.5px;margin-bottom:11px;transition:color .25s}
.foot-col a:hover{color:var(--ink)}
.copy{margin-top:54px;padding-top:24px;border-top:1px solid var(--line-2);display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;color:var(--ink-3);font-size:13px;letter-spacing:.4px}

/* mobile sticky book bar */
.bookbar{position:fixed;left:0;right:0;bottom:0;z-index:var(--z-sticky);display:none;align-items:center;justify-content:space-between;gap:14px;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:rgba(6,7,13,.92);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--line)}
.bookbar .t{font-size:13px;color:var(--ink-2);line-height:1.3}
.bookbar .t b{display:block;font-family:var(--d);font-size:14px;color:var(--ink);letter-spacing:.4px}
.bookbar .btn{padding:13px 22px;flex:0 0 auto}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease-expo),transform .8s var(--ease-expo)}
.reveal.in{opacity:1;transform:none}

/* ===== page hero (kontakt/events) ===== */
.chero.short{min-height:auto;padding:clamp(120px,16vw,156px) 0 clamp(34px,5vw,52px)}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(22px,4vw,44px);margin-top:clamp(40px,6vw,64px);align-items:start}
.cardx{border:1px solid var(--line);border-radius:20px;background:var(--surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:clamp(26px,4vw,40px)}
.cardx h3{font-family:var(--d);font-weight:800;font-size:22px;letter-spacing:.5px;margin-bottom:6px}
.info-list{display:flex;flex-direction:column;gap:20px;margin-top:18px}
.info-row{display:flex;gap:15px;align-items:flex-start}
.info-row .ico{flex:0 0 auto;width:44px;height:44px;border-radius:12px;display:grid;place-items:center;color:var(--cyan);background:rgba(34,240,255,.08);border:1px solid var(--line)}
.info-row .ico svg{width:20px;height:20px}
.info-row .it h4{font-family:var(--d);font-weight:700;font-size:11.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-3);margin-bottom:3px}
.info-row .it a,.info-row .it p{color:var(--ink);font-size:15.5px;font-weight:500}
.info-row .it a:hover{color:var(--cyan)}
.hours{margin-top:6px;display:grid;grid-template-columns:auto 1fr;gap:5px 20px;font-size:14.5px;color:var(--ink-2)}
.hours b{color:var(--ink);font-weight:600}
.hours-note{display:flex;gap:9px;align-items:flex-start;margin-top:14px;font-size:13px;color:var(--cyan);background:rgba(34,240,255,.06);border:1px solid var(--line);border-radius:10px;padding:11px 13px;line-height:1.5}
.hours-note svg{width:16px;height:16px;flex:0 0 auto;margin-top:1px}
.map-link{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-family:var(--d);font-weight:600;font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--cyan)}
.map-link svg{width:16px;height:16px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:15px}
.field label{font-family:var(--d);font-weight:600;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-3)}
.field input,.field textarea,.field select{font:inherit;color:var(--ink);background:rgba(8,11,20,.6);border:1px solid var(--line);border-radius:10px;padding:13px 15px;transition:border-color .25s,box-shadow .25s}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,240,255,.15)}
.field textarea{resize:vertical;min-height:118px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-note{font-size:12.5px;color:var(--ink-3);margin-top:8px}
.form-foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:6px}

/* ===== events occasion body button ===== */
.game .game-cta{margin-top:24px}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}.row2{grid-template-columns:1fr}}

/* ===== whatsapp button ===== */
.btn-wa{color:#06210f;background:linear-gradient(118deg,#25d366,#5bf08a);box-shadow:0 0 24px rgba(37,211,102,.32)}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 10px 40px -6px rgba(37,211,102,.6)}

/* ===== embedded map (tap = route) ===== */
.map{position:relative;display:block;border:1px solid var(--line);border-radius:18px;overflow:hidden;aspect-ratio:16/9;margin-top:clamp(36px,5vw,56px);box-shadow:0 30px 70px -40px rgba(0,0,0,.9);
  background:radial-gradient(120% 100% at 50% 0,rgba(34,240,255,.08),transparent 60%),linear-gradient(160deg,#0c1124,#070910)}
.map-fallback{position:absolute;inset:0;z-index:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;color:var(--ink-2);padding:20px}
.map-fallback svg{width:34px;height:34px;color:var(--cyan)}
.map-fallback b{font-family:var(--d);font-weight:700;font-size:15px;color:var(--ink)}
.map iframe{position:relative;z-index:1;width:100%;height:100%;border:0;pointer-events:none;filter:grayscale(.25) contrast(1.05) brightness(.92)}
.map .map-over{position:absolute;inset:0;z-index:2;display:flex;align-items:flex-end;padding:16px;background:linear-gradient(180deg,rgba(6,7,13,.05) 55%,rgba(6,7,13,.55))}
.map .map-cta{display:inline-flex;align-items:center;gap:8px;font-family:var(--d);font-weight:700;font-size:12.5px;letter-spacing:1px;text-transform:uppercase;color:#04060c;background:linear-gradient(118deg,var(--cyan),#9bf6ff);padding:11px 16px;border-radius:10px;box-shadow:0 6px 24px rgba(34,240,255,.4);transition:transform .3s var(--ease)}
.map:hover .map-cta{transform:translateY(-2px)}
.map .map-cta svg{width:16px;height:16px}

/* ===== events page (own look) ===== */
.ev-hero{position:relative;padding:clamp(122px,16vw,164px) 0 clamp(8px,2vw,20px);text-align:center}
.ev-hero .kicker{justify-content:center}
.ev-hero h1{font-family:var(--d);font-weight:900;font-size:clamp(38px,7vw,82px);line-height:1.02;letter-spacing:.5px;margin-top:16px;text-wrap:balance}
.ev-hero h1 em{font-style:normal;color:var(--cyan)}
.ev-hero p{color:var(--ink-2);font-size:clamp(16px,2vw,20px);max-width:62ch;margin:20px auto 0;text-wrap:pretty}
.pills{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:32px}
.pills a,.pills span{font-family:var(--d);font-weight:600;font-size:12.5px;letter-spacing:1px;text-transform:uppercase;color:var(--ink);padding:11px 18px;border:1px solid var(--line);border-radius:100px;background:var(--surface-2);transition:border-color .25s,color .25s,background .25s}
.pills a:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(34,240,255,.06)}
.ev-list{padding-top:clamp(36px,5vw,64px)}
.event{padding:clamp(40px,6vw,72px) 0;border-top:1px solid var(--line-2);scroll-margin-top:90px}
.ev-grid{display:grid;grid-template-columns:minmax(290px,370px) 1fr;gap:clamp(28px,5vw,58px);align-items:start}
.ev-summary{position:sticky;top:92px;border:1px solid var(--line);border-radius:20px;background:var(--surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:clamp(24px,3vw,32px)}
.ev-num{font-family:var(--d);font-weight:900;font-size:13px;color:var(--cyan);letter-spacing:2px}
.ev-summary h2{font-family:var(--d);font-weight:900;font-size:clamp(27px,4vw,38px);line-height:1.04;margin:8px 0 0}
.ev-sub{color:var(--ink-2);font-size:15px;margin-top:12px;line-height:1.55}
.ev-price{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin:22px 0 0}
.ev-price b{font-family:var(--d);font-weight:800;font-size:32px;color:var(--ink);line-height:1}
.ev-price .pp{font-family:var(--d);font-size:13px;color:var(--cyan)}
.ev-price small{width:100%;color:var(--ink-3);font-size:12.5px;margin-top:5px}
.ev-facts{list-style:none;margin:20px 0 0;display:flex;flex-direction:column;gap:13px}
.ev-facts li{display:flex;align-items:center;gap:11px;font-size:14.5px;color:var(--ink-2)}
.ev-facts li svg{width:17px;height:17px;color:var(--cyan);flex:0 0 auto}
.ev-cta{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.ev-cta .btn{width:100%;justify-content:center;padding:14px 22px}
.ev-detail .block + .block{margin-top:clamp(38px,5vw,56px)}
.ev-detail h3{font-family:var(--d);font-weight:800;font-size:14px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink);margin:0 0 20px;display:flex;align-items:center;gap:10px}
.ev-detail h3::before{content:'';width:22px;height:2px;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.checks{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:18px 32px}
.checks li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-2);font-size:15px;line-height:1.6}
.checks li svg{width:19px;height:19px;color:var(--cyan);flex:0 0 auto;margin-top:1px}
.steps{list-style:none;counter-reset:s;display:flex;flex-direction:column;gap:20px}
.steps li{counter-increment:s;display:flex;gap:16px;align-items:flex-start;color:var(--ink-2);font-size:14.5px;line-height:1.65}
.steps li::before{content:counter(s,decimal-leading-zero);font-family:var(--d);font-weight:800;font-size:13px;color:var(--cyan);background:rgba(34,240,255,.08);border:1px solid var(--line);width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:0 0 auto}
.steps li b{color:var(--ink);font-family:var(--d);font-weight:600;font-size:14px;display:block;margin-bottom:2px;letter-spacing:.3px}
.price-rows{display:flex;flex-direction:column;gap:9px}
.price-rows .pr{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:13px 16px;border:1px solid var(--line-2);border-radius:11px;background:var(--surface-2)}
.price-rows .pr span{color:var(--ink-2);font-size:14.5px}
.price-rows .pr b{font-family:var(--d);font-weight:700;color:var(--ink);font-size:15px;white-space:nowrap}
details.faq{border:1px solid var(--line-2);border-radius:12px;background:var(--surface-2);margin-top:11px;overflow:hidden}
details.faq summary{list-style:none;cursor:pointer;padding:15px 18px;font-family:var(--d);font-weight:600;font-size:14px;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:12px;transition:color .2s}
details.faq summary:hover{color:var(--cyan)}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:'+';font-family:var(--d);font-size:20px;color:var(--cyan);transition:transform .3s var(--ease)}
details.faq[open] summary::after{transform:rotate(45deg)}
details.faq .faq-body{padding:0 18px 16px;color:var(--ink-2);font-size:14.5px;line-height:1.65}
@media(max-width:860px){.ev-grid{grid-template-columns:1fr}.ev-summary{position:static}.checks{grid-template-columns:1fr}}

/* events detail hero (left) */
.ev-hero.detail{text-align:left;padding-bottom:clamp(6px,1.5vw,16px)}
.ev-hero.detail .kicker{justify-content:flex-start}
.ev-hero.detail h1{margin-top:14px}
.ev-hero.detail h1 em{font-style:normal;color:var(--cyan)}
.ev-hero.detail p{margin-left:0;margin-right:0;max-width:64ch;line-height:1.75}
.ev-hero .back{margin-bottom:22px}

/* events overview cards */
.ev-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:clamp(36px,5vw,56px)}
.ev-card{position:relative;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:18px;background:var(--surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:clamp(24px,3vw,30px);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.ev-card:hover{transform:translateY(-6px);border-color:var(--cyan);box-shadow:0 26px 60px -34px rgba(34,240,255,.5)}
.ev-card .ev-num{font-family:var(--d);font-weight:900;font-size:12px;letter-spacing:2px;color:var(--cyan)}
.ev-card h2{font-family:var(--d);font-weight:900;font-size:clamp(23px,3vw,29px);margin:10px 0 0;line-height:1.05}
.ev-card p{color:var(--ink-2);font-size:14.5px;line-height:1.6;margin-top:12px;flex:1}
.ev-card .price{font-family:var(--d);font-weight:800;font-size:17px;color:var(--ink);margin-top:18px}
.ev-card .price span{color:var(--cyan);font-size:13px;font-weight:600}
.ev-card .go{display:inline-flex;align-items:center;gap:9px;margin-top:16px;font-family:var(--d);font-weight:700;font-size:12.5px;letter-spacing:1px;text-transform:uppercase;color:var(--cyan)}
.ev-card .go svg{width:18px;height:18px;transition:transform .3s var(--ease)}
.ev-card:hover .go svg{transform:translateX(4px)}
@media(max-width:860px){.ev-cards{grid-template-columns:1fr}}
/* a touch more breathing room at phone edges */
@media(max-width:560px){.wrap{padding-left:24px;padding-right:24px}}

/* ===== booking embed (anny widget) ===== */
.booking-wrap{position:relative;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--surface);min-height:420px;max-width:640px;margin:clamp(28px,4vw,44px) auto 0;box-shadow:0 30px 70px -42px rgba(0,0,0,.9)}
.booking-wrap a-organization-page,.booking-wrap a-resource-page,.booking-wrap a-resource-booking-panel{position:relative;z-index:1;display:block;width:100%;min-height:420px}
.booking-wrap iframe{display:block;width:100%;min-height:420px;border:0}
.booking-fallback{position:absolute;inset:0;z-index:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:30px;color:var(--ink-2)}
.booking-fallback svg{width:42px;height:42px;color:var(--cyan)}
.booking-fallback b{font-family:var(--d);font-weight:700;font-size:17px;color:var(--ink)}
.booking-fallback span{font-size:14px;max-width:42ch}
.booking-note{display:flex;flex-wrap:wrap;gap:10px 24px;align-items:center;justify-content:center;margin-top:22px;color:var(--ink-3);font-size:14px}
.booking-note b{color:var(--ink);font-weight:600}
.booking-note a{color:var(--cyan);font-weight:600}

/* responsive */
@media(max-width:860px){
  .game{grid-template-columns:1fr;gap:24px}
  .game.flip .game-media{order:0}
  .foot{grid-template-columns:1fr 1fr}
}
/* Nav früher auf Hamburger umstellen – Desktop-Menü passt unter ~900px nicht mehr */
@media(max-width:900px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(82vw,330px);flex-direction:column;justify-content:center;align-items:flex-start;gap:8px;z-index:var(--z-menu);
    background:var(--bg);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .45s var(--ease-expo);padding:90px 32px;overflow-y:auto;will-change:transform}
  .nav-links.open{transform:none}
  .nav-links a{font-size:16px;width:100%}
  .nav-cta{margin-left:0;margin-top:10px}
  .menu-btn{display:flex}
  /* offenes Menü: Body-Scroll sperren; nav darf kein backdrop-filter haben (sonst wird es Containing-Block für das fixed Panel) */
  body.menu-open{overflow:hidden}
}
@media(max-width:760px){
  .foot-col a{padding:8px 0;margin-bottom:2px}
  .foot .addr a{display:inline-block;padding:3px 0}
  .bookbar{display:flex}
  body{padding-bottom:74px}
  .chero{min-height:78vh;padding-top:120px}
}
@media(max-width:430px){.foot{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
}
