/* ── KryptoGuard Quiz ─────────────────────────────────────────────────────── */
:root {
  --kg-gold:    #B8965A;
  --kg-gold-lt: #F5E6C8;
  --kg-gold-dk: #7A5C2E;
  --kg-cream:   #FAF7F2;
  --kg-red:     #C03535;
  --kg-red-lt:  #FFF0EE;
  --kg-orange:  #C4622A;
  --kg-text:    #2C2416;
  --kg-muted:   #7A6A54;
  --kg-border:  #E8D9BC;
  --kg-card:    #FFFFFF;
  --kg-r:       16px;
  --kg-r-sm:    10px;
}
#kg-quiz *, #kg-quiz *::before, #kg-quiz *::after { box-sizing: border-box; margin: 0; padding: 0; }
#kg-quiz {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
  background: var(--kg-cream);
  border-radius: var(--kg-r);
  overflow: hidden;
  max-width: 680px;
  margin: 0 auto;
  position: relative;
  min-height: 400px;
}
.kg-hdr {
  background: var(--kg-card);
  border-bottom: 1px solid var(--kg-border);
  padding: 14px 24px 12px;
}
.kg-logo-row { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.kg-brand { font-size: 20px; font-weight: 700; color: var(--kg-gold-dk); letter-spacing: -.3px; }
.kg-prog-label { font-size: 12px; color: var(--kg-muted); margin-bottom: 5px; display: block; }
.kg-prog-track { height: 4px; background: var(--kg-gold-lt); border-radius: 2px; }
.kg-prog-fill { height: 4px; background: linear-gradient(90deg,var(--kg-gold),#C8A96E); border-radius: 2px; transition: width .4s; }
.kg-body { padding: 26px 24px 12px; }
.kg-title { font-size: 20px; font-weight: 600; color: var(--kg-text); margin-bottom: 6px; line-height: 1.3; }
.kg-sub { font-size: 14px; color: var(--kg-muted); margin-bottom: 22px; line-height: 1.5; }

/* Szenario-Grid */
.kg-sc-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(120px,1fr)); gap: 10px; margin-bottom: 20px; }
.kg-sc-card {
  background: var(--kg-card);
  border: 2px solid var(--kg-border);
  border-radius: var(--kg-r);
  padding: 16px 10px 12px;
  cursor: pointer;
  text-align: center;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.kg-sc-card:hover { border-color: var(--kg-gold); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(184,150,90,.15); }
.kg-sc-card.kg-sel { border-color: var(--kg-gold); background: var(--kg-gold-lt); }
.kg-sc-img-wrap {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--kg-gold-lt);
  margin: 0 auto 10px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.kg-sc-card.kg-sel .kg-sc-img-wrap { background: var(--kg-gold); }
.kg-sc-img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.kg-sc-label { font-size: 12px; font-weight: 500; color: var(--kg-text); line-height: 1.3; }

/* Fragen */
.kg-q-topic { font-size: 11px; font-weight: 700; color: var(--kg-gold); text-transform: uppercase; letter-spacing: .8px; margin-bottom: 8px; }
.kg-q-text { font-size: 17px; font-weight: 600; color: var(--kg-text); line-height: 1.5; margin-bottom: 18px; }

/* Antworten */
.kg-answers { display: flex; flex-direction: column; gap: 8px; }
.kg-ans {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  border: 2px solid var(--kg-border);
  border-radius: var(--kg-r-sm);
  cursor: pointer;
  transition: border-color .15s, background .15s;
  background: var(--kg-card);
  position: relative;
}
.kg-ans:hover { border-color: var(--kg-gold); background: #FFFDF8; }
.kg-ans.kg-sel { border-color: var(--kg-gold); background: var(--kg-gold-lt); }
.kg-ans.kg-crit:hover { border-color: var(--kg-orange); }
.kg-ans.kg-crit.kg-sel { border-color: var(--kg-red); background: var(--kg-red-lt); }

/* Radio dot */
.kg-dot {
  width: 20px; height: 20px; border-radius: 50%;
  border: 2px solid var(--kg-border); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.kg-ans.kg-sel .kg-dot { border-color: var(--kg-gold); background: var(--kg-gold); }
.kg-ans.kg-crit.kg-sel .kg-dot { border-color: var(--kg-red); background: var(--kg-red); }
.kg-dot-inner { width: 8px; height: 8px; border-radius: 50%; background: #fff; opacity: 0; transition: opacity .15s; }
.kg-ans.kg-sel .kg-dot-inner { opacity: 1; }

/* Checkbox */
.kg-box {
  width: 20px; height: 20px; border-radius: 5px;
  border: 2px solid var(--kg-border); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.kg-ans.kg-sel .kg-box { border-color: var(--kg-gold); background: var(--kg-gold); }
.kg-chk { width: 10px; height: 7px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg) translateY(-1px); opacity: 0; }
.kg-ans.kg-sel .kg-chk { opacity: 1; }

.kg-ans-text { font-size: 14px; color: var(--kg-text); font-weight: 500; flex: 1; line-height: 1.4; }

/* Info-Button & Tooltip */
.kg-info {
  width: 20px; height: 20px; border-radius: 50%;
  border: 1.5px solid var(--kg-border);
  background: none; cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--kg-muted);
  font-style: italic; font-weight: 700;
  transition: border-color .15s, color .15s;
  font-family: Georgia, serif;
  position: relative;
  z-index: 5;
}
.kg-info:hover { border-color: var(--kg-gold); color: var(--kg-gold-dk); }
.kg-tip {
  display: none;
  position: absolute;
  right: 32px; top: 50%; transform: translateY(-50%);
  background: var(--kg-text);
  color: #FFF8F0;
  font-size: 12px; line-height: 1.5;
  padding: 8px 12px;
  border-radius: 8px;
  max-width: 220px; min-width: 120px;
  z-index: 20;
  font-weight: 400;
  pointer-events: none;
}
.kg-tip::after {
  content: '';
  position: absolute; right: -5px; top: 50%; transform: translateY(-50%);
  border: 5px solid transparent;
  border-left-color: var(--kg-text); border-right: none;
}
.kg-tip.open { display: block; }

/* Actions */
.kg-actions { padding: 4px 24px 24px; display: flex; gap: 10px; align-items: center; }
.kg-btn {
  padding: 11px 26px; border-radius: var(--kg-r-sm);
  font-size: 14px; font-weight: 500; cursor: pointer;
  border: 2px solid transparent; font-family: inherit;
  transition: all .15s;
}
.kg-btn-gold { background: var(--kg-gold); color: #fff; }
.kg-btn-gold:hover { background: var(--kg-gold-dk); transform: translateY(-1px); }
.kg-btn-gold:disabled { background: var(--kg-border); color: var(--kg-muted); cursor: not-allowed; transform: none; }
.kg-btn-outline { background: none; border-color: var(--kg-border); color: var(--kg-muted); }
.kg-btn-outline:hover { border-color: var(--kg-gold); color: var(--kg-gold-dk); }
.kg-btn-red { background: var(--kg-red); color: #fff; }
.kg-btn-red:hover { background: #A02828; }

/* Overlay */
.kg-overlay {
  position: absolute; inset: 0;
  background: rgba(44,36,22,.6);
  display: flex; align-items: center; justify-content: center;
  z-index: 50; border-radius: var(--kg-r);
}
.kg-overlay[hidden] { display: none; }
.kg-dialog {
  background: var(--kg-card); border-radius: var(--kg-r);
  padding: 32px 28px; max-width: 360px; width: 92%;
}
.kg-dlg-icon { text-align: center; margin-bottom: 14px; }
.kg-dlg-title { font-size: 18px; font-weight: 600; color: var(--kg-red); text-align: center; margin-bottom: 10px; }
.kg-dlg-text { font-size: 13px; color: var(--kg-muted); line-height: 1.6; text-align: center; margin-bottom: 22px; }
.kg-dlg-btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

/* Spinner */
.kg-spinner {
  width: 34px; height: 34px;
  border: 3px solid var(--kg-gold-lt); border-top-color: var(--kg-gold);
  border-radius: 50%; margin: 0 auto 12px;
  animation: kgspin .7s linear infinite;
}
@keyframes kgspin { to { transform: rotate(360deg); } }
.kg-loading-text { font-size: 14px; color: var(--kg-muted); text-align: center; }

/* Error */
.kg-err { padding: 16px 24px; color: var(--kg-red); font-size: 13px; background: var(--kg-red-lt); border-radius: var(--kg-r-sm); margin: 12px 24px; }

/* Responsive */
@media (max-width: 480px) {
  .kg-sc-grid { grid-template-columns: repeat(2,1fr); }
  .kg-body { padding: 18px 16px 10px; }
  .kg-actions { padding: 4px 16px 18px; }
  .kg-hdr { padding: 12px 16px 10px; }
  .kg-title { font-size: 17px; }
  .kg-q-text { font-size: 15px; }
  .kg-tip { right: auto; left: 0; top: auto; bottom: calc(100% + 8px); transform: none; max-width: 180px; }
  .kg-tip::after { display: none; }
}
