/* First-Gen College App Bootcamp course styles.
   Warm, flat, readable. No gradients, no shadows, no glassmorphism. */

:root {
  --c-bg: #FAFAF7;
  --c-bg-card: #FFFFFF;
  --c-text-primary: #1C1917;
  --c-text-secondary: #78716C;
  --c-accent: #D97706;
  --c-accent-hover: #B45309;
  --c-accent-light: #FEF3C7;
  --c-border: #E7E5E4;
  --c-success: #16A34A;
  --c-progress-bg: #E7E5E4;
}

* {
  box-sizing: border-box;
}

.course-body {
  margin: 0;
  background: var(--c-bg);
  color: var(--c-text-primary);
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 18px;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
}

.course-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Top bar */
.course-topbar {
  border-bottom: 1px solid var(--c-border);
  background: var(--c-bg);
}
.course-topbar-inner {
  max-width: 720px;
  margin: 0 auto;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.course-brand {
  font-weight: 600;
  font-size: 16px;
  color: var(--c-text-primary);
  text-decoration: none;
  letter-spacing: 0.02em;
}
.course-topbar-link {
  font-size: 15px;
  color: var(--c-text-secondary);
  text-decoration: none;
}
.course-topbar-link:hover {
  color: var(--c-accent);
}

/* Generic section spacing */
.course-section {
  padding-top: 64px;
  padding-bottom: 64px;
}

/* Typography helpers */
.course-h1 {
  font-size: 34px;
  font-weight: 600;
  line-height: 1.25;
  margin: 0 0 16px;
}
.course-h2 {
  font-size: 28px;
  font-weight: 600;
  line-height: 1.3;
  margin: 0 0 12px;
}
.course-lead {
  font-size: 19px;
  color: var(--c-text-secondary);
  margin: 0 0 32px;
}
.course-text {
  margin: 0 0 20px;
}
.course-text-secondary {
  color: var(--c-text-secondary);
}

/* Buttons */
.course-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 52px;
  padding: 0 28px;
  border-radius: 10px;
  border: none;
  font-family: inherit;
  font-size: 17px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background-color 0.15s ease, color 0.15s ease;
}
.course-btn-primary {
  background: var(--c-accent);
  color: #fff;
}
.course-btn-primary:hover {
  background: var(--c-accent-hover);
}
.course-btn-success {
  background: var(--c-success);
  color: #fff;
}
.course-btn-block {
  width: 100%;
}
.course-btn:focus-visible,
.course-input:focus-visible,
.course-select:focus-visible,
.course-textarea:focus-visible,
.course-checkbox:focus-visible {
  outline: none;
  border: 2px solid var(--c-accent);
}

/* Inputs */
.course-input,
.course-select,
.course-textarea {
  width: 100%;
  font-family: inherit;
  font-size: 17px;
  color: var(--c-text-primary);
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: 10px;
  padding: 14px 16px;
}
.course-input {
  min-height: 52px;
}
.course-textarea {
  min-height: 120px;
  resize: vertical;
  line-height: 1.6;
}
.course-label {
  display: block;
  font-weight: 600;
  font-size: 16px;
  margin-bottom: 8px;
}

/* Landing page */
.landing-hero {
  padding-top: 72px;
  padding-bottom: 40px;
}
.landing-kicker {
  font-size: 15px;
  font-weight: 600;
  color: var(--c-accent);
  margin: 0 0 16px;
}
.landing-body {
  font-size: 18px;
  margin: 0 0 8px;
}
.landing-form {
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.landing-form-note {
  font-size: 15px;
  color: var(--c-text-secondary);
  margin: 4px 0 0;
}
.landing-error {
  color: #B91C1C;
  font-size: 15px;
  margin: 4px 0 0;
  min-height: 0;
}

/* Progress bar */
.progress-block {
  margin-bottom: 40px;
}
.progress-label {
  font-size: 15px;
  font-weight: 600;
  color: var(--c-text-secondary);
  margin: 0 0 10px;
}
.progress-track {
  width: 100%;
  height: 10px;
  background: var(--c-progress-bg);
  border-radius: 999px;
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  background: var(--c-accent);
  border-radius: 999px;
  width: 0;
  transition: width 0.3s ease;
}

/* Module cards on dashboard */
.module-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.module-card {
  display: flex;
  align-items: center;
  gap: 20px;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: 12px;
  padding: 24px;
  text-decoration: none;
  color: inherit;
}
.module-card:hover {
  border-color: var(--c-accent);
}
.module-card-main {
  flex: 1;
}
.module-card-num {
  font-size: 14px;
  font-weight: 600;
  color: var(--c-text-secondary);
  margin: 0 0 4px;
}
.module-card-title {
  font-size: 20px;
  font-weight: 600;
  margin: 0 0 6px;
}
.module-card-desc {
  font-size: 16px;
  color: var(--c-text-secondary);
  margin: 0 0 10px;
  line-height: 1.6;
}
.module-status {
  font-size: 14px;
  font-weight: 600;
}
.module-status-notstarted {
  color: var(--c-text-secondary);
}
.module-status-inprogress {
  color: var(--c-accent);
}
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--c-accent-light);
  color: var(--c-success);
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 13px;
  font-weight: 600;
}
.module-card-arrow {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--c-border);
  color: var(--c-accent);
}
.module-card:hover .module-card-arrow {
  background: var(--c-accent-light);
  border-color: var(--c-accent-light);
}

/* Breadcrumb */
.course-breadcrumb {
  font-size: 15px;
  color: var(--c-text-secondary);
  margin: 0 0 24px;
  padding-top: 40px;
}
.course-breadcrumb a {
  color: var(--c-text-secondary);
  text-decoration: none;
}
.course-breadcrumb a:hover {
  color: var(--c-accent);
}

/* Module page */
.module-badge {
  display: inline-block;
  font-size: 14px;
  font-weight: 600;
  color: var(--c-accent);
  background: var(--c-accent-light);
  border-radius: 999px;
  padding: 4px 12px;
  margin-bottom: 16px;
}
.module-section {
  margin-bottom: 36px;
}
.module-section-heading {
  font-size: 21px;
  font-weight: 600;
  margin: 0 0 10px;
}
.module-section-body {
  margin: 0;
}

/* Interactive block container */
.interactive-block {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: 12px;
  padding: 24px;
  margin: 40px 0;
}
.interactive-title {
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 6px;
}
.interactive-hint {
  font-size: 15px;
  color: var(--c-text-secondary);
  margin: 0 0 20px;
}

/* Checklist */
.check-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.check-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  font-size: 16px;
  line-height: 1.5;
}
.check-item input {
  margin-top: 4px;
  width: 20px;
  height: 20px;
  accent-color: var(--c-accent);
  flex-shrink: 0;
  cursor: pointer;
}
.check-result {
  margin-top: 20px;
  padding: 16px;
  background: var(--c-accent-light);
  border-radius: 10px;
  font-size: 16px;
}
.check-result strong {
  display: block;
  margin-bottom: 4px;
}

/* List builder + tracker */
.builder-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}
.builder-row .course-input,
.builder-row .course-select {
  flex: 1;
  min-width: 140px;
}
.builder-row .course-btn {
  flex-shrink: 0;
}
.builder-counts {
  display: flex;
  gap: 16px;
  font-size: 14px;
  font-weight: 600;
  color: var(--c-text-secondary);
  margin-bottom: 16px;
}
.builder-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.builder-list-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: 10px;
}
.builder-tag {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  border-radius: 999px;
  padding: 2px 10px;
  margin-left: 8px;
}
.tag-safety { background: #DCFCE7; color: #15803D; }
.tag-match { background: var(--c-accent-light); color: var(--c-accent-hover); }
.tag-reach { background: #FEE2E2; color: #B91C1C; }
.builder-delete {
  background: none;
  border: none;
  color: var(--c-text-secondary);
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  padding: 4px 8px;
}
.builder-delete:hover {
  color: #B91C1C;
}
.builder-empty {
  font-size: 15px;
  color: var(--c-text-secondary);
  font-style: italic;
}

/* Deadline tracker table */
.tracker-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 16px;
  font-size: 15px;
}
.tracker-table th {
  text-align: left;
  font-size: 13px;
  font-weight: 600;
  color: var(--c-text-secondary);
  padding: 8px;
  border-bottom: 1px solid var(--c-border);
}
.tracker-table td {
  padding: 8px;
  border-bottom: 1px solid var(--c-border);
  vertical-align: middle;
}
.tracker-table input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: var(--c-success);
  cursor: pointer;
}

/* Brainstorm + action plan */
.field-group {
  margin-bottom: 24px;
}
.saved-note {
  font-size: 14px;
  font-weight: 600;
  color: var(--c-success);
  opacity: 0;
  transition: opacity 0.2s ease;
}
.saved-note.show {
  opacity: 1;
}

/* Topic prompt result */
.prompt-result {
  margin-top: 20px;
  padding: 16px;
  background: var(--c-accent-light);
  border-radius: 10px;
  font-size: 17px;
  line-height: 1.6;
  display: none;
}
.prompt-result.show {
  display: block;
}

/* Takeaway card */
.takeaway-card {
  background: var(--c-accent-light);
  border-left: 4px solid var(--c-accent);
  border-radius: 12px;
  padding: 24px;
  margin: 40px 0;
}
.takeaway-heading {
  font-size: 16px;
  font-weight: 600;
  color: var(--c-accent-hover);
  margin: 0 0 8px;
}
.takeaway-body {
  margin: 0;
  font-size: 17px;
}

/* Navigation row */
.module-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 32px 0 64px;
  border-top: 1px solid var(--c-border);
  margin-top: 40px;
}
.module-nav a {
  font-size: 16px;
  font-weight: 600;
  color: var(--c-accent);
  text-decoration: none;
}
.module-nav a:hover {
  color: var(--c-accent-hover);
}

/* Completion page */
.complete-list {
  counter-reset: takeaway;
  list-style: none;
  margin: 0 0 40px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.complete-list li {
  counter-increment: takeaway;
  position: relative;
  padding-left: 44px;
  font-size: 17px;
  line-height: 1.6;
}
.complete-list li::before {
  content: counter(takeaway);
  position: absolute;
  left: 0;
  top: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-accent-light);
  color: var(--c-accent-hover);
  border-radius: 999px;
  font-size: 15px;
  font-weight: 600;
}
.action-plan-item {
  margin-bottom: 20px;
}
.action-plan-q {
  font-size: 15px;
  font-weight: 600;
  color: var(--c-text-secondary);
  margin: 0 0 4px;
}
.action-plan-a {
  font-size: 17px;
  margin: 0;
}

/* Mobile */
@media (max-width: 600px) {
  .course-h1 { font-size: 28px; }
  .course-h2 { font-size: 24px; }
  .builder-row .course-btn { width: 100%; }
}

/* Print styles for completion page */
@media print {
  .course-topbar,
  .module-nav,
  .no-print {
    display: none !important;
  }
  .course-body {
    background: #fff;
    color: #000;
    font-size: 14pt;
  }
  .takeaway-card,
  .complete-list li::before {
    background: #fff;
  }
}
