/* Spiele Darkmode Overrides */

html[data-theme="dark"] .gm-overlay {
  color-scheme: dark;
  background:
    radial-gradient(circle at 12% 8%, rgba(232, 189, 79, 0.1), transparent 38%),
    radial-gradient(circle at 88% 92%, rgba(255, 122, 56, 0.08), transparent 42%),
    linear-gradient(170deg, #0f0905 0%, #170f08 45%, #0b0704 100%);
  color: #f7ebd8;
}

html[data-theme="dark"] .gm-body {
  background: transparent;
}

html[data-theme="dark"] .gm-header {
  background: rgba(18, 12, 8, 0.94);
  border-bottom: 1px solid rgba(232, 189, 79, 0.22);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}

html[data-theme="dark"] .gm-close-btn {
  background: rgba(46, 31, 22, 0.96);
  color: #f8ecd6;
}

html[data-theme="dark"] .gm-close-btn:hover {
  background: rgba(62, 42, 30, 0.96);
}

html[data-theme="dark"] .gm-progress-bar {
  background: rgba(255, 255, 255, 0.14);
}

html[data-theme="dark"] .gm-progress-label {
  color: rgba(248, 236, 214, 0.76);
}

html[data-theme="dark"] .gm-energy {
  background: rgba(52, 35, 22, 0.96);
  border: 1px solid rgba(232, 189, 79, 0.38);
  color: #fff2d8;
}

html[data-theme="dark"] .gm-game-root {
  color: #f5ead6;
}

html[data-theme="dark"] .game-card {
  background:
    radial-gradient(circle at top left, rgba(232, 189, 79, 0.12), transparent 46%),
    linear-gradient(160deg, #1a120c 0%, #251911 56%, #140e09 100%);
  border: 1px solid rgba(232, 189, 79, 0.2);
  box-shadow: 0 20px 42px rgba(0, 0, 0, 0.42);
  color: #f6ead7;
}

html[data-theme="dark"] .game-card h1,
html[data-theme="dark"] .game-card h2,
html[data-theme="dark"] .game-card h3 {
  color: #fff2dc;
}

html[data-theme="dark"] .game-feedback {
  color: rgba(244, 232, 210, 0.86);
}

html[data-theme="dark"] .game-next-btn,
html[data-theme="dark"] .gm-correct-popup-btn,
html[data-theme="dark"] .gm-no-energy-btn {
  background: linear-gradient(180deg, #5f421f 0%, #3f2b14 100%);
  border: 1px solid rgba(232, 189, 79, 0.42);
  color: #fff2d7;
}

/* Multiple Choice Footer-Dock im Darkmode: nur Farben, keine Geometrie-Aenderung */
html[data-theme="dark"] .gm-overlay .mc-footer-row {
  background: linear-gradient(180deg, #5f421f 0%, #3f2b14 100%);
  border: 0;
  box-shadow: none;
}

html[data-theme="dark"] .gm-overlay .mc-footer-row::before {
  display: none;
}

html[data-theme="dark"] .gm-overlay .mc-next-btn {
  background: linear-gradient(180deg, #5f421f 0%, #3f2b14 100%);
  border: 0;
  color: #fff2d7;
}

html[data-theme="dark"] .gm-overlay .mc-footer-row .game-feedback {
  color: rgba(248, 235, 210, 0.9);
}

html[data-theme="dark"] .gm-no-energy p {
  color: rgba(248, 236, 214, 0.9);
}

html[data-theme="dark"] :is(
  .sc-card, .mc-card, .tfs-card, .gf-card, .mp-card, .os-card, .to-card, .qf-card-main,
  .scn-card, .cs-card, .fc-card-main, .sb-card
) {
  color: #f5ead6;
}

html[data-theme="dark"] :is(
  .sc-meta-row, .mc-meta-row, .tfs-meta-row, .gf-meta-row, .mp-meta-row, .os-meta-row, .to-meta-row,
  .qf-meta-row, .scn-meta-row, .cs-meta-row, .fc-meta-row, .sb-meta-row
) {
  color: rgba(245, 232, 210, 0.72);
}

html[data-theme="dark"] :is(
  .sc-question, .mc-question, .tfs-statement-card, .gf-question, .mp-question, .os-prompt, .to-prompt,
  .qf-question-box, .scn-bubble, .cs-prompt, .fc-card-front, .fc-card-back, .sb-question-box
) {
  background: linear-gradient(160deg, rgba(43, 31, 22, 0.96), rgba(31, 22, 16, 0.96));
  border: 1px solid rgba(232, 189, 79, 0.24);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.26);
  color: #f9eed9;
}

html[data-theme="dark"] :is(
  .scq-header-title, .scq-question-text, .mc-question-text, .gf-sentence, .mp-question-text,
  .os-prompt, .to-prompt, .qf-title, .qf-question-text, .scn-situation-title, .scn-situation-text,
  .cs-prompt, .fc-front-text, .fc-back-text, .sb-question
) {
  color: #fff1d8;
}

html[data-theme="dark"] :is(
  .sc-option, .mc-option, .tfs-choice, .gf-option, .mp-option, .os-option, .to-step-chip,
  .qf-btn, .scn-option, .cs-item, .sb-word, .sb-placed-word, .fc-know-btn, .fc-unknown-btn,
  .sb-audio-btn, .sb-silent-btn, .sb-reset-btn
) {
  background: linear-gradient(180deg, rgba(53, 39, 28, 0.98), rgba(39, 28, 20, 0.98));
  border: 1px solid rgba(232, 189, 79, 0.28);
  color: #f9edd8;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.24);
}

html[data-theme="dark"] :is(
  .mp-term-box, .os-slot, .to-slot, .cs-bucket, .cs-pool, .cs-bucket-body, .sb-word-bank,
  .sb-answer-slots, .sb-word-list, .sb-audio-wrapper
) {
  background: linear-gradient(170deg, rgba(41, 29, 21, 0.98), rgba(30, 21, 15, 0.98));
  border-color: rgba(232, 189, 79, 0.24);
  color: #f7ead5;
}

html[data-theme="dark"] :is(.mc-option-icon, .os-slot-index, .os-review-index) {
  background: rgba(74, 51, 29, 0.98);
  border-color: rgba(232, 189, 79, 0.42);
  color: #ffeecb;
}

html[data-theme="dark"] .cs-bucket-count {
  background: transparent;
  border: 0;
  color: rgba(248, 235, 210, 0.86);
}

html[data-theme="dark"] :is(.sc-option--selected, .mc-option--selected, .tfs-choice--selected, .gf-option--selected) {
  background: linear-gradient(180deg, rgba(86, 62, 26, 0.98), rgba(66, 46, 20, 0.98));
  border-color: rgba(232, 189, 79, 0.85);
  color: #fff4d8;
}

html[data-theme="dark"] :is(.sc-option--correct, .mc-option--correct, .gf-option--correct, .os-slot--correct, .to-slot--correct, .scn-option--correct) {
  background: rgba(46, 125, 50, 0.32);
  border-color: rgba(108, 201, 112, 0.9);
  color: #eaffea;
}

html[data-theme="dark"] :is(.sc-option--wrong, .mc-option--wrong, .gf-option--wrong, .os-slot--wrong, .to-slot--wrong, .scn-option--wrong) {
  background: rgba(198, 40, 40, 0.3);
  border-color: rgba(255, 124, 124, 0.86);
  color: #ffe8e8;
}

html[data-theme="dark"] .tfs-statement-card--answered {
  border-color: rgba(232, 189, 79, 0.68);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.34);
}

html[data-theme="dark"] .tfs-choice--true {
  background: linear-gradient(180deg, rgba(32, 82, 58, 0.98), rgba(22, 58, 42, 0.98));
  border-color: rgba(111, 219, 146, 0.58);
  color: #dfffea;
}

html[data-theme="dark"] .tfs-choice--false {
  background: linear-gradient(180deg, rgba(108, 44, 44, 0.98), rgba(76, 31, 31, 0.98));
  border-color: rgba(255, 131, 131, 0.56);
  color: #ffe2e2;
}

html[data-theme="dark"] .tfs-choice--true:hover:not(.tfs-choice--disabled) {
  background: linear-gradient(180deg, rgba(36, 92, 65, 0.98), rgba(24, 66, 47, 0.98));
  box-shadow: 0 12px 24px rgba(24, 85, 55, 0.32);
}

html[data-theme="dark"] .tfs-choice--false:hover:not(.tfs-choice--disabled) {
  background: linear-gradient(180deg, rgba(118, 49, 49, 0.98), rgba(84, 35, 35, 0.98));
  box-shadow: 0 12px 24px rgba(124, 36, 36, 0.3);
}

html[data-theme="dark"] .tfs-choice--selected.tfs-choice--true {
  border-color: rgba(130, 236, 162, 0.88);
  box-shadow: 0 0 0 1px rgba(130, 236, 162, 0.26), 0 14px 28px rgba(24, 85, 55, 0.38);
}

html[data-theme="dark"] .tfs-choice--selected.tfs-choice--false {
  border-color: rgba(255, 151, 151, 0.88);
  box-shadow: 0 0 0 1px rgba(255, 151, 151, 0.26), 0 14px 28px rgba(124, 36, 36, 0.36);
}

html[data-theme="dark"] .tfs-choice--disabled {
  opacity: 0.92;
}

html[data-theme="dark"] .tfs-result-badge--true {
  background: rgba(52, 146, 93, 0.96);
  color: #f2fff6;
  border: 1px solid rgba(151, 244, 185, 0.52);
}

html[data-theme="dark"] .tfs-result-badge--false {
  background: rgba(168, 59, 59, 0.96);
  color: #fff3f3;
  border: 1px solid rgba(255, 165, 165, 0.48);
}

html[data-theme="dark"] .gm-exit-sheet {
  background: linear-gradient(180deg, #21160f 0%, #120b06 100%);
  border-top: 1px solid rgba(232, 189, 79, 0.28);
  box-shadow: 0 -14px 34px rgba(0, 0, 0, 0.42);
}

html[data-theme="dark"] .gm-exit-sheet-handle {
  background: rgba(255, 239, 206, 0.3);
}

html[data-theme="dark"] .gm-exit-sheet-image-wrapper {
  background: rgba(43, 31, 22, 0.96);
}

html[data-theme="dark"] .gm-exit-sheet-text {
  color: #f3e8d3;
}

html[data-theme="dark"] .gm-exit-primary-btn {
  background: linear-gradient(180deg, #6a4a22 0%, #4a3318 100%);
  border: 1px solid rgba(232, 189, 79, 0.42);
  color: #fff2d7;
}

html[data-theme="dark"] .gm-exit-secondary-btn {
  color: rgba(245, 232, 210, 0.68);
}

html[data-theme="dark"] .gm-correct-popup-card {
  background:
    radial-gradient(circle at top left, rgba(232, 189, 79, 0.14), transparent 44%),
    linear-gradient(160deg, #1a120c 0%, #23180f 58%, #140d08 100%);
  color: #f7ead7;
}

html[data-theme="dark"] .gm-correct-popup-title {
  color: #fff1d7;
}

html[data-theme="dark"] .gm-correct-popup-text {
  color: #f6e9d4;
}

html[data-theme="dark"] .gm-fb-explanation {
  background: rgba(43, 31, 23, 0.96);
  border-left-color: rgba(232, 189, 79, 0.8);
  color: #f8ecd8;
}

html[data-theme="dark"] .gm-fb-error-block {
  background: rgba(74, 32, 23, 0.86);
  border-left-color: rgba(255, 147, 102, 0.92);
}

html[data-theme="dark"] .gm-fb-error-label {
  color: #ffd0b4;
}

html[data-theme="dark"] .gm-fb-error-text {
  color: #ffe9dc;
}

html[data-theme="dark"] .gm-fb-merksatz {
  background: rgba(45, 34, 15, 0.98);
  color: #f5d37b;
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--wrong .gm-answer-popup-block--why .gm-answer-popup-block-inner {
  background: linear-gradient(180deg, rgba(58, 32, 27, 0.98), rgba(44, 24, 20, 0.98));
  color: #ffece4;
  box-shadow:
    0 0 0 1px rgba(255, 132, 94, 0.34),
    0 14px 34px rgba(0, 0, 0, 0.38),
    0 0 24px rgba(255, 114, 74, 0.2);
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--wrong .gm-answer-popup-block--why .gm-answer-popup-block-kicker {
  color: #ffc0a3;
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--wrong .gm-answer-popup-block--mistake .gm-answer-popup-block-inner {
  background: linear-gradient(180deg, rgba(102, 40, 32, 0.96), rgba(78, 30, 26, 0.98));
  color: #ffe8e0;
  border-left-color: rgba(255, 140, 109, 0.94);
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--wrong .gm-answer-popup-block--mistake .gm-answer-popup-block-kicker {
  color: #ffd0b8;
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--wrong .gm-answer-popup-block--takeaway .gm-answer-popup-block-inner {
  background: linear-gradient(180deg, rgba(48, 39, 26, 0.98), rgba(36, 30, 20, 0.98));
  color: #f8df9a;
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--wrong .gm-answer-popup-block--takeaway .gm-answer-popup-block-kicker {
  color: rgba(248, 223, 154, 0.9);
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--correct .gm-answer-popup-block--why .gm-answer-popup-block-inner {
  background: linear-gradient(180deg, rgba(67, 54, 24, 0.98), rgba(52, 41, 18, 0.98));
  color: #fff3d9;
  box-shadow:
    0 0 0 1px rgba(244, 207, 99, 0.36),
    0 14px 34px rgba(0, 0, 0, 0.36),
    0 0 28px rgba(244, 207, 99, 0.18);
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--correct .gm-answer-popup-block--why .gm-answer-popup-block-kicker {
  color: #f6d78c;
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--correct .gm-answer-popup-block--mistake .gm-answer-popup-block-inner {
  background: linear-gradient(180deg, rgba(78, 58, 24, 0.98), rgba(61, 45, 19, 0.98));
  color: #fff1d6;
  border-left-color: rgba(244, 207, 99, 0.94);
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--correct .gm-answer-popup-block--mistake .gm-answer-popup-block-kicker {
  color: #f4d994;
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--correct .gm-answer-popup-block--takeaway .gm-answer-popup-block-inner {
  background: linear-gradient(180deg, rgba(48, 39, 26, 0.98), rgba(36, 30, 20, 0.98));
  color: #f6de98;
}

html[data-theme="dark"] .gm-overlay .gm-answer-popup--correct .gm-answer-popup-block--takeaway .gm-answer-popup-block-kicker {
  color: rgba(246, 222, 152, 0.92);
}

/* Kontrast-Feinschliff fuer Darkmode (alle Spiele) */
html[data-theme="dark"] .gm-overlay :is(
  .scq-header-meta, .mc-hint, .gf-hint, .mp-hint, .mp-term-progress,
  .os-slot-label, .to-line-label, .to-pool-label, .to-slot-placeholder,
  .scn-hint, .scn-feedback-extra, .qf-question-label, .qf-stats-row,
  .qf-timer-label, .qf-meta-row, .fc-progress-row,
  .sb-instruction, .sb-answer-label, .sb-word-bank-label, .sb-reset-btn,
  .cs-pool-title, .cs-buckets-title, .cs-bucket-placeholder
) {
  color: rgba(245, 232, 210, 0.8);
}

html[data-theme="dark"] .gm-overlay :is(
  .os-review-user, .to-slot-text, .qf-feedback, .qf-summary,
  .cs-bucket-name, .cs-bucket-chip
) {
  color: #f8eedb;
}

html[data-theme="dark"] .gm-overlay .qf-error {
  color: rgba(245, 232, 210, 0.8);
}

html[data-theme="dark"] .gm-overlay .scn-option-label,
html[data-theme="dark"] .gm-overlay .to-slot-index {
  background: linear-gradient(180deg, rgba(95, 70, 36, 0.98), rgba(72, 52, 26, 0.98));
  color: #ffefca;
  border: 1px solid rgba(232, 189, 79, 0.36);
}

html[data-theme="dark"] .gm-overlay .mp-review-pair--correct {
  background: linear-gradient(135deg, rgba(43, 96, 59, 0.34), rgba(25, 64, 40, 0.32));
  border-color: rgba(122, 214, 142, 0.74);
}

html[data-theme="dark"] .gm-overlay .mp-review-pair--wrong {
  background: linear-gradient(135deg, rgba(124, 45, 45, 0.34), rgba(84, 32, 32, 0.32));
  border-color: rgba(255, 149, 149, 0.7);
}

html[data-theme="dark"] .gm-overlay .mp-review-pair--wrong .mp-review-chosen {
  color: rgba(245, 232, 210, 0.45);
}

html[data-theme="dark"] .gm-overlay .mp-review-correct-hint {
  color: #b9f2c8;
}

/* Begriffe zuordnen: klare visuelle Trennung zwischen Pool-Chips und Ziel-Containern */
html[data-theme="dark"] .gm-overlay .cs-buckets {
  border-radius: 16px;
  padding: 8px;
  background: linear-gradient(170deg, rgba(43, 30, 22, 0.84), rgba(30, 21, 16, 0.84));
  border: 1px solid rgba(232, 189, 79, 0.16);
}

html[data-theme="dark"] .gm-overlay .cs-pool {
  border-radius: 16px;
  padding: 10px 8px 8px;
  background: linear-gradient(170deg, rgba(28, 20, 15, 0.95), rgba(21, 16, 12, 0.95));
  border: 1px solid rgba(232, 189, 79, 0.14);
}

html[data-theme="dark"] .gm-overlay .cs-bucket {
  background: linear-gradient(180deg, rgba(46, 33, 24, 0.98), rgba(34, 24, 18, 0.98));
  border-color: rgba(232, 189, 79, 0.24);
}

html[data-theme="dark"] .gm-overlay .cs-bucket-body {
  background: linear-gradient(180deg, rgba(29, 21, 15, 0.95), rgba(23, 17, 13, 0.95));
  border: 1px dashed rgba(232, 189, 79, 0.28);
  border-radius: 12px;
  padding: 8px;
}

html[data-theme="dark"] .gm-overlay .cs-item {
  background: linear-gradient(180deg, rgba(68, 51, 33, 0.98), rgba(49, 37, 24, 0.98));
  border-color: rgba(248, 210, 120, 0.44);
  color: #fff1d3;
  box-shadow:
    0 8px 18px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 241, 211, 0.12);
}

html[data-theme="dark"] .gm-overlay .cs-item:hover:not(.cs-item--assigned) {
  background: linear-gradient(180deg, rgba(77, 58, 36, 0.98), rgba(56, 42, 26, 0.98));
  border-color: rgba(249, 216, 134, 0.58);
}

html[data-theme="dark"] .gm-overlay .cs-item--selected {
  background: linear-gradient(180deg, rgba(101, 74, 35, 0.98), rgba(78, 56, 26, 0.98));
  border-color: rgba(255, 223, 142, 0.9);
  box-shadow:
    0 0 0 1px rgba(255, 223, 142, 0.26),
    0 12px 24px rgba(0, 0, 0, 0.32);
}

html[data-theme="dark"] .gm-overlay .cs-item--wrong {
  background: linear-gradient(180deg, rgba(115, 45, 45, 0.96), rgba(84, 34, 34, 0.98));
  border-color: rgba(255, 146, 146, 0.82);
  color: #ffe7e7;
}

html[data-theme="dark"] .gm-overlay .cs-bucket-chip {
  background: linear-gradient(180deg, rgba(87, 64, 31, 0.98), rgba(64, 47, 23, 0.98));
  border-color: rgba(250, 216, 130, 0.46);
}

html[data-theme="dark"] .gm-overlay .cs-chip-ghost {
  background: linear-gradient(180deg, rgba(79, 58, 32, 0.98), rgba(58, 43, 24, 0.98));
  border-color: rgba(249, 216, 130, 0.48);
  color: #fff0cf;
}

html[data-theme="dark"] .gm-overlay .cs-bucket--active {
  border-color: rgba(248, 210, 120, 0.9);
  box-shadow: 0 0 0 1px rgba(248, 210, 120, 0.22), 0 10px 22px rgba(0, 0, 0, 0.3);
}

html[data-theme="dark"] .gm-overlay .cs-bucket--correct {
  background: linear-gradient(180deg, rgba(43, 95, 57, 0.36), rgba(29, 67, 40, 0.34));
  border-color: rgba(121, 219, 142, 0.82);
}

html[data-theme="dark"] .gm-overlay .cs-bucket--wrong {
  background: linear-gradient(180deg, rgba(122, 46, 46, 0.34), rgba(87, 34, 34, 0.34));
  border-color: rgba(255, 145, 145, 0.82);
}

/* ======================================
   FEHLENDE DARKMODE-OVERRIDES: SPIELE
   ====================================== */

/* Gap Fill: Lückentexte */
html[data-theme="dark"] .gm-overlay .gf-gap {
  color: #f5ead6;
  border-bottom-color: rgba(245, 232, 210, 0.42);
}

html[data-theme="dark"] .gm-overlay .gf-gap--correct {
  color: #86efac;
  border-color: rgba(134, 239, 172, 0.8);
}

html[data-theme="dark"] .gm-overlay .gf-gap--wrong {
  color: rgba(255, 190, 160, 0.95);
  border-color: rgba(255, 170, 140, 0.8);
}

/* Match Pairs: Überprüfungszeilen */
html[data-theme="dark"] .gm-overlay .mp-review-pair {
  border-bottom-color: rgba(245, 232, 210, 0.14);
}

html[data-theme="dark"] .gm-overlay .mp-review-chosen {
  color: #f8eedb;
}

html[data-theme="dark"] .gm-overlay .mp-review-pair--correct .mp-review-icon,
html[data-theme="dark"] .gm-overlay .mp-review-pair--correct .mp-review-term {
  color: #86efac;
}

html[data-theme="dark"] .gm-overlay .mp-review-pair--wrong .mp-review-icon,
html[data-theme="dark"] .gm-overlay .mp-review-pair--wrong .mp-review-term {
  color: rgba(255, 190, 160, 0.95);
}

html[data-theme="dark"] .gm-overlay .mp-score-dot--wrong {
  background: rgba(220, 100, 80, 0.85);
}

/* Order Steps: Korrekte Antwort-Box */
html[data-theme="dark"] .gm-overlay .os-review-correct {
  background: rgba(34, 80, 40, 0.38);
  border-color: rgba(134, 239, 172, 0.42);
  color: #a6f4bc;
}

/* Timeline Order: Ghost-Chip */
html[data-theme="dark"] .gm-overlay .to-chip-ghost {
  color: #f5ead6;
  border-color: rgba(232, 189, 79, 0.3);
  background: linear-gradient(180deg, rgba(53, 39, 28, 0.98), rgba(39, 28, 20, 0.98));
}

/* Hook-Karte (Intro vor dem Spiel) */
html[data-theme="dark"] .gm-overlay .gm-lesson-hook-eyebrow {
  color: rgba(245, 232, 210, 0.6);
}

html[data-theme="dark"] .gm-overlay .gm-lesson-hook-title {
  color: #fff2dc;
}

html[data-theme="dark"] .gm-overlay .gm-lesson-hook-text {
  color: rgba(245, 232, 210, 0.86);
}

html[data-theme="dark"] .gm-overlay :is(
  .gm-lesson-hook-block--why,
  .gm-lesson-hook-block--mistake,
  .gm-lesson-hook-block--takeaway
) {
  background: linear-gradient(180deg, rgba(43, 31, 22, 0.96), rgba(31, 22, 16, 0.96));
  border-color: rgba(232, 189, 79, 0.24);
  color: #f9eed9;
}

html[data-theme="dark"] .gm-overlay :is(
  .gm-lesson-hook-block--why,
  .gm-lesson-hook-block--mistake,
  .gm-lesson-hook-block--takeaway
) .gm-lesson-hook-block-kicker {
  color: rgba(232, 189, 79, 0.9);
}

html[data-theme="dark"] .gm-overlay .gm-lesson-hook-kp-card {
  background: linear-gradient(180deg, rgba(43, 31, 22, 0.96), rgba(31, 22, 16, 0.96));
  border-color: rgba(232, 189, 79, 0.24);
  color: #f9eed9;
}

html[data-theme="dark"] .gm-overlay .gm-lesson-hook-kp-num {
  background: rgba(232, 189, 79, 0.18);
  color: rgba(232, 189, 79, 0.95);
}

html[data-theme="dark"] .gm-overlay .gm-lesson-hook-kp-text {
  color: #f9eed9;
}

html[data-theme="dark"] .gm-overlay .gm-lesson-hook-dot {
  background: rgba(245, 232, 210, 0.25);
}

html[data-theme="dark"] .gm-overlay .gm-lesson-hook-dot--active {
  background: rgba(245, 232, 210, 0.9);
}

/* Quickfire: Karte (weißer Hintergrund → dunkel) */
html[data-theme="dark"] .gm-overlay .qf-card-main {
  background: linear-gradient(160deg, #1a120c 0%, #251911 56%, #140e09 100%);
  border: 1px solid rgba(232, 189, 79, 0.2);
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.42);
}

/* Timeline Order: Belegter Slot */
html[data-theme="dark"] .gm-overlay .to-slot--filled {
  background: linear-gradient(180deg, rgba(53, 39, 28, 0.98), rgba(39, 28, 20, 0.98));
  border-color: rgba(232, 189, 79, 0.28);
}

/* Sentence Builder */
html[data-theme="dark"] .gm-overlay .sb-answer-area {
  background: linear-gradient(180deg, rgba(43, 31, 22, 0.96), rgba(31, 22, 16, 0.96));
  border-color: rgba(232, 189, 79, 0.24);
}

html[data-theme="dark"] .gm-overlay .sb-placed-word {
  border-bottom-color: rgba(245, 232, 210, 0.5);
  color: #f9edd8;
}

html[data-theme="dark"] .gm-overlay .sb-feedback {
  color: rgba(245, 232, 210, 0.86);
}

html[data-theme="dark"] .gm-overlay .sb-audio-label {
  color: rgba(245, 232, 210, 0.72);
}

html[data-theme="dark"] .gm-overlay .sb-joker-float-action {
  background: linear-gradient(180deg, rgba(53, 39, 28, 0.98), rgba(39, 28, 20, 0.98));
  color: #f9edd8;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28);
}

html[data-theme="dark"] .gm-overlay .sb-placed-word:hover {
  border-color: rgba(232, 189, 79, 0.7);
  color: #f9edd8;
}

html[data-theme="dark"] .gm-overlay .sb-test-close {
  background: rgba(52, 38, 26, 0.96);
  color: #f5ead6;
}

html[data-theme="dark"] .gm-overlay .sb-joker-no-energy {
  color: rgba(255, 190, 160, 0.95);
}
