*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --pine:#1a3322;--pine-mid:#2e5c40;--pine-light:#4a8c62;
  --cream:#f5f0e8;--cream-dark:#d9d0be;
  --gold:#c9a84c;--gold-light:#e8c86a;
  --mist:#8fa89a;--r:8px;
  --danger:#c0392b;--ok:#4a8c62;
  --ember:#e05c2a;--ember-light:#f07d4a;
}
html,body{height:100%;overflow:hidden}
body{
  font-family:'DM Mono',monospace;
  background:linear-gradient(120deg,#13271a,#1a3322,#203a28,#17311f);
  background-size:300% 300%;
  animation:bgFlow 22s ease infinite;
  color:var(--cream);
  height:100dvh;
  display:flex;
  flex-direction:column;
  position:relative
}
body::before{
  content:'';
  position:fixed;inset:-20%;
  background:
    radial-gradient(circle at 18% 24%,rgba(201,168,76,.10),transparent 23%),
    radial-gradient(circle at 80% 18%,rgba(74,140,98,.14),transparent 26%),
    radial-gradient(circle at 72% 74%,rgba(201,168,76,.06),transparent 22%),
    radial-gradient(circle at 28% 80%,rgba(255,255,255,.03),transparent 22%);
  filter:blur(40px);
  animation:floatGlow 20s ease-in-out infinite alternate;
  pointer-events:none;z-index:0
}
@keyframes bgFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes floatGlow{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(2%,-2%,0) scale(1.05)}}

.screen-backdrop{
  position:fixed;inset:0;z-index:0;
  background-size:cover;background-position:center;
  opacity:0;transition:opacity 0.15s ease;
  filter:brightness(.22) saturate(.7);
  pointer-events:none;
}
.screen-backdrop.show{opacity:1}

.screen{display:none;flex-direction:column;height:100dvh;align-items:center;justify-content:center;opacity:0;transition:opacity .35s ease;position:relative;z-index:1}
.screen.active{display:flex}
.screen.visible{opacity:1}

#start-screen{gap:2rem;position:relative;overflow:hidden}
.logo{position:relative;z-index:1;text-align:center}
.logo h1{font-family:'Playfair Display',serif;font-size:clamp(2.8rem,9vw,5rem);font-weight:900;line-height:1;letter-spacing:-2px;transform:translateY(20px);opacity:0;transition:transform .7s cubic-bezier(.16,1,.3,1),opacity .7s ease}
.logo h1.in{transform:translateY(0);opacity:1}
.logo h1 em{color:var(--gold);font-style:normal}
.logo p{font-size:.68rem;letter-spacing:.25em;color:var(--mist);margin-top:.5rem;text-transform:uppercase;transform:translateY(10px);opacity:0;transition:transform .6s cubic-bezier(.16,1,.3,1) .15s,opacity .6s ease .15s}
.logo p.in{transform:translateY(0);opacity:1}
.start-main{display:flex;flex-direction:column;gap:.9rem;width:min(360px,88vw);opacity:0;transform:translateY(18px);transition:transform .6s cubic-bezier(.16,1,.3,1) .25s,opacity .6s ease .25s}
.start-main.in{opacity:1;transform:translateY(0)}
.start-main .info-btn-small{width:100%;font-size:.8rem;padding:.75rem 1rem;color:var(--mist);text-align:center}
.big-btn{font-family:'DM Mono',monospace;font-size:.95rem;font-weight:500;padding:1rem 1.1rem;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:var(--cream);border-radius:14px;cursor:pointer;letter-spacing:.06em;transition:transform .12s,background .15s,border-color .15s,box-shadow .2s}
.big-btn:hover{transform:translateY(-1px);border-color:var(--gold);box-shadow:0 14px 40px rgba(0,0,0,.18);background:rgba(255,255,255,.07)}
.big-btn.primary{background:linear-gradient(135deg,rgba(201,168,76,.22),rgba(201,168,76,.09));border-color:rgba(201,168,76,.55)}
.big-btn.primary:hover{background:linear-gradient(135deg,rgba(201,168,76,.34),rgba(201,168,76,.15))}
.big-btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}
.big-btn.danger-btn{background:linear-gradient(135deg,rgba(192,57,43,.35),rgba(192,57,43,.15));border-color:rgba(192,57,43,.7);color:#f5b7b1;font-size:.8rem;padding:.7rem 1.2rem;border-radius:10px;letter-spacing:.08em}
.big-btn.danger-btn:hover{background:linear-gradient(135deg,rgba(192,57,43,.55),rgba(192,57,43,.28));border-color:var(--danger);transform:translateY(-1px);box-shadow:0 8px 24px rgba(192,57,43,.25)}

.start-btn-row{display:flex;gap:.55rem;align-items:center}
.start-btn-row .big-btn{flex:1}
.start-btn-row .info-btn-small{flex:1;text-align:center}
.start-btn-row .changelog-inline-btn{flex:1.6}
.info-btn-small{font-family:'DM Mono',monospace;font-size:.72rem;font-weight:500;padding:.75rem .9rem;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:var(--mist);border-radius:14px;cursor:pointer;letter-spacing:.06em;transition:transform .12s,background .15s,border-color .15s;white-space:nowrap}
.info-btn-small:hover{transform:translateY(-1px);border-color:var(--mist);background:rgba(255,255,255,.07);color:var(--cream)}

/* ── START ICON BUTTONS ── */
.start-icon-btns{display:flex;gap:.6rem;justify-content:center;align-items:center}
.start-icon-btn{position:relative;width:3.1rem;height:3.1rem;border-radius:14px;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:var(--cream);font-size:1.15rem;cursor:pointer;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:transform .15s,border-color .2s,background .2s;flex-shrink:0}
.start-icon-btn:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.1)}
.start-icon-btn[data-label="Unterstützen"]:hover{border-color:rgba(74,160,100,.7);background:rgba(74,160,100,.16);color:rgba(150,230,170,.9)}
.start-icon-btn[data-label="Mehr Guessr"]:hover,.mehr-guessr-btn:hover{border-color:rgba(140,70,220,.65);background:rgba(120,50,200,.15);color:rgba(190,140,255,.9)}
.start-icon-btn[data-label="Was ist neu?"]:hover{border-color:rgba(201,168,76,.7);background:rgba(201,168,76,.14);color:rgba(240,210,100,.9)}
.start-icon-btn::after{content:attr(data-label);position:absolute;bottom:calc(100% + .45rem);left:50%;transform:translateX(-50%) translateY(5px);background:rgba(12,28,18,.97);border:1.5px solid rgba(255,255,255,.13);border-radius:8px;padding:.3rem .65rem;font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.06em;white-space:nowrap;color:var(--cream);opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:20}
.start-icon-btn:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
#profile-btn{display:none}
#profile-btn:hover{border-color:var(--gold);background:rgba(201,168,76,.1)}

/* ── MEHR GUESSR DROPDOWN ── */
.mehr-guessr-wrap{position:relative;width:3.1rem;height:3.1rem;flex-shrink:0}
.mehr-guessr-btn{width:100%;height:100%}
.mehr-guessr-dropdown{display:none;position:absolute;bottom:calc(100% + .4rem);left:50%;transform:translateX(-50%);min-width:160px;background:rgba(18,35,25,.97);border:1.5px solid rgba(255,255,255,.14);border-radius:12px;overflow:hidden;z-index:200;box-shadow:0 12px 40px rgba(0,0,0,.45);backdrop-filter:blur(8px)}
.mehr-guessr-dropdown.open{display:block}
.mehr-guessr-item{display:flex;align-items:center;gap:.5rem;padding:.65rem .9rem;font-family:'DM Mono',monospace;font-size:.75rem;color:var(--cream);cursor:pointer;transition:background .12s;letter-spacing:.04em}
.mehr-guessr-item:hover{background:rgba(255,255,255,.07)}
.mehr-guessr-active{color:var(--gold);cursor:default}
.mehr-guessr-active:hover{background:transparent}
.mehr-guessr-check{font-size:.8rem;width:1rem;text-align:center;flex-shrink:0}

/* ── PLAY MENU: reworked compact grid ── */
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem;width:min(700px,94vw)}
/* Hero card spans full width */
.menu-card-hero{grid-column:1/-1;padding:1.3rem 1.5rem!important}
.menu-card-hero .menu-card-title{font-size:1.7rem!important;line-height:1.05}
.menu-card-hero .menu-card-sub{font-size:.78rem!important;max-width:none!important}
.menu-card-hero .menu-card-cta{font-size:.82rem!important;padding:.75rem 1.2rem!important}
/* Daily Challenge also spans full width */
.menu-card.daily-card{grid-column:1/-1}
.menu-card{
  padding:.95rem 1.1rem;
  border-radius:16px;
  border:1.5px solid rgba(255,255,255,.1);
  background:linear-gradient(160deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:.6rem 1rem;
  cursor:pointer;
  transition:transform .14s,border-color .2s,box-shadow .25s,background .2s;
  position:relative;overflow:hidden;
  box-shadow:0 4px 20px rgba(0,0,0,.12)
}
.menu-card:hover{transform:translateY(-2px);border-color:var(--gold);box-shadow:0 16px 45px rgba(0,0,0,.22);background:linear-gradient(160deg,rgba(255,255,255,.09),rgba(255,255,255,.04))}
.menu-card.survival-card:hover{border-color:var(--ember)}
.menu-card.daily-card:hover{border-color:rgba(201,168,76,.8)}
.menu-card-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .4s;filter:brightness(.25) saturate(.6);z-index:0}
.menu-card:hover .menu-card-bg{opacity:1}
.menu-card-left{position:relative;z-index:1;display:flex;flex-direction:column;gap:.2rem}
.menu-card-right{position:relative;z-index:1}
.menu-card-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;line-height:1.1}
.menu-card-sub{font-size:.65rem;color:var(--mist);line-height:1.6;max-width:22ch}
.menu-card-cta{font-family:'DM Mono',monospace;font-size:.72rem;font-weight:500;padding:.6rem .9rem;border:1.5px solid rgba(255,255,255,.15);background:rgba(255,255,255,.05);color:var(--cream);border-radius:10px;cursor:pointer;letter-spacing:.05em;transition:transform .1s,background .12s,border-color .12s;white-space:nowrap}
.menu-card-cta:hover{background:rgba(255,255,255,.1);border-color:var(--gold);transform:scale(1.03)}
.menu-card-cta.gold{background:linear-gradient(135deg,rgba(201,168,76,.2),rgba(201,168,76,.08));border-color:rgba(201,168,76,.5)}
.menu-card-cta.ember{background:linear-gradient(135deg,rgba(224,92,42,.2),rgba(224,92,42,.08));border-color:rgba(224,92,42,.5)}
.menu-back{margin-top:.6rem;width:min(180px,70vw)}

/* survival badge on card */
.survival-badge{display:inline-flex;align-self:flex-start;align-items:center;gap:.3rem;font-size:.55rem;letter-spacing:.12em;color:var(--ember);background:rgba(224,92,42,.1);border:1px solid rgba(224,92,42,.3);border-radius:20px;padding:.18rem .5rem;text-transform:uppercase;white-space:nowrap}
.survival-badge::before{content:'🔥';font-size:.55rem}

/* daily timer */
.daily-timer{font-family:'DM Mono',monospace;font-size:.85rem;color:var(--gold);letter-spacing:.1em;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.3);border-radius:8px;padding:.35rem .7rem;text-align:center;display:inline-block}
.daily-timer-small{font-size:.58rem;color:var(--gold);letter-spacing:.08em;background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.2);border-radius:6px;padding:.18rem .4rem;display:inline-flex;align-items:center;gap:.25rem;white-space:nowrap}
.daily-timer-small::before{content:'⏱';font-size:.6rem}

.footer-made{position:absolute;left:50%;bottom:1.2rem;transform:translateX(-50%);font-size:.62rem;letter-spacing:.09em;color:rgba(143,168,154,.55);border:1px solid rgba(143,168,154,.2);background:rgba(0,0,0,.2);padding:.4rem 1rem;border-radius:20px;pointer-events:none;white-space:nowrap;z-index:5}

/* ── Seitliche Boards (Nachricht des Tages links, Was ist neu rechts) — nur PC ── */
.side-board{position:absolute;top:50%;transform:translateY(-50%);width:268px;max-width:23vw;z-index:5;background:linear-gradient(165deg,rgba(20,40,28,.82),rgba(10,20,14,.86));border:1px solid rgba(201,168,76,.32);border-radius:16px;padding:1rem 1.05rem;box-shadow:0 18px 50px rgba(0,0,0,.4),inset 0 0 30px rgba(201,168,76,.05);backdrop-filter:blur(8px);text-align:left}
#motd-board{left:1.6rem;animation:sideBoardInL .6s cubic-bezier(.16,1,.3,1) both .35s}
#changelog-board{right:1.6rem;cursor:pointer;animation:sideBoardInR .6s cubic-bezier(.16,1,.3,1) both .35s;transition:border-color .2s,box-shadow .2s}
#changelog-board:hover{border-color:rgba(201,168,76,.55);box-shadow:0 22px 60px rgba(0,0,0,.5),inset 0 0 30px rgba(201,168,76,.08)}
@keyframes sideBoardInL{from{opacity:0;transform:translateY(-50%) translateX(-14px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}
@keyframes sideBoardInR{from{opacity:0;transform:translateY(-50%) translateX(14px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}
.motd-head{display:flex;flex-direction:column;gap:.15rem;margin-bottom:.55rem;padding-bottom:.5rem;border-bottom:1px solid rgba(201,168,76,.18)}
.motd-title{font-family:'DM Mono',monospace;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light)}
.motd-date{font-size:.62rem;color:var(--mist);text-transform:capitalize}
.motd-text{font-size:.8rem;line-height:1.5;color:var(--cream);white-space:pre-wrap;word-break:break-word}
.motd-text.empty{color:var(--mist);font-style:italic}
.motd-admin{display:flex;flex-direction:column;gap:.5rem;margin-top:.7rem;padding-top:.6rem;border-top:1px solid rgba(201,168,76,.18)}
.motd-input{width:100%;resize:vertical;min-height:3.4rem;font-family:inherit;font-size:.75rem;line-height:1.45;color:var(--cream);background:rgba(0,0,0,.28);border:1px solid rgba(201,168,76,.3);border-radius:10px;padding:.55rem .6rem}
.motd-input:focus{outline:none;border-color:var(--gold)}
#motd-save-btn{font-size:.72rem;padding:.55rem 1rem}
/* Changelog-Board: Liste der letzten Updates */
.cl-board-list{display:flex;flex-direction:column;gap:.55rem}
.cl-board-item{display:flex;gap:.5rem;align-items:flex-start}
.cl-board-ico{font-size:.95rem;flex-shrink:0;line-height:1.35}
.cl-board-meta{min-width:0;flex:1}
.cl-board-title{font-size:.77rem;color:var(--cream);font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cl-board-date{font-size:.58rem;color:var(--mist);margin-top:.05rem}
.cl-board-item.cl-new .cl-board-title{color:var(--gold-light)}
.cl-new-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#e8503a;margin-left:.35rem;vertical-align:middle;box-shadow:0 0 7px rgba(232,80,58,.75);animation:notifPulseDot 1.5s ease-in-out infinite}
@keyframes notifPulseDot{0%,100%{opacity:1}50%{opacity:.45}}
.cl-board-more{margin-top:.7rem;padding-top:.55rem;border-top:1px solid rgba(201,168,76,.18);font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.08em;color:var(--gold-light);text-align:right}
.cl-board-badge{font-family:'DM Mono',monospace;font-size:.5rem;letter-spacing:.12em;color:#fff;background:#e8503a;border-radius:6px;padding:.1rem .32rem;margin-left:.35rem;vertical-align:middle;animation:clBadgePulse 1.5s ease-in-out infinite}
@keyframes clBadgePulse{0%,100%{opacity:1}50%{opacity:.5}}
/* Roter Benachrichtigungs-Punkt am 📰-Button (Mobil) */
.start-icon-btn.has-notif::before{content:'';position:absolute;top:-3px;right:-3px;width:11px;height:11px;border-radius:50%;background:#e8503a;border:2px solid var(--pine,#16271c);box-shadow:0 0 0 0 rgba(232,80,58,.55);animation:notifPulseRing 1.6s ease-out infinite;z-index:21}
@keyframes notifPulseRing{0%{box-shadow:0 0 0 0 rgba(232,80,58,.55)}70%{box-shadow:0 0 0 9px rgba(232,80,58,0)}100%{box-shadow:0 0 0 0 rgba(232,80,58,0)}}
/* Sichtbarkeit: Boards nur auf breiten Screens (Laptop/PC); 📰-Button nur sonst */
@media(max-width:1079px){ .side-board{display:none} }
@media(min-width:1080px){ #changelog-icon-btn{display:none} }
.kofi-btn{display:block;width:100%;font-family:'DM Mono',monospace;font-size:.72rem;font-weight:500;letter-spacing:.06em;text-align:center;text-decoration:none;color:rgba(74,140,98,.9);background:rgba(74,140,98,.08);border:1.5px solid rgba(74,140,98,.25);border-radius:14px;padding:.7rem 1rem;transition:background .2s,border-color .2s,color .2s;cursor:pointer}
.kofi-btn:hover{background:rgba(74,140,98,.15);border-color:rgba(74,140,98,.5);color:#6bbf85}

/* streak display on start screen */
.streak-pill{display:inline-flex;align-items:center;gap:.4rem;font-size:.68rem;color:#f07d4a;background:rgba(224,92,42,.12);border:1px solid rgba(224,92,42,.3);border-radius:20px;padding:.3rem .75rem;letter-spacing:.05em;animation:streakPulse 2.5s ease-in-out infinite;cursor:default;transition:transform .15s,background .2s,box-shadow .2s;max-width:min(90vw,320px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.streak-pill:hover{transform:scale(1.06);background:rgba(224,92,42,.22);box-shadow:0 0 18px 4px rgba(224,92,42,.2)}
.streak-pill.popped{transform:scale(1.1);background:rgba(224,92,42,.28)}
.streak-pill .streak-num{font-size:.9rem;font-weight:700;color:#f07d4a}
@keyframes streakPulse{0%,100%{box-shadow:0 0 0 0 rgba(224,92,42,0)}50%{box-shadow:0 0 8px 2px rgba(224,92,42,.15)}}

#auth-btn{position:absolute;top:1rem;right:1rem;font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.1em;border:1.5px solid;padding:.5rem 1rem;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:.4rem;transition:color .2s,border-color .2s,background .2s,transform .12s,box-shadow .2s;z-index:5}
#auth-btn.logged-out{color:#7ec89a;border-color:rgba(74,140,98,.7);background:rgba(74,140,98,.18)}
#auth-btn.logged-out:hover{color:#fff;border-color:var(--ok);background:rgba(74,140,98,.35);transform:translateY(-1px);box-shadow:0 6px 18px rgba(74,140,98,.25)}
#auth-btn.logged-in{color:#f5b7b1;border-color:rgba(192,57,43,.6);background:rgba(192,57,43,.15)}
#auth-btn.logged-in:hover{color:#fff;border-color:var(--danger);background:rgba(192,57,43,.35);transform:translateY(-1px);box-shadow:0 6px 18px rgba(192,57,43,.25)}

#logout-confirm-overlay{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.7);align-items:center;justify-content:center;backdrop-filter:blur(6px)}
#logout-confirm-overlay.show{display:flex}
#logout-confirm-box{background:#1e3d2a;border:1.5px solid rgba(192,57,43,.5);border-radius:16px;padding:1.5rem;text-align:center;display:flex;flex-direction:column;gap:1rem;max-width:320px;width:90vw;box-shadow:0 25px 70px rgba(0,0,0,.4)}
#logout-confirm-box h3{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--cream)}
#logout-confirm-box p{font-size:.72rem;color:var(--mist);line-height:1.7}
.logout-confirm-btns{display:flex;gap:.65rem}
.logout-confirm-btns button{flex:1;font-family:'DM Mono',monospace;padding:.75rem;border-radius:10px;cursor:pointer;font-size:.78rem;border:1.5px solid;transition:.15s}
#logout-yes-btn{background:rgba(192,57,43,.25);border-color:rgba(192,57,43,.7);color:#f5b7b1}
#logout-yes-btn:hover{background:rgba(192,57,43,.45);color:#fff}
#logout-no-btn{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.15);color:var(--cream)}
#logout-no-btn:hover{border-color:var(--gold);background:rgba(255,255,255,.1)}

.saved-ok{display:flex;align-items:center;justify-content:center;gap:.45rem}
.saved-ok::before{content:'✓';font-weight:700}

/* info screen */
#info-screen{overflow-y:auto;padding:2rem;justify-content:flex-start;align-items:stretch}
.info-layout{max-width:min(680px,94vw);margin:0 auto;width:100%;display:flex;flex-direction:column;gap:1.8rem;padding:1rem 0 2rem}
.info-header{text-align:center;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.07)}
.info-header h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,7vw,3.5rem);font-weight:900;letter-spacing:-1px}
.info-header h1 em{color:var(--gold);font-style:normal}
.info-header p{font-size:.65rem;letter-spacing:.2em;color:var(--mist);margin-top:.4rem;text-transform:uppercase}
.info-section{background:linear-gradient(160deg,rgba(255,255,255,.055),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:1.5rem 1.8rem;display:flex;flex-direction:column;gap:.8rem}
.info-section-label{font-size:.58rem;letter-spacing:.22em;color:var(--gold);text-transform:uppercase;font-weight:500}
.info-section-title{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--cream)}
.info-section-body{font-size:.8rem;color:rgba(245,240,232,.82);line-height:1.9}
.info-contact-links{display:flex;flex-direction:column;gap:.55rem;margin-top:.3rem}
.info-contact-link{display:flex;align-items:center;gap:.7rem;font-size:.78rem;color:var(--cream);text-decoration:none;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:10px;padding:.7rem 1rem;transition:border-color .15s,background .15s,transform .1s}
.info-contact-link:hover{border-color:var(--gold);background:rgba(201,168,76,.07);transform:translateX(3px)}
.info-contact-link .ico{font-size:1rem;width:1.4rem;text-align:center}
.info-legal-warn{font-size:.68rem;color:var(--ember-light);background:rgba(224,92,42,.08);border:1px solid rgba(224,92,42,.25);border-radius:8px;padding:.7rem 1rem;line-height:1.7;margin-top:.2rem}
.info-back-row{display:flex;justify-content:center;padding-bottom:1rem}

/* daily screen */
#daily-screen{padding:2rem;justify-content:center;align-items:center;overflow-y:auto}
.daily-layout{width:min(1160px,94vw);display:grid;grid-template-columns:1.05fr 1.2fr;gap:1.2rem;align-items:stretch}
.daily-left,.daily-right{border-radius:20px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.025));box-shadow:0 20px 60px rgba(0,0,0,.16)}
.daily-left{padding:1.4rem;display:flex;flex-direction:column;justify-content:space-between;gap:1.2rem;position:relative;overflow:hidden}
.daily-left-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s ease;filter:brightness(.18) saturate(.6);z-index:0}
.daily-left-bg.loaded{opacity:1}
.daily-left>*:not(.daily-left-bg){position:relative;z-index:1}
.daily-right{padding:1.1rem 1.1rem 1rem;display:flex;flex-direction:column;gap:.85rem}
.daily-kicker{font-size:.62rem;letter-spacing:.18em;color:var(--mist);text-transform:uppercase}
.daily-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3rem);line-height:.98}
.daily-date{font-size:1rem;color:var(--gold)}
.daily-desc{font-size:.82rem;color:var(--cream);line-height:1.95;max-width:32ch}
.daily-actions{display:flex;flex-wrap:wrap;gap:.7rem}
.daily-board-title{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.daily-board-title h2{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700}
.daily-small{font-size:.62rem;color:var(--mist)}

/* streak on daily screen */
.daily-streak-display{display:flex;align-items:center;gap:.5rem;font-size:.72rem}
.daily-streak-fire{font-size:1rem}
.daily-streak-count{color:var(--ember-light);font-weight:700;font-size:.95rem}
.daily-streak-label{color:var(--mist)}

.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:200;align-items:center;justify-content:center;opacity:0;transition:opacity .25s}
.modal-bg.open{display:flex}
.modal-bg.visible{opacity:1}
.modal{background:#1e3d2a;border:1.5px solid rgba(255,255,255,.1);border-radius:12px;padding:1.75rem;width:min(440px,92vw);display:flex;flex-direction:column;gap:1rem;transform:translateY(16px);opacity:0;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .3s ease;box-shadow:0 25px 70px rgba(0,0,0,.35)}
.modal.in{transform:translateY(0);opacity:1}
.modal h2{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--cream)}
.modal-input{font-family:'DM Mono',monospace;font-size:.82rem;padding:.65rem .85rem;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--r);color:var(--cream);width:100%;outline:none;transition:border-color .15s}
.modal-input:focus{border-color:var(--gold)}
.modal-input::placeholder{color:var(--mist)}
.modal-row{display:flex;gap:.6rem}
.modal-hint{font-size:.63rem;color:var(--mist);line-height:1.7}
.modal-field-label{font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mist);opacity:.7}
.modal-error{font-size:.65rem;color:#e8826a;min-height:1em}
.divider{height:1px;background:rgba(255,255,255,.08);margin:.25rem 0}
.account-toggle{display:flex;gap:.65rem;align-items:center;margin-top:.35rem}
.toggle-btn{font-family:'DM Mono',monospace;font-size:.85rem;padding:.65rem 1.4rem;border-radius:10px;border:1.5px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);color:var(--mist);cursor:pointer;transition:border-color .15s,color .15s,background .15s,transform .1s;flex:1;text-align:center}
.toggle-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.12);transform:translateY(-1px)}
.toggle-btn:hover:not(.active){border-color:rgba(255,255,255,.3);color:var(--cream)}

/* vs modal */
#vs-modal .modal{width:min(680px,95vw)}
.vs-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.vs-panel{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:1rem;display:flex;flex-direction:column;gap:.65rem}
.vs-panel-title{font-size:.62rem;letter-spacing:.18em;color:var(--mist);text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.07);padding-bottom:.5rem}
.vs-panel .modal-input{font-size:.78rem;padding:.55rem .75rem}
.vs-panel .big-btn{font-size:.78rem;padding:.7rem .9rem}
.vs-scan-btn{display:none;font-family:'DM Mono',monospace;font-size:.72rem;padding:.6rem .9rem;border-radius:10px;border:1.5px solid rgba(201,168,76,.4);background:rgba(201,168,76,.08);color:var(--gold);cursor:pointer;transition:.15s;text-align:center;align-items:center;justify-content:center;gap:.4rem}
.vs-scan-btn:hover{background:rgba(201,168,76,.16);border-color:var(--gold)}
@media(max-width:768px){.vs-scan-btn{display:flex}.vs-modal-grid{grid-template-columns:1fr}}

/* leaderboard */
.lb-tabs{display:flex;gap:.45rem;flex-wrap:wrap}
.lb-tab{font-family:'DM Mono',monospace;font-size:.63rem;padding:.35rem .6rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:var(--mist);cursor:pointer;transition:.15s}
.lb-tab.active,.lb-tab:hover{border-color:var(--gold);color:var(--gold)}
.lb-sort-row{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center}
.lb-sort-label{font-size:.56rem;color:var(--mist);letter-spacing:.1em;text-transform:uppercase}
.lb-sort-btn{font-family:'DM Mono',monospace;font-size:.58rem;padding:.25rem .5rem;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.02);color:var(--mist);cursor:pointer;transition:.15s;display:flex;align-items:center;gap:.25rem}
.lb-sort-btn.active{border-color:var(--pine-light);color:var(--pine-light)}
.lb-sort-btn:hover:not(.active){border-color:rgba(255,255,255,.25);color:var(--cream)}
#lb-list,#daily-lb-list{display:flex;flex-direction:column;gap:.35rem;overflow-y:auto}
#lb-list{max-height:min(420px,55vh);padding-right:2px;overflow-y:auto}
#daily-lb-list{max-height:min(520px,60vh);padding-right:2px;overflow-y:auto}
.lb-row{display:flex;align-items:center;gap:.75rem;padding:.8rem .9rem;border-radius:12px;background:rgba(255,255,255,.04);font-size:.77rem;transform:translateX(-10px);opacity:0;transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .35s ease,background .15s;cursor:pointer;border:1px solid transparent}
.lb-row:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.08)}
.lb-row.in{transform:translateX(0);opacity:1}
/* ── Admin Accounts-Übersicht ── */
.aa-count{font-family:'DM Mono',monospace;font-size:.62rem;color:var(--mist);font-weight:400;letter-spacing:.05em}
#admin-accounts-inner{width:min(440px,94vw)}
.aa-list{display:flex;flex-direction:column;gap:.35rem;max-height:60vh;overflow-y:auto;margin-top:.6rem}
.aa-loading{font-size:.7rem;color:var(--mist);text-align:center;padding:1.4rem}
.aa-row{display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05)}
.aa-num{font-family:'DM Mono',monospace;font-size:.58rem;color:var(--mist);min-width:2.4rem;text-align:right;flex-shrink:0}
.aa-av{width:1.9rem;height:1.9rem;border-radius:50%;flex-shrink:0;background:rgba(201,168,76,.18);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--gold-light);border:1px solid rgba(255,255,255,.12)}
.aa-av.has{color:transparent}
.aa-meta{flex:1;min-width:0}
.aa-name{font-size:.82rem;color:var(--cream);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.aa-real{font-size:.62rem;color:var(--mist);margin-left:.4rem;font-weight:400}
.aa-sub{font-size:.58rem;color:var(--mist);margin-top:.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.aa-open{flex-shrink:0;background:none;border:1px solid rgba(201,168,76,.4);color:var(--gold-light);font-family:'DM Mono',monospace;font-size:.6rem;border-radius:8px;padding:.35rem .6rem;cursor:pointer;transition:.15s}
.aa-open:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.1)}
.lb-rank{width:1.6rem;text-align:right;color:var(--mist);font-size:.65rem;flex-shrink:0}
.lb-rank.gold{color:var(--gold);font-size:.9rem}
.lb-avatar{width:1.9rem;height:1.9rem;border-radius:50%;flex-shrink:0;background:rgba(201,168,76,.18);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:var(--gold-light);border:1px solid rgba(255,255,255,.12)}
.lb-avatar.has{color:transparent}
.lb-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .15s;font-size:.85rem}
.lb-name:hover{color:var(--gold)}
.lb-games{font-size:.6rem;color:var(--mist);flex-shrink:0}
.lb-score{color:var(--gold);font-weight:500;min-width:4.2rem;text-align:right;flex-shrink:0;font-size:.88rem}
.lb-date{font-size:.6rem;color:var(--mist);cursor:default;flex-shrink:0;min-width:3.1rem;text-align:right;white-space:nowrap}
.lb-profile-btn{background:none;border:1px solid rgba(255,255,255,.1);color:var(--mist);font-size:.58rem;font-family:'DM Mono',monospace;border-radius:7px;padding:.2rem .48rem;cursor:pointer;transition:.15s;flex-shrink:0;opacity:0;pointer-events:none}
.lb-row:hover .lb-profile-btn{opacity:1;pointer-events:auto}
.lb-profile-btn:hover{border-color:var(--gold);color:var(--gold)}
.lb-date{position:relative}.lb-date:hover::after{content:attr(data-time);position:fixed;left:var(--tt-x,50%);top:var(--tt-y,50%);transform:translate(-50%,-110%);background:#1e3d2a;border:1px solid rgba(255,255,255,.15);padding:.25rem .5rem;border-radius:5px;font-size:.58rem;white-space:nowrap;color:var(--cream);box-shadow:0 4px 14px rgba(0,0,0,.3);pointer-events:none;z-index:9999}
.lb-del{font-size:.6rem;color:var(--danger);cursor:pointer;padding:.15rem .4rem;border:1px solid var(--danger);border-radius:3px;display:none;background:transparent;font-family:'DM Mono',monospace}
.lb-del:hover{background:var(--danger);color:var(--cream)}
.admin-mode .lb-del{display:inline-block}
.lb-rename{font-size:.6rem;color:var(--mist);cursor:pointer;padding:.15rem .4rem;border:1px solid rgba(255,255,255,.15);border-radius:3px;display:none;background:transparent;font-family:'DM Mono',monospace;flex-shrink:0}
.lb-rename:hover{border-color:var(--gold);color:var(--gold)}
.admin-mode .lb-rename{display:inline-block}
.lb-add-entry{font-size:.6rem;color:var(--mist);cursor:pointer;padding:.15rem .4rem;border:1px solid rgba(255,255,255,.15);border-radius:3px;display:none;background:transparent;font-family:'DM Mono',monospace;flex-shrink:0}
.lb-add-entry:hover{border-color:rgba(100,200,130,.6);color:rgba(100,200,130,.9)}
.admin-mode .lb-add-entry{display:inline-block}
.admin-mode .lb-date{display:none}
.admin-mode .lb-profile-btn{display:none}
.lb-name[data-realname]{cursor:default}
.lb-name.lb-realname-shown{color:var(--gold)}
/* Beim Hover über den Namen: vollen Namen zeigen, kollidierende Spalten ausblenden */
.lb-name:hover{overflow:visible;text-overflow:clip}
.lb-name:hover~.lb-score,.lb-name:hover~.lb-date{display:none}
/* Touch: Hover-Inhalte per Tippen erreichbar */
.is-touch .lb-profile-btn{opacity:1;pointer-events:auto}
.is-touch .lb-name-tappable{cursor:pointer;text-decoration:underline dotted rgba(201,168,76,.45);text-underline-offset:3px}
.is-touch .lb-date{cursor:pointer;text-decoration:underline dotted rgba(143,168,154,.4);text-underline-offset:3px}
/* Schmale Screens: Name bekommt Vorrang, Datum/Abstände kompakter */
@media(max-width:480px){
  .lb-row{gap:.45rem;padding:.7rem .6rem}
  .lb-rank{width:1.25rem}
  .lb-avatar{width:1.7rem;height:1.7rem}
  .lb-score{min-width:3.4rem;font-size:.8rem}
  .lb-date{min-width:2.7rem;font-size:.56rem}
  .lb-name{font-size:.8rem;min-width:4.5rem}
}
#name-prompt-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.72);backdrop-filter:blur(6px);z-index:600}
#name-prompt-modal.show{display:flex}
#name-prompt-modal.show .modal{opacity:1;transform:translateY(0)}
.name-avail{font-size:.62rem;min-height:1em;transition:color .2s}
.name-avail.ok{color:#7ec89a}
.name-avail.taken{color:#e8826a}
.name-avail.checking{color:var(--mist)}
.lb-player-scores{width:100%;display:none;flex-direction:column;gap:.25rem;padding:.4rem 0 .4rem 2.2rem;border-top:1px solid rgba(255,255,255,.06);margin-top:.3rem;max-height:none;overflow-y:visible}
.lb-player-scores.open{display:flex}
.lb-sub-sort-row{display:flex;gap:.3rem;padding-bottom:.3rem}
.lb-sub-sort-btn{font-family:'DM Mono',monospace;font-size:.53rem;padding:.18rem .4rem;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.02);color:var(--mist);cursor:pointer;transition:.15s}
.lb-sub-sort-btn.active{border-color:var(--pine-light);color:var(--pine-light)}
.lb-sub-score{font-size:.62rem;color:var(--mist);display:flex;justify-content:space-between;padding:.18rem .4rem;border-radius:4px;background:rgba(255,255,255,.025)}
.lb-sub-score span:last-child{color:var(--gold)}

/* vs stuff */
.vs-code-display{font-size:2rem;font-weight:500;letter-spacing:.35em;color:var(--gold);text-align:center;padding:.5rem;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.25);border-radius:var(--r)}
.vs-status{font-size:.68rem;color:var(--mist);text-align:center}
.vs-waiting{display:flex;align-items:center;justify-content:center;gap:.5rem}
.vs-dot{width:6px;height:6px;border-radius:50%;background:var(--mist);animation:blink 1.2s infinite}
.vs-dot:nth-child(2){animation-delay:.2s}
.vs-dot:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.2}40%{opacity:1}}
#vs-qr-wrap{display:flex;flex-direction:column;align-items:center;gap:.6rem}
#vs-qr-canvas{border-radius:8px;background:#fff;padding:10px;width:160px;height:160px;image-rendering:pixelated}
.qr-hint{font-size:.58rem;color:var(--mist);text-align:center;letter-spacing:.1em;max-width:22ch;line-height:1.7}

#qr-join-screen{gap:1.5rem}
.qr-join-box{background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.1);border-radius:16px;padding:1.6rem;width:min(360px,90vw);display:flex;flex-direction:column;gap:1rem}
.qr-join-box h2{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700}
.qr-join-box .hint{font-size:.7rem;color:var(--mist);line-height:1.7}
#qr-join-room-code{font-size:.65rem;color:var(--gold);letter-spacing:.15em;margin-top:-.35rem}

/* game screen */
#game-screen{display:none;flex-direction:column;align-items:stretch;height:100dvh;position:relative;background:#000}
#game-screen.active{display:flex}
#back-to-home-btn{position:absolute;top:.75rem;left:.75rem;z-index:20;font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.08em;padding:.42rem .85rem;border-radius:20px;border:1.5px solid rgba(255,255,255,.18);background:rgba(0,0,0,.55);color:rgba(245,240,232,.7);cursor:pointer;transition:color .15s,border-color .15s,background .15s,transform .1s;backdrop-filter:blur(6px);white-space:nowrap}#back-to-home-btn:hover{color:var(--cream);border-color:var(--gold);background:rgba(0,0,0,.75);transform:translateY(-1px)}#pano-container{flex:1;min-width:0;min-height:0;position:relative;overflow:hidden;background:#111;cursor:grab;touch-action:none}
#pano-strip{display:flex;width:max-content;height:100%;will-change:transform;position:relative;contain:none}
#pano-strip img{height:100%;width:auto;flex-shrink:0;display:block;pointer-events:none;user-select:none;-webkit-user-drag:none;will-change:auto;backface-visibility:visible}
.pano-hint{position:absolute;bottom:1.1rem;left:50%;transform:translateX(-50%);font-size:.6rem;color:rgba(255,255,255,.3);letter-spacing:.18em;pointer-events:none;transition:opacity 1.2s}
#compass{position:absolute;top:.9rem;right:1rem;display:flex;align-items:center;gap:.4rem;background:rgba(0,0,0,.62);border:1px solid rgba(201,168,76,.35);border-radius:20px;padding:.3rem .8rem;font-size:.72rem;font-weight:500;color:var(--gold-light);letter-spacing:.12em;z-index:30;backdrop-filter:blur(6px);box-shadow:0 4px 16px rgba(0,0,0,.4)}
#compass .compass-needle{display:inline-block;font-size:.7rem;color:var(--gold);transition:transform .12s linear;will-change:transform;line-height:1}
#compass #compass-dir{min-width:1.4em;text-align:center}
#top-bar{position:absolute;top:.9rem;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:0;z-index:15;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.12);border-radius:999px;backdrop-filter:blur(12px);overflow:hidden}
#round-badge{background:transparent;border:none;border-right:1px solid rgba(255,255,255,.1);border-radius:0;padding:.45rem 1rem;font-size:.75rem;color:rgba(245,240,232,.7);letter-spacing:.04em;white-space:nowrap}
#score-badge{display:none}
#survival-badge{position:absolute;top:1rem;left:50%;transform:translateX(-50%);background:rgba(8,16,10,.82);border:1.5px solid rgba(224,92,42,.6);border-radius:var(--r);padding:.38rem 1rem;font-size:.68rem;color:var(--ember-light);letter-spacing:.08em;display:none;white-space:nowrap;z-index:12;backdrop-filter:blur(6px);box-shadow:0 0 18px rgba(224,92,42,.2)}
#survival-badge.show{display:block}

#survival-fail-overlay{display:none;position:fixed;inset:0;z-index:800;background:rgba(8,16,10,.96);backdrop-filter:blur(12px);flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;text-align:center;padding:2rem}
#survival-fail-overlay.show{display:flex}
.survival-fail-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,8vw,4rem);font-weight:900;color:var(--ember-light);line-height:1}
.survival-fail-round{font-size:.85rem;color:var(--mist);letter-spacing:.15em}
.survival-fail-score{font-size:clamp(1.2rem,5vw,2rem);color:var(--gold);margin-top:.5rem}
.survival-fail-pts{font-size:.72rem;color:var(--mist);margin-top:-.2rem}

#vs-badge{position:absolute;top:1rem;left:1rem;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:.28rem .7rem;font-size:.62rem;color:var(--mist);display:none}
#map-panel{position:absolute;bottom:1rem;right:1rem;width:300px;border-radius:12px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.5);border:1.5px solid rgba(255,255,255,.08);transition:width .28s cubic-bezier(.16,1,.3,1),box-shadow .2s,transform .2s}
#map-panel:hover{width:560px;box-shadow:0 18px 60px rgba(0,0,0,.65);transform:translateY(-2px)}
#map-panel.expanded{width:min(680px,92vw)!important}
#map-el{height:220px;width:100%;background:#1a3322;transition:height .28s cubic-bezier(.16,1,.3,1)}
#map-panel:hover #map-el{height:400px}
#map-panel.expanded #map-el{height:460px!important}
#map-footer{background:rgba(12,25,17,.97);padding:.5rem .65rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.map-btn{font-family:'DM Mono',monospace;font-size:.6rem;padding:.28rem .5rem;border-radius:5px;cursor:pointer;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);color:var(--cream);transition:background .1s,transform .1s}
.map-btn:hover{background:rgba(255,255,255,.12)}
.map-btn:active{transform:scale(.93)}
.map-btn-expand{font-size:.72rem!important;padding:.4rem .9rem!important;border-radius:8px!important;border-color:rgba(201,168,76,.5)!important;background:rgba(201,168,76,.12)!important;color:var(--gold)!important;font-weight:500;letter-spacing:.04em}
.map-btn-expand:hover{background:rgba(201,168,76,.25)!important;border-color:var(--gold)!important}
#guess-btn{font-family:'DM Mono',monospace;font-size:.82rem;font-weight:500;padding:.5rem 1.3rem;border-radius:7px;cursor:pointer;border:2px solid var(--gold);background:var(--gold);color:var(--pine);transition:opacity .15s,transform .1s,background .15s;white-space:nowrap}
#guess-btn:not(:disabled):hover{background:var(--gold-light);transform:scale(1.04)}
#guess-btn:not(:disabled):active{transform:scale(.97)}
#guess-btn:disabled{opacity:.28;cursor:not-allowed}
#pin-hint{font-size:.57rem;color:var(--mist);flex:1;text-align:center}
#vol-btn{position:absolute;bottom:1rem;left:1rem;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:.28rem .65rem;font-size:.6rem;color:var(--mist);cursor:pointer;z-index:10;transition:color .15s,border-color .15s}
#vol-btn:hover{color:var(--gold);border-color:var(--gold)}
#pano-error{display:none;position:absolute;inset:0;background:rgba(12,25,17,.92);flex-direction:column;align-items:center;justify-content:center;gap:1rem;z-index:20}
#pano-error.show{display:flex}
#pano-error p{font-size:.75rem;color:var(--mist);text-align:center;max-width:260px;line-height:1.8}
#round-popup{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%) scale(.95);background:rgba(12,25,17,.82);border:1px solid rgba(201,168,76,.35);border-radius:16px;padding:1rem 1.5rem;backdrop-filter:blur(8px);box-shadow:0 25px 80px rgba(0,0,0,.35);color:var(--cream);font-family:'Playfair Display',serif;font-size:clamp(1.1rem,4vw,1.7rem);z-index:400;opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s ease}
#round-popup.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
#round-popup span{color:var(--gold)}
#round-popup.ember span{color:var(--ember-light)}

#vs-left-msg{display:none;position:fixed;inset:0;z-index:800;background:rgba(12,25,17,.92);backdrop-filter:blur(10px);flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;text-align:center;padding:2rem}
#vs-left-msg.show{display:flex}
#vs-left-msg .left-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,6vw,3rem);color:var(--cream)}
#vs-left-msg .left-sub{font-size:.8rem;color:var(--mist);letter-spacing:.1em}

/* result screen */
#result-screen{background:var(--pine);gap:0}
#result-screen.active{display:flex;flex-direction:column;height:100dvh}
#result-map-el{flex:1;width:100%;min-height:0;position:relative;z-index:0}
#result-footer{background:rgba(0,0,0,.5);padding:1.1rem 1.4rem;display:flex;flex-direction:column;gap:.85rem}
.result-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.65rem}
.stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:var(--r);padding:.7rem;text-align:center;transform:translateY(12px);opacity:0;transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .5s ease}
.stat.in{transform:translateY(0);opacity:1}
.stat-label{font-size:.57rem;color:var(--mist);letter-spacing:.14em;text-transform:uppercase;margin-bottom:.25rem}
.stat-value{font-size:1.2rem;font-weight:500;color:var(--cream)}
.stat-value.gold{color:var(--gold)}
.stat-value.ember{color:var(--ember-light)}
.btn-row{display:flex;gap:.65rem;justify-content:center;flex-wrap:wrap}
#score-verdict{font-size:.7rem;color:var(--mist);text-align:center;letter-spacing:.08em;min-height:1.2em;transform:translateY(6px);opacity:0;transition:transform .5s ease .6s,opacity .5s ease .6s}
#score-verdict.in{transform:translateY(0);opacity:1}
#survival-threshold-row{display:none;background:rgba(224,92,42,.07);border:1px solid rgba(224,92,42,.22);border-radius:var(--r);padding:.55rem .75rem;font-size:.65rem;color:var(--ember-light);text-align:center;letter-spacing:.06em}
#survival-threshold-row.show{display:block}

#vs-strip{display:none;background:rgba(0,0,0,.3);border-radius:var(--r);padding:.5rem .8rem;font-size:.68rem}
.vs-strip-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.vs-strip-name{color:var(--mist)}
.vs-strip-score{color:var(--gold);font-weight:500;min-width:3rem;text-align:right}
.vs-strip-bar-wrap{flex:1;height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.vs-strip-bar{height:100%;background:var(--gold);border-radius:2px;width:0%;transition:width .8s cubic-bezier(.16,1,.3,1)}
#vs-bottom-wait{display:none;text-align:center;font-size:.66rem;color:var(--mist);letter-spacing:.08em}
#vs-bottom-wait.show{display:block}

#final-screen{gap:1.75rem;background:var(--pine)}
.final-title{font-family:'Playfair Display',serif;font-size:clamp(1.4rem,5vw,2.3rem);font-weight:900;text-align:center}
.final-score-big{font-size:clamp(3rem,12vw,5.5rem);font-weight:500;color:var(--gold);text-align:center;line-height:1}
.final-sub{font-size:.68rem;color:var(--mist);text-align:center;letter-spacing:.15em}
.final-breakdown{display:flex;flex-direction:column;gap:.35rem;width:min(320px,90vw)}
.final-row{display:flex;justify-content:space-between;font-size:.72rem;padding:.38rem .55rem;border-radius:5px;background:rgba(255,255,255,.04);transform:translateX(-12px);opacity:0;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .4s ease}
.final-row.in{transform:translateX(0);opacity:1}
.final-row.survival-fail-row{border-left:2px solid var(--ember);background:rgba(224,92,42,.06)}
#vs-result-box{display:none;background:linear-gradient(160deg,rgba(0,0,0,.42),rgba(0,0,0,.3));border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:1.1rem 1.2rem;width:min(360px,92vw);text-align:center;box-shadow:0 14px 44px rgba(0,0,0,.35)}
#vs-result-box.show{display:block}
.vs-winner{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:900;color:var(--gold);margin-bottom:.7rem;line-height:1.15}
.vs-winner.win{color:var(--gold-light);text-shadow:0 0 18px rgba(201,168,76,.45)}
.vs-winner.lose{color:var(--mist)}
.vs-winner.tie{color:var(--cream)}
.vs-compare{display:grid;grid-template-columns:1fr auto 1fr;gap:.6rem;align-items:center;font-size:.82rem;font-weight:500;padding-bottom:.6rem;border-bottom:1px solid rgba(255,255,255,.08)}
.vs-compare .you{text-align:right;color:var(--gold)}
.vs-compare .them{text-align:left;color:var(--cream-dark)}
.vs-compare .vs-sep{color:rgba(255,255,255,.25);font-size:.62rem;letter-spacing:.1em}
.vs-rounds{display:flex;flex-direction:column;gap:.25rem;margin-top:.65rem}
.vs-round-row{display:grid;grid-template-columns:1fr 2.2rem 1fr;align-items:center;font-family:'DM Mono',monospace;font-size:.72rem;padding:.22rem .1rem;opacity:0;transform:translateY(6px);transition:opacity .35s ease,transform .35s cubic-bezier(.16,1,.3,1)}
.vs-round-row.in{opacity:1;transform:translateY(0)}
.vs-round-row.vs-round-head{opacity:1;transform:none;font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mist);border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:.3rem;margin-bottom:.15rem}
.vrr-you{text-align:right;color:var(--cream-dark);padding-right:.5rem}
.vrr-them{text-align:left;color:var(--cream-dark);padding-left:.5rem}
.vrr-lbl{text-align:center;color:var(--mist);font-size:.56rem}
.vrr-you.w{color:var(--gold-light);font-weight:500}
.vrr-them.w{color:var(--gold-light);font-weight:500}

/* ── End-of-round Rang-Panel ── */
#rank-panel{position:absolute;left:clamp(1rem,3vw,2.5rem);top:50%;transform:translateY(-50%) translateX(-18px);width:min(310px,30vw);opacity:0;pointer-events:none;z-index:6;transition:opacity .5s ease,transform .5s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;gap:.55rem}
#rank-panel.show{opacity:1;transform:translateY(-50%) translateX(0)}
#rank-panel:not(.show) .rank-rows,#rank-panel:not(.show){display:flex}
.rank-panel-head{display:flex;align-items:center;gap:.45rem;font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);opacity:.85;padding-left:.2rem}
.rank-panel-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px 1px rgba(201,168,76,.6)}
.rank-rows{position:relative;display:flex;flex-direction:column;gap:.5rem}
.rank-slot{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:12px;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.025));border:1px solid rgba(255,255,255,.08);box-shadow:0 6px 18px rgba(0,0,0,.22);backdrop-filter:blur(6px);will-change:transform}
.rank-slot .rank-num{flex-shrink:0;width:1.9rem;text-align:center;font-family:'DM Mono',monospace;font-size:.82rem;font-weight:500;color:var(--mist)}
.rank-slot.podium .rank-num{font-size:1.05rem}
.rank-slot .rank-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.86rem;color:var(--cream);display:flex;align-items:center;gap:.45rem}
.rank-slot .rank-pts{flex-shrink:0;font-family:'DM Mono',monospace;font-size:.86rem;font-weight:500;color:var(--cream-dark);font-variant-numeric:tabular-nums}
.rank-you{font-family:'DM Mono',monospace;font-size:.5rem;letter-spacing:.1em;background:var(--gold);color:#1a2e0e;border-radius:5px;padding:.1rem .32rem;font-weight:700}
.rank-slot.me{border-color:rgba(201,168,76,.55);background:linear-gradient(135deg,rgba(201,168,76,.22),rgba(201,168,76,.07));box-shadow:0 8px 26px rgba(201,168,76,.22)}
.rank-slot.me .rank-num,.rank-slot.me .rank-pts{color:var(--gold-light)}
.rank-slot.me.hs{animation:rankPulse 1.4s ease-in-out 1}
.rank-slot.me.lifting{z-index:9;box-shadow:0 22px 48px rgba(0,0,0,.5),0 0 28px rgba(201,168,76,.35);border-color:var(--gold)}
.rank-slot.me.dropping{transition:transform 1.05s cubic-bezier(.32,1.25,.4,1),box-shadow 1.05s ease}
.rank-slot.pushed{transition:transform 1.05s cubic-bezier(.3,.9,.3,1)}
@keyframes rankPulse{0%,100%{box-shadow:0 8px 26px rgba(201,168,76,.22)}50%{box-shadow:0 8px 34px rgba(201,168,76,.5)}}
.rank-jump{align-self:center;display:none;align-items:center;gap:.5rem;font-family:'Playfair Display',serif;font-weight:900;margin-top:.15rem;opacity:0;transform:scale(.7);transition:opacity .35s ease,transform .45s cubic-bezier(.34,1.56,.5,1)}
.rank-jump.show{display:flex;opacity:1;transform:scale(1)}
.rank-jump-from{font-size:1.1rem;color:var(--mist);opacity:.7}
.rank-jump-arrow{font-size:1.1rem;color:var(--gold)}
.rank-jump-to{font-size:1.7rem;color:var(--gold-light);text-shadow:0 0 18px rgba(201,168,76,.5)}
.rank-note{align-self:center;font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.06em;color:var(--mist);text-align:center;opacity:0;transition:opacity .4s ease;max-width:100%}
.rank-note.show{opacity:.9}
.rank-overtake{align-self:center;text-align:center;font-family:'DM Mono',monospace;font-size:.72rem;color:var(--cream);max-width:300px;line-height:1.4;opacity:0;transform:translateY(6px);transition:opacity .5s ease,transform .5s cubic-bezier(.16,1,.3,1)}
.rank-overtake.show{opacity:1;transform:translateY(0)}
.rank-overtake b{color:var(--gold-light);font-weight:700}
@media(max-width:880px){
  #rank-panel{position:static;transform:translateX(-18px);top:auto;left:auto;width:min(340px,90vw);margin:0 auto}
  #rank-panel.show{transform:translateX(0)}
}
#round-flash{position:fixed;inset:0;background:rgba(201,168,76,.07);pointer-events:none;opacity:0;z-index:100;transition:opacity .15s}
#round-flash.on{opacity:1}
#round-flash.ember-flash{background:rgba(224,92,42,.09)}
#vs-wait-overlay{display:none;position:fixed;inset:0;background:radial-gradient(circle at 50% 42%,#0c140e 0%,#050805 70%,#020302 100%);z-index:1200;flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;text-align:center;padding:2rem}
#vs-wait-overlay.show{display:flex}
#vs-wait-overlay .wl{font-family:'Playfair Display',serif;font-size:clamp(1.3rem,4.5vw,2rem);font-weight:700;color:var(--cream);max-width:18ch;line-height:1.25;transition:opacity .4s ease}
#vs-wait-overlay .ws{font-size:.68rem;color:var(--mist);letter-spacing:.1em}
.vs-wait-spinner{width:42px;height:42px;border-radius:50%;border:3px solid rgba(201,168,76,.18);border-top-color:var(--gold);animation:vsSpin .8s linear infinite}
@keyframes vsSpin{to{transform:rotate(360deg)}}
#next-vote-bar{display:none;font-size:.65rem;color:var(--mist);text-align:center}
#next-vote-bar.show{display:block}
#next-vote-timer{display:inline-block;color:var(--gold);margin-left:.3rem}
#dc-notice{display:none;position:fixed;top:.75rem;left:50%;transform:translateX(-50%);background:#b03a2e;color:#fff;font-size:.65rem;padding:.4rem 1rem;border-radius:20px;z-index:300;white-space:nowrap}
#dc-notice.show{display:block}
#vs-their-guess-row{display:none;font-size:.67rem;color:var(--mist);text-align:center}
#play-again-vote{display:none;font-size:.65rem;color:var(--mist);text-align:center;margin-top:-.5rem}

#result-screen .result-stats,#result-screen #score-verdict,#result-screen #vs-strip,#result-screen #vs-their-guess-row,#result-screen #vs-bottom-wait,#result-screen #next-vote-bar,#result-screen .btn-row{transition:opacity .2s ease}

#confetti-layer{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:500}#new-highscore-banner{position:fixed;top:2rem;left:50%;transform:translateX(-50%) translateY(-120px);z-index:600;background:linear-gradient(135deg,rgba(201,168,76,.95),rgba(232,200,106,.9));color:#1a2e0e;font-family:'Playfair Display',serif;font-size:clamp(1rem,4vw,1.6rem);font-weight:900;padding:.65rem 2rem;border-radius:999px;box-shadow:0 8px 40px rgba(201,168,76,.55),0 2px 8px rgba(0,0,0,.3);letter-spacing:.02em;transition:transform .6s cubic-bezier(.16,1,.3,1),opacity .4s ease;opacity:0;white-space:nowrap}#new-highscore-banner.show{transform:translateX(-50%) translateY(0);opacity:1}
.confetti{position:absolute;top:-20px;width:10px;height:16px;opacity:.95;animation:fallConfetti linear forwards}
@keyframes fallConfetti{to{transform:translateY(110vh) rotate(760deg);opacity:1}}

.kbd-hint{display:inline-block;font-size:.5rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:3px;padding:.1rem .3rem;color:var(--mist);vertical-align:middle;margin-left:.35rem}.kbd-hint-dark{background:rgba(0,0,0,.45)!important;border-color:rgba(255,255,255,.22)!important;color:rgba(245,240,232,.6)!important}

/* Share card */
#share-canvas-wrap{display:none}

::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}

/* ── Draggable pin marker ── */
.map-pin-marker{position:relative;width:28px;height:36px;cursor:grab;filter:drop-shadow(0 3px 8px rgba(0,0,0,.5))}
.map-pin-marker::before{content:'';position:absolute;left:50%;top:100%;transform:translateX(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:10px solid #c9a84c}
.map-pin-dot{width:28px;height:28px;border-radius:50% 50% 50% 0;background:linear-gradient(135deg,var(--gold-light),var(--gold));border:2.5px solid rgba(255,255,255,.4);transform:rotate(-45deg);box-shadow:0 4px 18px rgba(201,168,76,.5);transition:transform .15s}
.map-pin-marker:hover .map-pin-dot{transform:rotate(-45deg) scale(1.12)}
@keyframes pinDrop{0%{transform:translateY(-28px) scale(.85);opacity:0}60%{transform:translateY(4px) scale(1.05);opacity:1}80%{transform:translateY(-3px) scale(.97)}100%{transform:translateY(0) scale(1);opacity:1}}
.pin-drop .map-pin-marker{animation:pinDrop .38s cubic-bezier(.16,1,.3,1) both}
.leaflet-pin-icon{overflow:visible!important;background:none!important;border:none!important}
@keyframes pinRing{0%{transform:translate(-50%,-50%) scale(.6);opacity:.8}100%{transform:translate(-50%,-50%) scale(2.2);opacity:0}}
.map-pin-marker::after{content:'';position:absolute;left:50%;top:50%;width:24px;height:24px;border-radius:50%;border:2px solid var(--gold);animation:pinRing .7s ease-out both}

/* ── VS submit countdown ── */
#vs-submit-countdown{display:none;font-size:.72rem;text-align:center;padding:.55rem .9rem;border-radius:var(--r);background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.22);color:var(--gold);letter-spacing:.06em;position:relative;overflow:hidden}
#vs-submit-countdown.show{display:block}
#vs-submit-countdown::before{content:'⏱ ';opacity:.7}

/* ── VS skip pano button ── */
#vs-skip-pano-btn{position:absolute;bottom:calc(180px + 1.5rem);left:50%;transform:translateX(-50%);font-family:'DM Mono',monospace;font-size:.65rem;letter-spacing:.1em;padding:.5rem 1.1rem;border-radius:20px;border:2px solid rgba(201,168,76,.7);background:rgba(26,51,34,.88);color:var(--gold-light);cursor:pointer;z-index:15;transition:background .15s,border-color .15s,transform .12s,box-shadow .2s;white-space:nowrap;display:none;backdrop-filter:blur(6px);box-shadow:0 4px 20px rgba(0,0,0,.5),0 0 12px rgba(201,168,76,.15);text-shadow:0 1px 3px rgba(0,0,0,.6)}
#vs-skip-pano-btn:hover{background:rgba(201,168,76,.22);border-color:var(--gold-light);transform:translateX(-50%) translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.6),0 0 20px rgba(201,168,76,.25)}
#vs-skip-pano-btn:disabled{opacity:.5;cursor:not-allowed}
@media(max-width:768px){#vs-skip-pano-btn{bottom:calc(165px + 1.2rem);font-size:.6rem;padding:.42rem .85rem}}

/* ── VS Zwischenauswertung: Kopf-an-Kopf-Karte ── */
#vs-their-guess-row{display:none;text-align:center}
.vs-h2h{display:flex;align-items:stretch;justify-content:center;gap:.55rem;animation:fadeInPts .45s ease both}
.vs-h2h-side{flex:1;max-width:9.5rem;padding:.55rem .45rem;border-radius:10px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.07);text-align:center;transition:background .25s,border-color .25s}
.vs-h2h-side.win{background:rgba(201,168,76,.13);border-color:rgba(201,168,76,.42)}
.vs-h2h-name{font-family:'DM Mono',monospace;font-size:.56rem;letter-spacing:.08em;color:var(--mist);margin-bottom:.22rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vs-h2h-side.win .vs-h2h-name{color:var(--gold-light)}
.vs-h2h-pts{font-size:1.1rem;font-weight:600;color:var(--cream);line-height:1.05}
.vs-h2h-side.win .vs-h2h-pts{color:var(--gold-light)}
.vs-h2h-dist{font-size:.58rem;color:var(--mist);margin-top:.12rem;letter-spacing:.02em}
.vs-h2h-mid{display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--gold);font-weight:700;min-width:.9rem}
@keyframes fadeInPts{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
/* ── Hinweis im Spiel: Gegner hat schon geraten ── */
#vs-opponent-guessed{position:absolute;top:3.1rem;left:50%;transform:translateX(-50%) translateY(-10px) scale(.96);z-index:60;display:none;opacity:0;
  font-family:'DM Mono',monospace;font-weight:700;font-size:.74rem;letter-spacing:.04em;white-space:nowrap;
  padding:.5rem 1.05rem;border-radius:22px;color:#231a04;
  background:linear-gradient(180deg,#f3d889,#d6ad48);border:1px solid rgba(255,240,200,.7);
  box-shadow:0 6px 22px rgba(0,0,0,.5),0 0 22px rgba(201,168,76,.45);
  transition:opacity .3s ease,transform .3s ease;pointer-events:none}
#vs-opponent-guessed.show{display:block;opacity:1;transform:translateX(-50%) translateY(0) scale(1);animation:vsHintPulse 1.4s ease-in-out infinite}
@keyframes vsHintPulse{0%,100%{box-shadow:0 6px 22px rgba(0,0,0,.5),0 0 18px rgba(201,168,76,.4)}50%{box-shadow:0 6px 26px rgba(0,0,0,.5),0 0 34px rgba(201,168,76,.75)}}
@media(max-width:768px){#vs-opponent-guessed{top:2.7rem;font-size:.64rem;padding:.42rem .85rem}}

/* ── VS-Zwischenauswertung: nur die zwei Kopf-an-Kopf-Karten ── */
#result-screen.mp-mode #inline-diff-rating,
#result-screen.mp-mode #vs-strip,
#result-screen.mp-mode #vs-submit-countdown,
#result-screen.mp-mode #next-vote-bar,
#result-screen.mp-mode .btn-row,
#result-screen.mp-mode #survival-threshold-row{display:none!important}
#result-screen.mp-mode #result-footer{max-height:46vh;overflow-y:auto}

/* ── Result screen revamp ── */
#result-footer{background:linear-gradient(180deg,rgba(10,22,14,.92),rgba(12,25,17,.98));padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.7rem;border-top:1px solid rgba(255,255,255,.06)}
.result-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.55rem}
.stat{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:.6rem .5rem;text-align:center;transform:translateY(12px);opacity:0;transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .5s ease}
.stat.in{transform:translateY(0);opacity:1}
.stat-label{font-size:.52rem;color:var(--mist);letter-spacing:.16em;text-transform:uppercase;margin-bottom:.3rem}
.stat-value{font-size:1.15rem;font-weight:500;color:var(--cream)}

/* ── VS strip hidden score ── */
.vs-score-hidden{color:rgba(143,168,154,.4);font-style:italic}

/* ── daily layout ── */
.daily-layout{margin-top:auto;margin-bottom:auto}.daily-champions-title{font-size:.6rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;padding:.6rem .5rem .4rem;border-top:1px solid rgba(255,255,255,.08);margin-top:.4rem}.champion-entry{display:flex;align-items:center;gap:.65rem;padding:.5rem .6rem;border-radius:8px;margin:.2rem 0;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03);transition:background .15s}.champion-entry:hover{background:rgba(255,255,255,.06)}.champion-medal{font-size:1.1rem;flex-shrink:0}.champion-name{flex:1;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.champion-score{font-size:.7rem;color:var(--gold);white-space:nowrap}.champion-gold{border-color:rgba(201,168,76,.3);background:rgba(201,168,76,.06)}.champion-silver{border-color:rgba(192,192,192,.2);background:rgba(192,192,192,.03)}.champion-bronze{border-color:rgba(180,130,90,.2);background:rgba(180,130,90,.03)}

@media(max-width:768px){
  .daily-layout{margin:0}
}

/* ────────────────────────────────────────
   SURVIVAL ROUND INTRO OVERLAY
──────────────────────────────────────── */
#survival-intro-overlay{
  display:none;position:fixed;inset:0;z-index:900;
  background:radial-gradient(ellipse at 50% 120%,#5a1800 0%,#2d0a00 30%,#120800 60%,#050d08 100%);
  flex-direction:column;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;
}
#survival-intro-overlay.show{display:flex}
#survival-intro-flames{position:absolute;inset:0;pointer-events:none}
#survival-flames-svg{position:absolute;bottom:0;left:0;width:100%;height:75%}
#survival-intro-content{
  position:relative;z-index:2;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  animation:survivalIntroIn .5s cubic-bezier(.16,1,.3,1) both;
}
@keyframes survivalIntroIn{from{opacity:0;transform:translateY(32px) scale(.9)}to{opacity:1;transform:none}}
#survival-intro-round-label{font-size:.6rem;letter-spacing:.38em;text-transform:uppercase;color:var(--ember-light);opacity:.85;text-shadow:0 0 20px rgba(224,92,42,.8)}
#survival-intro-round-num{
  font-family:'Playfair Display',serif;font-size:clamp(3.5rem,16vw,7rem);font-weight:900;line-height:1;
  color:var(--cream);
  text-shadow:0 0 80px rgba(255,140,0,.8),0 0 40px rgba(224,92,42,.9),0 4px 20px rgba(0,0,0,.9);
  animation:sNumPop .6s .1s cubic-bezier(.16,1,.3,1) both;
  filter:drop-shadow(0 0 30px rgba(255,120,0,.6));
}
@keyframes sNumPop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
#survival-intro-divider{width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--ember),#ffcc44,var(--ember),transparent);margin:.4rem 0;animation:sDivIn .6s .25s ease both;box-shadow:0 0 12px rgba(255,180,0,.6)}
@keyframes sDivIn{from{width:0;opacity:0}to{width:60px;opacity:1}}
#survival-intro-threshold-label{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--mist);opacity:.8}
#survival-intro-threshold-num{
  font-family:'Playfair Display',serif;font-size:clamp(2rem,8vw,3.8rem);font-weight:700;
  color:#ffcc44;text-shadow:0 0 40px rgba(255,204,68,.7),0 0 20px rgba(224,92,42,.6);
  animation:sNumPop .6s .2s cubic-bezier(.16,1,.3,1) both;
  filter:drop-shadow(0 0 16px rgba(255,180,0,.5));
}

/* ── SURVIVAL EXPLAIN / INTRO ── */
#survival-explain-overlay{display:none;position:fixed;inset:0;z-index:880;background:radial-gradient(ellipse at 50% 120%,#5a1800 0%,#2d0a00 32%,#120800 62%,#050d08 100%);align-items:center;justify-content:center;overflow:hidden;padding:1.2rem}
#survival-explain-overlay.show{display:flex}
#se-flames{position:absolute;inset:0;pointer-events:none}
#se-flames-svg{position:absolute;bottom:0;left:0;width:100%;height:62%}
#se-embers{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.se-card{position:relative;z-index:3;width:min(440px,94vw);text-align:center;display:flex;flex-direction:column;align-items:center;gap:.85rem;padding:1.6rem 1.4rem;border-radius:20px;background:linear-gradient(170deg,rgba(40,14,4,.72),rgba(20,8,4,.82));border:1px solid rgba(255,140,60,.28);box-shadow:0 24px 70px rgba(0,0,0,.55),inset 0 0 40px rgba(224,92,42,.08);backdrop-filter:blur(8px);animation:seCardIn .6s cubic-bezier(.16,1,.3,1) both}
@keyframes seCardIn{from{opacity:0;transform:translateY(36px) scale(.92)}to{opacity:1;transform:none}}
.se-badge{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ember-light);background:rgba(224,92,42,.14);border:1px solid rgba(224,92,42,.4);border-radius:999px;padding:.28rem .85rem;text-shadow:0 0 16px rgba(224,92,42,.6)}
.se-title{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,7vw,2.6rem);font-weight:900;color:var(--cream);line-height:1.05;margin:0;text-shadow:0 0 36px rgba(255,140,0,.5)}
.se-rules{display:flex;flex-direction:column;gap:.6rem;width:100%;margin:.3rem 0 .2rem;text-align:left}
.se-rule{display:flex;align-items:flex-start;gap:.7rem;font-size:.8rem;line-height:1.4;color:var(--cream-dark);opacity:0;transform:translateX(-10px);animation:seRuleIn .5s cubic-bezier(.16,1,.3,1) both}
.se-rule:nth-child(1){animation-delay:.22s}.se-rule:nth-child(2){animation-delay:.34s}.se-rule:nth-child(3){animation-delay:.46s}.se-rule:nth-child(4){animation-delay:.58s}
@keyframes seRuleIn{to{opacity:1;transform:none}}
.se-rule .se-ico{flex-shrink:0;font-size:1.05rem;line-height:1.3;filter:drop-shadow(0 0 8px rgba(255,140,0,.4))}
.se-rule b{color:#ffcc66;font-weight:700}
.se-start{margin-top:.4rem;border-color:rgba(255,140,60,.6)!important;background:linear-gradient(135deg,rgba(224,92,42,.4),rgba(224,92,42,.18))!important;color:#ffe0c0!important;animation:sePulse 1.8s ease-in-out infinite;font-size:1rem;padding:.85rem 2rem}
.se-start:hover{background:linear-gradient(135deg,rgba(224,92,42,.6),rgba(224,92,42,.3))!important;border-color:var(--ember-light)!important;transform:translateY(-1px)}
@keyframes sePulse{0%,100%{box-shadow:0 0 0 0 rgba(224,92,42,.45)}50%{box-shadow:0 0 28px 6px rgba(224,92,42,.35)}}

/* ── BLITZ INTRO OVERLAY (Strom-Theme, nutzt .se-card-Struktur) ── */
#blitz-explain-overlay{display:none;position:fixed;inset:0;z-index:880;background:radial-gradient(ellipse at 50% 120%,#3a3000 0%,#1a1a05 32%,#0a0e0a 62%,#050d08 100%);align-items:center;justify-content:center;overflow:hidden;padding:1.2rem}
#blitz-explain-overlay.show{display:flex}
#bz-bolts{position:absolute;inset:0;pointer-events:none;overflow:hidden;background:radial-gradient(ellipse at 50% 0%,rgba(255,214,80,.10),transparent 60%);animation:bzFlicker 3.2s ease-in-out infinite}
@keyframes bzFlicker{0%,100%{opacity:.55}45%{opacity:.9}70%{opacity:.4}}
.blitz-card-intro{border-color:rgba(255,214,80,.4)!important;box-shadow:0 24px 70px rgba(0,0,0,.55),inset 0 0 40px rgba(255,214,80,.08)!important}
.blitz-card-intro .se-badge{color:#ffe680;background:rgba(255,214,80,.14);border-color:rgba(255,214,80,.45);text-shadow:0 0 16px rgba(255,214,80,.6)}
.blitz-card-intro .se-title{text-shadow:0 0 36px rgba(255,214,80,.5)}
.blitz-card-intro .se-rule .se-ico{filter:drop-shadow(0 0 8px rgba(255,214,80,.45))}
.blitz-card-intro .se-rule b{color:#ffe680}
.blitz-card-intro .se-start{border-color:rgba(255,214,80,.6)!important;background:linear-gradient(135deg,rgba(255,200,60,.4),rgba(255,200,60,.18))!important;color:#fff4d0!important;animation:bzPulse 1.8s ease-in-out infinite}
.blitz-card-intro .se-start:hover{background:linear-gradient(135deg,rgba(255,200,60,.6),rgba(255,200,60,.3))!important;border-color:#ffe680!important}
@keyframes bzPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,214,80,.45)}50%{box-shadow:0 0 28px 6px rgba(255,214,80,.35)}}

/* ── PODIUM ANIMATIONS ── */
@keyframes podiumRise{
  from{opacity:0;transform:translateY(30px) scale(.9)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes medalBounce{
  from{transform:translateY(0) scale(1)}
  to{transform:translateY(-5px) scale(1.08)}
}
@keyframes podiumShimmer{
  0%{background-position:-200% 0}
  100%{background-position:200% 0}
}
.podium-slot-gold .podium-block{
  background:linear-gradient(180deg,rgba(255,215,0,.28) 0%,rgba(255,215,0,.1) 50%,rgba(255,215,0,.04) 100%)!important;
}
.podium-slot-silver .podium-block{
  background:linear-gradient(180deg,rgba(192,192,192,.22) 0%,rgba(192,192,192,.08) 50%,rgba(192,192,192,.03) 100%)!important;
}
.podium-slot-bronze .podium-block{
  background:linear-gradient(180deg,rgba(205,127,50,.22) 0%,rgba(205,127,50,.08) 50%,rgba(205,127,50,.03) 100%)!important;
}

/* ── IMPROVED SURVIVAL ANIMATIONS ── */
.flame-path{
  transform-origin:50% 100%;
  animation:flameDance var(--fd,1.9s) ease-in-out infinite alternate;
  opacity:var(--fo,.8);
  mix-blend-mode:screen;
}
.flame-glow{
  filter:blur(14px);
}
@keyframes flameDance{
  0%  {transform:scaleX(1)   scaleY(1)    skewX(0deg)  translateY(0)}
  15% {transform:scaleX(.72) scaleY(1.22) skewX(-12deg) translateY(-10px)}
  35% {transform:scaleX(1.28) scaleY(.84) skewX(10deg) translateY(5px)}
  55% {transform:scaleX(.8)  scaleY(1.18) skewX(-6deg) translateY(-7px)}
  75% {transform:scaleX(1.15) scaleY(.92) skewX(5deg)  translateY(3px)}
  100%{transform:scaleX(.88)  scaleY(1.2) skewX(-3deg) translateY(-5px)}
}

/* ── Improved embers ── */
@keyframes emberFloat{
  0%  {opacity:0;  transform:translateY(0)      translateX(0)                  scale(1)}
  12% {opacity:1}
  50% {opacity:.7; transform:translateY(-110px) translateX(calc(var(--ex,0px)*.5)) scale(.8)}
  85% {opacity:.2}
  100%{opacity:0;  transform:translateY(-200px) translateX(var(--ex,0px))     scale(.25)}
}
.survival-ember{
  position:absolute;width:4px;height:4px;border-radius:50%;
  pointer-events:none;
  animation:emberFloat var(--ed,2.5s) var(--edl,0s) ease-in infinite;
  box-shadow:0 0 6px 2px currentColor;
}
.survival-ember-big{width:8px;height:8px;box-shadow:0 0 10px 3px currentColor}

/* ── Heat shimmer on survival intro ── */
#survival-intro-overlay::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,100,0,.018) 3px);
  animation:shimmer 2s linear infinite;z-index:1;
}
@keyframes shimmer{0%{transform:translateY(0)}100%{transform:translateY(-10px)}}

/* ── Radial pulse behind content ── */
#survival-intro-content::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,120,0,.18) 0%,transparent 70%);
  animation:corePulse 1.8s ease-in-out infinite alternate;z-index:-1;
  pointer-events:none;
}
@keyframes corePulse{
  from{transform:translate(-50%,-50%) scale(.8);opacity:.6}
  to{transform:translate(-50%,-50%) scale(1.4);opacity:1}
}

/* ────────────────────────────────────────
   SURVIVAL SCORE REVEAL OVERLAY
──────────────────────────────────────── */
#survival-score-overlay{
  display:none;position:fixed;inset:0;z-index:850;
  background:rgba(8,16,10,.97);backdrop-filter:blur(24px) saturate(1.4);
  flex-direction:column;align-items:center;justify-content:center;overflow:hidden;
}
#survival-score-overlay.show{display:flex}
#survival-score-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
#survival-score-content{
  position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;
  gap:1.1rem;text-align:center;width:min(440px,92vw);
}
#survival-score-label{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--mist);animation:ssIn .35s ease both}
#survival-score-num{
  font-family:'Playfair Display',serif;font-size:clamp(4rem,18vw,8rem);font-weight:900;line-height:1;
  color:var(--ember-light);text-shadow:0 0 80px rgba(224,92,42,.5);min-width:3ch;text-align:center;
  transition:color .5s ease,text-shadow .5s ease;
}
#survival-score-num.passed{color:var(--gold);text-shadow:0 0 80px rgba(201,168,76,.55)}
#survival-score-num.failed{color:#e87a5a;text-shadow:0 0 60px rgba(232,122,90,.4)}
#survival-score-bar-wrap{width:100%;display:flex;flex-direction:column;gap:.5rem;animation:ssIn .35s .12s ease both}
#survival-score-bar-track{position:relative;height:12px;background:rgba(255,255,255,.07);border-radius:999px;overflow:visible}
#survival-score-bar-fill{
  height:100%;width:0%;border-radius:999px;
  background:linear-gradient(90deg,var(--ember),var(--ember-light),#f5a060);
  transition:width 2s cubic-bezier(.16,1,.3,1),background 1s .8s ease;
  box-shadow:0 0 14px rgba(224,92,42,.65);
}
#survival-score-bar-fill.passed{
  background:linear-gradient(90deg,var(--gold),var(--gold-light),#f0e080);
  box-shadow:0 0 18px rgba(201,168,76,.75);
}
#survival-score-threshold-marker{
  position:absolute;top:-7px;bottom:-7px;width:3px;
  background:rgba(255,255,255,.6);border-radius:2px;
  box-shadow:0 0 8px rgba(255,255,255,.35);
}
#survival-score-threshold-marker::after{
  content:'Ziel';position:absolute;bottom:calc(100% + 5px);left:50%;
  transform:translateX(-50%);
  font-size:.46rem;letter-spacing:.12em;color:rgba(255,255,255,.55);white-space:nowrap;font-family:'DM Mono',monospace;
}
#survival-score-bar-labels{position:relative;height:1.2rem;margin-top:.2rem;font-size:.52rem;color:rgba(143,168,154,.6);letter-spacing:.06em}
#survival-score-verdict{
  font-family:'Playfair Display',serif;font-size:clamp(1.4rem,6vw,2.4rem);font-weight:700;
  opacity:0;transform:translateY(10px);transition:opacity .6s ease,transform .6s ease;min-height:1.3em;
}
#survival-score-verdict.show{opacity:1;transform:none}
#survival-score-verdict.passed{color:var(--gold)}
#survival-score-verdict.failed{color:#e87a5a}
.ss-flame{
  position:absolute;bottom:0;
  width:var(--fw,40px);border-radius:50% 50% 28% 28%;
  background:radial-gradient(ellipse at 50% 90%,var(--fc,#e05c2a),transparent 72%);
  animation:ssFlameRise var(--fdd,2.2s) var(--fdel,0s) ease-in infinite;
  opacity:0;pointer-events:none;
}
@keyframes ssFlameRise{
  0%{opacity:0;transform:translateY(0) scaleX(1)}
  12%{opacity:.85}
  55%{opacity:.4;transform:translateY(calc(var(--fh,-200px))) scaleX(.65)}
  100%{opacity:0;transform:translateY(calc(var(--fh,-340px))) scaleX(.3)}
}
@keyframes ssIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ────────────────────────────────────────
   CHANGELOG
──────────────────────────────────────── */

/* "Was ist neu?" trigger button on start screen */
/* Logo click animation */
@keyframes logoBounce{0%{transform:translateY(0) scale(1)}15%{transform:translateY(-10px) scale(1.07) rotate(-2deg)}35%{transform:translateY(0) scale(.96) rotate(1deg)}55%{transform:translateY(-5px) scale(1.03) rotate(-1deg)}75%{transform:translateY(0) scale(1) rotate(.5deg)}100%{transform:translateY(0) scale(1) rotate(0)}}
@keyframes logoShimmer{0%{color:var(--gold)}50%{color:#fff5d0;text-shadow:0 0 24px rgba(201,168,76,.6)}100%{color:var(--gold)}}
#logo-h1{cursor:pointer}
#logo-h1.logo-pop{animation:logoBounce .7s cubic-bezier(.16,1,.3,1) forwards}
#logo-h1.logo-pop em{animation:logoShimmer .7s ease forwards}
#logo-h1.logo-woes{animation:woesWiggle .28s ease-in-out infinite;color:#fff5d0;text-shadow:0 0 22px rgba(201,168,76,.55)}
@keyframes woesWiggle{0%,100%{transform:scale(1) rotate(-1deg)}50%{transform:scale(1.05) rotate(1.2deg)}}
/* Inline changelog button next to Info */
.changelog-inline-btn{color:var(--gold)!important;border-color:rgba(201,168,76,.45)!important;background:rgba(201,168,76,.07)!important}
.changelog-inline-btn:hover{color:#fff5d0!important;border-color:var(--gold)!important;background:rgba(201,168,76,.16)!important;box-shadow:0 6px 18px rgba(201,168,76,.15)}
/* Was ist neu standalone button -- hidden now (moved inline) */
.changelog-btn{display:none!important}
.changelog-btn-hidden{
  position:absolute;bottom:1.2rem;left:1rem;
  font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.1em;
  border:1.5px solid rgba(201,168,76,.35);
  background:rgba(201,168,76,.06);
  color:var(--gold);
  padding:.4rem .85rem;border-radius:20px;cursor:pointer;
  transition:background .15s,border-color .15s,transform .12s,box-shadow .2s;
  z-index:5;white-space:nowrap;
}
.changelog-btn:hover{
  background:rgba(201,168,76,.16);border-color:var(--gold);
  transform:translateY(-1px);box-shadow:0 6px 18px rgba(201,168,76,.18);
}

/* Changelog modal override — wider, newspaper feel */
.changelog-modal-inner{
  width:min(600px,95vw)!important;
  max-height:88vh;
  overflow:hidden;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,#1a2e1a,#182816)!important;
  border-color:rgba(201,168,76,.25)!important;
  padding:0!important;gap:0!important;
}

/* masthead / header */
.changelog-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:1.4rem 1.6rem 1rem;
  border-bottom:2px solid rgba(201,168,76,.25);
  background:linear-gradient(180deg,rgba(201,168,76,.07),transparent);
  flex-shrink:0;
}
.changelog-masthead{display:flex;flex-direction:column;gap:.2rem}
.changelog-masthead-eyebrow{
  font-size:.5rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);opacity:.7;
}
.changelog-masthead-title{
  font-family:'Playfair Display',serif;font-size:2rem;font-weight:900;
  color:var(--cream);line-height:1;letter-spacing:-.5px;
}
.changelog-masthead-sub{font-size:.6rem;color:var(--mist);letter-spacing:.1em;margin-top:.15rem}
.changelog-masthead-line{
  width:100%;height:1px;
  background:linear-gradient(90deg,var(--gold),transparent);
  margin-top:.6rem;opacity:.4;
}
.changelog-close-btn{
  font-family:'DM Mono',monospace;font-size:.75rem;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  color:var(--mist);border-radius:6px;padding:.3rem .55rem;cursor:pointer;
  transition:color .15s,border-color .15s,background .15s;flex-shrink:0;margin-top:.2rem;
}
.changelog-close-btn:hover{color:var(--cream);border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.09)}

/* scrollable list */
.changelog-list{
  flex:1;overflow-y:auto;
  padding:1rem 1.4rem 1.2rem;
  display:flex;flex-direction:column;gap:1rem;
}

/* individual entry */
.cl-entry{
  background:rgba(255,255,255,.033);
  border:1px solid rgba(255,255,255,.07);
  border-radius:12px;padding:1rem 1.1rem;
  display:flex;flex-direction:column;gap:.65rem;
  transition:border-color .2s,background .2s;
}
.cl-entry:hover{border-color:rgba(201,168,76,.22);background:rgba(255,255,255,.05)}

.cl-entry-head{display:flex;align-items:flex-start;gap:.85rem}
.cl-entry-icon{font-size:1.65rem;line-height:1;flex-shrink:0;margin-top:.05rem}
.cl-entry-meta{flex:1;display:flex;flex-direction:column;gap:.2rem}
.cl-entry-title{
  font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;
  color:var(--cream);line-height:1.2;
}
.cl-entry-sub{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}
.cl-entry-version{
  font-size:.54rem;letter-spacing:.18em;text-transform:uppercase;
  background:rgba(201,168,76,.14);border:1px solid rgba(201,168,76,.35);
  color:var(--gold);border-radius:999px;padding:.12rem .5rem;
}
.cl-entry-date{font-size:.6rem;color:var(--mist);letter-spacing:.06em}

/* bullet list body */
.cl-entry-body{
  list-style:none;display:flex;flex-direction:column;gap:.4rem;
  padding-left:.5rem;
}
.cl-entry-body li{
  font-size:.77rem;color:rgba(245,240,232,.85);line-height:1.65;
  display:flex;align-items:flex-start;gap:.5rem;
}
.cl-entry-body li::before{
  content:'◆';color:var(--gold);font-size:.45rem;flex-shrink:0;margin-top:.3rem;opacity:.7;
}

/* optional image */
.cl-entry-img-wrap{border-radius:8px;overflow:hidden;max-height:220px}
.cl-entry-img{width:100%;height:auto;display:block;object-fit:cover}

/* admin action buttons inside entry */
.cl-admin-btns{display:flex;gap:.4rem;margin-left:auto;flex-shrink:0}
.cl-edit-btn,.cl-del-btn{
  font-family:'DM Mono',monospace;font-size:.56rem;padding:.25rem .5rem;
  border-radius:5px;cursor:pointer;border:1px solid;
  transition:background .12s,color .12s;
}
.cl-edit-btn{color:var(--gold);border-color:rgba(201,168,76,.4);background:rgba(201,168,76,.08)}
.cl-edit-btn:hover{background:rgba(201,168,76,.22);border-color:var(--gold)}
.cl-del-btn{color:#e8826a;border-color:rgba(232,130,106,.4);background:rgba(232,130,106,.07)}
.cl-del-btn:hover{background:rgba(192,57,43,.3);color:#fff;border-color:var(--danger)}

/* admin bar at bottom */
.changelog-admin-bar{
  padding:.75rem 1.4rem;
  border-top:1px solid rgba(255,255,255,.07);
  background:rgba(0,0,0,.25);
  display:flex;align-items:center;gap:.65rem;
  flex-shrink:0;
}

/* ── textarea in editor modal ── */
#cl-edit-body{
  min-height:120px;background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.15);color:var(--cream);
  border-radius:var(--r);padding:.65rem .85rem;
  font-size:.78rem;line-height:1.7;
}
#cl-edit-body:focus{border-color:var(--gold);outline:none}

@media(max-width:768px){
  .changelog-modal-inner{max-height:94vh}
  .changelog-header{padding:1rem 1rem .75rem}
  .changelog-masthead-title{font-size:1.5rem}
  .changelog-list{padding:.75rem .9rem}
  .cl-entry{padding:.85rem .9rem}
}

/* ────────────────────────────────────────
   RESPONSIVE
──────────────────────────────────────── */
@media(max-width:900px){
  .menu-grid{grid-template-columns:1fr 1fr}
  .daily-layout{grid-template-columns:1fr}
}
@media(max-width:768px){
  html,body{overflow:hidden;height:100dvh}
  .screen{width:100%;padding:.9rem}
  .logo h1{font-size:clamp(2.2rem,10vw,3.2rem);letter-spacing:-1px}
  .logo p{font-size:.6rem;letter-spacing:.14em}
  .start-main{width:min(94vw,380px);gap:.75rem}
  .big-btn{font-size:.85rem;padding:.85rem 1rem;border-radius:12px}
  .info-btn-small{font-size:.65rem;padding:.7rem .75rem}
  .menu-grid{width:100%;gap:.6rem}
  .menu-card{padding:.8rem .9rem}
  .menu-card-title{font-size:1.05rem}
  .menu-card-sub{font-size:.6rem;max-width:none;line-height:1.5}
  .menu-card-cta{font-size:.65rem;padding:.5rem .75rem}
  /* 2-up Karten (1v1 + Hitzewelle) vertikal stapeln, damit der Button nicht abgeschnitten wird */
  .menu-card:not(.menu-card-hero):not(.daily-card){display:flex;flex-direction:column;align-items:stretch;gap:.5rem}
  .menu-card:not(.menu-card-hero):not(.daily-card) .menu-card-left{gap:.25rem}
  .menu-card:not(.menu-card-hero):not(.daily-card) .menu-card-right{margin-top:auto;width:100%}
  .menu-card:not(.menu-card-hero):not(.daily-card) .menu-card-cta{display:block;width:100%;text-align:center}
  /* Daily screen: vollständig scrollbar, Buttons immer sichtbar */
  #daily-screen{padding:.75rem;justify-content:flex-start;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom,1rem)}
  .daily-layout{width:100%;grid-template-columns:1fr;gap:.65rem;overflow-y:visible;max-height:none;padding-bottom:.5rem}
  .daily-left,.daily-right{border-radius:14px;padding:.85rem}
  .daily-left{min-height:unset;gap:.7rem}
  .daily-actions{position:static;margin-top:.25rem;display:flex;flex-wrap:wrap;gap:.5rem;width:100%}
  .daily-actions .big-btn{flex:1;min-width:120px;padding:.8rem .6rem;font-size:.82rem}
  .daily-title{font-size:clamp(1.4rem,6vw,2rem)}
  .daily-desc{max-width:none;font-size:.72rem;line-height:1.65}
  /* Kein verschachteltes Scrollen auf Mobile — die ganze Seite scrollt, Board komplett sichtbar */
  .daily-right{max-height:none;overflow:visible}
  #daily-lb-list{max-height:none;overflow:visible}
  .daily-board-title h2{font-size:1.15rem}
  /* Game top-bar: auf Mobile kompakter, Schwierigkeits-Badge ausblenden */
  #top-bar{top:calc(.65rem + env(safe-area-inset-top));left:50%;transform:translateX(-50%);right:auto;max-width:calc(100vw - 8rem);flex-wrap:nowrap}
  #top-bar-diff{display:none!important}
  #round-badge{font-size:.58rem;padding:.28rem .65rem;white-space:nowrap}
  #score-badge{font-size:.58rem;padding:.28rem .65rem}
  #vs-badge{top:calc(.65rem + env(safe-area-inset-top));left:calc(.65rem + env(safe-area-inset-left));max-width:35vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  #compass{top:calc(.65rem + env(safe-area-inset-top));right:calc(.65rem + env(safe-area-inset-right))}
  #vol-btn{left:calc(.65rem + env(safe-area-inset-left));bottom:calc(165px + .9rem + env(safe-area-inset-bottom));z-index:12}
  #survival-badge{top:calc(3rem + env(safe-area-inset-top));font-size:.58rem;padding:.22rem .6rem}
  #back-to-home-btn{font-size:.56rem;padding:.38rem .7rem;top:calc(.55rem + env(safe-area-inset-top));left:calc(.55rem + env(safe-area-inset-left))}#map-panel{left:calc(.65rem + env(safe-area-inset-left));right:calc(.65rem + env(safe-area-inset-right));bottom:calc(.65rem + env(safe-area-inset-bottom));width:auto;border-radius:12px;transform:none!important}
  #map-panel:hover{width:auto;transform:none;box-shadow:0 8px 40px rgba(0,0,0,.5)}
  #map-el{height:140px}
  #map-panel:hover #map-el{height:140px}
  #map-panel.expanded{width:auto!important}
  #map-panel.expanded #map-el{height:50dvh!important}
  #map-footer{padding:.4rem .45rem;gap:.3rem}
  .map-btn{font-size:.54rem;padding:.23rem .4rem}
  #guess-btn{font-size:.72rem;padding:.44rem .9rem;white-space:nowrap}
  #pin-hint{font-size:.48rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  #result-footer{padding:.75rem;gap:.6rem}
  .result-stats{grid-template-columns:1fr;gap:.4rem}
  .stat{padding:.55rem}
  .stat-value{font-size:.95rem}
  .btn-row{flex-direction:column}
  .btn-row .big-btn{width:100%;font-size:.82rem;padding:.8rem}
  #vs-strip{padding:.45rem .6rem}
  .vs-strip-row{gap:.3rem}
  .vs-strip-name,.vs-strip-score{font-size:.6rem}
  .final-breakdown{width:min(94vw,380px)}
  /* Endbildschirm: von oben scrollbar statt zentriert-überlappt, mit Safe-Area */
  #final-screen{justify-content:flex-start;overflow-y:auto;gap:1rem;padding:calc(1.25rem + env(safe-area-inset-top)) 1rem calc(2.5rem + env(safe-area-inset-bottom))}
  #auth-btn{top:calc(1rem + env(safe-area-inset-top));right:calc(1rem + env(safe-area-inset-right))}
  .footer-made{bottom:calc(1.2rem + env(safe-area-inset-bottom))}
  .modal{width:min(96vw,440px);padding:1rem;border-radius:14px}
  .modal h2{font-size:1.15rem}
  .modal-row{flex-direction:column}
  .modal-row .big-btn{width:100%}
  #vs-qr-canvas{width:130px;height:130px}
  .footer-made{font-size:.56rem;padding:.32rem .75rem;bottom:.85rem}
  #auth-btn{top:.65rem;right:.65rem;font-size:.62rem;padding:.44rem .85rem}
  .account-toggle{gap:.5rem}
  .toggle-btn{font-size:.78rem;padding:.6rem 1rem}
  #vs-modal .modal{width:min(96vw,440px)}
  .kbd-hint{display:none}
  .info-layout{padding:.5rem 0 3rem}
  .info-section{padding:1rem 1.2rem}
  .changelog-btn{bottom:.85rem;left:.75rem;font-size:.58rem;padding:.35rem .7rem}
}
@media(max-width:380px){
  .logo h1{font-size:clamp(2rem,11vw,2.8rem)}
  .big-btn{font-size:.8rem;padding:.8rem .9rem}
}

/* ── PROFILE SCREEN ── */
.profile-layout{max-width:min(600px,94vw);margin:0 auto;width:100%;display:flex;flex-direction:column;gap:1.2rem;padding-bottom:2rem}
.profile-header{display:flex;align-items:center;gap:1.2rem;padding:1.2rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:18px}
.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--pine-light));display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:900;color:var(--pine);flex-shrink:0}
.profile-name{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700}
#profile-name-display[data-realname]{cursor:default;border-bottom:1px dashed rgba(201,168,76,.35);padding-bottom:1px}
.profile-since{font-size:.6rem;color:var(--mist);letter-spacing:.1em;margin-top:.2rem}
.profile-edit-btn{margin-top:.5rem;font-size:.62rem;letter-spacing:.04em;color:var(--gold);background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.4);border-radius:7px;padding:.32rem .7rem;cursor:pointer;transition:background .15s,border-color .15s}
.profile-edit-btn:hover{background:rgba(201,168,76,.2);border-color:rgba(201,168,76,.7)}
.profile-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:.6rem}
@media(max-width:500px){.profile-stats-grid{grid-template-columns:repeat(3,1fr)}}
.profile-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:.8rem .5rem;text-align:center}
.profile-stat-val{font-size:1.2rem;font-weight:500;color:var(--cream);line-height:1}
.profile-stat-val.gold{color:var(--gold)}
.profile-stat-val.ember{color:var(--ember-light)}
.profile-stat-label{font-size:.52rem;color:var(--mist);letter-spacing:.12em;text-transform:uppercase;margin-top:.3rem}
.profile-section-title{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);padding-bottom:.4rem;border-bottom:1px solid rgba(255,255,255,.07)}
.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.6rem;margin-top:.25rem}
.ach-item{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.9rem .7rem .75rem;border-radius:14px;border:1.5px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);transition:border-color .2s,background .2s;text-align:center;position:relative}
.ach-item:hover{border-color:rgba(201,168,76,.35);background:rgba(255,255,255,.07)}
.ach-item.ach-locked{opacity:.32;filter:grayscale(.85)}
.ach-item.ach-unlocked{border-color:rgba(201,168,76,.3);background:linear-gradient(160deg,rgba(201,168,76,.08),rgba(255,255,255,.03))}
.ach-icon{font-size:2rem;line-height:1}
.ach-info{flex:1}
.ach-title{font-size:.72rem;font-weight:600;color:var(--cream);letter-spacing:.02em}
.ach-desc{font-size:.57rem;color:var(--mist);margin-top:.2rem;line-height:1.4}
.ach-check{position:absolute;top:.45rem;right:.55rem;color:var(--gold);font-size:.7rem;font-weight:700}
.profile-score-row{display:flex;justify-content:space-between;font-size:.72rem;padding:.35rem .5rem;border-radius:5px;background:rgba(255,255,255,.03);margin-bottom:.25rem}
.profile-score-row .gold{color:var(--gold)}
#profile-btn:hover{border-color:var(--gold);background:rgba(201,168,76,.1)}

/* ── ACHIEVEMENT TOAST ── */
.achievement-toast{
  position:fixed;bottom:2rem;left:50%;
  transform:translateX(-50%) translateY(100px);
  background:linear-gradient(135deg,rgba(20,40,28,.97),rgba(15,30,20,.97));
  border:1.5px solid rgba(201,168,76,.5);border-radius:16px;
  padding:.9rem 1.3rem;display:flex;align-items:center;gap:.9rem;
  z-index:1000;box-shadow:0 20px 60px rgba(0,0,0,.55),0 0 0 1px rgba(201,168,76,.08);
  opacity:0;transition:transform .45s cubic-bezier(.16,1,.3,1),opacity .35s ease;
  min-width:260px;max-width:320px;
}
.achievement-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.ach-toast-icon{font-size:1.8rem;flex-shrink:0}
.ach-toast-title{font-size:.84rem;font-weight:600;color:var(--gold);letter-spacing:.02em}
.ach-toast-desc{font-size:.62rem;color:var(--mist);margin-top:.15rem;line-height:1.4}

/* ── DIFFICULTY OVERLAY ── */
#difficulty-overlay{display:none;position:fixed;inset:0;z-index:350;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);align-items:flex-end;justify-content:center;padding-bottom:2rem}
#difficulty-overlay.show{display:flex}
#difficulty-box{background:linear-gradient(160deg,#1e3d2a,#17311f);border:1.5px solid rgba(201,168,76,.35);border-radius:18px;padding:1.4rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.9rem;box-shadow:0 20px 60px rgba(0,0,0,.45);animation:diffIn .35s cubic-bezier(.16,1,.3,1) both}
@keyframes diffIn{from{transform:translateY(30px);opacity:0}to{transform:none;opacity:1}}
.diff-title{font-size:.75rem;color:var(--mist);letter-spacing:.1em}
.diff-stars{display:flex;gap:.3rem}
.diff-star{font-size:2rem;color:rgba(201,168,76,.25);background:none;border:none;cursor:pointer;transition:color .12s,transform .1s;line-height:1;padding:.1rem .15rem}
.diff-star.hover,.diff-star.active{color:var(--gold);transform:scale(1.15)}
.diff-skip{font-family:'DM Mono',monospace;font-size:.6rem;color:var(--mist);background:none;border:none;cursor:pointer;letter-spacing:.1em;padding:.3rem .6rem;border-radius:6px;transition:color .15s}
.diff-skip:hover{color:var(--cream)}
.diff-display{font-size:.68rem;color:var(--mist);text-align:center;padding:.4rem .7rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px}
.diff-label{color:var(--gold);font-weight:500}
.diff-count{color:var(--mist);font-size:.58rem}
#difficulty-display{display:none}

/* ── SCORE CHART ── */
#score-chart{border-radius:10px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.07);display:block}

/* ── ENTWICKLER BADGE ── */
.dev-badge{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#a3d4ff;background:rgba(80,150,255,.12);
  border:1px solid rgba(80,150,255,.4);border-radius:999px;
  padding:.15rem .65rem;margin-top:.25rem;
}

/* ── PROFIL: Zurück-Button oben + Badge-Reihe ── */
.profile-back-top{
  position:sticky;top:0;align-self:flex-start;z-index:6;
  font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.08em;
  padding:.45rem .9rem;border-radius:20px;cursor:pointer;
  border:1.5px solid rgba(255,255,255,.18);background:rgba(0,0,0,.62);
  color:rgba(245,240,232,.78);backdrop-filter:blur(6px);
  transition:color .15s,border-color .15s,background .15s,transform .1s;
}
.profile-back-top:hover{color:var(--cream);border-color:var(--gold);background:rgba(0,0,0,.82);transform:translateY(-1px)}
.profile-badges{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.4rem}
.profile-badge{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.56rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  border-radius:999px;padding:.16rem .6rem;white-space:nowrap;
  color:var(--gold-light);background:rgba(201,168,76,.13);border:1px solid rgba(201,168,76,.42);
}
.profile-badge.badge-gold1{color:#ffe39a;background:rgba(255,203,74,.16);border-color:rgba(255,203,74,.55)}
.profile-badge.badge-gold2{color:#e6e6ea;background:rgba(200,200,210,.14);border-color:rgba(200,200,210,.5)}
.profile-badge.badge-gold3{color:#f0b890;background:rgba(205,127,80,.15);border-color:rgba(205,127,80,.5)}
.profile-badge.badge-champ{color:#ffd66b;background:rgba(201,168,76,.18);border-color:rgba(201,168,76,.6)}
.profile-badge.badge-allach{color:#b9f0c4;background:rgba(80,200,120,.13);border-color:rgba(80,200,120,.45)}

/* ── TOP-BAR SCHWIERIGKEITS-BADGE ── */
#top-bar-diff{
  font-family:'DM Mono',monospace;font-size:.75rem;
  color:#e8c86a;letter-spacing:.04em;
  background:transparent;border:none;
  padding:.45rem 1.1rem;
  white-space:nowrap;
}

/* ── INLINE DIFFICULTY RATING IM RESULT-FOOTER ── */
#inline-diff-rating{
  text-align:center;padding:.6rem .5rem .4rem;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:10px;
}
.inline-diff-label{font-size:.62rem;color:var(--mist);letter-spacing:.08em;margin-bottom:.35rem}
.inline-diff-stars{display:flex;gap:.2rem;justify-content:center}
.inline-diff-confirmed{font-size:.75rem;color:var(--gold);padding:.3rem 0}

/* ──────────────────────────────────────────
   MEHRSPIELER (Lobby, Modifiers, Ergebnisse)
────────────────────────────────────────── */
/* Einstellungen im Erstellen-Panel */
.mp-setting-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.mp-setting-row label{font-size:.8rem;color:var(--cream)}
.modal-input.mp-num{width:5.5rem;text-align:center;padding:.5rem}
.modal-input.mp-num-sm{width:4.2rem;padding:.4rem;margin-left:auto}
.mp-mods{display:flex;flex-direction:column;gap:.4rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.7rem .8rem}
.mp-mods-title{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.1rem}
.mp-toggle{display:flex;align-items:center;gap:.55rem;font-size:.76rem;color:var(--cream);cursor:pointer}
.mp-toggle input[type=checkbox]{width:1.05rem;height:1.05rem;accent-color:var(--gold);flex-shrink:0;cursor:pointer}

/* Lobby */
.mp-lobby-box{width:min(440px,94vw);display:flex;flex-direction:column;align-items:center;gap:.7rem;background:linear-gradient(170deg,rgba(255,255,255,.055),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:1.4rem 1.3rem;box-shadow:0 22px 60px rgba(0,0,0,.3)}
.mp-lobby-h{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--cream)}
.mp-lobby-code-row{display:flex;align-items:center;gap:.6rem}
.mp-lobby-code-label{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mist)}
#mp-lobby-qr{border-radius:8px;background:#fff;padding:5px}
.mp-lobby-settings{font-size:.64rem;color:var(--mist);text-align:center;line-height:1.6}
.mp-lobby-players-title{align-self:flex-start;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:.2rem}
#mp-lobby-players{width:100%;display:flex;flex-direction:column;gap:.35rem;max-height:34vh;overflow-y:auto}
.mp-player-row{display:flex;align-items:center;gap:.55rem;padding:.5rem .65rem;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.mp-player-row.me{border-color:rgba(201,168,76,.45);background:rgba(201,168,76,.08)}
.mp-player-dot{width:.65rem;height:.65rem;border-radius:50%;background:var(--mist);flex-shrink:0;opacity:.5}
.mp-player-dot.ready{background:#7dcc6a;opacity:1;box-shadow:0 0 8px rgba(125,204,106,.6)}
.mp-player-name{flex:1;font-size:.8rem;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mp-player-status{font-size:.62rem;color:var(--mist)}
.mp-kick-btn{background:rgba(192,57,43,.18);border:1px solid rgba(192,57,43,.5);color:#f5b7b1;width:1.5rem;height:1.5rem;border-radius:6px;cursor:pointer;font-size:.7rem;line-height:1;flex-shrink:0}
.mp-kick-btn:hover{background:rgba(192,57,43,.4);color:#fff}
.mp-lobby-actions{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;width:100%;margin-top:.3rem}
.mp-lobby-actions .big-btn{flex:1;min-width:130px}
#mp-ready-btn.active{background:rgba(125,204,106,.18);border-color:rgba(125,204,106,.6);color:#aee79c}

/* Countdown */
#mp-countdown{display:none;position:fixed;inset:0;z-index:1300;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 45%,rgba(12,20,14,.82),rgba(3,6,4,.92));font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(5rem,28vw,16rem);color:var(--cream);text-shadow:0 0 60px rgba(201,168,76,.6),0 6px 30px rgba(0,0,0,.7)}
#mp-countdown.show{display:flex;animation:mpCdPop .35s cubic-bezier(.16,1,.3,1)}
@keyframes mpCdPop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}

/* In-Game Badges */
#mp-timer{position:absolute;top:.9rem;left:50%;transform:translateX(-50%) translateY(2.6rem);z-index:14;background:rgba(0,0,0,.7);border:1px solid rgba(201,168,76,.4);border-radius:20px;padding:.3rem .85rem;font-size:.78rem;font-weight:600;color:var(--gold-light);letter-spacing:.06em;backdrop-filter:blur(6px);transition:transform .15s}
#mp-timer.mp-timer-urgent{background:rgba(176,58,46,.92);border-color:#ff6f61;color:#fff;animation:mpTimerFlash .55s ease-in-out infinite}
@keyframes mpTimerFlash{0%,100%{transform:translateX(-50%) translateY(2.6rem) scale(1);box-shadow:0 0 0 rgba(255,80,60,0)}50%{transform:translateX(-50%) translateY(2.6rem) scale(1.18);box-shadow:0 0 22px rgba(255,80,60,.8)}}
#mp-timeup{display:none;position:fixed;top:42%;left:50%;transform:translate(-50%,-50%);z-index:1250;background:rgba(176,58,46,.95);color:#fff;font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(1.4rem,6vw,2.4rem);padding:.7rem 1.6rem;border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.5);white-space:nowrap}
#mp-timeup.show{display:block;animation:mpTimeupPop .3s cubic-bezier(.16,1,.3,1)}
@keyframes mpTimeupPop{from{transform:translate(-50%,-50%) scale(.6);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}
/* sauberer Pano-Lade-Spinner (statt grünem Skeleton) */
.pano-loading{position:absolute;inset:0;z-index:6;display:flex;align-items:center;justify-content:center;background:#0a160e}
.pano-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--gold,#c9a84c);border-radius:50%;animation:panoSpin .8s linear infinite}
@keyframes panoSpin{to{transform:rotate(360deg)}}
.mp-player-dot.clickable{cursor:pointer;box-shadow:0 0 0 2px rgba(201,168,76,.5);animation:mpDotPulse 1.4s ease-in-out infinite}
.mp-player-dot.clickable:hover{background:var(--gold-light);opacity:1}
@keyframes mpDotPulse{0%,100%{box-shadow:0 0 0 2px rgba(201,168,76,.3)}50%{box-shadow:0 0 0 4px rgba(201,168,76,.6)}}
#mp-speed-badge{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);z-index:14;background:linear-gradient(180deg,#f3d889,#d6ad48);color:#231a04;border-radius:20px;padding:.32rem .9rem;font-size:.78rem;font-weight:700;letter-spacing:.04em;box-shadow:0 4px 16px rgba(0,0,0,.4),0 0 18px rgba(201,168,76,.4)}

/* Rundenergebnis-Board (3+ Spieler, links) */
#mp-round-board{position:absolute;top:50%;left:clamp(.75rem,3vw,2rem);transform:translateY(-50%);z-index:20;width:min(280px,42vw);max-height:80vh;overflow-y:auto;background:linear-gradient(170deg,rgba(14,24,16,.94),rgba(10,18,12,.96));border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:.8rem .7rem;box-shadow:0 16px 50px rgba(0,0,0,.5)}
.mp-board-title{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);text-align:center;margin-bottom:.5rem}
.mp-board-row{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:8px;margin-bottom:.25rem;background:rgba(255,255,255,.04);font-size:.74rem}
.mp-board-row.me{background:rgba(201,168,76,.14);border:1px solid rgba(201,168,76,.4)}
.mp-board-rank{width:1.4rem;text-align:center;color:var(--mist);font-weight:600}
.mp-board-name{flex:1;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mp-board-pts{color:var(--gold-light);font-weight:600}

/* Endstand (3+ Spieler) */
#mp-final-standings{width:min(420px,92vw)}
.mp-standings-place{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:var(--cream);text-align:center;margin-bottom:.6rem}
.mp-standings-list{display:flex;flex-direction:column;gap:.35rem}
.mp-standings-row{display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.mp-standings-row.first{background:rgba(201,168,76,.12);border-color:rgba(201,168,76,.4)}
.mp-standings-row.me{box-shadow:inset 0 0 0 1.5px rgba(201,168,76,.55)}
.mp-standings-rank{width:1.8rem;text-align:center;font-size:.95rem}
.mp-standings-name{flex:1;font-size:.82rem;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mp-standings-total{font-size:.82rem;font-weight:600;color:var(--gold-light)}

@media(max-width:768px){
  #mp-lobby-screen{justify-content:flex-start;overflow-y:auto;padding:calc(1rem + env(safe-area-inset-top)) .8rem calc(1.5rem + env(safe-area-inset-bottom))}
  .mp-lobby-box{padding:1rem .9rem}
  #mp-lobby-qr{width:120px;height:120px}
  /* Board nach oben, kompakter, damit die Karte nutzbar bleibt */
  #mp-round-board{top:calc(.65rem + env(safe-area-inset-top));left:.65rem;right:.65rem;width:auto;transform:none;max-height:34vh}
  /* Timer + Speed-Badge nach oben (mittig, gestapelt unter der Top-Bar) statt unten – sonst verdeckt die Karte sie */
  #mp-timer{left:50%;right:auto;bottom:auto;top:calc(.65rem + env(safe-area-inset-top));transform:translateX(-50%) translateY(2.6rem)}
  #mp-speed-badge{left:50%;right:auto;bottom:auto;top:calc(.65rem + env(safe-area-inset-top));transform:translateX(-50%) translateY(5rem)}
}

/* ── Lobby: zweispaltig (Spieler | Einstellungen) ── */
#mp-lobby-screen{justify-content:center}
.mp-lobby-box{width:min(720px,94vw)!important}
.mp-lobby-header{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1rem;flex-wrap:wrap}
.mp-lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%;align-items:start}
.mp-lobby-col{display:flex;flex-direction:column;gap:.55rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:.85rem .8rem;min-width:0}
.mp-col-title{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.mp-col-sub{color:var(--mist);letter-spacing:0;text-transform:none;font-size:.62rem}
.mp-empty{font-size:.7rem;color:var(--mist);text-align:center;padding:1rem .5rem;font-style:italic}
.mp-lobby-qr-wrap{display:flex;flex-direction:column;align-items:center;gap:.3rem;margin-top:.4rem}
#mp-lobby-qr{border-radius:8px;background:#fff;padding:5px}
.mp-lobby-col .mp-mods{background:rgba(0,0,0,.18)}
.mp-toggle input[type=checkbox]:disabled,.mp-num:disabled{opacity:.55;cursor:not-allowed}
@media(max-width:768px){
  .mp-lobby-grid{grid-template-columns:1fr}
}

/* ── Skeleton-Loader (site-weit) ── */
.skeleton{position:relative;overflow:hidden;background:rgba(255,255,255,.05);border-radius:8px}
.skeleton::after{content:'';position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.09),transparent);animation:skelShimmer 1.25s infinite}
@keyframes skelShimmer{100%{transform:translateX(100%)}}
.skel-row{height:2.6rem;margin-bottom:.45rem}
.skel-line{height:.8rem;margin:.4rem 0}
.skel-stat{height:3.2rem;border-radius:10px}
.skel-ach{height:3rem;margin-bottom:.3rem}

/* ── Pano-Modifier-Filter ── */
#game-screen.mp-gray #pano-strip img{filter:grayscale(1)!important}
#game-screen.mp-blur #pano-strip img{filter:blur(7px)!important}
#game-screen.mp-gray.mp-blur #pano-strip img{filter:grayscale(1) blur(7px)!important}

/* ── Modifier: Toggle-Switches mit Beschreibung ── */
.mp-mods{display:flex;flex-direction:column;gap:0;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:.3rem .8rem}
.mp-mods-title{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);padding:.55rem 0 .35rem}
.mp-mod{display:flex;align-items:center;justify-content:space-between;gap:.7rem;padding:.6rem 0;border-top:1px solid rgba(255,255,255,.05);cursor:pointer;margin:0}
.mp-mod-info{display:flex;flex-direction:column;gap:.12rem;min-width:0}
.mp-mod-name{font-size:.8rem;color:var(--cream);font-weight:500}
.mp-mod-desc{font-size:.62rem;color:var(--mist);line-height:1.35}
.mp-mod input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}
.mp-switch{position:relative;width:2.5rem;height:1.4rem;border-radius:1rem;background:rgba(255,255,255,.14);flex-shrink:0;transition:background .25s}
.mp-switch::after{content:'';position:absolute;top:2px;left:2px;width:calc(1.4rem - 4px);height:calc(1.4rem - 4px);border-radius:50%;background:#fff;transition:transform .26s cubic-bezier(.16,1,.3,1),box-shadow .2s;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.mp-mod input:checked + .mp-switch{background:var(--gold)}
.mp-mod input:checked + .mp-switch::after{transform:translateX(1.1rem);box-shadow:0 1px 6px rgba(201,168,76,.6)}
.mp-mod input:disabled + .mp-switch{opacity:.45}
.mp-mod:has(input:disabled){cursor:not-allowed}
.mp-inline-num{width:3rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:5px;color:var(--cream);font-family:'DM Mono',monospace;font-size:.7rem;padding:.12rem .25rem;text-align:center}

/* ── Bereit-Bar + Start-Hinweis ── */
.mp-ready-bar{width:100%;transition:background .2s,opacity .2s,transform .1s}
.mp-ready-bar.is-ready{background:rgba(125,204,106,.18)!important;border-color:rgba(125,204,106,.55)!important;color:#aee79c!important;cursor:default}
.mp-ready-bar:disabled{opacity:.9}
.mp-start-hint{font-size:.66rem;color:var(--mist);text-align:center;min-height:1em;letter-spacing:.03em}

/* ── Warte-Overlay: Namensliste ── */
.mp-wait-names{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;margin-top:.3rem}
.mp-wait-name{font-family:'DM Mono',monospace;font-size:.8rem;color:var(--cream);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:.35rem .85rem;animation:mpWaitPulse 1.6s ease-in-out infinite}
@keyframes mpWaitPulse{0%,100%{opacity:.6}50%{opacity:1}}

/* ── Überspringen-Abstimmung ── */
.mp-skip-vote{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.4rem}
.mp-skip-vote-btn{background:rgba(201,168,76,.16);border:1px solid rgba(201,168,76,.5);color:var(--gold);font-family:'DM Mono',monospace;font-size:.78rem;letter-spacing:.03em;border-radius:22px;padding:.55rem 1.3rem;cursor:pointer;transition:background .15s,transform .1s}
.mp-skip-vote-btn:hover:not(:disabled){background:rgba(201,168,76,.28);transform:translateY(-1px)}
.mp-skip-vote-btn:disabled{opacity:.6;cursor:default}
.mp-skip-tally{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mist)}
#mp-skip-notice{display:none;position:fixed;top:3.1rem;left:50%;transform:translateX(-50%);background:rgba(201,168,76,.92);color:#1a1206;font-size:.66rem;font-weight:600;letter-spacing:.02em;padding:.45rem 1.05rem;border-radius:20px;z-index:300;white-space:nowrap;box-shadow:0 4px 14px rgba(0,0,0,.3)}
#mp-skip-notice.show{display:block;animation:mpWaitPulse 1.8s ease-in-out infinite}
@media(max-width:600px){#mp-skip-notice{top:2.7rem}}

/* ── Raumliste (Beitreten) ── */
.mp-roomlist-head{display:flex;align-items:center;justify-content:space-between;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.mp-refresh-btn{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);color:var(--cream);border-radius:6px;width:1.7rem;height:1.7rem;cursor:pointer;font-size:.9rem;line-height:1;transition:transform .3s,background .15s}
.mp-refresh-btn:hover{background:rgba(255,255,255,.12);transform:rotate(180deg)}
#vs-room-list{display:flex;flex-direction:column;gap:.4rem;max-height:38vh;overflow-y:auto}
.mp-room-row{display:grid;grid-template-columns:1fr auto;grid-template-areas:'host join' 'meta join';gap:.05rem .5rem;align-items:center;text-align:left;width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.6rem .75rem;cursor:pointer;transition:border-color .15s,background .15s,transform .1s}
.mp-room-row:hover{border-color:var(--gold);background:rgba(201,168,76,.08);transform:translateY(-1px)}
.mp-room-host{grid-area:host;font-size:.82rem;color:var(--cream);font-weight:600}
.mp-room-meta{grid-area:meta;font-size:.62rem;color:var(--mist)}
.mp-room-join{grid-area:join;font-size:.72rem;color:var(--gold-light);white-space:nowrap}
.mp-or{text-align:center;font-size:.6rem;color:var(--mist);letter-spacing:.1em;text-transform:uppercase;margin:.2rem 0 0;position:relative}

/* ── Ergebnis-Listen scrollbar (max ~5 Zeilen) ── */
.mp-standings-list{max-height:15.5rem;overflow-y:auto;padding-right:.2rem}
#mp-round-board{max-height:min(70vh,16rem);overflow-y:auto}
.mp-scrollhint{font-size:.58rem;color:var(--mist);text-align:center;padding-top:.3rem;opacity:.8}
/* dünne, sichtbare Scrollbar für die Listen */
#vs-room-list::-webkit-scrollbar,.mp-standings-list::-webkit-scrollbar,#mp-round-board::-webkit-scrollbar,#mp-lobby-players::-webkit-scrollbar{width:6px}
#vs-room-list::-webkit-scrollbar-thumb,.mp-standings-list::-webkit-scrollbar-thumb,#mp-round-board::-webkit-scrollbar-thumb,#mp-lobby-players::-webkit-scrollbar-thumb{background:rgba(201,168,76,.45);border-radius:3px}

/* Lobby-Box & VS-Modal undurchsichtiger machen (Backdrop nicht durchscheinen lassen) */
.mp-lobby-box{background:linear-gradient(170deg,rgba(22,42,28,.97),rgba(13,26,17,.98))!important;border-color:rgba(255,255,255,.1)!important;box-shadow:0 24px 70px rgba(0,0,0,.5)!important}

/* ── Gesamtpunkte-Zähler (Startseite) ── */
#total-points-wrap{text-align:center;margin-top:1.1rem}
#total-points-num{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,7vw,2.6rem);font-weight:900;color:var(--gold);line-height:1;letter-spacing:.02em}
#total-points-label{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mist);margin-top:.3rem}

/* ── Gesamtpunkte-Details ── */
#total-points-wrap{cursor:pointer}
#total-points-milestone{font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-light);margin-top:.3rem}

/* ── Beiträge-Feed (im Gesamtpunkte-Detail-Popup) ── */
.tpd-feed-label{font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mist);text-align:center;margin:.6rem 0 .35rem}
.tpd-feed-label:has(+ #total-points-feed:empty){display:none}
#total-points-feed{display:flex;flex-direction:column;gap:.25rem;width:100%}
#total-points-feed:empty{display:none}
.tpf-row{display:flex;align-items:baseline;justify-content:center;gap:.4rem;font-family:'DM Mono',monospace;font-size:.62rem;line-height:1.3;color:var(--cream-dark);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:8px;padding:.22rem .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tpf-row .tpf-name{color:var(--gold-light);font-weight:500;overflow:hidden;text-overflow:ellipsis;max-width:9rem}
.tpf-row .tpf-pts{color:var(--gold)}
.tpf-row .tpf-time{color:var(--mist);font-size:.56rem}
.tpf-row.tpf-new{animation:tpfIn .5s cubic-bezier(.16,1,.3,1) both}
@keyframes tpfIn{from{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.tpd-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin:.5rem 0}
.tpd-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.7rem;text-align:center}
.tpd-num{font-family:'Playfair Display',serif;font-size:clamp(1.2rem,5vw,1.8rem);font-weight:900;color:var(--gold)}
.tpd-lbl{font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mist);margin-top:.2rem}
.tpd-top-row{font-size:.78rem;color:var(--cream);text-align:center;margin:.3rem 0 .5rem}
.tpd-milestone-label{font-size:.66rem;color:var(--gold-light);text-align:center;margin-bottom:.3rem}
.tpd-milestone-track{height:.6rem;border-radius:6px;background:rgba(255,255,255,.1);overflow:hidden}
.tpd-milestone-bar{height:100%;width:0;background:linear-gradient(90deg,#d6ad48,#f3d889);transition:width .5s ease}
#tpd-admin{margin-top:.8rem;border-top:1px solid rgba(255,255,255,.1);padding-top:.7rem}
.tpd-admin-title{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.tpd-admin-hint{font-size:.58rem;color:var(--mist);margin-top:.3rem}

/* ── Level / XP / Erfolg-Fortschritt / Avatar-Rahmen ── */
.lvl-badge{background:rgba(201,168,76,.18);border:1px solid rgba(201,168,76,.5);color:var(--gold)}
#profile-xp{width:100%;max-width:280px;margin-top:.5rem}
.xp-track{height:.5rem;border-radius:5px;background:rgba(255,255,255,.1);overflow:hidden}
.xp-bar{height:100%;background:linear-gradient(90deg,#d6ad48,#f3d889);transition:width .5s ease}
.xp-lbl{font-size:.55rem;color:var(--mist);margin-top:.2rem;letter-spacing:.04em}
.ach-prog{height:.4rem;border-radius:4px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:.3rem}
.ach-prog-bar{height:100%;background:var(--gold);opacity:.7}
.ach-prog-lbl{font-size:.52rem;color:var(--mist);margin-top:.15rem;letter-spacing:.04em}
.profile-avatar.pf-frame-bronze{box-shadow:0 0 0 3px #b08d57}
.profile-avatar.pf-frame-silver{box-shadow:0 0 0 3px #cfd4da}
.profile-avatar.pf-frame-gold{box-shadow:0 0 0 3px var(--gold)}
.profile-avatar.pf-frame-rainbow{animation:pgRainbow 4s linear infinite}
@keyframes pgRainbow{0%,100%{box-shadow:0 0 0 3px #e23b3b}25%{box-shadow:0 0 0 3px #f3d24b}50%{box-shadow:0 0 0 3px #4bbf6b}75%{box-shadow:0 0 0 3px #4aa3f0}}

/* ── Blitz-Tag (Rotation) ── */
.blitz-card .menu-card-cta{background:linear-gradient(180deg,#f3d889,#d6ad48);color:#231a04;border-color:transparent}
.blitz-card .survival-badge{background:#4aa3f0;color:#fff}
