/* ─── Student Switcher ──────────────────────────────── */

student-switcher {
  display: flex;
  gap: var(--space-xs);
  align-items: center;
}

student-switcher .switch-btn {
  padding: var(--space-xs) var(--space-md);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-bg);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: 600;
  transition: all var(--transition-fast);
  font-family: var(--font-body);
}

student-switcher .switch-btn:hover {
  border-color: var(--color-text-light);
}

student-switcher .switch-btn[data-student="ami"].active {
  background: var(--color-ami);
  border-color: var(--color-ami);
  color: white;
}

student-switcher .switch-btn[data-student="ida"].active {
  background: var(--color-ida);
  border-color: var(--color-ida);
  color: white;
}

/* ─── Collapsible Section ──────────────────────────── */

collapsible-section {
  display: block;
  margin-bottom: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

collapsible-section .cs-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) var(--space-lg);
  background: var(--color-bg-alt);
  cursor: pointer;
  user-select: none;
  border: none;
  width: 100%;
  text-align: left;
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--color-text);
}

collapsible-section .cs-header:hover {
  background: var(--color-border-light);
}

collapsible-section .cs-chevron {
  transition: transform var(--transition-fast);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

collapsible-section[open] .cs-chevron {
  transform: rotate(90deg);
}

collapsible-section .cs-body {
  padding: var(--space-lg);
  display: none;
}

collapsible-section[open] .cs-body {
  display: block;
}

/* Student-specific sections */
collapsible-section[data-variant="ami"] .cs-header {
  border-left: 4px solid var(--color-ami);
}

collapsible-section[data-variant="ida"] .cs-header {
  border-left: 4px solid var(--color-ida);
}

collapsible-section[data-variant="shared"] .cs-header {
  border-left: 4px solid var(--color-primary);
}

/* ─── Lesson Checklist ─────────────────────────────── */

lesson-checklist {
  display: block;
  margin: var(--space-md) 0;
}

lesson-checklist .checklist-title {
  font-weight: 600;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-sm);
}

lesson-checklist .checklist-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-border-light);
}

lesson-checklist .checklist-item:last-child {
  border-bottom: none;
}

lesson-checklist .checklist-item input[type="checkbox"] {
  margin-top: 0.3em;
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--color-success);
  flex-shrink: 0;
}

lesson-checklist .checklist-item label {
  cursor: pointer;
  flex: 1;
}

lesson-checklist .checklist-item.checked label {
  text-decoration: line-through;
  color: var(--color-text-muted);
}

lesson-checklist .checklist-progress {
  font-size: var(--font-size-xs);
  color: var(--color-text-light);
  margin-top: var(--space-sm);
}

/* ─── Code Block ───────────────────────────────────── */

code-block {
  display: block;
  margin: var(--space-md) 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--color-border);
}

code-block .cb-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-xs) var(--space-md);
  background: #1e293b;
  color: #94a3b8;
  font-size: var(--font-size-xs);
  font-family: var(--font-mono);
}

code-block .cb-copy {
  background: none;
  border: 1px solid #475569;
  color: #94a3b8;
  padding: 2px var(--space-sm);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: var(--font-size-xs);
  font-family: var(--font-body);
}

code-block .cb-copy:hover {
  background: #334155;
  color: #e2e8f0;
}

code-block .cb-code {
  display: block;
  padding: var(--space-md) var(--space-lg);
  background: #0f172a;
  color: #e2e8f0;
  overflow-x: auto;
  white-space: pre;
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  line-height: 1.7;
}

/* ─── Tip Box ──────────────────────────────────────── */

tip-box {
  display: block;
  margin: var(--space-md) 0;
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md);
  border-left: 4px solid;
  font-size: var(--font-size-sm);
}

tip-box .tip-label {
  font-weight: 700;
  text-transform: uppercase;
  font-size: var(--font-size-xs);
  letter-spacing: 0.05em;
  margin-bottom: var(--space-xs);
}

tip-box[type="tip"] {
  background: var(--color-primary-light);
  border-color: var(--color-primary);
}

tip-box[type="warning"] {
  background: var(--color-warning-light);
  border-color: var(--color-warning);
}

tip-box[type="parent-note"] {
  background: #f0fdf4;
  border-color: var(--color-success);
}

tip-box[type="scope-warning"] {
  background: var(--color-danger-light);
  border-color: var(--color-danger);
}

/* ─── Scope Warning ────────────────────────────────── */

scope-warning {
  display: block;
  margin: var(--space-md) 0;
  padding: var(--space-md) var(--space-lg);
  background: var(--color-danger-light);
  border: 2px dashed var(--color-danger);
  border-radius: var(--radius-md);
}

scope-warning .sw-title {
  font-weight: 700;
  color: var(--color-danger);
  margin-bottom: var(--space-xs);
}

/* ─── Reflection Field ─────────────────────────────── */

reflection-field {
  display: block;
  margin: var(--space-md) 0;
}

reflection-field .rf-prompt {
  font-weight: 600;
  margin-bottom: var(--space-sm);
  color: var(--color-text);
}

reflection-field textarea {
  width: 100%;
  min-height: 100px;
  padding: var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  resize: vertical;
  transition: border-color var(--transition-fast);
}

reflection-field textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-light);
}

reflection-field .rf-status {
  font-size: var(--font-size-xs);
  color: var(--color-text-light);
  margin-top: var(--space-xs);
  text-align: right;
}

reflection-field .rf-status.saved {
  color: var(--color-success);
}

/* ─── Video Placeholder ────────────────────────────── */

video-placeholder {
  display: block;
  margin: var(--space-md) 0;
}

video-placeholder .vp-container {
  position: relative;
  padding-bottom: 56.25%;
  background: var(--color-bg-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  overflow: hidden;
}

video-placeholder .vp-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

video-placeholder .vp-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  gap: var(--space-sm);
}

video-placeholder .vp-placeholder-icon {
  font-size: 2rem;
}

/* ─── Worksheet Link ───────────────────────────────── */

worksheet-link {
  display: block;
  margin: var(--space-md) 0;
}

worksheet-link a {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-primary);
  font-weight: 500;
  transition: all var(--transition-fast);
}

worksheet-link a:hover {
  background: var(--color-primary-light);
  text-decoration: none;
}

/* ─── Day Header ───────────────────────────────────── */

day-header {
  display: block;
  margin-bottom: var(--space-2xl);
  padding-bottom: var(--space-lg);
  border-bottom: 2px solid var(--color-border);
}

day-header .dh-day-num {
  font-size: var(--font-size-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-primary);
  margin-bottom: var(--space-xs);
}

day-header .dh-title {
  font-size: var(--font-size-3xl);
  font-weight: 800;
  line-height: var(--line-height-tight);
  margin-bottom: var(--space-sm);
}

day-header .dh-meta {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  margin-bottom: var(--space-md);
}

day-header .dh-tag {
  font-size: var(--font-size-xs);
  padding: 2px var(--space-sm);
  background: var(--color-bg-alt);
  border-radius: var(--radius-full);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
}

day-header .dh-objectives {
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

/* ─── Build Milestone ──────────────────────────────── */

build-milestone {
  display: block;
  margin: var(--space-xl) 0;
  padding: var(--space-lg);
  background: linear-gradient(135deg, var(--color-primary-light), #ede9fe);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-lg);
}

build-milestone .bm-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

build-milestone .bm-icon {
  font-size: var(--font-size-xl);
}

build-milestone .bm-title {
  font-weight: 700;
  font-size: var(--font-size-lg);
  color: var(--color-primary-dark);
}

build-milestone .bm-body {
  color: var(--color-text);
  font-size: var(--font-size-sm);
}

build-milestone .bm-check {
  margin-top: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

build-milestone .bm-check input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: var(--color-primary);
}

build-milestone .bm-check label {
  font-weight: 600;
  cursor: pointer;
}

/* ─── Lesson Nav ───────────────────────────────────── */

lesson-nav {
  display: block;
  margin-top: var(--space-3xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-border);
}

lesson-nav .ln-container {
  display: flex;
  justify-content: space-between;
  gap: var(--space-md);
}

lesson-nav .ln-btn {
  display: flex;
  flex-direction: column;
  padding: var(--space-md) var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--color-text);
  transition: all var(--transition-fast);
  max-width: 45%;
}

lesson-nav .ln-btn:hover {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
  text-decoration: none;
}

lesson-nav .ln-btn .ln-label {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

lesson-nav .ln-btn .ln-title {
  font-weight: 600;
  font-size: var(--font-size-sm);
}

lesson-nav .ln-btn.ln-next {
  text-align: right;
  margin-left: auto;
}

/* ─── Sidebar Nav ──────────────────────────────────── */

sidebar-nav {
  display: block;
}

.sidebar .sn-section-title {
  font-size: var(--font-size-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-light);
  padding: var(--space-md) var(--space-lg) var(--space-xs);
}

.sidebar .sn-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sidebar .sn-item {
  list-style: none;
}

.sidebar .sn-item a {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-lg);
  color: var(--color-text);
  font-size: var(--font-size-sm);
  text-decoration: none;
  transition: background var(--transition-fast);
}

.sidebar .sn-item a:hover {
  background: var(--color-border-light);
}

.sidebar .sn-item.active a {
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  font-weight: 600;
}

.sidebar .sn-item .sn-check {
  width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--color-success);
  flex-shrink: 0;
}

.sidebar .sn-divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-md) var(--space-lg);
}

/* ─── Progress Ring ────────────────────────────────── */

progress-ring {
  display: inline-block;
}

progress-ring svg {
  transform: rotate(-90deg);
}

progress-ring .pr-bg {
  stroke: var(--color-border);
  fill: none;
}

progress-ring .pr-fill {
  fill: none;
  stroke-linecap: round;
  transition: stroke-dashoffset var(--transition-base);
}

progress-ring .pr-text {
  font-weight: 700;
  font-size: var(--font-size-sm);
  fill: var(--color-text);
}

/* ─── Progress Card ────────────────────────────────── */

progress-card {
  display: block;
  padding: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg);
}

progress-card .pc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
}

progress-card .pc-name {
  font-weight: 700;
  font-size: var(--font-size-xl);
}

progress-card .pc-project {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

progress-card .pc-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-md);
}

progress-card .pc-stat {
  text-align: center;
}

progress-card .pc-stat-value {
  font-size: var(--font-size-2xl);
  font-weight: 700;
}

progress-card .pc-stat-label {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

progress-card[data-student="ami"] {
  border-top: 3px solid var(--color-ami);
}

progress-card[data-student="ida"] {
  border-top: 3px solid var(--color-ida);
}
