@import url("../styles-shared.css");

.wg-applet .llm-applet-hero {
  background: linear-gradient(145deg, #1a2744 0%, #2d4a7a 55%, #1e3d5c 100%);
  color: #f8fafc;
  border-radius: 12px;
  padding: 1.25rem 1rem;
  margin-bottom: 1rem;
}

.wg-applet .llm-applet-hero h1,
.wg-applet .subtitle,
.wg-applet .philosophy {
  color: #f8fafc;
}

.wg-applet .subtitle {
  font-weight: 600;
}

.game-intro h2 {
  margin: 0 0 0.75rem;
  font-size: 1.2rem;
  color: #1a2744;
}

.game-intro__block {
  margin-bottom: 0.75rem;
}

.game-intro__block h3 {
  margin: 0 0 0.25rem;
  font-size: 1.05rem;
  color: #1a2744;
}

.game-intro__block p,
.game-intro__block ul {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.5;
}

.game-intro__block ul {
  padding-left: 1.25rem;
}

.game-intro__skills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.5rem;
  list-style: none;
  padding: 0;
}

.game-intro__skills li {
  background: #ede9fe;
  border: 1px solid #c4b5fd;
  border-radius: 999px;
  padding: 0.25rem 0.65rem;
  font-size: 0.95rem;
  font-weight: 600;
}

.game-intro__hint,
.philosophy,
.subtitle {
  font-size: 1.05rem;
  line-height: 1.55;
}

.wg-start-btn {
  width: 100%;
  max-width: 20rem;
  min-height: 3rem;
  font-size: 1.1rem;
}

.load-status {
  text-align: center;
  color: var(--llm-muted);
  margin: 0 0 1rem;
}

.load-status--error {
  color: #8a1f1f;
  font-weight: 600;
}

[hidden] {
  display: none !important;
}

.wg-is-hidden {
  display: none !important;
}

.game-panel {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.wg-board-card {
  background: linear-gradient(180deg, #f5f3ff 0%, #eef2ff 100%);
  border: 2px solid #6366f1;
  border-radius: 14px;
  padding: 1rem;
  box-shadow: 0 4px 14px rgba(49, 46, 129, 0.12);
}

.wg-board-card__title {
  margin: 0 0 0.75rem;
  font-size: 1.15rem;
  color: #312e81;
}

.wg-board-hint {
  margin: 0 0 0.75rem;
  font-size: 0.95rem;
  color: #4338ca;
}

.wg-grid-mount {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.wg-board {
  display: grid;
  grid-template-columns: minmax(5.5rem, 1.35fr) 1fr 1fr;
  gap: 0.45rem;
  width: 100%;
  min-width: 0;
  max-width: 36rem;
  margin: 0 auto;
}

.wg-board--values-2 {
  grid-template-columns: minmax(5.5rem, 1.35fr) 1fr 1fr;
}

.wg-board--values-3 {
  grid-template-columns: minmax(5rem, 1.3fr) repeat(3, minmax(2.75rem, 1fr));
}

.wg-board--values-4 {
  grid-template-columns: minmax(4.75rem, 1.25fr) repeat(4, minmax(2.5rem, 1fr));
  max-width: 40rem;
}

.wg-board--values-5 {
  grid-template-columns: minmax(4.5rem, 1.2fr) repeat(5, minmax(2.35rem, 1fr));
  max-width: 42rem;
}

.wg-grid-mount--wide {
  padding-bottom: 0.25rem;
}

.wg-grid-mount--wide::after {
  content: "Scroll sideways for all point columns →";
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: #6366f1;
  margin-top: 0.35rem;
  text-align: center;
}

.wg-board__corner {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #4338ca;
  align-self: end;
  padding-bottom: 0.2rem;
}

.wg-board__col-head {
  text-align: center;
  font-weight: 800;
  font-size: 1.05rem;
  color: #fff;
  background: linear-gradient(180deg, #4f46e5, #3730a3);
  border-radius: 8px;
  padding: 0.55rem 0.35rem;
  min-height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.wg-board__row-head {
  display: flex;
  align-items: center;
  font-weight: 700;
  font-size: 0.92rem;
  line-height: 1.25;
  color: #1e1b4b;
  background: #e0e7ff;
  border: 1px solid #a5b4fc;
  border-radius: 8px;
  padding: 0.45rem 0.5rem;
  min-height: 3rem;
}

.wg-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  border: none;
  border-radius: 10px;
  font-weight: 800;
  font-size: 1.05rem;
  cursor: pointer;
  color: #1e1b4b;
  background: linear-gradient(180deg, #fef08a 0%, #facc15 55%, #eab308 100%);
  box-shadow: 0 2px 0 #a16207, inset 0 1px 0 rgba(255, 255, 255, 0.45);
  transition: transform 0.12s ease, box-shadow 0.12s ease, opacity 0.12s ease;
  touch-action: manipulation;
}

.wg-cell:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 4px 0 #a16207, inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.wg-cell:focus-visible {
  outline: 3px solid #4f46e5;
  outline-offset: 2px;
}

.wg-cell--done {
  cursor: default;
  background: #e2e8f0;
  color: #475569;
  box-shadow: none;
  font-size: 1.35rem;
}

.wg-cell--done::after {
  content: none;
}

.wg-cell--soon {
  cursor: not-allowed;
  background: #e2e8f0;
  color: #64748b;
  box-shadow: none;
  font-size: 0.78rem;
  font-weight: 700;
  min-height: 2.75rem;
}

.wg-cell__soon-label {
  line-height: 1.1;
}

.wg-cell__check {
  font-size: 1.35rem;
  line-height: 1;
}

.wg-board-status {
  margin: 0 0 0.65rem;
  font-size: 0.92rem;
  line-height: 1.45;
  color: #4338ca;
  font-weight: 600;
}

.reflection-style-picker {
  margin: 1rem 0;
}

.reflection-style-picker__title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  color: #1a2744;
}

.reflection-style-picker__grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.reflection-style-picker__btn {
  min-height: 2.75rem;
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  border: 1px solid #a5b4fc;
  background: #fff;
  color: #312e81;
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
}

.reflection-style-picker__btn[aria-checked="true"] {
  background: #4f46e5;
  border-color: #4338ca;
  color: #fff;
}

.wg-audience-senior .wg-board__row-head {
  font-size: 1rem;
}

.wg-audience-senior .wg-cell {
  min-height: 3.25rem;
  font-size: 1.1rem;
}

.wg-audience-senior .wg-board__col-head {
  font-size: 1.1rem;
  min-height: 2.75rem;
}

.wg-audience-child .wg-cell {
  min-height: 3.1rem;
  font-size: 1.08rem;
}

.wg-qa-card {
  background: linear-gradient(160deg, #1e3a5f 0%, #1d4ed8 100%);
  color: #f8fafc;
  border-radius: 14px;
  padding: 1rem 1.1rem;
  border: 2px solid #93c5fd;
}

.wg-qa-head {
  margin-bottom: 0.75rem;
}

.wg-qa-meta {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: #bfdbfe;
}

.wg-qa-card__title {
  margin: 0;
  font-size: 1.15rem;
  color: #fff;
}

.wg-qa-card .wq-question {
  color: #f8fafc;
  font-size: 1.12rem;
  line-height: 1.5;
}

/* Default choices: light blue-gray on blue Q&A card */
.wg-qa-card .wq-choice {
  background: #e8eef7;
  color: #1e293b;
  border: 2px solid #94a3b8;
  font-weight: 600;
}

.wg-qa-card .wq-choice:hover:not(:disabled) {
  border-color: #4f46e5;
  background: #eef2ff;
}

/* Do not dim all choices equally after answer (shared quiz-ui uses opacity on :disabled) */
.wg-qa-card .wq-choice.wg-choice--revealed:disabled {
  opacity: 1;
  cursor: default;
}

.wg-qa-card .wg-choice--has-inner {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.wg-choice__inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  width: 100%;
  text-align: left;
}

.wg-choice__badge {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.2;
  border-radius: 4px;
  padding: 0.15rem 0.45rem;
}

.wg-choice__text {
  display: block;
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.4;
  width: 100%;
}

/* Unselected incorrect — muted, clearly not selected */
.wg-qa-card .wq-choice.wg-choice--muted {
  background: #dde4ee;
  color: #64748b;
  border: 2px solid #cbd5e1;
  opacity: 0.82;
  font-weight: 500;
}

.wg-qa-card .wq-choice.wg-choice--muted .wg-choice__text {
  font-weight: 500;
}

/* Correct answer — strong green */
.wg-qa-card .wq-choice.wg-choice--correct-answer {
  background: #dcfce7;
  color: #14532d;
  border: 3px solid #15803d;
  box-shadow: 0 0 0 1px #86efac;
}

.wg-qa-card .wq-choice.wg-choice--correct-answer .wg-choice__badge {
  background: #bbf7d0;
  color: #166534;
}

.wg-qa-card .wq-choice.wg-choice--picked-correct {
  background: #bbf7d0;
  color: #14532d;
  border: 3px solid #16a34a;
  box-shadow: 0 0 0 2px #4ade80;
}

.wg-qa-card .wq-choice.wg-choice--picked-correct .wg-choice__badge {
  background: #86efac;
  color: #14532d;
}

/* Selected wrong — strong red/amber */
.wg-qa-card .wq-choice.wg-choice--picked-wrong {
  background: #ffedd5;
  color: #7c2d12;
  border: 3px solid #ea580c;
  box-shadow: 0 0 0 2px #fdba74;
}

.wg-qa-card .wq-choice.wg-choice--picked-wrong .wg-choice__badge {
  background: #fed7aa;
  color: #9a3412;
}

/* Response/learning card: light surface, dark text — do not inherit .wg-qa-card pale text */
.wg-qa-card .wq-feedback.wisdom-grid-feedback-card {
  margin-top: 1rem;
  padding: 1rem 1.05rem;
  border-radius: 10px;
  border: 1px solid #b8cfe6;
  background: #ffffff;
  color: #111827;
  -webkit-text-fill-color: #111827;
}

.wg-qa-card .wq-feedback.wisdom-grid-feedback-card.wq-feedback--ok {
  background: #edf7f0;
  border-color: #9fd4b0;
  border-left: 4px solid #4ade80;
  padding-left: 0.85rem;
}

.wg-qa-card .wq-feedback.wisdom-grid-feedback-card.wq-feedback--learn {
  background: #f8fafc;
  border-color: #b8cfe6;
  border-left: 4px solid #fbbf24;
  padding-left: 0.85rem;
}

.wg-qa-card .wisdom-grid-feedback-card .wg-feedback-result,
.wg-qa-card .wisdom-grid-feedback-card h3.wg-feedback-result {
  margin: 0 0 0.75rem;
  font-size: 1.1rem;
  color: #111827;
  -webkit-text-fill-color: #111827;
}

.wg-qa-card .wisdom-grid-feedback-card .wg-feedback-details,
.wg-qa-card .wisdom-grid-feedback-card .wg-feedback-details p,
.wg-qa-card .wisdom-grid-feedback-card .wg-feedback-details strong {
  margin: 0 0 0.5rem;
  line-height: 1.5;
  color: #374151;
  -webkit-text-fill-color: #374151;
}

.wg-qa-card .wisdom-grid-feedback-card .wg-feedback-details .llm-link,
.wg-qa-card .wisdom-grid-feedback-card .wg-feedback-details a {
  color: #1d4ed8;
  -webkit-text-fill-color: #1d4ed8;
}

.wg-qa-card .wisdom-grid-feedback-card .wg-feedback-details a:hover,
.wg-qa-card .wisdom-grid-feedback-card .wg-feedback-details a:focus-visible {
  color: #0f5fb8;
  -webkit-text-fill-color: #0f5fb8;
}

.wg-qa-card .wisdom-grid-feedback-card .wg-back-btn {
  color: #fff;
  -webkit-text-fill-color: #fff;
}

.wg-back-btn {
  margin-top: 0.75rem;
  width: 100%;
  max-width: 16rem;
}

.wg-complete-progress {
  font-weight: 600;
  color: #4338ca;
  margin: 0 0 0.75rem;
}

.wg-game-reflection {
  background: #fff;
  border: 1px solid #c4b5fd;
  border-radius: 12px;
  padding: 1rem;
  margin: 0 0 1rem;
  color: #1e293b;
}

.wg-game-reflection__title {
  margin: 0 0 0.5rem;
  font-size: 1.1rem;
  color: #312e81;
}

.wg-game-reflection__intro,
.wg-game-reflection__path,
.wg-game-reflection__word,
.wg-game-reflection__meaning {
  margin: 0 0 0.45rem;
  line-height: 1.5;
}

.wg-game-reflection__label {
  font-weight: 600;
  color: #4338ca;
}

.wg-game-reflection__copy-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

#gameReflectionMount {
  margin: 0.5rem 0 1rem;
}

@media (max-width: 420px) {
  .wg-board {
    gap: 0.35rem;
  }

  .wg-board--values-2 {
    grid-template-columns: minmax(4.25rem, 1.2fr) 1fr 1fr;
  }

  .wg-board--values-3 {
    grid-template-columns: minmax(4rem, 1.15fr) repeat(3, minmax(2.35rem, 1fr));
  }

  .wg-board--values-4,
  .wg-board--values-5 {
    min-width: 20rem;
  }

  .wg-board__row-head {
    font-size: 0.82rem;
    padding: 0.35rem 0.4rem;
  }

  .wg-cell {
    font-size: 0.95rem;
    min-height: 2.65rem;
  }

  .wg-cell--soon {
    font-size: 0.72rem;
  }
}
