/* ==========================================================================
   OgbonMath — Practice Panel Redesign (Phase 3)
   --------------------------------------------------------------------------
   Overrides the original practice-panel styles in styles.css to match
   Warm Study Hall. Softer borders, generous padding, input focus that
   matches dialog focus ring, calmer hint/feedback affordances.

   Scope: #pp and descendants. Loaded AFTER styles.css so we win the cascade.
   ========================================================================== */

/* ==========================================================================
   Drawer container — softer chrome, same slide behavior
   ==========================================================================
*/
#pp {
  width: 420px;
  background: var(--bg2);
  border-left: 1px solid var(--bdr);
  box-shadow: none;
  transition: transform var(--dur-slow) var(--ease-calm),
              box-shadow var(--dur) var(--ease-out);
}

#pp.open {
  box-shadow: var(--shadow-lg);
}

/* ==========================================================================
   Header — calmer, more textbook-like
   ==========================================================================
*/
.pp-h {
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
  border-bottom: 1px solid var(--bdr);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  background: var(--bg2);
}

.pp-h h3 {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--tx2);
  margin: 0;
}

#b-pp-close {
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: var(--radius-md) !important;
  color: var(--tx2) !important;
  font-size: 18px !important;
  width: 32px;
  height: 32px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color var(--dur-fast), background var(--dur-fast);
}

#b-pp-close:hover {
  color: var(--tx);
  background: var(--hover-bg);
}

/* ==========================================================================
   Problem body — reading-comfortable, breathing room
   ==========================================================================
*/
#pb {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-6) var(--sp-5);
  background: var(--bg2);
}

/* Problem prompt — serif for textbook feel, larger font */
.prp {
  font-family: var(--font-serif);
  font-size: var(--fs-md);
  line-height: var(--lh-relaxed);
  color: var(--tx);
  margin-bottom: var(--sp-5);
}

.prp .katex {
  font-size: 1.05em;
}

.prp .katex-display {
  margin: var(--sp-3) 0;
}

/* ==========================================================================
   Answer input area
   ==========================================================================
*/
.pri {
  display: flex;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
  align-items: stretch;
}

.pri input {
  flex: 1;
  font-family: var(--font-mono);
  font-size: var(--fs-md);
  padding: 12px 14px;
  border: 1px solid var(--bdr);
  border-radius: var(--radius-md);
  background: var(--bg);
  color: var(--tx);
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}

.pri input:focus {
  outline: none;
  border-color: var(--ac);
  box-shadow: 0 0 0 3px var(--ac-ring);
}

.pri input::placeholder {
  color: var(--tx3);
  font-family: var(--font-mono);
}

/* Submit button inside .pri (if present) */
.pri button {
  background: var(--ac);
  color: var(--ac-tx);
  border: 1px solid var(--ac);
  border-radius: var(--radius-md);
  padding: 0 20px;
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  transition: background var(--dur-fast), transform var(--dur-fast);
  flex-shrink: 0;
}

.pri button:hover { background: var(--ac2); }
.pri button:active { transform: scale(var(--active-scale)); }

/* ==========================================================================
   Hint button — subtle, secondary
   ==========================================================================
*/
.hb {
  background: transparent;
  color: var(--tx2);
  border: 1px solid var(--bdr);
  border-radius: var(--radius-md);
  padding: 8px 14px;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color var(--dur-fast), color var(--dur-fast), background var(--dur-fast);
}

.hb:hover {
  border-color: var(--ac);
  color: var(--ac);
  background: var(--ac-soft);
}

/* ==========================================================================
   Feedback (correct / incorrect)
   ==========================================================================
*/
.fb {
  font-family: var(--font-serif);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-md);
  margin-top: var(--sp-3);
  border: 1px solid transparent;
}

.fb-yes,
.fb.fb-yes,
.fb.correct {
  background: var(--gn-bg);
  border-color: var(--gn);
  color: var(--tx);
}

.fb-no,
.fb.fb-no,
.fb.incorrect {
  background: var(--rd-bg);
  border-color: var(--rd);
  color: var(--tx);
}

/* ==========================================================================
   Hint / solution reveal blocks (shared with lesson-prose)
   ==========================================================================
*/
#pb .hc,
#pb .hint-reveal {
  background: var(--ac-soft);
  border-left: 3px solid var(--ac);
  border-radius: var(--radius-md);
  padding: var(--sp-3) var(--sp-4);
  margin: var(--sp-3) 0;
  color: var(--tx);
  font-family: var(--font-serif);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
}

#pb .hc strong {
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--ac);
  display: block;
  margin-bottom: var(--sp-1);
}

/* ==========================================================================
   Footer — cleaner nav, primary action prominent
   ==========================================================================
*/
.pp-f {
  display: flex;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5) calc(var(--sp-3) + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid var(--bdr);
  background: var(--bg2);
}

.pp-f button {
  flex: 1;
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--bdr);
  background: transparent;
  color: var(--tx1);
  cursor: pointer;
  transition: background var(--dur-fast), border-color var(--dur-fast), color var(--dur-fast), transform var(--dur-fast);
}

.pp-f button:hover {
  background: var(--hover-bg);
  color: var(--tx);
  border-color: var(--bdr2);
}

.pp-f button:active { transform: scale(var(--active-scale)); }

/* Next button = primary */
#b-next.btn1,
.pp-f #b-next {
  background: var(--ac);
  color: var(--ac-tx);
  border-color: var(--ac);
}

#b-next.btn1:hover,
.pp-f #b-next:hover {
  background: var(--ac2);
  border-color: var(--ac2);
  color: var(--ac-tx);
}

/* Prev button = tertiary (disabled-ish look when opacity:0.5 is inline) */
.pp-f #b-prev { max-width: 80px; flex-grow: 0; }

/* ==========================================================================
   Empty state — "Select a lesson and click Practice"
   ==========================================================================
*/
#pb > p {
  font-family: var(--font-sans) !important;
  font-size: var(--fs-xs) !important;
  color: var(--tx3) !important;
  letter-spacing: var(--ls-widest) !important;
  text-transform: uppercase !important;
  text-align: center;
  padding: var(--sp-10) var(--sp-5) !important;
  line-height: var(--lh-relaxed);
}

/* ==========================================================================
   Responsive
   ==========================================================================
*/
@media (max-width: 768px) {
  #pp { width: 100vw; max-width: 100vw; border-left: none; }
  .pp-h { padding: var(--sp-4); }
  #pb { padding: var(--sp-5) var(--sp-4); }
  .pp-f { padding: var(--sp-3) var(--sp-4) calc(var(--sp-3) + env(safe-area-inset-bottom, 0px)); }
  .prp { font-size: var(--fs-base); }
}

/* ==========================================================================
   Mobile keyboard handling — lift the drawer's interactive area above the
   on-screen keyboard. Driven by --kbd-offset from design/mobile-keyboard.js.
   ==========================================================================
*/
:root { --kbd-offset: 0px; }

@media (max-width: 768px) {
  /* When keyboard is open, the practice drawer's footer + body content
     shift up so the active input stays visible. */
  html[data-kbd-open="1"] #pp {
    bottom: var(--kbd-offset, 0px);
    height: calc(100vh - var(--kbd-offset, 0px));
    transition: bottom var(--dur-fast) var(--ease-out),
                height var(--dur-fast) var(--ease-out);
  }

  /* Same treatment for the AI tutor full view when typing */
  html[data-kbd-open="1"] body[data-view="tutor"] #ct {
    padding-bottom: calc(var(--sp-6) + var(--kbd-offset, 0px));
  }

  /* And the inline-tutor on the welcome screen */
  html[data-kbd-open="1"] body[data-view="welcome"] #ct {
    padding-bottom: calc(var(--sp-6) + var(--kbd-offset, 0px));
  }
}

/* ==========================================================================
   Lightning drill mode — signature accent (the reserved "spark")
   ==========================================================================
   When #pp has class .drill-active, the practice panel gets the lime spark
   as a signal that something different/exciting is happening.
*/
#pp.drill-active {
  border-left-color: var(--spark);
  box-shadow: 0 0 0 1px var(--spark), var(--shadow-lg);
}

#pp.drill-active .pp-h h3 {
  color: var(--ac);
}

#pp.drill-active .pp-h h3::before {
  content: "⚡ ";
  font-weight: normal;
}
