.mzb-wrap{--bg:#091230;--cream:#EAF2FF;--gold:#3FD2FF;--coral:#2E6FE0;--mint:#23C7E6;--ink:#04122e;--line:rgba(234,242,255,.15);
  font-family:system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--cream);
  background:radial-gradient(800px 500px at 10% -10%,rgba(46,111,224,.3),transparent 60%),radial-gradient(700px 500px at 95% 5%,rgba(17,181,230,.22),transparent 55%),var(--bg);
  border-radius:18px;padding:18px;max-width:980px;margin:0 auto}
.mzb-wrap *{box-sizing:border-box}
.mzb-h{font-size:26px;font-weight:800;margin:0 0 4px}
.mzb-sub{opacity:.8;font-size:14px;margin:0 0 14px}
.mzb-btn{font-family:inherit;font-weight:800;font-size:16px;border:none;border-radius:12px;padding:13px 20px;cursor:pointer;color:#fff;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;line-height:1.15;text-align:center;
  background:linear-gradient(180deg,#56B4FF,#2E6FE0);box-shadow:0 8px 0 #173f8e}
.mzb-btn:active{transform:translateY(4px);box-shadow:0 4px 0 #173f8e}
.mzb-btn.alt{background:linear-gradient(180deg,#9BE9FF,#23C7E6);color:var(--ink);box-shadow:0 8px 0 #0f8197}
.mzb-btn.warn{background:rgba(255,255,255,.16);color:var(--cream);box-shadow:0 8px 0 rgba(0,0,0,.4)}
.mzb-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:12px 0}
.mzb-in{font-size:16px;padding:12px 14px;border-radius:11px;border:1px solid var(--line);background:rgba(0,0,0,.3);color:var(--cream);flex:1;min-width:160px}
.mzb-card{background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:16px;padding:16px;margin:14px 0}
.mzb-sec{padding:0}
.mzb-sec>summary.mzb-sum{list-style:none;cursor:pointer;font-weight:800;font-size:17px;padding:15px 16px;display:flex;align-items:center;justify-content:space-between}
.mzb-sec>summary.mzb-sum::-webkit-details-marker{display:none}
.mzb-sec>summary.mzb-sum::after{content:'▾';opacity:.6;font-size:14px;transition:transform .2s}
.mzb-sec[open]>summary.mzb-sum::after{transform:rotate(180deg)}
.mzb-sec>summary.mzb-sum:hover{background:rgba(255,255,255,.04)}
.mzb-sec>*:not(summary){margin-left:16px;margin-right:16px}
.mzb-sec>*:last-child{margin-bottom:16px}
.mzb-draw{font-size:21px;padding:18px 24px;width:100%;background:linear-gradient(180deg,#FFC23C,#FF7A59);color:#1a0d00;box-shadow:0 8px 0 #9c4a1f}
.mzb-draw:active{box-shadow:0 4px 0 #9c4a1f}
.mzb-loginbox{max-width:380px}
.mzb-loginbox label{display:block;font-weight:700;margin:12px 0 5px;font-size:14px}
.mzb-loginbox input[type=text],.mzb-loginbox input[type=password]{width:100%;font-size:16px;padding:12px 14px;border-radius:11px;border:1px solid var(--line);background:rgba(0,0,0,.3);color:var(--cream)}
.mzb-loginbox .login-remember{font-weight:400;margin-top:12px;opacity:.85}
.mzb-loginbox .login-remember input{margin-right:7px}
.mzb-loginbox .button,.mzb-loginbox input[type=submit]{margin-top:14px;font-weight:800;font-size:16px;border:none;border-radius:12px;padding:13px 22px;cursor:pointer;color:#fff;background:linear-gradient(180deg,#56B4FF,#2E6FE0);box-shadow:0 8px 0 #173f8e}
.mzb-loginbox .button:active{transform:translateY(4px);box-shadow:0 4px 0 #173f8e}
.mzb-wrap a{color:var(--gold)}
.mzb-code{font-size:40px;font-weight:900;letter-spacing:6px;color:var(--gold)}
.mzb-now{font-size:16px;background:rgba(63,210,255,.12);border:1px solid rgba(63,210,255,.4);border-radius:12px;padding:12px 14px;margin:10px 0}
.mzb-now b{color:var(--gold)}

/* bingo grid */
.mzb-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:12px}
.mzb-cell{min-height:64px;border:1.5px solid var(--line);border-radius:10px;background:rgba(255,255,255,.04);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:5px 4px;cursor:pointer;transition:transform .08s, background .15s;-webkit-tap-highlight-color:transparent;position:relative}
.mzb-cell[data-i]:active{transform:scale(.93)}
.mzb-cell .t{font-weight:800;font-size:12px;line-height:1.12;word-break:break-word;hyphens:auto;color:#fff}
.mzb-cell .a{font-size:10px;opacity:.85;margin-top:3px;line-height:1.1;word-break:break-word;color:#cfe0ff}
.mzb-cell.nope{animation:mzbshake .4s ease;border-color:#ff5050;background:rgba(255,80,80,.18)}
@keyframes mzbshake{10%,90%{transform:translateX(-2px)}30%,70%{transform:translateX(3px)}50%{transform:translateX(-3px)}}
.mzb-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);z-index:70;background:#0c1f4d;border:1px solid var(--line);color:#fff;font-weight:700;font-size:14px;padding:11px 16px;border-radius:12px;box-shadow:0 12px 30px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s}
.mzb-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.mzb-drawnlist{display:flex;flex-direction:column;gap:4px;max-height:240px;overflow:auto}
.mzb-drow{font-size:14px;padding:6px 8px;border-radius:8px;background:rgba(255,255,255,.05)}
.mzb-dn{display:inline-block;min-width:22px;font-weight:900;color:var(--gold)}
.mzb-wheelpop{animation:mzbwheelpop .8s ease}
.mzb-vcount{position:absolute;inset:0;z-index:5;display:none;align-items:center;justify-content:center;background:rgba(4,12,30,.92);color:var(--gold);font-family:Anton,sans-serif;font-size:30vh;line-height:1;font-weight:900;text-shadow:0 6px 30px rgba(0,0,0,.6);animation:mzbcount .9s ease infinite}
@keyframes mzbcount{0%{transform:scale(.7);opacity:.4}40%{transform:scale(1.1);opacity:1}100%{transform:scale(1);opacity:.9}}
.mzb-chorusbig{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:linear-gradient(135deg,#3a2a00,#6b4e00);border:2px solid var(--gold);border-radius:14px;padding:10px 20px;font-size:15px;font-weight:800;color:#ffe6a3;text-transform:uppercase;letter-spacing:.5px;min-width:130px}
.mzb-chorusbig b{font-size:30px;color:var(--gold);line-height:1}
@keyframes mzbwheelpop{0%{transform:scale(.6);opacity:.2}40%{transform:scale(1.12)}70%{transform:scale(.97)}100%{transform:scale(1);opacity:1}}
.mzb-cell.free{background:linear-gradient(135deg,#1B3FA6,#2E6FE0);color:#fff;border:none}
.mzb-cell.drawn{border-color:var(--mint);background:rgba(35,199,230,.18);animation:mzbtap 1.4s ease-in-out infinite}
.mzb-cell.drawn::after{content:'tik';position:absolute;bottom:3px;font-size:7.5px;font-weight:800;color:var(--mint);opacity:.85;letter-spacing:.5px}
@keyframes mzbtap{0%,100%{box-shadow:0 0 0 0 rgba(35,199,230,.5)}50%{box-shadow:0 0 0 5px rgba(35,199,230,0)}}
.mzb-cell.marked{background:var(--gold);border-color:#1380a0;color:var(--ink);animation:none;box-shadow:none}
.mzb-cell.marked::before{content:'✓';position:absolute;top:2px;right:4px;font-size:12px;font-weight:900;color:var(--ink)}
.mzb-cell.marked .a{color:var(--ink);opacity:.7}
.mzb-cell.locked{opacity:.4;cursor:default}
.mzb-cell.now{border-color:var(--gold);background:rgba(255,194,60,.28);box-shadow:0 0 0 2px rgba(255,194,60,.5);animation:mzbnowcell .9s ease-in-out infinite}
.mzb-cell.now .t,.mzb-cell.now .a{color:#fff}
.mzb-cell.now::after{content:'tik!';color:var(--gold);opacity:1}
@keyframes mzbnowcell{50%{box-shadow:0 0 0 6px rgba(255,194,60,.22)}}
.mzb-now.hit{background:rgba(255,194,60,.22);border-color:var(--gold);animation:mzbnow 1s ease-in-out infinite}
@keyframes mzbnow{50%{background:rgba(255,194,60,.34)}}
.mzb-taphint{margin-top:6px;font-weight:900;color:var(--gold);font-size:15px}
.mzb-okhint{margin-top:6px;font-weight:700;color:var(--mint);font-size:13px}

/* scoreboard */
.mzb-list{display:flex;flex-direction:column;gap:9px;margin-top:12px}
.mzb-srow{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:14px;padding:11px 13px}
.mzb-srow .rk{font-weight:900;font-size:20px;color:var(--gold);min-width:26px;text-align:center}
.mzb-av{width:42px;height:42px;border-radius:50%;overflow:hidden;flex:none;background:rgba(63,210,255,.16);display:grid;place-items:center;font-weight:800}
.mzb-av img{width:100%;height:100%;object-fit:cover}
.mzb-srow .nm{font-weight:800;font-size:16px;white-space:normal;word-break:break-word;line-height:1.15}
.mzb-srow .st{font-size:12px;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mzb-srow .mid{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}
.mzb-bdg{flex:none;display:inline-flex;align-items:center;white-space:nowrap;font-size:12px;font-weight:800;color:var(--ink);background:var(--gold);border-radius:999px;padding:5px 10px;line-height:1}
.mzb-bar{height:7px;border-radius:99px;background:rgba(255,255,255,.12);margin-top:6px;overflow:hidden}
.mzb-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--mint),var(--gold))}
.mzb-srow.close{border-color:#FFC23C}
.mzb-srow.win{border-color:#FFD56B;background:linear-gradient(110deg,rgba(255,194,60,.2),rgba(46,111,224,.16))}
.mzb-srow.pulse{animation:mzbrow .7s ease}
.mzb-kick{flex:0 0 auto;background:rgba(255,80,80,.15);border:1px solid rgba(255,80,80,.4);color:#ff9b9b;border-radius:9px;padding:7px 11px;font-weight:800;cursor:pointer;font-size:14px;line-height:1}
.mzb-spinrow{flex:0 0 auto;background:rgba(54,210,255,.15);border:1px solid rgba(54,210,255,.45);color:#bfeeff;border-radius:9px;padding:7px 10px;font-weight:800;cursor:pointer;font-size:15px;line-height:1;margin-right:6px}
.mzb-spinrow:active{transform:scale(.92)}
.mzb-viewc{flex:0 0 auto;background:rgba(255,194,60,.16);border:1px solid rgba(255,194,60,.5);color:var(--gold);border-radius:9px;padding:7px 10px;font-weight:800;cursor:pointer;font-size:15px;line-height:1;margin-right:6px}
.mzb-viewc:active{transform:scale(.92)}
.mzb-modal{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;background:rgba(4,9,24,.86);padding:16px}
.mzb-modalbox{background:#0c1830;border:1px solid var(--line);border-radius:16px;padding:16px;max-width:520px;width:100%;max-height:92vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.mzb-cardgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:5px}
.mzb-kick:active{transform:scale(.92)}
@keyframes mzbrow{0%{box-shadow:0 0 0 0 rgba(63,210,255,0)}30%{box-shadow:0 0 0 3px rgba(63,210,255,.55);background:rgba(63,210,255,.16)}100%{box-shadow:0 0 0 0 rgba(63,210,255,0)}}
.mzb-bdg{font-size:11px;font-weight:700;padding:3px 8px;border-radius:99px;background:rgba(63,210,255,.18);color:var(--gold);margin-left:auto;white-space:nowrap}

.mzb-banner{border-radius:16px;padding:18px;margin:12px 0;text-align:center;background:linear-gradient(120deg,#2E6FE0,#11B5E6);border:3px solid #FFD56B}
.mzb-banner .wn{font-size:30px;font-weight:900;color:#fff}
.mzb-prizes{font-size:13px;opacity:.9;line-height:1.7;margin-top:8px}

/* video overlay */
.mzb-vid{display:none;position:fixed;inset:0;z-index:99999;background:rgba(2,8,22,.98);
  flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:16px}
.mzb-vid.show{display:flex}
.mzb-vframe{width:min(1280px,96vw);aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden}
.mzb-vframe iframe,.mzb-vframe video{width:100%;height:100%;border:0}
.mzb-soundnote{font-size:13px;font-weight:700;background:rgba(255,194,60,.16);border:1px solid rgba(255,194,60,.5);color:#FFD56B;border-radius:10px;padding:9px 12px;margin:8px 0}
.mzb-bingo{width:100%;font-size:22px;font-weight:900;letter-spacing:.5px;padding:16px;background:linear-gradient(135deg,#FFC23C,#FF7A59);color:#1a0d00;margin:6px 0}
.mzb-bingo:active{transform:scale(.98)}
.mzb-claim{margin:8px 0;padding:13px;border-radius:12px;font-weight:800;text-align:center;font-size:17px}
.mzb-claim.win{background:rgba(70,210,120,.18);border:1px solid #46d278;color:#9af0b8}
.mzb-claim.false{background:rgba(255,80,80,.18);border:1px solid #ff5050;color:#ff9b9b}
.mzb-claim.late{background:rgba(255,194,60,.16);border:1px solid #FFC23C;color:#FFD56B}
.mzb-events{margin:8px 0;display:flex;flex-direction:column;gap:6px}
.mzb-evrow{font-size:14px;font-weight:700;padding:8px 11px;border-radius:9px;background:rgba(255,255,255,.06)}
.mzb-evrow.win{background:rgba(70,210,120,.16);color:#9af0b8}
.mzb-evrow.false{background:rgba(255,80,80,.16);color:#ff9b9b}
.mzb-evrow.late{background:rgba(255,194,60,.13);color:#FFD56B}
.mzb-evflash{display:none}
.mzb-evflash.show{display:flex;align-items:center;justify-content:center;text-align:center;position:fixed;left:50%;top:18%;transform:translateX(-50%);z-index:50;font-size:clamp(22px,5vw,46px);font-weight:900;padding:18px 30px;border-radius:18px;box-shadow:0 18px 60px rgba(0,0,0,.5);animation:mzbpop .35s ease}
.mzb-evflash.win{background:linear-gradient(135deg,#1f7a45,#46d278);color:#04140a}
.mzb-evflash.false{background:linear-gradient(135deg,#7a1f1f,#ff5050);color:#fff}
.mzb-evflash.late{background:linear-gradient(135deg,#7a5a1f,#FFC23C);color:#1a0d00}
@keyframes mzbpop{from{transform:translateX(-50%) scale(.7);opacity:0}to{transform:translateX(-50%) scale(1);opacity:1}}
.mzb-join{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.mzb-chips{display:flex;flex-wrap:wrap;gap:7px;margin:8px 0}
.mzb-chip{width:42px;height:42px;border-radius:11px;border:1.5px solid var(--line);background:rgba(255,255,255,.05);color:#fff;font-weight:800;font-size:16px;cursor:pointer}
.mzb-chip:active{transform:scale(.94)}
.mzb-chip.on{background:linear-gradient(135deg,#FFC23C,#FF7A59);color:#1a0d00;border-color:#FFC23C}
.mzb-helpline{margin-top:10px}
.mzb-helpline a{color:var(--cyan);font-weight:800;text-decoration:none;cursor:pointer}
.mzb-helpline a:hover{text-decoration:underline}
.mzb-qrbig{display:none}
.mzb-qrbig.show{display:flex;align-items:center;justify-content:center;position:fixed;inset:0;z-index:60;background:rgba(4,10,30,.96);cursor:pointer}
.mzb-qrbig-in{text-align:center}
.mzb-qrbig-in img{width:min(72vw,72vh);height:auto;background:#fff;padding:14px;border-radius:18px}
.mzb-joinL{flex:1;min-width:200px}
.mzb-joinR{text-align:center}
.mzb-qr{width:200px;height:200px;display:block;background:#fff;padding:8px;border-radius:14px}
.mzb-near{display:none}
.mzb-near.show{display:block;position:fixed;right:16px;bottom:16px;z-index:49;background:linear-gradient(135deg,#7a5a1f,#FFC23C);color:#1a0d00;font-weight:800;font-size:16px;padding:12px 18px;border-radius:13px;box-shadow:0 12px 34px rgba(0,0,0,.45);animation:mzbpop2 .3s ease}
.mzb-wheelwrap{position:relative;text-align:center;color:#fff;max-width:340px;padding:0 12px}
.mzb-pptr{position:absolute;top:-4px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:13px solid transparent;border-right:13px solid transparent;border-top:22px solid #FFC23C;z-index:3;filter:drop-shadow(0 2px 3px rgba(0,0,0,.5))}
#mzbPWheel{max-width:86vw;height:auto}
#wheelclose{margin-top:14px}
.mzb-boardwrap{width:100%;max-width:520px;max-height:88vh;overflow:auto;padding:18px;color:#fff}
@keyframes mzbpop2{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.mzb-vintro{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;color:#fff}
.mzb-vbanner{display:none;position:absolute;top:14px;left:50%;transform:translateX(-50%);background:#FFD56B;color:#04122e;font-weight:900;font-size:18px;padding:9px 18px;border-radius:99px;z-index:3;animation:mzbpulse 1s ease-in-out infinite}
#vunmute{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;font-size:18px;font-weight:900;padding:15px 22px;box-shadow:0 10px 30px rgba(0,0,0,.5);animation:mzbpulse 1.1s ease-in-out infinite}
@keyframes mzbpulse{50%{transform:translateX(-50%) scale(1.06)}}
.mzb-vhint{font-size:13px;opacity:.7}
.mzb-err{color:#FF9AA8;font-size:13px;margin-top:6px}

/* tools: rad + spotify */
.mzb-tools{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:14px;margin-top:8px}
.mzb-tool{margin:0}
.mzb-wheelbox{position:relative;width:min(300px,78vw);aspect-ratio:1;margin:10px auto 0}
.mzb-wheelbox canvas{width:100%;height:100%;display:block;filter:drop-shadow(0 14px 26px rgba(0,0,0,.4))}
.mzb-ptr{position:absolute;top:-4px;left:50%;transform:translateX(-50%);z-index:2;width:0;height:0;
  border-left:14px solid transparent;border-right:14px solid transparent;border-top:26px solid #FFC23C}
.mzb-res{margin-top:12px;text-align:center;background:rgba(8,22,58,.92);border:2px solid var(--gold);border-radius:14px;padding:14px;min-height:60px;max-width:92vw}
.mzb-wheelname{font-weight:900;font-size:21px;color:#fff;margin-bottom:8px;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.mzb-dare-s{font-weight:900;color:var(--gold);font-size:24px;margin-top:6px;line-height:1.1}
.mzb-dare-f{font-size:17px;margin-top:6px;line-height:1.35}
.mzb-spinemoji{font-size:64px;line-height:1;display:inline-block;animation:mzbspinemoji .7s linear infinite}
@keyframes mzbspinemoji{to{transform:rotate(360deg)}}
.mzb-prizes{margin:10px 0 4px;background:rgba(8,22,58,.55);border:1px solid var(--line);border-radius:12px;padding:8px 10px}
.mzb-prizehead{font-weight:800;color:var(--gold);font-size:13px;margin-bottom:6px}
.mzb-prize{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:13px;padding:4px 0;border-top:1px solid rgba(255,255,255,.06)}
.mzb-prize:first-of-type{border-top:none}
.mzb-prize .mzb-pz-r{opacity:.7;font-size:12px;text-align:right}
.mzb-prize.won{opacity:.95}
.mzb-prize.won .mzb-pz-r{color:#7CF0B0;opacity:1;font-weight:700}
.mzb-prize.mine{background:rgba(255,194,60,.12);border-radius:8px;padding:4px 6px}
.mzb-prize.mine .mzb-pz-r{color:var(--gold)}
.mzb-embed{margin-top:10px;border-radius:12px;overflow:hidden;min-height:80px;background:rgba(0,0,0,.25);border:1px solid var(--line)}
.mzb-embed:empty::before{content:"Speler verschijnt na het laden van een link…";display:block;padding:20px;text-align:center;opacity:.5;font-size:12px}
#mzbSetup{margin-top:8px}
#mzbSetup summary{outline:none}
.mzb-linkrow{display:flex;gap:8px;align-items:center;margin:6px 0;flex-wrap:wrap}
.mzb-lname{font-size:13px;min-width:210px;flex:0 0 auto;opacity:.9}
.mzb-linkrow .mzb-in{min-width:160px}
.mzb-lsearch{flex:0 0 auto;background:#1DB954;color:#04140a;font-weight:800;font-size:12px;text-decoration:none;padding:8px 11px;border-radius:9px;white-space:nowrap}
.mzb-vrow{display:flex;gap:8px;align-items:center;margin:6px 0;flex-wrap:wrap}
.mzb-vname{flex:1;min-width:160px;font-size:13px;word-break:break-word}
.mzb-chk{display:flex;align-items:center;gap:7px;font-size:14px;cursor:pointer}
.mzb-chk input{width:18px;height:18px}

/* timer pil */
.mzb-timer{display:flex;align-items:center;gap:10px;
  background:rgba(7,16,42,.55);border:1px solid var(--line);border-radius:14px;padding:10px 14px}
.mzb-timer .mzb-clock{font-weight:900;font-size:26px;min-width:84px;text-align:center;color:#fff}
.mzb-timer button{font-weight:800;border:none;border-radius:999px;padding:8px 14px;cursor:pointer;color:#fff;background:linear-gradient(180deg,#56B4FF,#2E6FE0)}
.mzb-timer button#mzbTReset{background:rgba(255,255,255,.16)}
.mzb-timer.warn{border-color:#FFC23C} .mzb-timer.warn .mzb-clock{color:#FFD56B}
.mzb-timer.done{border-color:#2E6FE0} .mzb-timer.done .mzb-clock{color:#FF7A8A}

/* afdrukbare reservekaarten */
#mzb-print{display:none}
@media print{
  body > *:not(#mzb-print){ display:none !important; }
  #mzb-print{ display:block !important; }
  @page{ size:A4 portrait; margin:12mm; }
  .mzbp-card{ page-break-after:always; break-after:page; border:3px solid #000; border-radius:12px; padding:14px; height:250mm; display:flex; flex-direction:column; color:#000; }
  .mzbp-card:last-child{ page-break-after:auto; break-after:auto; }
  .mzbp-head{ display:flex; justify-content:space-between; align-items:baseline; border-bottom:3px solid #000; padding-bottom:8px; margin-bottom:10px; }
  .mzbp-head span:first-child{ font-size:30px; font-weight:900; text-transform:uppercase; }
  .mzbp-head span:last-child{ font-size:12px; text-transform:uppercase; letter-spacing:1px; }
  .mzbp-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:7px; flex:1; }
  .mzbp-cell{ border:2px solid #000; border-radius:10px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:5px; overflow:hidden; }
  .mzbp-cell b{ font-size:14px; line-height:1.1; }
  .mzbp-cell span{ font-size:11px; opacity:.7; margin-top:3px; }
  .mzbp-cell.free{ background:#eee; font-weight:900; }
  .mzbp-cell.mk{ background:#000; color:#fff; }
  .mzbp-cell.mk span{ color:#fff; }
  .mzbp-foot{ margin-top:10px; border-top:2px dashed #000; padding-top:8px; font-size:12px; text-align:center; }
}
@media (min-width:700px){ .mzb-cell .t{font-size:13px} .mzb-cell .a{font-size:10px} }
/* compacter op telefoons (host kan zo prima vanaf de telefoon) */
@media(max-width:560px){
  .mzb-wrap{padding:12px}
  .mzb-h{font-size:22px}
  .mzb-draw{font-size:19px;padding:16px}
  .mzb-code{font-size:32px;letter-spacing:4px}
  .mzb-join{gap:12px}
  .mzb-joinR{margin:0 auto}
  .mzb-qr{width:170px;height:170px}
  .mzb-btn{font-size:15px;padding:12px 16px}
  .mzb-sum{font-size:16px;padding:13px 14px}
}

/* ---- Projector / beamer (groot scherm) ---- */
.mzb-beamer{position:fixed;inset:0;z-index:100;background:#06122e;display:none;overflow:auto;padding:2.5vh 2.5vw;color:#fff}
.mzb-beamer.show{display:block}
.mzb-beamerclose{position:fixed;top:14px;right:16px;z-index:2;background:rgba(255,255,255,.16);color:#fff;border:none;border-radius:10px;padding:10px 14px;font-weight:800;font-size:16px;cursor:pointer;-webkit-appearance:none;appearance:none}
.bm-head{text-align:center;font-family:Anton,Arial,sans-serif;font-size:4.6vw;color:var(--gold);letter-spacing:.5px;line-height:1.05;margin-bottom:1.5vh}
.bm-banner{text-align:center;background:rgba(255,194,60,.16);border:2px solid var(--gold);border-radius:14px;padding:1.6vh 2vw;font-size:2.3vw;margin-bottom:2vh}
.bm-banner b{color:var(--gold)}
.bm-cols{display:flex;gap:2.5vw;align-items:flex-start}
.bm-left{flex:0 0 30%;display:flex;flex-direction:column;gap:1.6vh}
.bm-right{flex:1;min-width:0}
.bm-join{display:flex;align-items:center;gap:1.5vw;background:#fff;border-radius:16px;padding:1.5vh 1.5vw}
.bm-join img{width:11vw;height:11vw;max-width:200px;max-height:200px}
.bm-code{font-family:Anton,Arial,sans-serif;font-size:3.2vw;color:#06122e;letter-spacing:3px;line-height:1}
.bm-join .bm-sub{color:#0b1f49;font-size:1.3vw;opacity:.85}
.bm-prizes{display:flex;flex-direction:column;gap:1vh}
.bm-prize{display:flex;justify-content:space-between;gap:1vw;align-items:center;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:12px;padding:1.2vh 1.2vw;font-size:1.7vw;color:#cfe0ff}
.bm-prize b{color:#fff;margin-left:1vw}
.bm-prize.won{background:linear-gradient(110deg,rgba(255,194,60,.22),rgba(46,111,224,.16));border-color:var(--gold)}
.bm-prize.won b{color:var(--gold)}
.bm-tally{background:rgba(54,210,255,.12);border:1px solid rgba(54,210,255,.4);border-radius:12px;padding:1.2vh 1.2vw;font-size:1.5vw;color:#dff4ff;line-height:1.4}
.bm-boardhead{font-family:Anton,Arial,sans-serif;font-size:2.3vw;color:#fff;margin-bottom:1vh}
.bm-board{display:flex;flex-direction:column;gap:1vh}
.bm-row{display:flex;align-items:center;gap:1.5vw;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:14px;padding:1.3vh 1.4vw}
.bm-rank{font-family:Anton,Arial,sans-serif;font-size:2.6vw;color:var(--gold);min-width:3vw;text-align:center}
.bm-name{font-weight:800;font-size:2.4vw;color:#fff;flex:0 0 28%;white-space:normal;word-break:break-word;line-height:1.1}
.bm-bar{flex:1;height:2.2vh;background:rgba(255,255,255,.1);border-radius:999px;overflow:hidden}
.bm-bar>span{display:block;height:100%;background:linear-gradient(90deg,#36D2FF,#FFC23C);border-radius:999px}
.bm-st{font-size:1.6vw;color:#cfe0ff;flex:0 0 22%;text-align:right;white-space:normal;line-height:1.15}
.bm-sub{color:#9fb4dd;font-size:1.4vw}

/* ---- Quiz buzzer ---- */
.mzb-quizbox{background:#0c1830;border:2px solid var(--gold);border-radius:18px;padding:22px 18px;max-width:480px;width:92%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.mzb-quizlabel{color:var(--gold);font-weight:800;font-size:14px;letter-spacing:1.5px}
.mzb-quizq{font-size:24px;font-weight:800;color:#fff;margin:12px 0 18px;line-height:1.25}
.mzb-buzz{font-size:24px;padding:22px;width:100%;background:linear-gradient(180deg,#FFD56B,#F2A23C);color:#06122e;box-shadow:0 8px 0 #b5701a}
.mzb-buzz:disabled{opacity:.6;box-shadow:0 8px 0 rgba(0,0,0,.3)}
.mzb-quizpos{margin-top:14px;font-size:20px;font-weight:800;color:var(--gold);min-height:24px}
.mzb-refresh{background:rgba(255,255,255,.1);border:1px solid var(--line);color:#cfe0ff;border-radius:9px;padding:7px 12px;font-weight:700;font-size:13px;cursor:pointer;-webkit-appearance:none;appearance:none}

/* ---- Brede tekst-chips (modus / bingo-type) ---- */
.mzb-chip.mzb-chipw{width:auto;min-width:0;height:auto;padding:11px 15px;font-size:14px;line-height:1.1}

/* ---- Overzichtskop boven de gereedschappen ---- */
.mzb-toolhead{margin:20px 0 8px;padding-top:14px;border-top:1px solid var(--line);font-family:Anton,Arial,sans-serif;font-size:18px;letter-spacing:.3px;color:#cfe0ff}
.mzb-toolhead .mzb-sub{font-family:inherit;font-weight:400}

/* ---- Prijzen afvinken ---- */
.mzb-prizelist{display:flex;flex-direction:column;gap:8px}
.mzb-prow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.mzb-prow .mzb-pttl{font-weight:800;font-size:15px;flex:1;min-width:130px}
.mzb-prow .mzb-pwin{font-size:14px;color:var(--gold);font-weight:700;flex:none}
.mzb-prow.won{border-color:#FFC23C;background:linear-gradient(110deg,rgba(255,194,60,.16),rgba(46,111,224,.10))}
.mzb-prow.done{border-color:#3FBF6A;background:rgba(63,191,106,.12)}
.mzb-prow.done .mzb-pttl{text-decoration:line-through;opacity:.7}

/* ---- Filmpje als 'gespeeld' ---- */
.mzb-vrow.done{opacity:.6}
.mzb-vrow.done .mzb-vname{text-decoration:line-through}

/* ---- Afgeroepen getal/item groot op de projector (getallen-/vrije bingo) ---- */
.bm-now{text-align:center;background:rgba(54,210,255,.12);border:2px solid #36D2FF;border-radius:14px;padding:1.2vh 2vw;font-size:2.1vw;margin-bottom:2vh;color:#dff4ff}
.bm-now b{font-size:6.5vw;color:var(--gold);display:inline-block;margin:0 1vw;line-height:1;vertical-align:middle}
.bm-now span{font-size:1.8vw;opacity:.8}

/* ---- Projector: achtergrond-thema's ---- */
.mzb-beamer.bm-theme-nacht{background:#06122e}
.mzb-beamer.bm-theme-feest{background:linear-gradient(135deg,#3a0ca3,#7209b7,#f72585)}
.mzb-beamer.bm-theme-goud{background:radial-gradient(circle at 50% -10%,#3d2c00,#0a0800 70%)}
.mzb-beamer.bm-theme-disco{background:linear-gradient(135deg,#ff005e,#7a00ff,#00d4ff,#00e676);background-size:400% 400%;animation:bmShift 12s ease infinite}
.mzb-beamer.bm-theme-groen{background:linear-gradient(135deg,#04340f,#0b6b2e,#02160a)}
.mzb-beamer.bm-theme-regenboog{background:linear-gradient(90deg,#ff004d,#ff8a00,#ffe000,#00c853,#00b0ff,#aa00ff);background-size:400% 400%;animation:bmShift 10s linear infinite}
@keyframes bmShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.bm-head{text-shadow:0 2px 10px rgba(0,0,0,.55)}

/* themavoorbeeld op de keuzeknoppen */
.mzb-chip[data-th]{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7);border:2px solid transparent}
.mzb-chip[data-th].on{border-color:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.45)}
.bm-th-nacht{background:#06122e !important}
.bm-th-feest{background:linear-gradient(135deg,#7209b7,#f72585) !important}
.bm-th-goud{background:linear-gradient(135deg,#2a1d00,#000) !important;color:#FFD56B !important}
.bm-th-disco{background:linear-gradient(135deg,#ff005e,#7a00ff,#00d4ff) !important}
.bm-th-groen{background:linear-gradient(135deg,#0b6b2e,#04340f) !important}
.bm-th-regenboog{background:linear-gradient(90deg,#ff004d,#ff8a00,#ffe000,#00c853,#00b0ff,#aa00ff) !important}

/* ---- Projector: effecten bij nieuw nummer ---- */
.bm-confetti{position:fixed;top:-24px;z-index:9;pointer-events:none;opacity:.96;animation-name:bmFall;animation-timing-function:linear;animation-fill-mode:forwards}
@keyframes bmFall{0%{transform:translateY(-24px) rotate(0);opacity:1}100%{transform:translateY(106vh) rotate(720deg);opacity:.15}}
.bm-spark{position:fixed;z-index:9;pointer-events:none;filter:drop-shadow(0 0 8px #fff);animation:bmSpark 1.5s ease forwards}
@keyframes bmSpark{0%{transform:scale(0) rotate(0);opacity:0}30%{transform:scale(1.25) rotate(18deg);opacity:1}100%{transform:scale(.4) rotate(0);opacity:0}}
.bm-flashlayer{position:fixed;inset:0;z-index:8;pointer-events:none;background:#fff;animation:bmFlash .6s ease forwards}
@keyframes bmFlash{0%{opacity:0}12%{opacity:.85}100%{opacity:0}}
.mzb-beamer.bm-glow .bm-head,.mzb-beamer.bm-glow .bm-now b{animation:bmGlow 1.25s ease}
@keyframes bmGlow{0%{text-shadow:0 0 0 transparent}40%{text-shadow:0 0 28px var(--gold),0 0 64px var(--gold)}100%{text-shadow:0 2px 10px rgba(0,0,0,.55)}}

/* ---- Sticky bovenbalk host (overzicht + snel trekken) ---- */
.mzb-topbar{position:sticky;top:0;z-index:30;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;background:rgba(8,18,40,.96);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin:0 0 12px}
.mzb-tbinfo{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.mzb-tbpill{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:14px;white-space:nowrap}
.mzb-tbpill b{color:var(--gold);font-size:15px}
.mzb-tbbtns{display:flex;gap:8px;align-items:stretch;flex:1;min-width:210px}
.mzb-tbbtns .mzb-draw{flex:1;font-size:16px;padding:12px 14px}
.mzb-tbbtns #tbBoard{flex:none;font-size:18px;padding:12px 15px}

/* ---- Quiz: vragenlijst ---- */
.mzb-qblist{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.mzb-qbrow{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:10px;padding:8px 10px}
.mzb-qbrow .mzb-qbq{flex:1;font-size:14px;word-break:break-word}

/* ---- Wat extra finish op het hostpaneel ---- */
.mzb-sec{transition:border-color .15s}
.mzb-sec[open]{border-color:rgba(255,194,60,.35)}

/* ---- Aanpasbare bingotitel ---- */
.mzb-titlerow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.mzb-editname{background:rgba(255,255,255,.08);border:1px solid var(--line);color:#cfe0ff;border-radius:9px;padding:6px 11px;font-size:15px;cursor:pointer;-webkit-appearance:none;appearance:none}
.mzb-editname:hover{background:rgba(255,255,255,.16)}

/* ---- Getallenbord op de telefoon ---- */
.mzb-flashwrap{width:100%;max-width:600px;max-height:88vh;overflow:auto;text-align:center}
.mzb-flashgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(46px,1fr));gap:8px;margin-top:6px}
.fcell{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-weight:800;font-size:18px;background:rgba(255,255,255,.05);border:1px solid var(--line);color:#7e8db0}
.fcell.lit{background:linear-gradient(180deg,#2e6fe0,#1b4fb0);color:#fff;border-color:#5b8def;box-shadow:0 4px 14px rgba(46,111,224,.4)}
.fcell.cur{background:linear-gradient(180deg,#FFD56B,#F2A23C);color:#06122e;border-color:var(--gold);animation:fpulse 1s ease infinite}
@keyframes fpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* ---- Getallenbord op de projector ---- */
.bmf-sub{text-align:center;font-size:2vw;color:#cfe0ff;margin:1vh 0 2vh}
.bmf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(5vw,1fr));gap:.8vw;padding:0 2vw}
.bmf-cell{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;border-radius:.7vw;font-family:Anton,Arial,sans-serif;font-size:2.4vw;background:rgba(255,255,255,.05);border:1px solid var(--line);color:#6f7ea3}
.bmf-cell.lit{background:linear-gradient(180deg,#2e6fe0,#143b86);color:#fff;border-color:#5b8def;box-shadow:0 .4vw 1.2vw rgba(46,111,224,.45)}
.bmf-cell.cur{background:linear-gradient(180deg,#FFD56B,#F2A23C);color:#06122e;border-color:var(--gold);animation:bmfpulse 1s ease infinite}
@keyframes bmfpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.bm-board-big .bm-name{font-size:2.8vw;flex-basis:34%}
.bm-board-big .bm-row{padding:1.7vh 1.7vw}
.bm-board-big .bm-rank{font-size:3vw}
.bm-board-big .bm-st{font-size:1.9vw}

/* ---- Pop-animatie bij nieuw getal/nummer (host) ---- */
.mzb-numpop{animation:numpop .55s cubic-bezier(.2,.8,.2,1)}
@keyframes numpop{0%{transform:scale(.72);opacity:.35}60%{transform:scale(1.07)}100%{transform:scale(1);opacity:1}}

/* ---- Namen op één regel (auto-verkleind via inline font-size) ---- */
.mzb-srow .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:normal}
.bm-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:normal}

/* ---- Avatar in de projector-stand ---- */
.bm-av{width:3.4vw;height:3.4vw;min-width:34px;min-height:34px;border-radius:50%;flex:none;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#2e6fe0,#143b86);color:#fff;font-family:Anton,Arial,sans-serif;font-size:1.6vw;border:2px solid rgba(255,255,255,.3)}
.bm-av img{width:100%;height:100%;object-fit:cover}
.bm-av.init{font-size:1.7vw}

/* ---- Winnaar vieren op de projector (foto groot) ---- */
.bm-cele{position:absolute;inset:0;z-index:40;display:none;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 38%, rgba(255,194,60,.22), rgba(6,18,46,.93) 62%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.bm-cele.show{display:flex;animation:celeIn .45s ease}
@keyframes celeIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}
.bm-cele-in{text-align:center}
.bm-celeclose{position:absolute;top:14px;right:16px;z-index:2;background:rgba(255,255,255,.16);color:#fff;border:none;border-radius:10px;padding:10px 14px;font-weight:800;font-size:16px;cursor:pointer;-webkit-appearance:none;appearance:none}
.cele-burst{font-size:5vw;line-height:1;margin-bottom:1vh;animation:celeBounce 1.2s ease infinite}
@keyframes celeBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-1.2vh)}}
.cele-photo{width:26vw;height:26vw;max-width:380px;max-height:380px;border-radius:50%;object-fit:cover;border:.6vw solid var(--gold);box-shadow:0 0 60px rgba(255,194,60,.55);display:flex;align-items:center;justify-content:center;margin:0 auto;background:linear-gradient(180deg,#2e6fe0,#143b86);color:#fff;font-family:Anton,Arial,sans-serif;font-size:10vw}
.cele-name{font-family:Anton,Arial,sans-serif;font-size:6vw;color:#fff;margin-top:2vh;line-height:1;text-shadow:0 4px 18px rgba(0,0,0,.5)}
.cele-prize{font-size:2.6vw;color:var(--gold);font-weight:800;margin-top:.6vh}
.cele-sub{font-family:Anton,Arial,sans-serif;font-size:3vw;color:#FFE08A;letter-spacing:2px;margin-top:1vh}

/* ---- Knop in apart beamer-venster (2e scherm) ---- */
.bm-fsbtn{position:fixed;bottom:14px;right:16px;z-index:35;background:rgba(255,255,255,.12);color:#cfe0ff;border:1px solid var(--line);border-radius:10px;padding:8px 12px;font-weight:700;font-size:13px;cursor:pointer;opacity:.45;-webkit-appearance:none;appearance:none}
.bm-fsbtn:hover{opacity:1}

/* ---- Eigen logo + eigen-foto-thema op de projector ---- */
.bm-logo{position:fixed;top:1.6vh;left:1.8vw;z-index:20;max-height:11vh;max-width:26vw;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 4px 14px rgba(0,0,0,.5))}
.bm-th-eigen{background:linear-gradient(135deg,#3a3f4a,#15171c) !important}

/* ===== Beamer-studio: blokken-raster + kaarten ===== */
.bm-header{padding:1.6vh 2vw 0;text-align:center}
.bm-stage{display:grid;grid-template-columns:repeat(12,1fr);gap:1.4vw;padding:1.6vh 2vw 2.4vh;align-content:start;box-sizing:border-box}
.bm-card{background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:1.1vw;padding:1.5vh 1.4vw;box-shadow:0 1.4vh 3.4vh rgba(0,0,0,.4);overflow:hidden;min-width:0}
.bm-w-1{grid-column:span 4}
.bm-w-2{grid-column:span 6}
.bm-w-3{grid-column:span 12}
.bmw-h{font-size:1.25vw;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);font-weight:800;margin-bottom:.9vh;opacity:.92}
.bmw-now{font-family:Anton,Arial,sans-serif;font-weight:900;line-height:.98;color:#fff;text-align:center;text-shadow:0 .5vh 2.2vh rgba(0,0,0,.55);margin:.6vh 0 .2vh}
.bmw-nowsub{text-align:center;font-size:2vw;color:#cfe0ff;font-weight:700;margin-top:.3vh}
.bmw-nowcount{text-align:center;font-size:1.2vw;color:#9fb3d9;margin-top:.9vh}
.bmw-nowwait{text-align:center;font-size:2.1vw;color:#9fb3d9;padding:3vh 0}
.bmw-clock{font-family:Anton,Arial,sans-serif;font-size:5.2vw;text-align:center;color:#fff;line-height:1.04}
.bmw-text{font-size:2.3vw;line-height:1.32;color:#fff;text-align:center;font-weight:700;padding:1.4vh 0;white-space:pre-wrap;word-break:break-word}
.bmw-wheel{text-align:center;font-size:1.5vw;color:#cfe0ff}
.bmw-wheel b{color:#fff;font-size:1.9vw}
.bmw-dare{display:block;font-family:Anton,Arial,sans-serif;font-size:2.5vw;color:var(--gold);margin:.7vh 0}
.bmw-daref{font-size:1.4vw;color:#9fb3d9}
/* kaart-interne maatvoering zodat blokken netjes passen */
.bm-card .bm-head{font-size:2vw;margin-bottom:1vh}
.bm-card .bm-board{display:flex;flex-direction:column;gap:.8vh;max-height:46vh;overflow:auto}
.bm-card .bm-row{padding:.9vh 1vw;gap:1vw;border-radius:11px}
.bm-card .bm-rank{font-size:1.9vw;min-width:2.4vw}
.bm-card .bm-av{width:2.7vw;height:2.7vw;font-size:1.3vw}
.bm-card .bm-st{font-size:1.2vw}
.bm-card .bm-prize{font-size:1.35vw;padding:.85vh 1vw}
.bm-card .bm-join{padding:1.2vh 1.2vw;gap:1.2vw}
.bm-card .bm-join img{width:8vw;height:8vw}
.bm-card .bm-code{font-size:2.5vw}
.bm-card .bm-join .bm-sub{font-size:1vw}
.bm-card .bmf-grid{padding:0}
.bm-card .bmf-cell{font-size:1.7vw}
.bm-card .bm-tally{font-size:1.2vw}

/* ===== Beamer-studio: editor (op het hoofdscherm) ===== */
.bmw-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.bmw-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:8px 10px}
.bmw-row.on{background:rgba(46,111,224,.12);border-color:rgba(91,141,239,.5)}
.bmw-on{display:flex;align-items:center;gap:8px;flex:1 1 44%;font-weight:700;font-size:14px;cursor:pointer;color:var(--cream)}
.bmw-on input{width:18px;height:18px;flex:none}
.bmw-tools{display:flex;align-items:center;gap:6px;margin-left:auto}
.bmw-szwrap{display:inline-flex;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.bmw-sz{background:transparent;color:#9fb3d9;border:none;padding:6px 11px;font-weight:800;font-size:13px;cursor:pointer;-webkit-appearance:none;appearance:none}
.bmw-sz.on{background:var(--gold);color:#06122e}
.bmw-mv{background:rgba(255,255,255,.08);color:#cfe0ff;border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:13px;cursor:pointer;-webkit-appearance:none;appearance:none}
.bmw-mv:disabled{opacity:.3;cursor:default}
.bmw-txt{flex:1 1 100%;margin-top:4px}

/* ===== Getallenbingo: spannende bal + recente getallen op de beamer ===== */
.bm-ball{position:relative;width:clamp(120px,18vw,260px);height:clamp(120px,18vw,260px);margin:1vh auto .4vh;border-radius:50%;background:radial-gradient(circle at 34% 30%,#fff7df 0%,#FFD56B 32%,#F2A23C 70%,#d9831f 100%);box-shadow:0 1.4vh 3.4vh rgba(0,0,0,.45),inset 0 -1.2vh 2.2vh rgba(0,0,0,.18),inset 0 1vh 1.6vh rgba(255,255,255,.5);display:flex;flex-direction:column;align-items:center;justify-content:center}
.bm-ball-l{font-family:Anton,Arial,sans-serif;font-size:2vw;color:#a85e12;letter-spacing:.1em;line-height:1;margin-top:.4vh}
.bm-ball-n{font-family:Anton,Arial,sans-serif;font-size:7.5vw;color:#3a2206;line-height:.9;text-shadow:0 1px 0 rgba(255,255,255,.4)}
.bm-ball.pop{animation:bmball .75s cubic-bezier(.2,1.4,.4,1)}
@keyframes bmball{0%{transform:scale(.2) rotate(-25deg);opacity:0}55%{transform:scale(1.12) rotate(6deg)}100%{transform:scale(1) rotate(0);opacity:1}}
.bm-recent{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.6vw;margin-top:1.1vh}
.bm-recent-h{color:#9fb3d9;font-size:1vw;margin-right:.3vw}
.bm-rchip{display:inline-flex;align-items:center;justify-content:center;min-width:2.6vw;height:2.6vw;padding:0 .5vw;border-radius:.6vw;background:rgba(46,111,224,.28);border:1px solid rgba(91,141,239,.5);color:#dfe9ff;font-family:Anton,Arial,sans-serif;font-size:1.5vw}
.bm-prize.bm-grand{background:linear-gradient(110deg,rgba(255,194,60,.18),rgba(46,111,224,.12));border-color:rgba(255,194,60,.55)}
.bm-prize.bm-grand.won{box-shadow:0 0 2vw rgba(255,194,60,.5)}

/* ===================== PUB QUIZ ===================== */
/* ---- Host: vraag-editor ---- */
.pq-optrow{display:flex;align-items:center;gap:8px;margin-top:6px}
.pq-optlbl{flex:none;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--line);border-radius:9px;cursor:pointer;background:rgba(255,255,255,.04)}
.pq-optlbl input{width:18px;height:18px;cursor:pointer}
.pq-oin{flex:1 1 auto}
.pq-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.pq-li{display:flex;align-items:flex-start;gap:8px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:8px 10px}
.pq-li-q{flex:1 1 auto;font-size:14px;line-height:1.3;color:var(--cream)}
.pq-li-a{font-size:12px;color:#7fd48a;margin-top:3px}
.pq-li-bt{display:flex;gap:5px;flex:none;flex-wrap:wrap;justify-content:flex-end;max-width:46%}
/* ---- Host: live paneel ---- */
.pq-live{background:linear-gradient(180deg,rgba(46,111,224,.16),rgba(255,255,255,.03));border:1px solid rgba(91,141,239,.5);border-radius:14px;padding:12px;margin-bottom:6px}
.pq-lhead{font-weight:800;color:var(--gold);font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.pq-lq{font-size:18px;font-weight:800;margin:4px 0 8px;color:#fff;line-height:1.25}
.pq-lcount{font-size:13px;color:#cfe0ff;margin-bottom:6px}
.pq-ltimerwrap{height:8px;background:rgba(255,255,255,.12);border-radius:6px;overflow:hidden;margin-bottom:2px}
.pq-ltimer{height:100%;background:linear-gradient(90deg,#FFD56B,#F2A23C);border-radius:6px}
.pq-ltime{font-size:12px;color:#9fb3d9;text-align:right;margin-bottom:6px}
.pq-lopts{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.pq-lopt{background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:14px;color:var(--cream)}
.pq-lopt b{display:inline-block;min-width:18px;color:var(--gold)}
.pq-lopt.correct{background:rgba(38,137,12,.32);border-color:#3fb43f;color:#fff}
.pq-lopt.dim{opacity:.55}
.pq-lc{float:right;font-weight:800}
.pq-llb{margin-top:8px;font-size:13px;color:#cfe0ff;line-height:1.5}
/* ---- Speler: antwoord-overlay ---- */
#pqov .pq-box{width:100%;max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:12px;padding:16px;max-height:100%;overflow:auto}
.pq-num{align-self:center;background:var(--gold);color:#06122e;font-weight:800;padding:5px 16px;border-radius:999px;font-size:14px}
.pq-q{font-size:24px;font-weight:800;text-align:center;color:#fff;line-height:1.25}
.pq-opts{display:flex;flex-direction:column;gap:10px}
.pq-opt{display:flex;align-items:center;gap:12px;width:100%;border:none;border-radius:14px;padding:16px 16px;font-size:18px;font-weight:800;color:#fff;text-align:left;cursor:pointer;-webkit-appearance:none;appearance:none;box-shadow:0 4px 0 rgba(0,0,0,.25);transition:transform .06s}
.pq-opt:active{transform:translateY(2px);box-shadow:0 2px 0 rgba(0,0,0,.25)}
.pq-c0{background:#e8403a}.pq-c1{background:#1368ce}.pq-c2{background:#caa200}.pq-c3{background:#26890c}
.pq-ltr{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,.25);flex:none;font-size:16px}
.pq-txt{flex:1 1 auto}
.pq-cnt{background:rgba(0,0,0,.28);border-radius:8px;padding:2px 9px;font-size:15px}
.pq-opt.sel{outline:4px solid #fff;outline-offset:1px}
.pq-opt.locked{opacity:.92}
.pq-opt.correct{box-shadow:0 0 0 4px #fff, 0 0 22px rgba(63,180,63,.9)}
.pq-opt.wrong{opacity:.55;filter:grayscale(.3)}
.pq-opt.dim{opacity:.4}
.pq-stat{text-align:center;font-size:18px;font-weight:800;color:#fff}
.pq-myscore{text-align:center;color:#cfe0ff;font-size:15px}
.pq-myscore b{color:var(--gold);font-size:18px}
.pq-lb{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:12px;padding:10px}
.pq-lb-h{font-weight:800;color:var(--gold);margin-bottom:6px;text-align:center}
.pq-lb-row{display:flex;align-items:center;gap:10px;padding:4px 2px;border-top:1px solid rgba(255,255,255,.06)}
.pq-lb-row:first-of-type{border-top:none}
.pq-lb-rk{width:22px;text-align:center;font-weight:800;color:var(--gold)}
.pq-lb-nm{flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}
.pq-lb-pt{font-weight:800;color:#cfe0ff}
/* ---- Beamer: quiz ---- */
.bmq-wrap{display:flex;flex-direction:column;align-items:center;gap:1.4vh;padding:3vh 4vw 4vh;height:100%;box-sizing:border-box;justify-content:center}
.bmq-num{background:var(--gold);color:#06122e;font-weight:800;padding:.6vh 2vw;border-radius:999px;font-size:1.6vw}
.bmq-q{font-family:Anton,Arial,sans-serif;font-size:4vw;color:#fff;text-align:center;line-height:1.1;text-shadow:0 .4vh 2vh rgba(0,0,0,.5);max-width:92vw}
.bmq-count{font-size:1.5vw;color:#cfe0ff}
.bmq-timerwrap{width:60vw;height:1.4vh;background:rgba(255,255,255,.14);border-radius:1vh;overflow:hidden}
.bmq-bar{height:100%;background:linear-gradient(90deg,#FFD56B,#F2A23C)}
.bmq-time{font-size:1.4vw;color:#9fb3d9}
.bmq-opts{display:grid;grid-template-columns:1fr 1fr;gap:1.4vw;width:84vw;margin-top:1vh}
.bmq-opt{display:flex;align-items:center;gap:1.2vw;border-radius:1vw;padding:2.2vh 1.6vw;font-size:2.2vw;font-weight:800;color:#fff;box-shadow:0 .8vh 0 rgba(0,0,0,.25)}
.bmq-c0{background:#e8403a}.bmq-c1{background:#1368ce}.bmq-c2{background:#caa200}.bmq-c3{background:#26890c}
.bmq-shape{font-size:2.4vw;flex:none}
.bmq-txt{flex:1 1 auto}
.bmq-cnt{background:rgba(0,0,0,.3);border-radius:.7vw;padding:.3vh 1.1vw;font-size:2vw}
.bmq-opt.correct{box-shadow:0 0 0 .5vw #fff,0 0 3vw rgba(63,180,63,.9)}
.bmq-opt.dim{opacity:.42}
.bmq-lb{margin-top:1.6vh;width:60vw;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:1vw;padding:1.4vh 1.6vw}
.bmq-lb-h{font-weight:800;color:var(--gold);text-align:center;font-size:1.8vw;margin-bottom:.6vh}
.bmq-lb-row{display:flex;align-items:center;gap:1.2vw;padding:.5vh 0;border-top:1px solid rgba(255,255,255,.07);font-size:1.8vw}
.bmq-lb-row:first-of-type{border-top:none}
.bmq-lb-rk{width:2vw;text-align:center;color:var(--gold);font-weight:800}
.bmq-lb-nm{flex:1 1 auto;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bmq-lb-pt{color:#cfe0ff;font-weight:800}

/* ===== Getallenbal: gloed + aftel-ring (beamer) ===== */
.bm-ballwrap{position:relative;width:clamp(150px,24vw,330px);height:clamp(150px,24vw,330px);margin:1.2vh auto .6vh;display:flex;align-items:center;justify-content:center}
.bm-ballwrap .bm-ball{position:relative;width:100%;height:100%;margin:0;z-index:2;animation:bmglow 2.6s ease-in-out infinite}
.bm-ring{position:absolute;inset:-6%;border-radius:50%;display:none;z-index:1;-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 1.3vw),#000 calc(100% - 1.3vw));mask:radial-gradient(farthest-side,transparent calc(100% - 1.3vw),#000 calc(100% - 1.3vw));filter:drop-shadow(0 0 1vw rgba(255,194,60,.55))}
@keyframes bmglow{0%,100%{box-shadow:0 1.4vh 3.4vh rgba(0,0,0,.45),inset 0 -1.2vh 2.2vh rgba(0,0,0,.18),inset 0 1vh 1.6vh rgba(255,255,255,.5),0 0 0 rgba(255,194,60,0)}50%{box-shadow:0 1.4vh 3.4vh rgba(0,0,0,.5),inset 0 -1.2vh 2.2vh rgba(0,0,0,.18),inset 0 1vh 1.6vh rgba(255,255,255,.55),0 0 6vw rgba(255,194,60,.6)}}
.bm-card .bm-ballwrap .bm-ball-n{font-size:9vw}
.bm-card .bm-ballwrap .bm-ball-l{font-size:2.4vw}
.bm-recent{margin-top:1.4vh}
.bm-rchip{min-width:3vw;height:3vw;font-size:1.8vw;border-radius:.8vw}

/* ===== Host: automatisch trekken ===== */
.mzb-autodraw{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:8px 12px;margin:8px 0}
.mzb-autodraw .mzb-chk{font-weight:800}
.mzb-autodraw input[type=number]{text-align:center}

/* ===== Host: volgende nummers (klaarzetten) ===== */
.mzb-upnext{background:linear-gradient(180deg,rgba(46,111,224,.14),rgba(255,255,255,.02));border:1px solid rgba(91,141,239,.45);border-radius:14px;padding:10px 12px;margin:6px 0 10px}
.mzb-upnext-h{font-weight:800;color:var(--gold);font-size:13px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.mzb-upnext-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid var(--line);text-decoration:none;color:var(--cream);margin-top:6px}
.mzb-upnext-row:hover{background:rgba(255,255,255,.09)}
.mzb-upnext-i{flex:none;width:24px;height:24px;border-radius:50%;background:var(--gold);color:#06122e;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:13px}
.mzb-upnext-t{flex:1 1 auto;font-size:15px;line-height:1.25}
.mzb-upnext-go{flex:none;font-size:13px;color:#9fd2ff;font-weight:700}

/* ===== Host-paneel: fris & overzichtelijk ===== */
.mzb-sec{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.012));border-radius:16px;box-shadow:0 2px 10px rgba(0,0,0,.18)}
.mzb-sec>summary.mzb-sum{border-left:4px solid transparent;border-radius:16px;transition:background .15s,border-color .15s}
.mzb-sec[open]>summary.mzb-sum{border-left-color:var(--gold);background:rgba(255,194,60,.07);border-bottom:1px solid var(--line);border-radius:16px 16px 0 0}
.mzb-topbar{box-shadow:0 6px 18px rgba(0,0,0,.3)}
.mzb-tbinfo{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.mzb-tbpill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:14px;color:#cfe0ff}
.mzb-tbpill b{color:#fff;font-size:15px}
.mzb-now{font-size:17px;background:linear-gradient(180deg,rgba(63,210,255,.16),rgba(63,210,255,.06));border:1px solid rgba(63,210,255,.45);box-shadow:inset 0 0 24px rgba(63,210,255,.06)}

/* beamer-blokken verticaal centreren zodat het scherm niet leeg/bovenzwaar oogt */
.bm-stage{align-content:center;min-height:82vh}

/* ===== Beamer: spannende bingo-controle (past altijd op 1 scherm, geen scroll) ===== */
.bm-check{position:fixed;inset:0;z-index:60;display:none;flex-direction:column;align-items:center;justify-content:center;gap:1.2vh;text-align:center;padding:3vh 4vw;box-sizing:border-box;overflow:hidden;background:radial-gradient(circle at 50% 38%, rgba(20,30,60,.97), rgba(4,8,20,.99))}
.bm-check.show{display:flex;animation:bmcIn .3s ease}
@keyframes bmcIn{from{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}
.bm-check.valid{background:radial-gradient(circle at 50% 35%, rgba(22,86,44,.97), rgba(4,16,10,.99))}
.bm-check.late{background:radial-gradient(circle at 50% 35%, rgba(96,74,20,.97), rgba(18,14,4,.99))}
.bm-check.invalid{background:radial-gradient(circle at 50% 35%, rgba(104,30,30,.97), rgba(20,6,6,.99))}
.bmc-spin{width:11vh;height:11vh;border-radius:50%;border:1.1vh solid rgba(255,255,255,.16);border-top-color:var(--gold);animation:bmcSpin 1s linear infinite}
@keyframes bmcSpin{to{transform:rotate(360deg)}}
.bmc-badge{font-size:11vh;line-height:1;animation:bmcPop .5s cubic-bezier(.2,1.4,.4,1)}
@keyframes bmcPop{from{transform:scale(0)}to{transform:scale(1)}}
.bmc-h{font-size:4vh;font-weight:800;color:#fff;margin:0}
.bmc-h2{font-size:6.4vh;font-weight:900;color:#fff;letter-spacing:.02em;text-shadow:0 3px 18px rgba(0,0,0,.45);margin:0}
.bmc-name{font-size:4.6vh;font-weight:800;color:var(--gold);margin:0}
.bmc-win{font-size:5.4vh;font-weight:900;color:var(--gold);margin:0}
.bmc-prize{font-size:3.6vh;font-weight:800;color:#fff;margin:0}
.bmc-sub{font-size:2.7vh;color:rgba(255,255,255,.85);margin:0;max-width:80vw}
.bmc-card{display:grid;grid-template-columns:repeat(5,1fr);gap:.7vmin;width:min(40vh,86vw);margin-top:.6vh}
.bmc-cell{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;border-radius:1vmin;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);padding:.3vmin;overflow:hidden}
.bmc-cell span{font-size:2.1vmin;font-weight:700;color:#dfe7ff;line-height:1.04;text-align:center;word-break:break-word}
.bmc-cell.free{background:rgba(255,194,60,.18)}
.bmc-cell.marked{background:rgba(255,194,60,.30);border-color:rgba(255,194,60,.6)}
.bmc-cell.marked span{color:#fff}
.bmc-cell.win{background:linear-gradient(180deg,#2fae58,#1c8a44);border-color:#7fffa8;box-shadow:0 0 2vmin rgba(80,255,150,.6)}
.bmc-cell.win span{color:#fff}

/* ===== Host: kaartweergave met kanskleuren ===== */
.pc-status{font-size:15px}
.pc-cell.pc-ok{background:rgba(60,180,90,.22);border-color:rgba(90,210,120,.55)}
.pc-cell.pc-wrong{background:rgba(220,70,70,.20);border-color:rgba(240,110,110,.6)}
.pc-cell.pc-wrong .t,.pc-cell.pc-wrong .a{text-decoration:line-through;opacity:.7}
.pc-cell.pc-missed{opacity:.5}
.pc-cell.pc-lwin{outline:3px solid #4fd07a;outline-offset:-3px}
.pc-cell.pc-lclose{box-shadow:inset 0 0 0 3px rgba(255,200,80,.55)}
.pc-cell.pc-need{background:rgba(255,200,60,.32)!important;border-color:#ffd24a!important;animation:pcNeed 1s ease-in-out infinite}
@keyframes pcNeed{0%,100%{box-shadow:0 0 0 rgba(255,210,74,0)}50%{box-shadow:0 0 14px rgba(255,210,74,.9)}}
.pc-legend{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:10px;font-size:12px;color:rgba(255,255,255,.8)}
.pc-legend span{display:inline-flex;align-items:center;gap:5px}
.pc-sw{display:inline-block;width:14px;height:14px;border-radius:4px;border:1px solid rgba(255,255,255,.25)}
.pc-sw.ok{background:rgba(60,180,90,.65)}
.pc-sw.need{background:#ffd24a}
.pc-sw.wrong{background:rgba(220,70,70,.6)}
.pc-sw.missed{background:rgba(255,255,255,.18)}

/* ===== Host: hybride fysieke kaarten ===== */
.mzb-hybrid{margin-top:12px;padding:12px;border:1px dashed rgba(255,194,60,.45);border-radius:12px;background:rgba(255,194,60,.05)}

/* ===== Beamer: vrije indeling (zelf getekend scherm) ===== */
.bm-free{position:absolute;inset:0;width:100%;height:100%}
.bm-blk{position:absolute;box-sizing:border-box;overflow:hidden;display:flex;align-items:center;justify-content:center}
.bm-free .bm-blk .bm-card{width:100%;height:100%;margin:0;background:transparent;border:0;box-shadow:none;overflow:hidden}
.bm-ftext{font-weight:900;line-height:1.12;text-shadow:0 2px 12px rgba(0,0,0,.4);padding:0 1vw;box-sizing:border-box}

/* ===== Host: scherm-editor ===== */
.bme-tools{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 6px}
.bme-tools .mzb-btn{padding:9px 11px;font-size:13px;flex:0 0 auto}
.bme-tools .mzb-btn.on{background:var(--gold);color:#06122e;font-weight:800}
.bme-tools .mzb-in{flex:1 1 38%}
.bme-canvas{position:relative;width:100%;aspect-ratio:16/9;border:1px solid var(--line);border-radius:12px;overflow:hidden;touch-action:none;margin:6px 0;background:linear-gradient(135deg,#0b1838,#0a0f24);box-shadow:inset 0 0 40px rgba(0,0,0,.4)}
.bme-blk{position:absolute;box-sizing:border-box;border:2px solid rgba(255,255,255,.32);border-radius:9px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;cursor:move;-webkit-user-select:none;user-select:none;overflow:hidden;touch-action:none}
.bme-blk.sel{border-color:var(--gold);box-shadow:0 0 0 2px rgba(255,194,60,.45),0 4px 14px rgba(0,0,0,.3);z-index:5}
.bme-lbl{font-size:12px;font-weight:800;color:#dfe7ff;text-align:center;padding:2px 6px;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:96%}
.bme-rs{position:absolute;right:-3px;bottom:-3px;width:20px;height:20px;background:var(--gold);border:2px solid #06122e;border-radius:5px;cursor:nwse-resize;touch-action:none;z-index:6}
.bme-insp{margin-top:10px;padding:12px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.03)}
.bme-insp-h{font-weight:800;margin-bottom:6px;color:var(--gold)}
.bme-insp label{display:block;margin:8px 0 3px;font-size:12px;color:rgba(255,255,255,.75)}
.bme-bgrow{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.bme-bgrow .mzb-btn{padding:7px 10px;font-size:12px}
.bme-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.bme-actions .mzb-btn{padding:8px 11px;font-size:13px}

/* ===== Beamer-skins: gedeelde basis (1280×720, schaalt naar het scherm) ===== */
#beamerIn{ position:relative; }
.bmskin{ position:absolute; left:50%; top:50%; width:1280px; height:720px; transform-origin:center center; transform:translate(-50%,-50%) scale(1); border-radius:0; overflow:hidden; }
.sk-almost{ margin-top:14px; font-weight:800; font-size:20px; color:#ffcf6b; background:rgba(255,200,80,.12); border:1px solid rgba(255,200,80,.4); border-radius:999px; padding:8px 18px; animation:skpulse 1.4s ease-in-out infinite; }
@keyframes skpulse{ 0%,100%{ box-shadow:0 0 0 rgba(255,207,107,0);} 50%{ box-shadow:0 0 22px rgba(255,207,107,.6);} }
.sk-dim{ color:#9fb6e6; opacity:.7; }
.sk-music{ display:flex; flex-direction:column; align-items:center; gap:10px; }
.sk-note{ font-size:120px; line-height:1; } .sk-mtxt{ font-size:30px; font-weight:800; opacity:.92; }
.sk-word{ font-size:120px; font-weight:900; line-height:1; text-align:center; }
.sk-wait{ font-size:40px; opacity:.7; }
.sk-mq{ font-size:96px !important; color:#fff; }
.pop{ animation:skpop .8s cubic-bezier(.2,1.3,.35,1); }
@keyframes skpop{ 0%{ transform:translateY(-90px) scale(.6); opacity:0;} 60%{ opacity:1;} 100%{ transform:none; opacity:1;} }

/* ===== Skin: AVONDGALA ===== */
.skin-av{ background:radial-gradient(130% 120% at 50% -10%, #11463a 0%, #0a2c24 42%, #061d18 78%, #04130f 100%); color:#f4efe1; font-family:Inter,system-ui,sans-serif; }
.skin-av .spot{ position:absolute; inset:-20%; background:radial-gradient(closest-side, rgba(235,217,168,.16), rgba(235,217,168,0) 70%); filter:blur(6px); animation:avspot 11s ease-in-out infinite; }
@keyframes avspot{ 0%{transform:translate(-22%,-12%) scale(1.1)} 50%{transform:translate(24%,8%) scale(1.25)} 100%{transform:translate(-22%,-12%) scale(1.1)} }
.skin-av .grain{ position:absolute; inset:0; opacity:.05; background-image:radial-gradient(rgba(255,255,255,.7) .5px, transparent .6px); background-size:3px 3px; }
.skin-av .frame{ position:absolute; inset:22px; border:1.5px solid rgba(201,162,75,.65); border-radius:18px; box-shadow:0 0 0 7px rgba(201,162,75,.10) inset, 0 0 60px rgba(0,0,0,.45) inset; }
.skin-av .inner{ position:absolute; inset:40px 46px; display:grid; grid-template-columns:1fr 392px; grid-template-rows:auto 1fr; gap:26px 34px; }
.skin-av .masthead{ grid-column:1/-1; text-align:center; }
.skin-av .eyebrow{ font-size:13px; letter-spacing:.34em; text-transform:uppercase; color:#c9a24b; font-weight:600; }
.skin-av .title{ font-family:"Cormorant Garamond",Georgia,serif; font-weight:700; font-size:54px; line-height:.98; margin:4px 0 0; letter-spacing:.5px; }
.skin-av .title .sh{ background:linear-gradient(100deg,#f6f1e4 30%,#fff7df 45%,#c9a24b 55%,#f6f1e4 70%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; background-size:220% 100%; animation:avshine 6s linear infinite; }
@keyframes avshine{ 0%{background-position:140% 0} 100%{background-position:-40% 0} }
.skin-av .heroL{ grid-row:2; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.skin-av .ballwrap{ position:relative; width:332px; height:332px; display:grid; place-items:center; }
.skin-av .ring{ position:absolute; inset:-16px; border-radius:50%; -webkit-mask:radial-gradient(farthest-side, transparent calc(100% - 11px), #000 calc(100% - 11px)); mask:radial-gradient(farthest-side, transparent calc(100% - 11px), #000 calc(100% - 11px)); filter:drop-shadow(0 0 10px rgba(201,162,75,.5)); }
.skin-av .ball{ width:300px; height:300px; border-radius:50%; position:relative; overflow:hidden; background:radial-gradient(120px 120px at 38% 30%, #fffdf6 0%, #f3ead2 40%, #d9c79b 72%, #b89a59 100%); box-shadow:0 26px 50px rgba(0,0,0,.5), inset 0 -22px 40px rgba(120,90,30,.35), inset 0 16px 30px rgba(255,255,255,.7); display:grid; place-items:center; animation:avfloat 5.5s ease-in-out infinite; }
.skin-av .ball::after{ content:""; position:absolute; top:-60%; left:-30%; width:80%; height:160%; transform:rotate(18deg); background:linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent); animation:avsheen 6.5s ease-in-out infinite; }
@keyframes avsheen{ 0%,55%{left:-40%} 80%,100%{left:120%} }
@keyframes avfloat{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
.skin-av .ball .let{ position:absolute; top:42px; font-family:"Cormorant Garamond",serif; font-weight:700; font-size:34px; color:#9a7b32; }
.skin-av .ball .num{ font-family:"Cormorant Garamond",serif; font-weight:700; font-size:150px; line-height:1; color:#3a2c10; text-shadow:0 2px 0 rgba(255,255,255,.4); }
.skin-av .ball.pop{ animation:avpop .85s cubic-bezier(.2,1.3,.35,1), avfloat 5.5s ease-in-out infinite .85s; }
@keyframes avpop{ 0%{transform:translateY(-130px) scale(.7) rotate(-8deg); opacity:0} 60%{opacity:1} 75%{transform:translateY(10px) scale(1.04)} 100%{transform:translateY(0) scale(1)} }
.skin-av .count{ margin-top:22px; font-size:18px; color:#d9cfb4; } .skin-av .count b{ color:#f6f1e4; }
.skin-av .recent{ margin-top:14px; display:flex; gap:10px; align-items:center; }
.skin-av .recent .rl{ font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:#9d8a5e; margin-right:2px; }
.skin-av .tok{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-weight:700; font-size:19px; color:#f1e7cd; background:radial-gradient(circle at 38% 32%, rgba(255,255,255,.14), rgba(255,255,255,.03)); border:1.5px solid rgba(201,162,75,.55); box-shadow:inset 0 2px 6px rgba(0,0,0,.35); }
.skin-av .col{ grid-column:2; grid-row:2; display:flex; flex-direction:column; gap:22px; }
.skin-av .card{ background:linear-gradient(180deg, rgba(13,46,38,.72), rgba(7,28,23,.72)); border:1px solid rgba(201,162,75,.4); border-radius:14px; padding:18px 20px; box-shadow:0 18px 40px rgba(0,0,0,.35); }
.skin-av .card h3{ margin:0 0 12px; font-size:13px; letter-spacing:.28em; text-transform:uppercase; color:#c9a24b; font-weight:600; }
.skin-av .prize{ display:flex; align-items:center; gap:12px; padding:11px 4px; border-bottom:1px solid rgba(201,162,75,.16); position:relative; }
.skin-av .prize:last-child{ border-bottom:0; }
.skin-av .prize .m{ font-size:22px; width:30px; text-align:center; }
.skin-av .prize .pl{ flex:1; font-family:"Cormorant Garamond",serif; font-size:23px; font-weight:600; color:#f1ead7; }
.skin-av .prize .w{ font-size:16px; font-weight:700; color:#8fa39a; }
.skin-av .prize.won .w{ color:#f6e7b8; }
.skin-av .prize.won::after{ content:""; position:absolute; inset:0; border-radius:8px; background:linear-gradient(90deg, transparent, rgba(235,217,168,.18), transparent); background-size:240% 100%; animation:avsweep 3s linear infinite; }
@keyframes avsweep{ 0%{background-position:160% 0} 100%{background-position:-60% 0} }
.skin-av .join{ display:flex; align-items:center; gap:16px; }
.skin-av .qr{ width:96px; height:96px; border-radius:10px; background:#fff; padding:7px; flex:0 0 auto; } .skin-av .qr img{ width:100%; height:100%; display:block; }
.skin-av .join .jc{ font-family:"Cormorant Garamond",serif; font-weight:700; font-size:38px; letter-spacing:3px; color:#f6f1e4; line-height:1; }
.skin-av .join .js{ font-size:13px; color:#a9b3ab; margin-top:4px; }

/* ===== Skin: BROADCAST ===== */
.skin-bc{ background:linear-gradient(180deg,#0c1f44 0%, #091735 55%, #060f25 100%); color:#eaf1ff; font-family:Inter,system-ui,sans-serif; }
.skin-bc .studio{ position:absolute; inset:0; background:radial-gradient(70% 50% at 50% -6%, rgba(46,139,255,.28), rgba(46,139,255,0) 60%); }
.skin-bc .floor{ position:absolute; left:0; right:0; bottom:0; height:46%; opacity:.16; background:repeating-linear-gradient(90deg, transparent 0 78px, rgba(120,170,255,.5) 78px 79px); transform:perspective(420px) rotateX(62deg); transform-origin:bottom; -webkit-mask:linear-gradient(to top, #000, transparent); mask:linear-gradient(to top, #000, transparent); }
.skin-bc .top{ position:absolute; left:0; right:0; top:0; height:74px; display:flex; align-items:center; gap:14px; padding:0 26px; background:linear-gradient(180deg, rgba(7,16,38,.96), rgba(7,16,38,.78)); border-bottom:2px solid rgba(46,139,255,.5); }
.skin-bc .logo{ width:46px; height:46px; border-radius:9px; display:grid; place-items:center; font-family:Oswald,sans-serif; font-weight:700; font-size:22px; color:#0a1530; background:linear-gradient(135deg,#ffd45a,#ffb02e); box-shadow:0 0 18px rgba(255,196,60,.4); }
.skin-bc .ttl{ line-height:1; } .skin-bc .ttl .eye{ font-family:Oswald,sans-serif; font-weight:500; font-size:12px; letter-spacing:.34em; color:#7fb0ff; text-transform:uppercase; } .skin-bc .ttl .nm{ font-family:Oswald,sans-serif; font-weight:700; font-size:27px; letter-spacing:.04em; text-transform:uppercase; margin-top:2px; }
.skin-bc .right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.skin-bc .clock{ font-family:Oswald,sans-serif; font-weight:500; font-size:20px; color:#cfe0ff; }
.skin-bc .liveb{ display:flex; align-items:center; gap:8px; background:#e21b1b; color:#fff; font-family:Oswald,sans-serif; font-weight:600; font-size:15px; letter-spacing:.16em; padding:7px 13px; border-radius:6px; box-shadow:0 0 16px rgba(226,27,27,.5); }
.skin-bc .liveb .dot{ width:9px; height:9px; border-radius:50%; background:#fff; animation:bcpulse 1.2s ease-in-out infinite; }
@keyframes bcpulse{ 0%,100%{opacity:.35; transform:scale(.8)} 50%{opacity:1; transform:scale(1.25)} }
.skin-bc .accent{ position:absolute; left:0; right:0; top:74px; height:5px; background:linear-gradient(90deg,#2e8bff 0 60%, #ffc23c 60% 100%); box-shadow:0 2px 14px rgba(46,139,255,.5); }
.skin-bc .body{ position:absolute; left:26px; right:26px; top:96px; bottom:84px; display:grid; grid-template-columns:1fr 372px; gap:24px; }
.skin-bc .draw{ position:relative; border-radius:16px; overflow:hidden; padding:26px 30px; display:flex; flex-direction:column; justify-content:center; background:linear-gradient(160deg, rgba(20,42,86,.85), rgba(9,20,46,.85)); border:1px solid rgba(94,150,255,.35); box-shadow:0 20px 50px rgba(0,0,0,.4); }
.skin-bc .draw::before{ content:""; position:absolute; top:0; left:0; border-top:64px solid #ffc23c; border-right:64px solid transparent; opacity:.9; }
.skin-bc .swoosh{ position:absolute; inset:0; background:linear-gradient(105deg, transparent 40%, rgba(120,180,255,.18) 50%, transparent 60%); transform:translateX(-100%); animation:bcswoosh .9s ease; }
@keyframes bcswoosh{ from{transform:translateX(-100%)} to{transform:translateX(100%)} }
.skin-bc .deye{ font-family:Oswald,sans-serif; font-weight:500; letter-spacing:.3em; text-transform:uppercase; font-size:14px; color:#7fb0ff; }
.skin-bc .bigrow{ display:flex; align-items:center; gap:22px; margin:6px 0 2px; }
.skin-bc .letbadge{ width:96px; height:96px; flex:0 0 auto; border-radius:14px; display:grid; place-items:center; font-family:Oswald,sans-serif; font-weight:700; font-size:54px; color:#0a1530; background:linear-gradient(135deg,#5ea2ff,#2e8bff); box-shadow:0 0 26px rgba(46,139,255,.55); }
.skin-bc .bignum{ font-family:Oswald,sans-serif; font-weight:700; font-size:200px; line-height:.82; letter-spacing:-2px; color:#fff; text-shadow:0 6px 30px rgba(0,0,0,.45); overflow:hidden; }
.skin-bc .bignum .n{ display:inline-block; }
.skin-bc .bignum.flip .n{ animation:bcflip .55s cubic-bezier(.2,1,.3,1); }
@keyframes bcflip{ 0%{transform:translateY(46%); filter:blur(7px); opacity:0} 100%{transform:translateY(0); filter:blur(0); opacity:1} }
.skin-bc .cdwrap{ margin-top:14px; } .skin-bc .cdlab{ font-family:Oswald,sans-serif; font-weight:500; letter-spacing:.18em; text-transform:uppercase; font-size:12px; color:#9fb6e6; display:flex; justify-content:space-between; }
.skin-bc .cdbar{ margin-top:6px; height:8px; border-radius:6px; background:rgba(255,255,255,.12); overflow:hidden; } .skin-bc .cdfill{ height:100%; width:100%; background:linear-gradient(90deg,#2e8bff,#7fd0ff); box-shadow:0 0 12px rgba(46,139,255,.6); }
.skin-bc .recent{ margin-top:18px; display:flex; align-items:center; gap:9px; flex-wrap:wrap; } .skin-bc .recent .rl{ font-family:Oswald,sans-serif; font-weight:500; letter-spacing:.16em; text-transform:uppercase; font-size:12px; color:#9fb6e6; }
.skin-bc .tok{ width:48px; height:48px; border-radius:9px; display:grid; place-items:center; font-family:Oswald,sans-serif; font-weight:600; font-size:21px; color:#dfeaff; background:rgba(94,150,255,.16); border:1px solid rgba(94,150,255,.4); }
.skin-bc .rail{ display:flex; flex-direction:column; gap:18px; min-height:0; }
.skin-bc .panel{ background:linear-gradient(180deg, rgba(16,34,72,.9), rgba(9,20,46,.9)); border:1px solid rgba(94,150,255,.3); border-radius:14px; overflow:hidden; }
.skin-bc .ph{ font-family:Oswald,sans-serif; font-weight:600; letter-spacing:.14em; text-transform:uppercase; font-size:15px; color:#0a1530; padding:9px 16px; background:linear-gradient(90deg,#ffc23c,#ffb02e); }
.skin-bc .pb{ padding:8px 14px 12px; }
.skin-bc .prow{ display:flex; align-items:center; gap:10px; padding:9px 2px; border-bottom:1px solid rgba(120,160,240,.14); } .skin-bc .prow:last-child{ border-bottom:0; }
.skin-bc .prow .m{ font-size:19px; width:26px; text-align:center; } .skin-bc .prow .pl{ flex:1; font-weight:600; font-size:17px; color:#e8f0ff; } .skin-bc .prow .w{ font-family:Oswald,sans-serif; font-weight:600; font-size:15px; color:#8aa3cf; } .skin-bc .prow.won .w{ color:#ffd45a; }
.skin-bc .lrow{ display:flex; align-items:center; gap:11px; padding:8px 2px; } .skin-bc .lrow .rk{ font-family:Oswald,sans-serif; font-weight:700; font-size:16px; width:22px; color:#7fb0ff; } .skin-bc .lrow.top .rk{ color:#ffd45a; }
.skin-bc .bav{ width:30px; height:30px; border-radius:7px; display:grid; place-items:center; font-family:Oswald,sans-serif; font-weight:700; color:#0a1530; font-size:15px; }
.skin-bc .lrow .nm{ flex:1; font-weight:600; font-size:17px; } .skin-bc .lrow .mk{ display:flex; gap:3px; } .skin-bc .lrow .mk i{ width:7px; height:15px; border-radius:2px; background:rgba(255,255,255,.22); } .skin-bc .lrow .mk i.on{ background:#2e8bff; box-shadow:0 0 6px rgba(46,139,255,.7); }
.skin-bc .joinmini{ display:flex; align-items:center; gap:12px; padding:4px 2px 2px; } .skin-bc .joinmini .qr{ width:62px; height:62px; background:#fff; border-radius:8px; padding:5px; flex:0 0 auto; } .skin-bc .joinmini .qr img{ width:100%; height:100%; display:block; } .skin-bc .joinmini .jc{ font-family:Oswald,sans-serif; font-weight:700; font-size:28px; letter-spacing:2px; color:#fff; line-height:1; } .skin-bc .joinmini .js{ font-size:12px; color:#9fb6e6; margin-top:3px; }
.skin-bc .ticker{ position:absolute; left:0; right:0; bottom:0; height:58px; display:flex; align-items:center; background:linear-gradient(180deg, rgba(7,16,38,.96), rgba(5,11,28,.98)); border-top:2px solid rgba(46,139,255,.5); overflow:hidden; }
.skin-bc .tag{ flex:0 0 auto; height:100%; display:flex; align-items:center; padding:0 34px 0 20px; font-family:Oswald,sans-serif; font-weight:700; letter-spacing:.2em; font-size:18px; color:#0a1530; background:linear-gradient(135deg,#ffd45a,#ffb02e); clip-path:polygon(0 0,100% 0,86% 100%,0 100%); }
.skin-bc .track{ display:flex; white-space:nowrap; animation:bcmarq 26s linear infinite; }
.skin-bc .seq{ display:flex; align-items:center; }
.skin-bc .seq span{ font-family:Oswald,sans-serif; font-weight:500; font-size:19px; color:#dbe7ff; padding:0 22px; } .skin-bc .seq .gold{ color:#ffd45a; font-weight:600; } .skin-bc .seq .dotk{ color:#2e8bff; }
@keyframes bcmarq{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ===== Beamer video-overlay ===== */
.bm-video{ position:absolute; inset:0; z-index:55; display:none; background:#000; }
.bm-video.show{ display:block; }
.bm-video iframe,.bm-video video{ position:absolute; inset:0; width:100%; height:100%; }
.bm-video-h{ position:absolute; left:0; right:0; bottom:0; text-align:center; font-weight:700; font-size:18px; color:#fff; background:linear-gradient(0deg, rgba(0,0,0,.7), transparent); padding:14px; pointer-events:none; }

@media (prefers-reduced-motion: reduce){
  .skin-av .spot,.skin-av .ball,.skin-av .ball::after,.skin-av .title .sh,.skin-av .prize.won::after,.skin-bc .track,.skin-bc .liveb .dot,.skin-bc .swoosh,.sk-almost{ animation:none !important; }
}

/* ===== Skin: KLASSIEK KIEN (55+) — rustig, groot, hoog contrast ===== */
.skin-kien{ background:#f6efe0; color:#241a10; font-family:Inter,system-ui,sans-serif; }
.skin-kien .k-top{ position:absolute; left:0;right:0;top:0; height:84px; display:flex; align-items:center; justify-content:space-between; padding:0 40px; background:#7a1220; color:#fff; }
.skin-kien .k-title{ font-size:36px; font-weight:900; }
.skin-kien .k-count{ font-size:30px; font-weight:800; background:#fff; color:#7a1220; padding:4px 16px; border-radius:10px; }
.skin-kien .k-body{ position:absolute; left:0;right:0; top:84px; bottom:0; display:grid; grid-template-columns:46% 54%; }
.skin-kien .k-left{ display:flex; flex-direction:column; align-items:center; justify-content:center; padding:24px; border-right:3px solid #d8c9a8; }
.skin-kien .k-eye{ font-size:24px; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:#7a1220; }
.skin-kien .k-hero{ display:flex; flex-direction:column; align-items:center; }
.skin-kien .k-let{ font-size:56px; font-weight:900; color:#b08d3e; line-height:1; margin-top:6px; }
.skin-kien .k-num{ font-size:300px; font-weight:900; line-height:.9; color:#241a10; }
.skin-kien .k-num.kfade{ animation:kfade .5s ease; }
@keyframes kfade{ from{ opacity:0; transform:scale(.92);} to{ opacity:1; transform:none;} }
.skin-kien .k-sub2{ font-size:34px; font-weight:800; color:#7a1220; margin-top:8px; text-align:center; }
.skin-kien .k-cd{ font-size:26px; margin-top:18px; } .skin-kien .k-cd b{ color:#7a1220; }
.skin-kien .k-cdbar{ width:60%; height:12px; background:#e4d7bb; border-radius:8px; overflow:hidden; margin-top:8px; }
.skin-kien .k-cdfill{ height:100%; width:100%; background:#7a1220; }
.skin-kien .k-almost{ margin-top:16px; font-size:26px; font-weight:800; color:#7a1220; background:#ffe9b0; border:2px solid #e3b23a; border-radius:12px; padding:8px 18px; text-align:center; }
.skin-kien .k-right{ padding:18px 28px; display:flex; flex-direction:column; gap:14px; overflow:hidden; }
.skin-kien .k-bh{ font-size:22px; font-weight:900; color:#7a1220; margin-bottom:8px; text-transform:uppercase; letter-spacing:.05em; }
.skin-kien .k-bgrid{ display:grid; gap:5px; }
.skin-kien .k-bcell{ height:34px; display:grid; place-items:center; font-size:17px; font-weight:800; border-radius:6px; background:#eaddc0; color:#9a8a64; }
.skin-kien .k-bcell.on{ background:#7a1220; color:#fff; }
.skin-kien .k-prize{ display:flex; justify-content:space-between; font-size:23px; font-weight:700; padding:6px 2px; border-bottom:1px solid #e0d2b4; }
.skin-kien .k-prize b{ color:#0a7d3b; } .skin-kien .k-prize.won{ color:#0a7d3b; }
.skin-kien .k-join{ display:flex; align-items:center; gap:16px; margin-top:auto; background:#fff; border:2px solid #d8c9a8; border-radius:14px; padding:14px; }
.skin-kien .k-qr{ width:104px; height:104px; flex:0 0 auto; } .skin-kien .k-qr img{ width:100%; height:100%; display:block; }
.skin-kien .k-jc{ font-size:40px; font-weight:900; letter-spacing:3px; color:#241a10; line-height:1; }
.skin-kien .k-js{ font-size:18px; color:#5a4a30; margin-top:4px; }

/* ===== Skin: ORANJE (Koningsdag) — feestelijk ===== */
.skin-or{ background:radial-gradient(120% 100% at 50% -10%, #ff9d33 0%, #ff7a00 45%, #e85d04 78%, #c44a00 100%); color:#fff; font-family:Inter,system-ui,sans-serif; }
.skin-or .o-bunting{ position:absolute; top:0; left:0; right:0; height:34px; display:flex; justify-content:space-around; z-index:3; }
.skin-or .o-bunting i{ width:0; height:0; border-left:18px solid transparent; border-right:18px solid transparent; border-top:30px solid #fff; filter:drop-shadow(0 3px 2px rgba(0,0,0,.2)); }
.skin-or .o-bunting i.bf0{ border-top-color:#c1121f; } .skin-or .o-bunting i.bf1{ border-top-color:#fff; } .skin-or .o-bunting i.bf2{ border-top-color:#1a3a8f; }
.skin-or .o-top{ position:absolute; left:0;right:0; top:40px; height:72px; display:flex; align-items:center; gap:14px; padding:0 30px; }
.skin-or .o-crown{ font-size:46px; filter:drop-shadow(0 3px 6px rgba(0,0,0,.3)); }
.skin-or .o-ttl{ line-height:1; } .skin-or .o-eye{ font-size:14px; font-weight:800; letter-spacing:.24em; text-transform:uppercase; color:#ffe6c2; } .skin-or .o-nm{ font-size:36px; font-weight:900; text-shadow:0 3px 10px rgba(0,0,0,.25); }
.skin-or .o-right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.skin-or .o-flag{ width:54px; height:34px; border-radius:5px; box-shadow:0 2px 8px rgba(0,0,0,.3); background:linear-gradient(#ae1c28 0 33.3%, #fff 33.3% 66.6%, #21468b 66.6% 100%); }
.skin-or .o-right .clock{ font-weight:800; font-size:20px; color:#fff; }
.skin-or .o-body{ position:absolute; left:26px; right:26px; top:122px; bottom:26px; display:grid; grid-template-columns:1fr 372px; gap:22px; }
.skin-or .o-left{ display:flex; flex-direction:column; align-items:center; justify-content:center; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.3); border-radius:18px; padding:18px; }
.skin-or .deye{ font-size:14px; font-weight:800; letter-spacing:.26em; text-transform:uppercase; color:#ffe6c2; }
.skin-or .ballwrap{ position:relative; width:300px; height:300px; display:grid; place-items:center; margin:8px 0; }
.skin-or .ring{ position:absolute; inset:-14px; border-radius:50%; -webkit-mask:radial-gradient(farthest-side, transparent calc(100% - 10px), #000 calc(100% - 10px)); mask:radial-gradient(farthest-side, transparent calc(100% - 10px), #000 calc(100% - 10px)); filter:drop-shadow(0 0 8px rgba(255,255,255,.5)); }
.skin-or .oball{ width:268px; height:268px; border-radius:50%; position:relative; overflow:hidden; background:radial-gradient(100px 100px at 38% 30%, #fff 0%, #ffd9a0 38%, #ff9b3d 72%, #e8650a 100%); box-shadow:0 22px 44px rgba(0,0,0,.4), inset 0 -18px 34px rgba(150,60,0,.4), inset 0 14px 26px rgba(255,255,255,.7); display:grid; place-items:center; }
.skin-or .oball .let{ position:absolute; top:34px; font-size:30px; font-weight:900; color:#b9540a; }
.skin-or .oball .num{ font-size:150px; font-weight:900; line-height:1; color:#5a2600; text-shadow:0 2px 0 rgba(255,255,255,.4); }
.skin-or .oball.pop{ animation:skpop .8s cubic-bezier(.2,1.3,.35,1); }
.skin-or .ocount{ font-size:20px; margin-top:10px; } .skin-or .ocount b{ font-weight:900; }
.skin-or .orecent{ margin-top:10px; display:flex; gap:9px; align-items:center; }
.skin-or .orecent .rl{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:#ffe6c2; }
.skin-or .otok{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-weight:800; font-size:19px; color:#fff; background:rgba(255,255,255,.18); border:2px solid rgba(255,255,255,.5); }
.skin-or .o-cdbar{ width:70%; height:8px; background:rgba(255,255,255,.25); border-radius:6px; overflow:hidden; margin-top:12px; } .skin-or .o-cdfill{ height:100%; width:100%; background:#fff; }
.skin-or .o-rail{ display:flex; flex-direction:column; gap:16px; }
.skin-or .opanel{ background:rgba(255,255,255,.95); color:#3a1c00; border-radius:14px; padding:12px 14px; box-shadow:0 14px 30px rgba(0,0,0,.25); }
.skin-or .oph{ font-size:15px; font-weight:900; letter-spacing:.08em; text-transform:uppercase; color:#e8650a; margin-bottom:8px; }
.skin-or .oprize{ display:flex; align-items:center; gap:10px; padding:7px 2px; border-bottom:1px solid rgba(0,0,0,.08); } .skin-or .oprize:last-child{ border-bottom:0; }
.skin-or .oprize .m{ font-size:20px; width:26px; text-align:center; } .skin-or .oprize .pl{ flex:1; font-weight:700; font-size:18px; } .skin-or .oprize .w{ font-size:14px; font-weight:800; color:#8a7a60; } .skin-or .oprize.won .w{ color:#0a7d3b; }
.skin-or .olrow{ display:flex; align-items:center; gap:10px; padding:6px 2px; } .skin-or .olrow .rk{ font-weight:900; width:20px; color:#e8650a; } .skin-or .olrow.top .rk{ color:#c98a00; }
.skin-or .oav{ width:28px; height:28px; border-radius:7px; display:grid; place-items:center; font-weight:900; color:#fff; font-size:14px; }
.skin-or .olrow .nm{ flex:1; font-weight:700; font-size:17px; } .skin-or .olrow .mk{ display:flex; gap:3px; } .skin-or .olrow .mk i{ width:7px; height:14px; border-radius:2px; background:rgba(0,0,0,.15); } .skin-or .olrow .mk i.on{ background:#e8650a; }
.skin-or .ojoin{ display:flex; align-items:center; gap:12px; } .skin-or .oqr{ width:74px; height:74px; flex:0 0 auto; } .skin-or .oqr img{ width:100%; height:100%; display:block; } .skin-or .ojc{ font-size:28px; font-weight:900; letter-spacing:2px; line-height:1; } .skin-or .ojs{ font-size:12px; color:#8a7a60; margin-top:3px; }

/* ===== Speler: grote-letters-modus (toegankelijkheid / 55+) ===== */
body.mzb-big #mzb-player{ font-size:18px; }
body.mzb-big .mzb-h{ font-size:28px; }
body.mzb-big .mzb-now{ font-size:24px; padding:16px; }
body.mzb-big .mzb-cell{ min-height:88px; }
body.mzb-big .mzb-cell .t{ font-size:19px; line-height:1.15; }
body.mzb-big .mzb-cell .a{ font-size:14px; }
body.mzb-big .mzb-cell.free .t{ font-size:18px; }
body.mzb-big .mzb-bingo{ font-size:24px; padding:20px; }
body.mzb-big .mzb-btn{ font-size:17px; }
body.mzb-big .mzb-prizes .mzb-pz{ font-size:18px; }
body.mzb-big #bigText{ background:linear-gradient(135deg,#FFC23C,#FF7A59); color:#1a0d00; }

@media (prefers-reduced-motion: reduce){
  .skin-kien .k-num.kfade,.skin-or .oball.pop,.skin-or .o-crown{ animation:none !important; }
}
