
:root{
  --bg1:#08101d;
  --bg2:#13213a;
  --panel:rgba(10,19,34,.90);
  --border:rgba(243,211,154,.14);
  --gold1:#c7a25f;
  --gold2:#ead2a0;
  --bronze1:#9d6d33;
  --copper1:#ad7b42;
  --silver1:#7288a0;
  --text:#e6edf8;
  --muted:#aebbd0;
  --link:#9fc8ea;
  --sky:#88adc9;
  --paper:#0f1a2e;
}
*{box-sizing:border-box}
html,body{height:100%;overflow-x:hidden}
body{
  margin:0;
  font-family: "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  background:
    radial-gradient(circle at 10% 10%, rgba(136,173,201,.12), transparent 24%),
    radial-gradient(circle at 88% 6%, rgba(199,162,95,.14), transparent 24%),
    linear-gradient(180deg, var(--bg2), var(--bg1));
  color:var(--text);
  overscroll-behavior-x:none;
}

a{color:var(--link); text-decoration:underline; text-underline-offset:3px}
a:hover{filter:brightness(1.1)}
/* Header */
header{
  position:sticky; top:0; z-index:50;
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 14px;
  background:
    linear-gradient(180deg, rgba(12,20,39,.96), rgba(7,11,23,.95)),
    radial-gradient(circle at top, rgba(243,211,154,.08), rgba(0,0,0,0));
  backdrop-filter: blur(12px);
  border-bottom:1px solid rgba(243,211,154,.14);
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}
.brand{display:flex; gap:12px; align-items:center; min-width:220px}
.brand img{height:32px; width:auto; display:block}
.brand .title{font-family:Georgia,"Times New Roman",serif;font-weight:800; letter-spacing:.4px; font-size:15px; color:var(--gold2); text-shadow:0 0 20px rgba(243,211,154,.14)}
nav{display:flex; gap:6px; flex-wrap:wrap; justify-content:flex-end; padding:6px 7px; border-radius:999px; background:linear-gradient(180deg, rgba(14,22,41,.88), rgba(8,12,25,.95)); border:1px solid rgba(243,211,154,.12); box-shadow:0 14px 26px rgba(0,0,0,.22), inset 0 0 0 1px rgba(136,173,201,.05)}
nav a{
  color:#c8d5ea;
  text-decoration:none;
  font-weight:700;
  padding:9px 12px;
  border-radius:999px;
  border:1px solid transparent;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
nav a:hover{border-color:rgba(243,211,154,.16); background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(243,211,154,.03)); box-shadow:0 8px 18px rgba(7,11,23,.28), 0 0 14px rgba(243,211,154,.06); text-shadow:0 0 14px rgba(243,211,154,.14)}
nav a[aria-current="page"]{background:rgba(255,255,255,.04); border-color:rgba(243,211,154,.18); color:var(--text)}

/* Mobile nav: burger menu */
.burgerBtn{
  display:none;
  border:1px solid rgba(243,211,154,.18);
  background:linear-gradient(180deg, rgba(16,27,52,.92), rgba(7,11,23,.96));
  color:var(--text);
  border-radius:14px;
  padding:10px 12px;
  font-weight:850;
  cursor:pointer;
}
.burgerBtn:hover{background:rgba(255,255,255,.06); border-color:rgba(255,215,120,.35)}

/* Mobile nav overlay/drawer */
.navOverlay{
  position:fixed;
  inset:0;
  background:rgba(2,8,16,.6);
  z-index:120;
  display:none;
}
.navOverlay.open{display:block}
.navDrawer{
  position:absolute;
  top:0;
  right:0;
  height:100%;
  width:min(360px, 92vw);
  background:linear-gradient(180deg, rgba(10,19,34,.99), rgba(5,10,20,.995));
  border-left:1px solid rgba(243,211,154,.14);
  box-shadow: -18px 0 60px rgba(0,0,0,.34);
  padding:14px;
  transform: translateX(0);
}
.navDrawerHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:18px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(255,215,120,.14);
}
.navDrawerHead .navDrawerTitle{font-weight:900; color:var(--text); letter-spacing:.2px; font-size:16px}
.navDrawer nav{display:flex; flex-direction:column; gap:8px}
.navDrawer nav a{
  display:block;
  width:100%;
  padding:14px 16px;
  border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(243,211,154,.12);
  color:var(--text);
  text-decoration:none;
  font-weight:650;
  font-size:15px;
  text-align:center;
}
.navDrawer nav a:hover{background:rgba(255,255,255,.08); border-color:rgba(255,215,120,.28); box-shadow:0 0 18px rgba(243,211,154,.08)}

@media (max-width: 820px){
  #mwNav{display:none}
  .burgerBtn{display:inline-flex; align-items:center; justify-content:center}
  .brand{min-width:0}
  .brand img{height:30px}
}

/* Sticky mini status bar (shown on quiz page) */
.miniBar{
  position:sticky;
  top: var(--mwHeaderHeight, 0px);
  z-index:49;
  background:rgba(8,16,29,.9);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(243,211,154,.08);
}
.miniInner{
  max-width:1160px;
  margin:0 auto;
  padding:10px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.miniLeft{
  color:#8a6931;
  font-weight:900;
  font-size:13px;
  letter-spacing:.2px;
  white-space:nowrap;
}
.miniMid{flex:1; display:flex; justify-content:center}
.miniMeter{
  width:min(420px, 100%);
  height:8px;
  border-radius:999px;
  background:rgba(24,50,75,.08);
  border:1px solid rgba(24,50,75,.08);
  overflow:hidden;
}
.miniMeter > div{
  height:100%;
  width:0%;
  background:linear-gradient(90deg,var(--gold1),var(--gold2));
  transition: width .22s ease;
}
.miniRight{
  display:flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
}
.miniPoints{color:var(--text); font-size:13px}
.miniTier{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(243,211,154,.10);
  background:rgba(255,255,255,.04);
  font-weight:900;
  letter-spacing:.2px;
  text-transform:none;
  font-size:11px;
  max-width: 260px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.miniTier.tier-ufergast{
  color:var(--bronze1);
  border-color:rgba(205,127,50,.45);
  background:rgba(205,127,50,.10);
}
.miniTier.tier-wellenlauscher{
  color:var(--copper1);
  border-color:rgba(208,140,60,.46);
  background:rgba(208,140,60,.10);
}
.miniTier.tier-muscheltraeger{
  color:var(--silver1);
  border-color:rgba(214,222,239,.42);
  background:rgba(214,222,239,.10);
}
.miniTier.tier-windgefaehrte{
  color:var(--gold2);
  border-color:rgba(255,231,163,.42);
  background:rgba(255,231,163,.08);
}
.miniTier.tier-lied-traeger{
  color:var(--gold1);
  border-color:rgba(212,175,55,.48);
  background:rgba(212,175,55,.10);
}
.miniTier.tier-hafenmeister{
  color:var(--gold1);
  border-color:rgba(212,175,55,.62);
  background:rgba(212,175,55,.18);
}
@media (max-width: 520px){
  .miniMid{display:none}
}

.container{
  max-width:1160px;
  margin:22px auto;
  padding:16px;
}

.grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
}
@media (max-width: 900px){
  .grid{grid-template-columns:1fr; }
  nav{gap:8px}
}

.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:18px;
  padding:20px;
  box-shadow: 0 24px 50px rgba(0,0,0,.28);
  backdrop-filter: blur(10px);
}

/* Quiz card transition between questions */
#quizCard{transition: opacity .22s ease, transform .22s ease}
#quizCard.is-transitioning{opacity:0; transform: translateY(6px)}

h1{
  margin:0 0 10px 0;
  font-size:32px;
  line-height:1.12;
  color:var(--text);
}
.kicker{
  color:#8a6931;
  letter-spacing:2px;
  text-transform:uppercase;
  font-size:12px;
  margin-bottom:10px;
}
.lead{color:var(--muted); line-height:1.55; font-size:15px}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:999px;
  border:1px solid rgba(199,162,95,.24);
  background:rgba(243,211,154,.10);
  color:#8a6931;
  font-weight:650;
  margin:10px 0 14px 0;
}

hr.sep{
  border:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,215,120,.25), transparent);
  margin:16px 0;
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px;
  border:1px solid rgba(243,211,154,.14);
  background:rgba(255,255,255,.04);
  color:var(--text);
  padding:12px 14px;
  border-radius:14px;
  font-weight:750;
  cursor:pointer;
  text-decoration:none;
}
.btn:hover{background:rgba(255,255,255,.08); border-color:rgba(243,211,154,.24)}
.btn-primary{
  border:none;
  background:linear-gradient(45deg,var(--gold1),var(--gold2));
  color:#16283a;
  box-shadow:0 14px 34px rgba(24,50,75,.14);
}
.btn-primary:hover{filter:brightness(1.02)}
.btn-ghost{
  border:1px solid rgba(243,211,154,.14);
  color:var(--text);
}
.btn-danger{
  border:1px solid rgba(156,98,74,.22);
  background:rgba(190,126,97,.10);
}
.btn-small{padding:10px 12px; border-radius:12px; font-size:14px}

/* Media box */
.hero{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(243,211,154,.18);
  background:rgba(255,255,255,.03);
}
.hero img{
  width:100%;
  height:auto;
  aspect-ratio: 16/9;
  object-fit:cover;
  object-position:center;
  display:block;
}
.hero.tall img{
  aspect-ratio: 4/5;
  object-position: 50% 30%;
}
@media (max-width: 900px){
  .hero img{aspect-ratio: 16/10}
}

.soft-note{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(136,173,201,.18);
  background:rgba(255,255,255,.04);
  color:var(--text);
  line-height:1.45;
}

/* Quiz */
.quizShell{display:grid; grid-template-columns:1.1fr .9fr; gap:18px}
@media (max-width: 900px){ .quizShell{grid-template-columns:1fr} }

.quizTop{display:flex; justify-content:space-between; align-items:flex-start; gap:12px; flex-wrap:wrap}

.progressRow{
  display:flex; justify-content:space-between; align-items:center; gap:12px;
  flex-wrap:wrap;
}
.progressText{color:#e7c46a; font-weight:750}
.meter{
  height:10px; width:220px; border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,215,120,.14);
  overflow:hidden;
}
.meter > div{
  height:100%;
  width:0%;
  background:linear-gradient(90deg,var(--gold1),var(--gold2));
}

.question{
  font-size:24px;
  font-weight:800;
  margin:10px 0 14px 0;
  line-height:1.34;
  color:var(--text);
}

.answers{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:12px;
}
button.answerBtn{
  text-align:left;
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:flex-start;
  gap:12px;
  min-height:70px;
  padding:15px 16px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(18,31,53,.96), rgba(10,19,34,.94));
  border:1px solid rgba(243,211,154,.14);
  color:var(--text);
  cursor:pointer;
  font-weight:700;
  line-height:1.4;
  box-shadow:0 12px 26px rgba(0,0,0,.24);
}
.answerBtn:hover{background:linear-gradient(180deg, rgba(22,36,60,.98), rgba(12,22,39,.96)); border-color:rgba(243,211,154,.24)}
button.answerBtn:active{transform: translateY(1px)}
.answerBtn:is(select, input){
  display:block;
  width:100%;
  min-height:auto;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(243,211,154,.14);
  color:var(--text);
  box-shadow:none;
}
.answerKey{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:999px;
  background:rgba(136,173,201,.12);
  border:1px solid rgba(136,173,201,.18);
  color:#d4e6f4;
  font-weight:800;
  font-size:14px;
  flex:0 0 auto;
}
.answerText{
  display:block;
  padding-top:4px;
}
button.answerBtn.hinted{
  opacity:.6;
  border-style:dashed;
  background:rgba(255,255,255,.03);
}
button.answerBtn.selected{
  border-color:rgba(199,162,95,.4);
  box-shadow:0 0 0 2px rgba(199,162,95,.12), 0 18px 30px rgba(0,0,0,.28);
}
button.answerBtn[disabled]{opacity:.65; cursor:not-allowed}
button.answerBtn.correct{
  border-color:rgba(199,162,95,.34);
  background:linear-gradient(180deg, rgba(36,49,66,.98), rgba(15,25,39,.96));
  box-shadow:0 0 0 1px rgba(199,162,95,.16) inset, 0 14px 26px rgba(0,0,0,.24);
}
button.answerBtn.wrong{
  border-color:rgba(180,120,88,.24);
  background:rgba(193,143,117,.09);
}
button.answerBtn.hinted{
  opacity:.45;
  filter: grayscale(.25);
  border-color:rgba(243,211,154,.08);
  background:rgba(255,255,255,.03);
}

.resultBox{
  margin-top:12px;
  border-radius:14px;
  padding:12px 14px;
  border:1px solid rgba(243,211,154,.12);
  background:rgba(255,255,255,.04);
  display:none;
}
.resultBox.good{border-color:rgba(199,162,95,.24); background:linear-gradient(180deg, rgba(34,47,63,.96), rgba(14,24,38,.94))}
.resultBox.bad{border-color:rgba(180,120,88,.18); background:rgba(193,143,117,.10)}
.resultTitle{font-weight:900; margin-bottom:6px}
.resultText{color:var(--muted); line-height:1.45}

.footerBar{
  margin-top:14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

/* End */
.bigScore{
  font-size:44px; font-weight:950;
  background:linear-gradient(90deg,var(--gold2),var(--gold1));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  margin:0;
}
.codePill{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 12px; border-radius:999px;
  border:1px dashed rgba(255,215,120,.55);
  background:rgba(255,255,255,.04);
  font-weight:900;
  letter-spacing:1px;
}
.small{color:var(--muted); font-size:13px; line-height:1.45}
.iconBtn{
  display:inline-flex; align-items:center; gap:8px;
}
.iconBtn img{height:18px; width:18px; display:block}

/* Live sidebar */
.sideHero{margin:0 0 12px 0}
.sideHeroFrame{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(243,211,154,.12);
  background:rgba(255,255,255,.04);
  box-shadow: 0 18px 36px rgba(0,0,0,.26);
}
#sideImgQuiz{
  width:100%;
  height:auto;
  aspect-ratio: 16/10;
  object-fit:cover;
  object-position:center;
  display:block;
}
.sideBody{padding:0}
.sideKicker{font-weight:950; color:#8a6931; letter-spacing:.3px}
.sideStat{margin-top:10px; font-size:13px; color:var(--muted); line-height:1.45}
.sideRankBig{
  margin-top:4px;
  font-weight:950;
  letter-spacing:.2px;
  font-size:20px;
  color:var(--gold2);
  line-height:1.2;
}
.tier-ufergast .sideRankBig{color:var(--bronze1)}
.tier-wellenlauscher .sideRankBig{color:var(--copper1)}
.tier-muscheltraeger .sideRankBig{color:var(--silver1)}
.tier-windgefaehrte .sideRankBig{color:var(--gold2)}
.tier-lied-traeger .sideRankBig{color:var(--gold1)}
.tier-hafenmeister .sideRankBig{color:var(--gold1)}
.sideRankBadge{
  display:inline-flex;
  margin-top:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(243,211,154,.12);
  background:rgba(255,255,255,.04);
  font-weight:900;
  letter-spacing:1px;
  text-transform:uppercase;
  font-size:12px;
  box-shadow: 0 0 0 1px rgba(0,0,0,.18) inset;
}
.sideRankBadge.tier-ufergast{
  color:var(--bronze1);
  border-color:rgba(205,127,50,.45);
  background:rgba(205,127,50,.10);
}
.sideRankBadge.tier-wellenlauscher{
  color:var(--copper1);
  border-color:rgba(208,140,60,.46);
  background:rgba(208,140,60,.10);
}
.sideRankBadge.tier-muscheltraeger{
  color:var(--silver1);
  border-color:rgba(214,222,239,.42);
  background:rgba(214,222,239,.10);
}
.sideRankBadge.tier-windgefaehrte{
  color:var(--gold2);
  border-color:rgba(255,231,163,.42);
  background:rgba(255,231,163,.08);
}
.sideRankBadge.tier-lied-traeger{
  color:var(--gold1);
  border-color:rgba(212,175,55,.48);
  background:rgba(212,175,55,.10);
}
.sideRankBadge.tier-hafenmeister{
  color:var(--gold1);
  border-color:rgba(212,175,55,.62);
  background:rgba(212,175,55,.18);
}

.notice{
  margin-top:12px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(243,211,154,.12);
  background:rgba(255,255,255,.04);
  color:var(--muted);
}

/* Chefkrabbe ticker */
.crabBox{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(136,173,201,.16);
  background:linear-gradient(180deg, rgba(16,27,46,.92), rgba(10,18,31,.88));
}
.crabTitle{font-weight:950; color:#d7ebfb; letter-spacing:.2px; margin-bottom:6px}
.crabLine{color:var(--text); line-height:1.55; font-size:13px}

/* Endscreen: Rank + Certificate */
.finalRankWrap{
  margin-top:8px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(243,211,154,.12);
  background:rgba(255,255,255,.04);
}
.finalRankWrap.tier-ufergast{border-color:rgba(205,127,50,.35); background:rgba(205,127,50,.07)}
.finalRankWrap.tier-wellenlauscher{border-color:rgba(208,140,60,.35); background:rgba(208,140,60,.07)}
.finalRankWrap.tier-muscheltraeger{border-color:rgba(214,222,239,.30); background:rgba(214,222,239,.06)}
.finalRankWrap.tier-windgefaehrte{border-color:rgba(255,231,163,.30); background:rgba(255,231,163,.06)}
.finalRankWrap.tier-lied-traeger{border-color:rgba(212,175,55,.38); background:rgba(212,175,55,.08)}
.finalRankWrap.tier-hafenmeister{border-color:rgba(212,175,55,.48); background:rgba(212,175,55,.12)}
.finalRankBig{
  margin-top:6px;
  font-weight:950;
  font-size:22px;
  line-height:1.18;
  color:#8a6931;
}
.finalRankWrap.tier-ufergast .finalRankBig{color:var(--bronze1)}
.finalRankWrap.tier-wellenlauscher .finalRankBig{color:var(--copper1)}
.finalRankWrap.tier-muscheltraeger .finalRankBig{color:var(--silver1)}
.finalRankWrap.tier-windgefaehrte .finalRankBig{color:var(--gold2)}
.finalRankWrap.tier-lied-traeger .finalRankBig{color:var(--gold1)}
.finalRankWrap.tier-hafenmeister .finalRankBig{color:var(--gold1)}

.certGrid{
  display:grid;
  grid-template-columns: 1fr;
  gap:10px;
  align-items:start;
  max-width: 420px;
  margin: 0 auto;
}
.certPreviewWrap{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(243,211,154,.12);
  background:rgba(255,255,255,.04);
  display:flex;
  align-items:center;
  justify-content:center;
  max-width: 420px;
  justify-self: center;
  cursor: zoom-in;
}
.certPreviewWrap img{
  width:100%;
  height:auto;
  max-height:260px;
  object-fit:contain;
  background:rgba(255,255,255,.02);
  display:block;
}
.certActions{
  display:grid;
  gap:10px;
}

/* Certificate modal */
.modal{
  position:fixed; inset:0;
  background:rgba(0,0,0,.55);
  display:none;
  align-items:center; justify-content:center;
  padding:18px;
  z-index:200;
}
.modal .panel{
  width:min(860px, 96vw);
  background:rgba(10,19,34,.98);
  border:1px solid rgba(243,211,154,.12);
  border-radius:18px;
  padding:16px;
  box-shadow:0 24px 60px rgba(0,0,0,.36);
}
.modalHeader{
  display:flex; justify-content:space-between; align-items:center; gap:8px; flex-wrap:wrap;
  margin-bottom:10px;
}
.modalHeader h3{margin:0; color:var(--text)}
.canvasWrap{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(243,211,154,.12);
  background:rgba(255,255,255,.04);
}
canvas{width:100%; height:auto; display:block}

/* Endscreen (Quizmeister): edel, raffiniert */
.endHero{
  margin: 0 auto 10px;
  max-width: 680px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(243,211,154,.12);
  background: rgba(255,255,255,.04);
  box-shadow: 0 12px 32px rgba(0,0,0,.26);
}
#finalImg{
  width:100%;
  height:auto;
  max-height:180px;
  object-fit:contain;
  aspect-ratio: auto;
  display:block;
  background: transparent;
}

/* End layout */
.endTop{
  display:grid;
  grid-template-columns: 1fr;
  gap:10px;
  align-items:center;
  text-align: center;
}
.endHeadline{margin:0; font-size:26px}
.endCrab{margin-top:6px; color:var(--muted); line-height:1.5; font-size:14px}
.endHeroBlock{
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(243,211,154,.12);
  background: rgba(255,255,255,.04);
}
.endHeroBlock .endHeadline{font-size: 20px; line-height: 1.12}
.endStats{display:grid; gap:8px; justify-items:center; margin-top:8px}

.endGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  align-items:start;
  max-width: 920px;
  margin: 0 auto;
}
@media (max-width: 900px){
  .endGrid{grid-template-columns:1fr; max-width:100%}
}

/* Make certificate feel premium on desktop */
.endGrid #certPreviewWrap{
  max-width: 100%;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(243,211,154,.12);
  background: rgba(255,255,255,.04);
}
.endGrid #certPreviewWrap img{
  max-height: 420px;
}
@media (max-width: 900px){
  .endGrid #certPreviewWrap img{ max-height: 320px; }
}
.endPass{
  border-radius:16px;
  padding:14px;
  border:1px solid rgba(243,211,154,.12);
  background:rgba(255,255,255,.04);
}
.passRow{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:12px;
  padding:6px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.passRow:last-of-type{border-bottom:0}

.endActions{margin-top:12px; display:grid; gap:8px}
.endActions2,.endActions3,.endActions4{display:flex; gap:8px; flex-wrap:wrap; justify-content:center}

.btn-secondary{
  border:1px solid rgba(243,211,154,.14);
  background:rgba(255,255,255,.04);
  color:var(--text);
}
.btn-secondary:hover{background:rgba(255,255,255,.08); border-color:rgba(243,211,154,.24)}


/* --- Möwenwinkel polish --- */
a.textLink{
  color: rgba(255,216,138,0.95);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
}
a.textLink:hover{color: rgba(255,230,183,1)}

/* --- Mobile optimizations (Quiz) --- */
@media (max-width: 820px){
  .quizShell{
    display:flex !important;
    flex-direction:column;
  }
  
  #quizCard, #sideLive{
    width: 100% !important;
    margin-bottom: 12px;
  }

  #sideLive{
    order:-1;
    display:grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap:12px;
    align-items:start;
    padding:14px;
  }

  .sideHero{margin:0}

  .sideHeroFrame{
    border-radius:14px;
    overflow:hidden;
    height:100%;
  }

  #sideImgQuiz{
    aspect-ratio: 4/5;
    height:100%;
  }

  .sideBody{padding:0;min-width:0}

  .crabBox{
    position: static;
    max-height: none;
    overflow: visible;
    margin-top: 10px;
    padding: 12px 14px;
    border-radius: 14px;
    border:1px solid rgba(243,211,154,.12);
    background: linear-gradient(180deg, rgba(16,27,46,0.96), rgba(10,18,31,0.94));
    backdrop-filter: blur(10px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.28);
  }
  
  .crabTitle{
    font-size: 11px;
    margin-bottom: 4px;
    letter-spacing: 0.5px;
  }
  
  .crabLine{
    font-size: 13px;
    line-height: 1.45;
  }
  
  /* Platz am unteren Ende der Seite für die fixe crabBox */
  #pageQuiz .quizShell{
    padding-bottom: 0;
  }

  #quizCard{
    position: relative;
    padding-bottom: calc(18px + env(safe-area-inset-bottom));
  }

  .footerBar{
    position: sticky;
    bottom: max(8px, env(safe-area-inset-bottom));
    z-index: 12;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 10px;
    border-radius: 16px;
    background: rgba(10,19,34,0.96);
    border: 1px solid rgba(243,211,154,.12);
    backdrop-filter: blur(10px);
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.28);
  }

  #nextBtn{
    display:none;
    grid-column: 1 / -1;
    width: 100%;
  }

  #hintBtn,
  #quitBtn{
    width: 100%;
    justify-content: center;
  }

  /* Antworten kompakter */
  button.answerBtn{
    padding: 12px 13px;
    font-size: 15px;
    line-height: 1.25;
    min-height: 54px;
  }

  .resultBox{
    margin-top:10px;
    padding:13px 14px;
  }

  /* Erklärungstext direkt unter Antworten (falls vorhanden) */
  #explainBox{
    margin-top: 12px;
    font-size: 14px;
    line-height: 1.3;
    color: var(--muted);
  }

  /* Endscreen compacter auf mobile */
  .endHeadline{
    margin-top: 0 !important;
    margin-bottom: 6px;
    font-size: 22px;
  }

  .endStats{
    gap: 4px;
    margin-top: 4px;
  }

  .badge{
    margin: 6px 0 8px 0 !important;
    padding: 6px 10px;
    font-size: 13px;
  }

  .bigScore{
    font-size: 36px;
    margin: 0 !important;
  }

  .finalRankWrap{
    margin-top: 4px;
    padding: 8px 10px;
  }

  .finalRankBig{
    margin-top: 3px;
    font-size: 18px;
  }

  .endCrab{
    margin-top: 3px;
    font-size: 12px;
  }
}

@media (max-width: 560px){
  #sideLive{
    grid-template-columns: 80px minmax(0, 1fr);
    gap:10px;
    padding:12px;
  }

  .sideRankBig{font-size:18px}
  .sideStat{font-size:12px}
  .sideRankBadge{font-size:11px;padding:7px 10px}
}
