/* MSHS visual polish: green, gold and white system-wide theme */
:root {
  --mshs-green: #005A32;
  --mshs-green-dark: #003D24;
  --mshs-green-deep: #002C1A;
  --mshs-green-soft: #EAF4EE;
  --mshs-gold: #F2A900;
  --mshs-gold-hover: #D89200;
  --mshs-gold-soft: #FFF5D7;
  --mshs-page: #F7FAF6;
  --mshs-line: #D9E6DD;
  --mshs-muted: #5F7168;
  --mshs-shadow: 0 18px 44px rgba(0, 90, 50, 0.10);
  --mshs-shadow-soft: 0 10px 26px rgba(0, 90, 50, 0.075);

  --navy: var(--mshs-green-dark) !important;
  --navy-hover: var(--mshs-green-deep) !important;
  --green: var(--mshs-green) !important;
  --gold: var(--mshs-gold) !important;
  --gold-hover: var(--mshs-gold-hover) !important;
  --page: var(--mshs-page) !important;
  --bg: var(--mshs-page) !important;
  --line: var(--mshs-line) !important;
  --border: var(--mshs-line) !important;
  --muted: var(--mshs-muted) !important;
  --text: var(--mshs-green-deep) !important;
  --soft-gold: var(--mshs-gold-soft) !important;
  --soft-green: var(--mshs-green-soft) !important;
  --shadow: var(--mshs-shadow) !important;
  --softShadow: var(--mshs-shadow-soft) !important;
  --shadow-soft: var(--mshs-shadow-soft) !important;
}

html {
  background: var(--mshs-page) !important;
}

body {
  color: var(--mshs-green-deep) !important;
  background:
    radial-gradient(circle at 88% 0%, rgba(242, 169, 0, 0.18), transparent 30%),
    radial-gradient(circle at 0% 8%, rgba(0, 90, 50, 0.08), transparent 28%),
    linear-gradient(180deg, #FFFFFF 0%, var(--mshs-page) 100%) !important;
}

a,
h1,
h2,
h3,
h4,
.panel-header h1,
.preview-panel-header h1,
.preview-panel-header h2,
.custom-card h1,
.custom-card h2,
.library-hero h1,
.hero h2,
.pretty-copy h4,
.activity-card h3,
.empty-state h3 {
  color: var(--mshs-green-deep) !important;
}

p,
.brand small,
.stw-brand-subtitle,
.library-hero p,
.hero p,
.pretty-copy p,
.meta,
.empty-state p,
.helper-card p,
.example span {
  color: var(--mshs-muted) !important;
}

/* Header / brand */
.topbar-clean,
.stw-topbar {
  background: transparent !important;
  border-bottom: 0 !important;
}

.brand,
.stw-brand {
  color: var(--mshs-green-deep) !important;
}

.brand-mark,
.stw-brand-mark {
  background: var(--mshs-green) !important;
  color: var(--mshs-gold) !important;
  box-shadow: 0 14px 28px rgba(0, 90, 50, 0.18), inset 0 -2px 0 rgba(0, 0, 0, 0.08) !important;
}

.brand h1,
.stw-brand-title {
  color: var(--mshs-green-deep) !important;
  letter-spacing: -0.05em !important;
}

/* Navigation buttons */
.top-actions a,
.top-actions button,
.stw-actions a,
.stw-actions button,
.btn {
  background: #FFFFFF !important;
  border: 1px solid var(--mshs-line) !important;
  color: var(--mshs-green-deep) !important;
  box-shadow: var(--mshs-shadow-soft) !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease !important;
}

.top-actions a:hover,
.top-actions button:hover,
.stw-actions a:hover,
.stw-actions button:hover,
.btn:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(0, 90, 50, 0.28) !important;
  background: var(--mshs-green-soft) !important;
}

.top-actions a.primary,
.stw-actions a.primary,
.btn.gold,
.hero-btn-primary,
#btn-generate-activity,
button.primary-action,
.pretty-copy a {
  background: var(--mshs-gold) !important;
  border-color: var(--mshs-gold) !important;
  color: var(--mshs-green-deep) !important;
  box-shadow: 0 14px 26px rgba(242, 169, 0, 0.24) !important;
}

.top-actions a.primary:hover,
.stw-actions a.primary:hover,
.btn.gold:hover,
.hero-btn-primary:hover,
#btn-generate-activity:hover,
button.primary-action:hover,
.pretty-copy a:hover {
  background: var(--mshs-gold-hover) !important;
  border-color: var(--mshs-gold-hover) !important;
}

/* Cards and panels */
.section-card,
.helper-card,
.custom-card,
.result-card,
.builder-panel,
.preview-panel,
.activity-card,
.empty-state,
.pretty-strategy-card,
.action-card,
.notice,
.selected-strategy-card,
.teacher-planning-panel,
.builder-purpose-card,
.output-card,
.output-callout {
  border-color: var(--mshs-line) !important;
  box-shadow: var(--mshs-shadow-soft) !important;
}

.section-card,
.builder-panel,
.preview-panel,
.custom-card,
.result-card {
  border-top: 4px solid var(--mshs-green) !important;
}

.pretty-strategy-card.featured,
.action-card.gold,
.notice {
  background: linear-gradient(135deg, var(--mshs-gold-soft) 0%, #FFFFFF 100%) !important;
  border-color: rgba(242, 169, 0, 0.55) !important;
}

.pretty-image,
.action-icon,
.problem-icon {
  background: linear-gradient(180deg, #FFFFFF 0%, var(--mshs-green-soft) 100%) !important;
}

.section-kicker,
.hero-pill,
.strategy-pill,
.student-view-pill,
.support-badge,
.strategy-count,
.year {
  background: var(--mshs-gold-soft) !important;
  border: 1px solid rgba(242, 169, 0, 0.55) !important;
  color: var(--mshs-green-deep) !important;
}

.problem,
.example {
  color: var(--mshs-green-deep) !important;
  border-color: var(--mshs-line) !important;
}

.problem:hover,
.example:hover {
  background: var(--mshs-green-soft) !important;
}

/* Carousel arrow buttons */
.mini-arrows {
  align-items: center !important;
}

.mini-arrows button,
.big-arrow,
button[data-card-prev],
button[data-card-next] {
  display: inline-grid !important;
  place-items: center !important;
  border: 1px solid rgba(0, 90, 50, 0.22) !important;
  background: #FFFFFF !important;
  color: var(--mshs-green-deep) !important;
  border-radius: 999px !important;
  box-shadow: var(--mshs-shadow-soft) !important;
  cursor: pointer !important;
  font-size: 0 !important;
  line-height: 1 !important;
  padding: 0 !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease !important;
}

.mini-arrows button,
button[data-card-prev]:not(.big-arrow),
button[data-card-next]:not(.big-arrow) {
  width: 42px !important;
  height: 42px !important;
}

.big-arrow {
  width: 56px !important;
  height: 56px !important;
}

button[data-card-prev]::before,
button[data-card-next]::before {
  display: block !important;
  font-size: 28px !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  margin-top: -2px !important;
  color: currentColor !important;
}

button[data-card-prev]::before { content: "‹" !important; }
button[data-card-next]::before { content: "›" !important; }
.big-arrow::before { font-size: 34px !important; }

.mini-arrows button:hover,
.big-arrow:hover,
button[data-card-prev]:hover,
button[data-card-next]:hover {
  transform: translateY(-2px) !important;
  background: var(--mshs-green) !important;
  border-color: var(--mshs-green) !important;
  color: #FFFFFF !important;
  box-shadow: 0 18px 34px rgba(0, 90, 50, 0.18) !important;
}

button[data-card-prev]:focus-visible,
button[data-card-next]:focus-visible,
.dot:focus-visible,
.top-actions a:focus-visible,
.top-actions button:focus-visible,
.stw-actions a:focus-visible,
.stw-actions button:focus-visible,
.btn:focus-visible,
.pretty-copy a:focus-visible {
  outline: 3px solid rgba(242, 169, 0, 0.45) !important;
  outline-offset: 3px !important;
}

.carousel-controls {
  gap: 16px !important;
}

.dot {
  background: #D9E6DD !important;
  border: 0 !important;
  width: 10px !important;
  height: 10px !important;
}

.dot.active {
  background: var(--mshs-green) !important;
  box-shadow: 0 0 0 4px rgba(242, 169, 0, 0.22) !important;
}

/* Builder form polish */
input,
textarea,
select,
.copy-html-box,
.code-box {
  border-color: var(--mshs-line) !important;
  color: var(--mshs-green-deep) !important;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--mshs-green) !important;
  box-shadow: 0 0 0 4px rgba(0, 90, 50, 0.12) !important;
  outline: none !important;
}

.output-tabs button.active {
  background: var(--mshs-green) !important;
  border-color: var(--mshs-green) !important;
  color: #FFFFFF !important;
}

/* Floating feedback button */
.learnai-feedback-button {
  background: var(--mshs-green) !important;
  color: #FFFFFF !important;
  border: 2px solid var(--mshs-gold) !important;
  box-shadow: 0 14px 34px rgba(0, 90, 50, 0.24) !important;
}

.learnai-feedback-button:hover {
  background: var(--mshs-green-deep) !important;
  transform: translateY(-2px) !important;
}

@media (max-width: 760px) {
  .brand-mark,
  .stw-brand-mark {
    width: 44px !important;
    height: 44px !important;
  }

  .big-arrow {
    width: 50px !important;
    height: 50px !important;
  }
}

/* Strategy card decision support polish */
.pretty-strategy-card {
  border-color: rgba(0, 90, 50, 0.16) !important;
  background: #FFFFFF !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease !important;
}

.pretty-strategy-card:hover {
  border-color: rgba(242, 169, 0, 0.72) !important;
}

.pretty-image {
  background: linear-gradient(180deg, #FFFFFF 0%, var(--mshs-green-soft) 100%) !important;
  border: 1px solid rgba(0, 90, 50, 0.08) !important;
}

.pretty-copy h4 {
  color: var(--mshs-green-deep) !important;
}

.pretty-copy p {
  margin-bottom: 14px !important;
}

.teacher-card-info {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin: 14px 0 16px !important;
}

.teacher-card-info span {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  min-height: 54px !important;
  padding: 9px 10px !important;
  border-radius: 14px !important;
  background: var(--mshs-green-soft) !important;
  border: 1px solid rgba(0, 90, 50, 0.10) !important;
  color: var(--mshs-green-deep) !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  line-height: 1.18 !important;
}

.teacher-card-info strong {
  color: var(--mshs-muted) !important;
  font-size: 10px !important;
  font-weight: 950 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
}

.pretty-copy a {
  background: var(--mshs-gold) !important;
  color: var(--mshs-green-deep) !important;
}

.pretty-copy a:hover {
  background: var(--mshs-green) !important;
  color: #FFFFFF !important;
}

/* Help me choose strategy panel: MSHS palette, no pink/purple icons */
.problem-list {
  border-color: var(--mshs-line) !important;
  border-radius: 18px !important;
  background: #FFFFFF !important;
}

.problem {
  min-height: 74px !important;
  align-items: center !important;
  padding: 12px 14px !important;
  background: #FFFFFF !important;
}

.problem:hover {
  background: linear-gradient(90deg, var(--mshs-green-soft) 0%, #FFFFFF 100%) !important;
}

.problem-left {
  align-items: flex-start !important;
  gap: 12px !important;
  min-width: 0 !important;
}

.problem-icon {
  width: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;
  background: var(--mshs-green-soft) !important;
  border: 1px solid rgba(0, 90, 50, 0.12) !important;
  color: var(--mshs-green) !important;
  display: grid !important;
  place-items: center !important;
  font-size: 15px !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  font-family: Arial, Helvetica, sans-serif !important;
}

.problem:hover .problem-icon {
  background: var(--mshs-gold) !important;
  border-color: var(--mshs-gold) !important;
  color: var(--mshs-green-deep) !important;
}

.problem-copy {
  display: grid !important;
  gap: 3px !important;
  min-width: 0 !important;
}

.problem-copy strong {
  color: var(--mshs-green-deep) !important;
  font-size: 15px !important;
  line-height: 1.2 !important;
  font-weight: 950 !important;
}

.problem-copy small {
  color: var(--mshs-muted) !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  font-weight: 750 !important;
}

.problem-copy em {
  color: var(--mshs-green) !important;
  font-style: normal !important;
  font-size: 11px !important;
  line-height: 1.2 !important;
  font-weight: 950 !important;
  letter-spacing: 0.02em !important;
}

.problem-arrow {
  color: var(--mshs-green-deep) !important;
  font-size: 24px !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  margin-left: 10px !important;
}

@media (max-width: 900px) {
  .teacher-card-info {
    grid-template-columns: 1fr !important;
  }

  .teacher-card-info span {
    min-height: auto !important;
  }
}


/* ------------------------------------------------------------------
   HARD FIX: strategy card layout
   This fixes the squished Browse all strategies cards by making the
   library cards vertical, while keeping the homepage carousel card wide.
------------------------------------------------------------------ */
.library-grid {
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch !important;
}

.library-grid > .pretty-strategy-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 16px !important;
  min-height: 520px !important;
  height: 100% !important;
  padding: 20px !important;
  border-radius: 26px !important;
  overflow: hidden !important;
}

.library-grid > .pretty-strategy-card .pretty-image {
  width: 100% !important;
  height: 190px !important;
  min-height: 190px !important;
  border-radius: 22px !important;
  flex: 0 0 auto !important;
}

.library-grid > .pretty-strategy-card .pretty-image img {
  width: 100% !important;
  height: 190px !important;
  max-height: 190px !important;
  object-fit: contain !important;
  padding: 0 !important;
}

.library-grid > .pretty-strategy-card .pretty-copy {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  width: 100% !important;
}

.library-grid > .pretty-strategy-card .pretty-copy h4 {
  margin: 0 0 10px !important;
  font-size: 25px !important;
  line-height: 1.08 !important;
  letter-spacing: -0.04em !important;
  min-height: 54px !important;
}

.library-grid > .pretty-strategy-card .pretty-copy p {
  margin: 0 0 16px !important;
  min-height: 74px !important;
  color: var(--mshs-muted) !important;
  font-size: 15.5px !important;
  line-height: 1.45 !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
}

.library-grid > .pretty-strategy-card .teacher-card-info {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
  width: 100% !important;
  margin: auto 0 16px !important;
}

.library-grid > .pretty-strategy-card .teacher-card-info span {
  min-width: 0 !important;
  min-height: 68px !important;
  padding: 10px 9px !important;
  border-radius: 14px !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}

.library-grid > .pretty-strategy-card .teacher-card-info strong {
  white-space: nowrap !important;
  font-size: 9.5px !important;
  letter-spacing: 0.055em !important;
}

.library-grid > .pretty-strategy-card .pretty-copy a {
  width: 100% !important;
  min-height: 54px !important;
  border-radius: 15px !important;
  align-self: stretch !important;
  margin-top: 0 !important;
  text-align: center !important;
}

/* Homepage carousel: keep one clean feature card, not three cramped cards. */
.strategy-card-grid {
  grid-template-columns: 1fr !important;
}

.strategy-card-grid .pretty-strategy-card {
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr) !important;
  align-items: center !important;
}

.strategy-card-grid .teacher-card-info {
  grid-template-columns: repeat(3, minmax(120px, 1fr)) !important;
}

.strategy-card-grid .teacher-card-info span {
  min-width: 0 !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

/* Make the feedback button less likely to cover strategy CTAs. */
.learnai-feedback-button {
  right: 18px !important;
  bottom: 18px !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  border-radius: 999px !important;
}

@media (max-width: 1160px) {
  .library-grid {
    grid-template-columns: repeat(2, minmax(300px, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .library-grid {
    grid-template-columns: 1fr !important;
  }

  .library-grid > .pretty-strategy-card {
    min-height: 0 !important;
  }

  .library-grid > .pretty-strategy-card .pretty-copy h4,
  .library-grid > .pretty-strategy-card .pretty-copy p {
    min-height: 0 !important;
  }

  .library-grid > .pretty-strategy-card .teacher-card-info,
  .strategy-card-grid .teacher-card-info {
    grid-template-columns: 1fr !important;
  }

  .strategy-card-grid .pretty-strategy-card {
    grid-template-columns: 1fr !important;
  }
}
