/* modules.css – stiler for læringsmoduler */

/* ── Felles oppgavekort ── */
.task-question {
  font-weight: 700; color: var(--text-med);
  font-size: 18px; margin-bottom: 16px; text-align: center;
}
.next-btn { display: block; margin: 16px auto 0; }

/* ── MATEMATIKK ── */
.math-task {
  background: var(--surface); border-radius: var(--radius);
  padding: 32px 24px; text-align: center;
  box-shadow: var(--shadow-sm); margin-bottom: 16px;
}
.count-objects {
  font-size: 40px; letter-spacing: 6px; margin-bottom: 20px;
  display: block; line-height: 1.4; word-break: break-all;
}
.answer-grid {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 12px;
}
.answer-btn {
  background: var(--math-light); color: var(--math);
  font-family: var(--font); font-weight: 900; font-size: 28px;
  border: 3px solid transparent; border-radius: var(--radius-sm);
  padding: 16px 8px; cursor: pointer; min-height: var(--tap-min);
  transition: all .15s;
}
.answer-btn:hover  { border-color: var(--math); transform: scale(1.05); }
.answer-btn.correct{ background: var(--nature); color: white; border-color: var(--nature);
  animation: pop calc(.4s * var(--anim-speed)) ease; }
.answer-btn.wrong  { background: #FFE0E0; border-color: #EF476F;
  animation: shake calc(.4s * var(--anim-speed)) ease; }

@keyframes pop  { 0%,100%{transform:scale(1)}  50%{transform:scale(1.2)} }
@keyframes shake{ 0%,100%{transform:translateX(0)} 25%{transform:translateX(-8px)} 75%{transform:translateX(8px)} }

/* ── BOKSTAVER ── */
.lang-card {
  background: var(--surface); border-radius: var(--radius);
  padding: 32px 24px; text-align: center;
  box-shadow: var(--shadow-sm); margin-bottom: 16px;
}
.lang-emoji {
  font-size: 88px; display: block; margin-bottom: 12px;
  animation: bounce calc(2s * var(--anim-speed)) ease-in-out infinite;
}
.lang-hint { font-size: 16px; color: var(--text-med); margin-bottom: 20px; }
.word-display {
  display: flex; gap: 8px; justify-content: center;
  flex-wrap: wrap; min-height: 64px; margin-bottom: 20px;
}
.word-slot {
  width: 52px; height: 52px; border-radius: 12px;
  border: 3px dashed #ccc; display: flex; align-items: center;
  justify-content: center; font-size: 26px; font-weight: 900;
  transition: all .15s;
}
.lang-letters {
  display: flex; gap: 10px; justify-content: center; flex-wrap: wrap;
}
.letter-btn {
  width: 64px; height: 64px; border-radius: var(--radius-sm);
  background: var(--lang-light); color: var(--lang);
  font-family: var(--font); font-weight: 900; font-size: 26px;
  border: 3px solid transparent; cursor: pointer; transition: all .15s;
}
.letter-btn:hover  { border-color: var(--lang); transform: scale(1.08); }
.letter-btn.picked { background: var(--lang); color: white; opacity: .5; cursor: default; }

/* ── NATUR ── */
.nature-quiz {
  background: var(--surface); border-radius: var(--radius);
  padding: 32px 24px; text-align: center;
  box-shadow: var(--shadow-sm); margin-bottom: 16px;
}
.nature-img {
  font-size: 88px; display: block; margin-bottom: 12px;
  animation: bounce calc(2s * var(--anim-speed)) ease-in-out infinite;
}
.nature-question { font-size: 18px; font-weight: 700; margin-bottom: 20px; }
.nature-options  { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.nature-btn {
  background: var(--nature-light); color: #1a5c3a;
  font-family: var(--font); font-weight: 800; font-size: 16px;
  border: 3px solid transparent; border-radius: var(--radius-sm);
  padding: 18px 12px; cursor: pointer; min-height: 64px; transition: all .15s;
}
.nature-btn:hover  { border-color: var(--nature); transform: scale(1.03); }
.nature-btn.correct{ background: var(--nature); color: white;
  animation: pop calc(.4s * var(--anim-speed)) ease; }
.nature-btn.wrong  { background: #FFE0E0; border-color: #EF476F;
  animation: shake calc(.4s * var(--anim-speed)) ease; }

/* ── TEGNING ── */
.draw-toolbar {
  display: flex; gap: 8px; flex-wrap: wrap;
  background: var(--surface); border-radius: var(--radius-sm);
  padding: 12px 14px; box-shadow: var(--shadow-sm); margin-bottom: 12px;
  align-items: center;
}
.color-btn {
  width: 40px; height: 40px; border-radius: 50%;
  border: 3px solid transparent; cursor: pointer; transition: transform .15s;
  flex-shrink: 0;
}
.color-btn:hover, .color-btn.active { transform: scale(1.25); border-color: var(--text); }
.size-btn {
  background: var(--draw-light); border: 2px solid transparent;
  border-radius: 100px; padding: 7px 13px;
  font-family: var(--font); font-weight: 700; font-size: 14px;
  cursor: pointer; white-space: nowrap; color: var(--draw);
}
.size-btn.active, .size-btn:hover { border-color: var(--draw); }
.tool-sep { width: 1px; height: 30px; background: #eee; flex-shrink: 0; }

#draw-canvas {
  width: 100%; border-radius: var(--radius);
  box-shadow: var(--shadow-sm); cursor: crosshair;
  touch-action: none; background: #fff; display: block;
}

@media(max-width:400px){
  .answer-grid  { grid-template-columns: repeat(2,1fr); }
  .nature-options { grid-template-columns: 1fr; }
  .color-btn    { width: 34px; height: 34px; }
}
