/* Purchase page styles for purchase-template.php */
.purchase-page-wrap {
  --primary: #0060a9;
  /* Official TechnoKids Blue */
  --primary-hover: #004d88;
  --secondary: #8ed1fc;
  --accent-orange: #f37421;
  /* Official TechnoKids Orange */
  --accent-red: #ff5f5f;
  --accent-green: #006837;
  --text-main: #1f2937;
  --text-muted: #6b7280;
  --bg-page: #f9fafb;
  --bg-card: #ffffff;
  --border: #e5e7eb;
  --accent-bg: #f3f4f6;
  --radius-lg: 10px;
  --radius-md: 8px;
  --radius-sm: 4px;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow:
    0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg:
    0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --header-height: 80px;
}

.purchase-page-wrap,
.purchase-page-wrap * {
  box-sizing: border-box !important;
}

.purchase-page-wrap {
  font-family: "Outfit", "Inter", sans-serif !important;
  background-color: var(--bg-page) !important;
  color: var(--text-main) !important;
  line-height: 1.5 !important;
  -webkit-font-smoothing: antialiased !important;
}

.purchase-page-wrap h1,
.purchase-page-wrap h2,
.purchase-page-wrap h3,
.purchase-page-wrap h4,
.purchase-page-wrap h5,
.purchase-page-wrap .logo-text {
  font-family: "Outfit", sans-serif !important;
}

.tk-container {
  max-width: 1320px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
}

/* Header */
.tk-header-obsolete {
  background: rgba(255, 255, 255, 0.85) !important;
  backdrop-filter: saturate(180%) blur(20px) !important;
  -webkit-backdrop-filter: saturate(180%) blur(20px) !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1) !important;
  position: relative !important;
  z-index: 1000 !important;
  transition: background 0.3s ease !important;
}

.container-header {
  max-width: 1400px !important;
  margin: 0 auto !important;
  padding: 12px 24px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.header-left {
  display: flex !important;
  align-items: center !important;
  gap: 40px !important;
}

.logo {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-shrink: 0 !important;
}

.logo-icon {
  background: var(--primary) !important;
  color: white !important;
  width: 36px !important;
  height: 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  font-size: 20px !important;
}

/* Slot Machine Number Animation */
.slot-machine-container {
  display: inline-block !important;
  vertical-align: bottom !important;
  height: 1.2em !important;
  line-height: 1.2em !important;
  overflow: hidden !important;
  position: relative !important;
}

.slot-machine-rail {
  display: flex !important;
  flex-direction: column !important;
  transition: transform 0.6s cubic-bezier(0.45, 0.05, 0.55, 0.95) !important;
}

.slot-item {
  height: 1.2em !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.number-roll-up .slot-machine-rail {
  transform: translateY(-1.2em) !important;
}

/* Coming Soon Styling */
.coming-soon-overlay {
  position: relative !important;
}

.coming-soon-overlay::after {
  content: "";
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(255, 255, 255, 0.5) !important;
  pointer-events: none !important;
}

.course-age-badge {
  position: absolute !important;
  bottom: 12px !important;
  right: 0 !important;
  background: var(--primary) !important;
  color: white !important;
  padding: 4px 12px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  border-radius: 4px 0 0 4px !important;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1) !important;
  z-index: 10 !important;
}

/* Age-specific badge colors */
.course-age-badge.age-8-11 {
  background: #ef2b2b !important;
  /* Premium Red */
  color: white !important;
}

.course-age-badge.age-11-14 {
  background: #ef6c00 !important;
  /* Premium Amber/Orange */
  color: white !important;
}

.course-age-badge.age-6-8 {
  background: #0e1b8d !important;
  /* Premium Blue */
  color: white !important;
}

.course-age-badge.age-13 {
  background: #006b40 !important;
  /* Premium Green */
  color: white !important;
}

.course-age-badge.age-6-18 {
  background: #000 !important;
  /* Premium Black */
  color: white !important;
}

.coming-soon-ribbon {
  position: absolute !important;
  top: 15px !important;
  right: -5px !important;
  background: var(--accent-red) !important;
  color: white !important;
  padding: 5px 15px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1) !important;
  z-index: 10 !important;
}

.coming-soon-text {
  font-size: 20px !important;
  font-weight: 900 !important;
  color: #94a3b8 !important;
  letter-spacing: 2px !important;
}

.coming-soon-banner {
  padding: 10px !important;
  background: #f8fafc !important;
  border: 1px dashed #cbd5e1 !important;
  border-radius: 4px !important;
  color: #64748b !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  margin: 15px 0 !important;
  text-transform: uppercase !important;
}

.add-to-cart-btn:disabled {
  background: #e2e8f0 !important;
  color: #94a3b8 !important;
  cursor: not-allowed !important;
  transform: none !important;
  box-shadow: none !important;
}

.logo-text {
  font-size: 24px !important;
  font-weight: 700 !important;
  color: var(--text-main) !important;
  letter-spacing: -0.5px !important;
}

.logo-text span {
  color: var(--primary) !important;
}

.nav-desktop {
  display: flex !important;
  gap: 32px !important;
}

.nav-link {
  text-decoration: none !important;
  color: #4b5563 !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  transition: all 0.2s !important;
  padding: 12px 0 !important;
  position: relative !important;
  text-transform: capitalize !important;
}

.nav-link:hover,
.nav-link.active {
  color: var(--primary) !important;
}

.nav-link.active::after {
  content: "";
  position: absolute !important;
  bottom: 4px !important;
  left: 0 !important;
  width: 100% !important;
  height: 3px !important;
  background: var(--secondary) !important;
  border-radius: 2px !important;
}

.header-right {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
}

.header-icons {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.icon-btn {
  background: none !important;
  border: none !important;
  padding: 8px !important;
  color: var(--text-muted) !important;
  cursor: pointer !important;
  border-radius: 8px !important;
  transition:
    background 0.2s,
    color 0.2s;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
}

.icon-btn:hover {
  background: var(--accent) !important;
  color: var(--primary) !important;
}

.cart-count {
  position: absolute !important;
  top: 2px !important;
  right: 2px !important;
  background: #ef4444 !important;
  color: white !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  width: 16px !important;
  height: 16px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 2px solid white !important;
}

.header-buttons {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}

.auth-btn {
  text-decoration: none !important;
  color: var(--text-main) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  transition: color 0.2s !important;
}

.auth-btn:hover {
  color: var(--primary) !important;
}

.contact-btn {
  text-decoration: none !important;
  background: var(--primary) !important;
  color: white !important;
  padding: 12px 24px !important;
  border-radius: 4px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  transition: all 0.2s ease !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

.contact-btn:hover {
  background: var(--primary-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow) !important;
}

.mobile-toggle {
  display: none !important;
  background: none !important;
  border: none !important;
  color: var(--text-main) !important;
  cursor: pointer !important;
  padding: 4px !important;
}

/* Mobile Nav Overlay */
.mobile-nav {
  position: fixed !important;
  top: 70px !important;
  left: 0 !important;
  width: 100% !important;
  background: white !important;
  height: calc(100vh - 70px) !important;
  z-index: 999 !important;
  padding: 24px !important;
  display: none !important;
  flex-direction: column !important;
  overflow-y: auto !important;
}

.mobile-nav.active {
  display: flex !important;
}

.nav-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
}

.nav-list hr {
  border: 0 !important;
  border-top: 1px solid var(--border) !important;
  margin: 8px 0 !important;
}

/* Hero Section */
.hero {
  background: #ffffff !important;
  padding: 80px 0 !important;
  border-bottom: 1px solid var(--border) !important;
  margin-bottom: 40px !important;
}

.hero-grid {
  display: grid !important;
  grid-template-columns: 1.1fr 1fr !important;
  gap: 48px !important;
  align-items: center !important;
}

.hero-tag {
  color: var(--primary) !important;
  font-weight: 800 !important;
  font-size: 15px !important;
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  margin-bottom: 12px !important;
}

.hero-age {
  background: #e0f2fe !important;
  color: #0369a1 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  padding: 6px 14px !important;
  border-radius: 4px !important;
  display: inline-block !important;
  margin-bottom: 24px !important;
}

.hero-title {
  font-size: 56px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  margin-bottom: 24px !important;
  color: var(--primary) !important;
  letter-spacing: -1px !important;
}

.hero-subtitle {
  font-size: 20px !important;
  color: var(--text-muted) !important;
  max-width: 580px !important;
  line-height: 1.6 !important;
  font-weight: 400 !important;
}

.illustration-placeholder {
  width: 100% !important;
  aspect-ratio: 4/3 !important;
  background: #f1f5f9 !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 2px dashed #cbd5e1 !important;
}

.illustration-placeholder svg {
  width: 80% !important;
  height: auto !important;
}

/* Breadcrumb Update */
.breadcrumb {
  padding: 0 0 24px 0 !important;
  display: flex !important;
  gap: 8px !important;
  font-size: 14px !important;
}

.breadcrumb a {
  text-decoration: none !important;
  color: var(--text-muted) !important;
}

.breadcrumb .separator {
  color: #cbd5e1 !important;
}

.breadcrumb .current {
  color: var(--text-main) !important;
  font-weight: 500 !important;
}

/* Main Tab Views */
.tab-view {
  display: none !important;
  animation: fadeIn 0.4s ease !important;
}

.tab-view.active {
  display: block !important;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Secondary Tabs Navigation */
/* Secondary Tabs Navigation */
.secondary-tabs {
  display: flex !important;
  justify-content: center !important;
  gap: 32px !important;
  border-bottom: 2px solid var(--border) !important;
  margin: 40px 0 48px !important;
  padding: 0 !important;
}

.secondary-tab-btn,
.secondary-tab-link {
  background: transparent !important;
  border: none !important;
  color: #6b7280 !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  padding: 0 4px 16px !important;
  position: relative !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  font-family: inherit !important;
  text-decoration: none !important;
  display: inline-block !important;
}

.secondary-tab-btn:hover,
.secondary-tab-link:hover {
  color: var(--primary) !important;
}

.secondary-tab-btn.active {
  color: var(--primary) !important;
}

.secondary-tab-btn.active::after {
  content: "";
  position: absolute !important;
  bottom: -2px !important;
  left: 0 !important;
  width: 100% !important;
  height: 4px !important;
  background: var(--accent-orange) !important;
}

/* Skills Matrix Matrix Styling - Perfectly matching the grid in the image */
.skills-matrix-container {
  padding: 40px 0 !important;
  overflow-x: auto !important;
}

.skills-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 12px !important;
  min-width: 1100px !important;
}

.skills-table th {
  padding: 20px 10px !important;
  text-align: center !important;
  background: #f1f5f9 !important;
  border-radius: 8px !important;
}

.grade-label {
  display: block !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  color: var(--primary) !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
}

.grade-range {
  display: block !important;
  font-size: 11px !important;
  color: #64748b !important;
  font-weight: 700 !important;
  margin-top: 6px !important;
  text-transform: uppercase !important;
}

.skill-row {
  margin-bottom: 12px !important;
}

.skill-label-cell {
  width: 160px !important;
  text-align: center !important;
  padding: 15px 10px !important;
  vertical-align: middle !important;
}

.skill-icon-wrapper {
  width: 44px !important;
  height: 44px !important;
  margin: 0 auto 8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #475569 !important;
  background: #f1f5f9 !important;
  border-radius: 12px !important;
  transition: all 0.3s ease !important;
}

.skill-row:hover .skill-icon-wrapper {
  transform: scale(1.1) !important;
  color: var(--primary) !important;
  background: #e0f2fe !important;
}

.skill-icon-wrapper svg {
  width: 24px !important;
  height: 24px !important;
}

.skill-title {
  font-size: 10px !important;
  font-weight: 900 !important;
  color: #1e293b !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

.matrix-cell {
  padding: 20px !important;
  border-radius: 12px !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
  font-weight: 500 !important;
  width: 20% !important;
  vertical-align: top !important;
  transition: all 0.2s ease !important;
  border: 1px solid transparent !important;
}

.matrix-cell:hover:not(.matrix-cell-empty) {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05) !important;
  border-color: rgba(255, 255, 255, 0.5) !important;
}

.matrix-cell-empty {
  background: #f8fafc !important;
  border: 1px dashed #e2e8f0 !important;
}

/* Matrix Colors based on grades */
.cell-primary {
  background-color: #e0f2fe !important;
  color: #0369a1 !important;
}

/* Blue */
.cell-junior {
  background-color: #fee2e2 !important;
  color: #991b1b !important;
}

/* Red/Pink */
.cell-intermediate {
  background-color: #ffedd5 !important;
  color: #9a3412 !important;
}

/* Orange */
.cell-senior {
  background-color: #f0fdf4 !important;
  color: #166534 !important;
}

/* Green */

/* Scope and Sequence Redesign */
.scope-container {
  display: flex !important;
  flex-direction: column !important;
  gap: 60px !important;
  padding: 40px 0 !important;
}

.scope-group {
  width: 100% !important;
}

.scope-header {
  width: 100% !important;
  padding: 16px 0 !important;
  background: #f1f5f9 !important;
  border-left: 20px solid var(--primary) !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  color: #1e3a8a !important;
  text-align: center !important;
  margin-bottom: 30px !important;
  box-shadow: inset 0 -2px 0 rgba(0, 0, 0, 0.05) !important;
}

.scope-group.junior .scope-header {
  border-left-color: #ef4444 !important;
  color: #7f1d1d !important;
  background: #fef2f2 !important;
}

.scope-group.intermediate .scope-header {
  border-left-color: #f97316 !important;
  color: #7c2d12 !important;
  background: #fff7ed !important;
}

.scope-group.senior .scope-header {
  border-left-color: #10b981 !important;
  color: #064e3b !important;
  background: #f0fdf4 !important;
}

.scope-subcategory-title {
  font-size: 14px !important;
  color: #64748b !important;
  margin-bottom: 24px !important;
  text-align: center !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  width: 100% !important;
}

.scope-card-sections {
  display: grid !important;
  grid-template-columns: 1fr 280px !important;
  gap: 40px !important;
}

.scope-cards-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 20px !important;
  justify-content: flex-start !important;
}

.scope-card {
  background: white !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 8px !important;
  width: 220px !important;
  padding: 24px !important;
  display: flex !important;
  flex-direction: column !important;
  transition: all 0.2s ease !important;
  position: relative !important;
}

.scope-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1) !important;
  border-color: #94a3b8 !important;
}

.scope-card.highlighted {
  border: 2px solid #1e293b !important;
}

.card-top-icons {
  display: flex !important;
  gap: 8px !important;
  margin-bottom: 12px !important;
  color: #94a3b8 !important;
}

.skill-meter {
  display: flex !important;
  gap: 4px !important;
  margin-bottom: 16px !important;
}

.skill-bar {
  width: 14px !important;
  height: 6px !important;
  background: #e2e8f0 !important;
  border-radius: 2px !important;
}

.skill-bar.active {
  background: #10b981 !important;
}

.product-icon-overlay {
  position: absolute !important;
  top: 24px !important;
  right: 24px !important;
  width: 32px !important;
  height: 32px !important;
  object-fit: contain !important;
}

.scope-card h5 {
  font-size: 16px !important;
  font-weight: 800 !important;
  color: #0f172a !important;
  margin-bottom: 8px !important;
}

.scope-card p {
  font-size: 12px !important;
  color: #475569 !important;
  line-height: 1.5 !important;
  margin-bottom: 20px !important;
  flex: 1 !important;
}

.card-software-footer {
  display: flex !important;
  gap: 10px !important;
  padding-top: 15px !important;
  border-top: 1px solid #f1f5f9 !important;
}

.sw-icon {
  width: 20px !important;
  height: 20px !important;
  object-fit: contain !important;
}

/* Skills Matrix Styling */
.skills-matrix {
  overflow-x: auto !important;
  margin-top: 32px !important;
}

.skills-matrix table {
  width: 100% !important;
  border-collapse: collapse !important;
}

.skills-matrix th {
  text-align: left !important;
  padding: 24px !important;
  background: #f8fafc !important;
  font-size: 14px !important;
  border-bottom: 2px solid var(--border) !important;
}

.skills-matrix th span {
  font-weight: 400 !important;
  color: #64748b !important;
  font-size: 11px !important;
}

.skills-matrix td {
  padding: 16px !important;
  border-bottom: 1px solid var(--border) !important;
  vertical-align: middle !important;
}

.skill-name {
  font-weight: 800 !important;
  color: #1e293b !important;
  width: 150px !important;
}

.skill-box {
  padding: 16px !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
  border-radius: 4px !important;
  height: 100% !important;
  min-height: 80px !important;
}

.bg-blue {
  background: #eff6ff !important;
  color: #1e3a8a !important;
}

.bg-red {
  background: #fff1f2 !important;
  color: #9f1239 !important;
}

.bg-orange {
  background: #fff7ed !important;
  color: #9a3412 !important;
}

.bg-green {
  background: #f0fdf4 !important;
  color: #14532d !important;
}

/* How to Pick Styling */
.how-to-pick-content {
  max-width: 800px !important;
  margin: 0 auto !important;
  padding: 48px 0 !important;
}

.how-to-pick-content h3 {
  font-size: 24px !important;
  margin-bottom: 24px !important;
}

.how-to-pick-content p {
  font-size: 16px !important;
  line-height: 1.6 !important;
  margin-bottom: 24px !important;
}

.how-to-pick-content ul {
  list-style: none !important;
}

.how-to-pick-content li {
  margin-bottom: 16px !important;
  padding-left: 24px !important;
  position: relative !important;
}

.how-to-pick-content li::before {
  content: "-";
  color: var(--primary) !important;
  font-weight: bold !important;
  position: absolute !important;
  left: 0 !important;
}

/* Buy Now Section */
.buy-now-header {
  margin-bottom: 32px !important;
  text-align: center !important;
  width: 100% !important;
}

.buy-now-title {
  font-size: 28px !important;
  font-weight: 800 !important;
  margin-bottom: 12px !important;
  color: #111827 !important;
}

.buy-now-subtitle {
  color: var(--text-muted) !important;
  font-size: 16px !important;
  max-width: 800px !important;
  margin: 0 auto 32px !important;
  line-height: 1.6 !important;
}

.pagination {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 8px !important;
  margin-top: 60px !important;
  padding-top: 40px !important;
  border-top: 2px solid #f1f5f9 !important;
}

.pagination-btn {
  min-width: 40px !important;
  height: 40px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: none !important;
  background: transparent !important;
  color: var(--text-muted) !important;
  font-weight: 600 !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
}

.pagination-btn.active {
  background: #fef3c7 !important;
  /* Light yellow/gold */
  color: var(--text-dark) !important;
}

.pagination-btn:hover:not(.active) {
  background: #f1f5f9 !important;
}

.pagination-btn.nav-btn {
  color: var(--text-dark) !important;
  font-weight: 700 !important;
}

.tabs-container {
  display: flex !important;
  justify-content: center !important;
  gap: 12px !important;
  background: #ffffff !important;
  padding: 16px 24px !important;
  border-radius: 0 !important;
  width: 100% !important;
  flex-wrap: wrap !important;
  margin: 0 auto 32px !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 100 !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

.tab-btn {
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  padding: 12px 28px !important;
  border-radius: 8px !important;
  /* More rounded as in screenshot */
  font-weight: 700 !important;
  font-size: 15px !important;
  color: #475569 !important;
  cursor: pointer !important;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
  white-space: nowrap !important;
  flex: 0 1 auto !important;
  min-width: 140px !important;
  text-align: center !important;
}

.tab-btn:hover {
  background: #f1f5f9 !important;
  border-color: #cbd5e1 !important;
}

.tab-btn.active {
  background: var(--primary) !important;
  color: white !important;
  border-color: var(--primary) !important;
  box-shadow: 0 4px 6px -1px rgba(0, 96, 169, 0.2) !important;
}

.license-filter-row {
  display: flex !important;
  align-items: stretch !important;
  justify-content: center !important;
  gap: 16px !important;
  max-width: 1000px !important;
  margin: 0 auto 16px !important;
}

.license-info-text {
  margin: 0 !important;
  font-size: 15px !important;
  color: #1f2937 !important;
  padding: 12px 24px !important;
  background-color: #f0f7ff !important;
  border-left: 4px solid var(--primary) !important;
  border-radius: 4px !important;
  line-height: 1.5 !important;
  flex: 1 !important;
  text-align: left !important;
  font-weight: 500 !important;
  box-shadow: var(--shadow-sm) !important;
  display: flex !important;
  align-items: center !important;
}

.license-info-text strong {
  color: var(--primary) !important;
  text-transform: uppercase !important;
  font-size: 13px !important;
  letter-spacing: 0.5px !important;
  margin-right: 8px !important;
  white-space: nowrap !important;
}

/* Catalog Layout */
.catalog-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 350px !important;
  gap: 40px !important;
  align-items: stretch !important;
  margin-bottom: 64px !important;
}

.main-catalog {
  min-width: 0 !important;
}

.filter-toggle-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: fixed !important;
  top: 350px !important;
  left: 0 !important;
  gap: 10px !important;
  background: white !important;
  border: 2px solid var(--primary) !important;
  padding: 12px 24px !important;
  border-radius: 0 0 12px 12px !important;
  font-weight: 800 !important;
  color: var(--primary) !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  z-index: 100001 !important;
  font-family: "Outfit", sans-serif !important;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  transform-origin: top left !important;
  transform: rotate(-90deg) translateX(-100%) !important;
  border-top: none !important;
}

.filters-sidebar {
  position: fixed !important;
  left: -350px;
  top: 0 !important;
  bottom: 0 !important;
  width: 320px !important;
  background: white !important;
  z-index: 100000 !important;
  box-shadow: 20px 0 50px rgba(0, 0, 0, 0.15) !important;
  padding: 30px !important;
  overflow-y: auto !important;
  transition: left 0.3s ease !important;
  display: flex !important;
  flex-direction: column !important;
}

.filter-backdrop {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, 0.5) !important;
  z-index: 99999 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 0.3s ease !important;
}

/* Desktop Sticky Layout - Stick to left of screen outside container */
@media (min-width: 992px) {
  .purchase-template-body .page-content {
    padding-left: 300px !important; /* Push everything to make room for fixed sidebar */
  }

  .catalog-layout-container {
    display: block !important;
    position: static !important;
  }

  .filters-sidebar {
    position: fixed !important;
    top: 100px !important;
    left: 0 !important;
    width: 300px !important;
    height: calc(100vh - 100px) !important;
    background: #ffffff !important;
    z-index: 9999 !important;
    box-shadow: 4px 0 15px rgba(0, 0, 0, 0.05) !important;
    border-right: 1px solid #e5e7eb !important;
    padding: 30px !important;
    border-radius: 0 !important;
    transition: none !important;
    display: flex !important;
  }

  .catalog-main-row {
    margin: 0 !important;
    width: 100% !important;
  }

  .filter-toggle-btn,
  .filter-backdrop,
  #close-filters {
    display: none !important;
  }

  .catalog-main-content {
    width: 100% !important;
    padding: 0 !important;
  }
}

.filter-backdrop.active {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.filter-toggle-btn.filters-active {
  border-color: var(--primary) !important;
  background: rgba(35, 82, 140, 0.05) !important;
}

.filter-toggle-btn.filters-active::after {
  content: "";
  width: 8px !important;
  height: 8px !important;
  background: var(--accent-red) !important;
  border-radius: 50% !important;
  position: absolute !important;
  top: 10px !important;
  right: 15px !important;
  border: 2px solid white !important;
}

.filter-toggle-btn:hover {
  background: #f8fafc !important;
  border-color: var(--primary) !important;
  transform: rotate(-90deg) translateX(-100%) translateY(4px) !important;
  box-shadow: var(--shadow) !important;
}

.sidebar-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 24px !important;
}

.header-main-title {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.sidebar-header h3 {
  margin-bottom: 0 !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
  font-size: 18px !important;
  letter-spacing: 0.5px !important;
}

.active-count {
  background: var(--primary) !important;
  color: white !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 2px 8px !important;
  border-radius: 20px !important;
  display: none !important;
  /* Hidden when 0 */
}

.active-count.active {
  display: inline-block !important;
}

.header-actions {
  display: flex !important;
  align-items: center !important;
  gap: 15px !important;
}

.clear-btn {
  background: none !important;
  border: none !important;
  color: var(--primary) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  padding: 0 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
  opacity: 0.7 !important;
  transition: opacity 0.2s !important;
}

.clear-btn:hover {
  opacity: 1 !important;
}

.close-sidebar-btn {
  background: #f1f5f9 !important;
  border: none !important;
  color: var(--text-muted) !important;
  cursor: pointer !important;
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.2s !important;
}

.close-sidebar-btn:hover {
  background: #fee2e2 !important;
  color: var(--accent-red) !important;
}

.search-box {
  position: relative !important;
  margin-bottom: 12px !important;
}

.search-box input {
  width: 100% !important;
  padding: 14px 44px 14px 16px !important;
  border: 2px solid #f1f5f9 !important;
  border-radius: 12px !important;
  font-size: 14px !important;
  outline: none !important;
  transition: all 0.3s ease !important;
  background: #f8fafc !important;
}

.search-box input:focus {
  border-color: var(--primary) !important;
  background: white !important;
  box-shadow: 0 0 0 4px rgba(35, 82, 140, 0.1) !important;
}

.search-box svg {
  position: absolute !important;
  right: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  color: var(--text-muted) !important;
  pointer-events: none !important;
}

.group-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  cursor: pointer !important;
  margin-bottom: 16px !important;
  border-bottom: 2px solid #f1f5f9 !important;
  padding-bottom: 8px !important;
  transition: all 0.2s ease !important;
}

.group-header h3 {
  font-size: 13px !important;
  font-weight: 800 !important;
  margin-bottom: 0 !important;
  color: var(--primary) !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

.group-header .chevron {
  color: var(--text-muted) !important;
  transition: transform 0.3s ease !important;
}

.filter-group.collapsed .chevron {
  transform: rotate(-90deg) !important;
}

.filter-options {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  transition: all 0.3s ease !important;
  overflow: hidden !important;
  max-height: 1000px !important;
  /* Large enough for full expansion */
}

.filter-group.collapsed .filter-options {
  max-height: 0 !important;
  margin-top: 0 !important;
  opacity: 0 !important;
}

.filter-item {
  font-size: 14px !important;
  color: var(--text-muted) !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  cursor: pointer !important;
  padding: 4px 0 !important;
  transition: color 0.2s !important;
}

.filter-item:hover {
  color: var(--primary) !important;
}

.filter-item input {
  cursor: pointer !important;
  width: 16px !important;
  height: 16px !important;
  accent-color: var(--primary) !important;
}

.main-catalog {
  min-width: 0 !important;
}

/* Course Grid Update */
.course-grid {
  /* display: grid !important; */
  /* grid-template-columns: repeat(3, 1fr) !important;
  gap: 32px !important; */
  opacity: 1 !important;
  transition: opacity 0.3s ease !important;
}

/* Specific centering for 3+2 Collection layout */
.collection-active .course-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
  gap: 32px !important;
  justify-content: center !important;
}

.collection-active .course-card-grid-item {
  width: 100% !important;
}

/* Featured Schoolwide Layout */
.schoolwide-active .course-grid {
  display: block !important;
  width: 100% !important;
}

.schoolwide-active .course-card-grid-item {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: 350px 1fr !important;
  text-align: left !important;
  gap: 40px !important;
  padding: 40px !important;
  margin-bottom: 32px !important;
  border-left: 6px solid var(--primary) !important;
  background: #ffffff !important;
}

.schoolwide-active .course-img-wrapper {
  height: 100% !important;
  min-height: 250px !important;
  border-radius: 4px !important;
}

.schoolwide-active .course-content {
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

.schoolwide-active .course-content h3 {
  font-size: 28px !important;
  margin-bottom: 16px !important;
}

.schoolwide-active .course-content p {
  font-size: 16px !important;
  margin-bottom: 24px !important;
  max-width: 600px !important;
}

.schoolwide-active .classroom-selector {
  align-items: flex-start !important;
  border-top: 1px solid var(--border) !important;
  padding-top: 24px !important;
  margin-bottom: 10px !important;
}

.schoolwide-active .course-footer {
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding-top: 0px !important;
  border-top: 1px solid var(--border) !important;
}

.schoolwide-active .price-container {
  align-items: flex-start !important;
}

.schoolwide-active .course-price {
  font-size: 32px !important;
}

.schoolwide-active .add-to-cart-btn {
  width: auto !important;
  min-width: 200px !important;
  padding: 16px 32px !important;
}

.course-grid.switching {
  opacity: 0 !important;
}

/* New Course Card for Grid */
.course-card-grid-item {
  background: white !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  height: 100% !important;
  padding: 0 !important;
  text-align: left !important;
}

.course-card-grid-item:hover {
  box-shadow:
    0 20px 25px -5px rgba(0, 0, 0, 0.05),
    0 10px 10px -5px rgba(0, 0, 0, 0.02);
  transform: translateY(-4px) !important;
  border-color: var(--primary) !important;
}

.course-img-wrapper {
  width: 100% !important;
  aspect-ratio: 4/3 !important;
  background: #f1f5f9 !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.course-img-wrapper img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  display: block !important;
}

.course-age-badge {
  position: absolute !important;
  bottom: 12px !important;
  right: 12px !important;
  background: rgba(255, 255, 255, 0.95) !important;
  backdrop-filter: blur(4px) !important;
  padding: 4px 12px !important;
  border-radius: 20px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  color: var(--primary) !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  z-index: 5 !important;
  height: 25px;
}

.course-info-btn {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 32px !important;
  height: 32px !important;
  background: rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(4px) !important;
  color: var(--primary) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
  z-index: 10 !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
  text-decoration: none !important;
}

.course-info-btn:hover {
  background: var(--primary) !important;
  color: white !important;
  transform: scale(1.15) rotate(5deg) !important;
  box-shadow: 0 4px 12px rgba(0, 96, 169, 0.2) !important;
}

.course-content {
  padding: 20px !important;
  display: flex !important;
  flex-direction: column !important;
  flex-grow: 1 !important;
}

.course-content h3 {
  font-size: 18px !important;
  font-weight: 700 !important;
  margin-bottom: 8px !important;
  color: var(--text-main) !important;
}

.course-content p {
  font-size: 14px !important;
  color: var(--text-muted) !important;
  line-height: 1.5 !important;
  margin-bottom: 20px !important;
  flex-grow: 1 !important;
}

.individual-note {
  font-size: 13px !important;
  color: var(--accent-orange) !important;
  font-weight: 600 !important;
  margin-top: auto !important;
  /* push to bottom above footer */
  margin-bottom: 12px !important;
  padding-top: 8px !important;
  border-top: 1px dashed #fee2e2 !important;
}

.individual-note span {
  color: var(--accent-orange) !important;
}

.students-note {
  font-size: 13px !important;
  color: var(--accent-orange) !important;
  font-weight: 600 !important;
  margin-top: auto !important;
  margin-bottom: 12px !important;
  padding-top: 8px !important;
  border-top: 1px dashed var(--border) !important;
}

.students-note span {
  color: var(--accent-orange) !important;
}

.classroom-selector {
  display: flex !important;
  flex-direction: column !important;
  gap: 0px !important;
  align-items: flex-start !important;
  /* Moving everything to the left */
  margin-top: auto !important;
  margin-bottom: 16px !important;
  padding-top: 16px !important;
  border-top: 1px dashed #e2e8f0 !important;
}

.selection-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
}

.class-dropdown,
.collection-dropdown,
.schoolwide-dropdown {
  appearance: none !important;
  -webkit-appearance: none !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2.5' stroke-linecap='round' 
stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  padding: 8px 36px 8px 16px !important;
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 10px !important;
  font-size: 13px !important;
  background-color: #ffffff !important;
  color: var(--text-main) !important;
  cursor: pointer !important;
  font-weight: 700 !important;
  width: fit-content !important;
  min-width: 130px !important;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04) !important;
}

.class-dropdown:hover,
.collection-dropdown:hover,
.schoolwide-dropdown:hover {
  border-color: var(--primary) !important;
  background-color: #f8fafc !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05) !important;
}

.class-dropdown:focus,
.collection-dropdown:focus,
.schoolwide-dropdown:focus {
  outline: none !important;
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(30, 58, 138, 0.1) !important;
}

.students-count {
  font-size: 14px !important;
  color: var(--text-main) !important;
  font-weight: 700 !important;
  letter-spacing: 0.3px !important;
}

.course-footer {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  border-top: 1px solid #f1f5f9 !important;
  padding-top: 20px !important;
}

.price-container {
  display: flex !important;
  flex-direction: column !important;
}

.course-price {
  font-weight: 800 !important;
  font-size: 24px !important;
  color: var(--primary) !important;
  line-height: 1 !important;
}

.per-student {
  display: block !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--accent-orange) !important;
  margin-top: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  border-radius: 0 !important;
  border: none !important;
  width: fit-content !important;
  text-align: left !important;
}

.add-to-cart-btn {
  background: var(--accent-orange) !important;
  color: white !important;
  border: none !important;
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  flex-shrink: 0 !important;
}

.add-to-cart-btn svg {
  width: 22px !important;
  height: 22px !important;
}

.add-to-cart-btn:hover {
  background: #e66a1a !important;
  box-shadow: 0 4px 12px rgba(243, 116, 33, 0.3) !important;
  transform: translateY(-2px) !important;
}

/* Pagination styles removed to use global .pagination and .pagination-btn */

/* Footer */
.tk-footer-obsolete {
  background: #14171c !important;
  color: #ffffff !important;
  padding: 80px 0 40px !important;
  margin-top: 80px !important;
}

.footer-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 40px !important;
  padding-bottom: 32px !important;
  border-bottom: 1px solid #334155 !important;
}

.footer-col h4 {
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  margin-bottom: 16px !important;
  letter-spacing: 0.3px !important;
}

.footer-col ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.footer-col ul li {
  margin-bottom: 10px !important;
}

.footer-col ul li a {
  color: #94a3b8 !important;
  text-decoration: none !important;
  font-size: 15px !important;
  transition: color 0.2s !important;
}

.footer-col ul li a:hover {
  color: var(--secondary) !important;
}

.footer-bottom {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding-top: 24px !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
}

.footer-bottom p {
  font-size: 13px !important;
  color: #64748b !important;
  margin: 0 !important;
}

.payment-icons {
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
}

.payment-icon {
  display: inline-flex !important;
  align-items: center !important;
  transition: transform 0.2s !important;
}

.payment-icon:hover {
  transform: translateY(-2px) !important;
}

/* Tablet / Half Screen */
@media (max-width: 1200px) {
  .course-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

.course-badge {
  background: var(--accent) !important;
  color: var(--primary) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  padding: 4px 12px !important;
  border-radius: 20px !important;
  display: inline-block !important;
  margin-bottom: 16px !important;
}

.course-header h1 {
  font-size: 32px !important;
  margin-bottom: 12px !important;
}

.course-description {
  color: var(--text-muted) !important;
  font-size: 16px !important;
  max-width: 600px !important;
  margin-bottom: 40px !important;
}

/* License Selector */
.license-selector h2 {
  font-size: 20px !important;
  margin-bottom: 4px !important;
}

.selector-subtitle {
  color: var(--text-muted) !important;
  font-size: 14px !important;
  margin-bottom: 24px !important;
}

.license-options {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  margin-bottom: 40px !important;
}

.license-card {
  position: relative !important;
  border: 1px solid var(--border) !important;
  border-radius: 4px !important;
  padding: 24px !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  display: block !important;
  background: #ffffff !important;
}

.license-card:hover {
  border-color: var(--primary) !important;
  box-shadow: var(--shadow) !important;
}

.license-card.active {
  border-color: var(--primary) !important;
  border-width: 2px !important;
  background: #f0f7ff !important;
}

.license-card input {
  position: absolute !important;
  opacity: 0 !important;
}

.card-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 12px !important;
}

.license-name {
  font-weight: 600 !important;
  font-size: 18px !important;
}

.license-price {
  font-weight: 700 !important;
  font-size: 20px !important;
  color: var(--primary) !important;
}

.license-features {
  list-style: none !important;
  display: flex !important;
  gap: 24px !important;
}

.license-features li {
  font-size: 14px !important;
  color: var(--text-muted) !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.license-features li::before {
  content: "-";
  color: var(--primary) !important;
  font-weight: bold !important;
}

.selection-indicator {
  position: absolute !important;
  top: 24px !important;
  right: 24px !important;
  width: 20px !important;
  height: 20px !important;
  border: 2px solid var(--border) !important;
  border-radius: 50% !important;
  display: none !important;
  /* Can be enabled if needed */
}

/* Info Section */
.info-section h2 {
  font-size: 20px !important;
  margin-bottom: 24px !important;
}

.resource-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 24px !important;
}

.resource-item {
  display: flex !important;
  gap: 16px !important;
  align-items: flex-start !important;
}

.resource-icon {
  font-size: 24px !important;
  background: var(--accent) !important;
  width: 48px !important;
  height: 48px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 12px !important;
}

.resource-text strong {
  display: block !important;
  font-size: 15px !important;
  margin-bottom: 2px !important;
}

.resource-text span {
  font-size: 13px !important;
  color: var(--text-muted) !important;
}

.resourc.per-student {
  display: block !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  color: #10b981 !important;
  /* High-visibility green to denote savings/value */
  margin-top: 4px !important;
  background: #f0fdf4 !important;
  padding: 4px 12px !important;
  border-radius: 20px !important;
  border: 1px solid #bbf7d0 !important;
  width: fit-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.per-student span {
  font-weight: 900 !important;
}

/* Summary Card */
.summary-sidebar {
  position: sticky !important;
  top: 20px !important;
  height: fit-content !important;
  z-index: 10 !important;
}

.summary-card {
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-top: 4px solid var(--primary) !important;
  border-radius: 12px !important;
  padding: 24px !important;
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.05) !important;
}

.summary-card h3 {
  font-size: 18px !important;
  margin-bottom: 20px !important;
}

.summary-line {
  display: flex !important;
  justify-content: space-between !important;
  margin-bottom: 12px !important;
  font-size: 15px !important;
}

.summary-line.sub {
  color: var(--text-muted) !important;
  font-size: 14px !important;
}

.divider {
  height: 1px !important;
  background: var(--border) !important;
  margin: 16px 0 !important;
}

/* Cart Items Summary */
.cart-items-list {
  max-height: 400px !important;
  overflow-y: auto !important;
  margin-bottom: 8px !important;
}

.empty-cart-message {
  color: var(--text-muted) !important;
  font-size: 14px !important;
  text-align: center !important;
  padding: 20px 0 !important;
  font-style: italic !important;
}

.cart-item {
  padding: 12px 0 !important;
  border-bottom: 1px solid #f1f5f9 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 12px !important;
}

.cart-item:last-child {
  border-bottom: none !important;
}

.cart-item-info {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}

.cart-item-title {
  font-weight: 700 !important;
  font-size: 14px !important;
  color: var(--text-main) !important;
  margin-bottom: 4px !important;
}

.cart-item-meta {
  font-size: 12px !important;
  color: var(--text-muted) !important;
}

.cart-item-price-row {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 4px !important;
}

.cart-item-price {
  font-weight: 700 !important;
  font-size: 14px !important;
  color: var(--primary) !important;
}

.remove-item {
  background: transparent !important;
  border: none !important;
  color: #94a3b8 !important;
  cursor: pointer !important;
  font-size: 18px !important;
  line-height: 1 !important;
  padding: 0 4px !important;
  transition: color 0.2s !important;
}

.remove-item:hover {
  color: var(--accent-red) !important;
}

.summary-line.total {
  font-weight: 700 !important;
  font-size: 18px !important;
  margin-bottom: 24px !important;
}

.checkout-form {
  margin-bottom: 20px !important;
}

.form-group label {
  display: block !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  margin-bottom: 8px !important;
}

.form-group input {
  width: 100% !important;
  padding: 12px !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  font-family: inherit !important;
  font-size: 14px !important;
  transition: border-color 0.2s !important;
}

.form-group input:focus {
  outline: none !important;
  border-color: var(--primary) !important;
}

.primary-btn {
  width: 100% !important;
  background: var(--primary) !important;
  color: white !important;
  border: none !important;
  padding: 16px !important;
  border-radius: 4px !important;
  font-weight: 800 !important;
  font-size: 15px !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  transition: all 0.2s ease !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

.primary-btn:hover {
  background: var(--primary-hover) !important;
  box-shadow: var(--shadow) !important;
}

.primary-btn:active {
  transform: translateY(1px) !important;
}

.guarantee {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  color: var(--text-muted) !important;
  font-size: 12px !important;
  margin-top: 20px !important;
}

/* Responsive */
@media (max-width: 1100px) {
  .nav-desktop,
  .header-buttons {
    display: none !important;
  }

  .mobile-toggle {
    display: block !important;
  }

  .container-header {
    padding: 12px 16px !important;
  }

  .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
    text-align: center !important;
  }

  .hero-subtitle {
    margin: 0 auto !important;
  }
}

@media (max-width: 1200px) {
  .course-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

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

@media (max-width: 900px) {
  .hero-title {
    font-size: 36px !important;
  }

  .catalog-layout {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }

  .filters-sidebar {
    order: 2 !important;
  }

  .main-catalog {
    order: 1 !important;
  }

  .summary-sidebar {
    order: 0 !important;
    /* Show summary at the top on mobile for quick access */
    margin-bottom: 20px !important;
  }

  .summary-card.sticky {
    position: static !important;
  }

  .scope-card-sections {
    grid-template-columns: 1fr !important;
    gap: 30px !important;
  }

  .scope-cards-row {
    justify-content: center !important;
  }
}

@media (max-width: 600px) {
  .logo-text {
    font-size: 20px !important;
  }

  .license-features {
    flex-direction: column !important;
    gap: 8px !important;
  }

  .course-card {
    padding: 24px !important;
  }

  .resource-grid {
    grid-template-columns: 1fr !important;
  }

  .footer-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 24px !important;
  }

  .footer-bottom {
    flex-direction: column !important;
    text-align: center !important;
  }

  .scope-header {
    font-size: 18px !important;
    border-left-width: 10px !important;
    padding: 14px 20px !important;
    text-align: left !important;
    margin-bottom: 20px !important;
  }

  .scope-card {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 10px !important;
  }

  .scope-cards-row {
    gap: 15px !important;
  }

  .scope-subcategory-title {
    text-align: left !important;
    margin-bottom: 15px !important;
    font-size: 13px !important;
  }

  .scope-container {
    padding: 0 5px !important;
  }
}

@media (max-width: 480px) {
  .scope-header {
    font-size: 16px !important;
    padding: 12px 15px !important;
    border-left-width: 6px !important;
  }
  
  .scope-card {
    padding: 20px !important;
  }
  
  .scope-card h5 {
    font-size: 15px !important;
  }
}

/* License Comparison Table */
.comparison-container {
  max-width: 1200px !important;
  margin: 40px auto !important;
  padding: 0 20px !important;
}

.comparison-title {
  text-align: center !important;
  font-size: 2.5rem !important;
  color: var(--primary) !important;
  margin-bottom: 40px !important;
  font-weight: 800 !important;
}

.table-wrapper {
  overflow-x: auto !important;
  border-radius: 20px !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1) !important;
  background: white !important;
  max-height: 80vh !important;
  /* Allow scrolling within the table if it's too tall */
  overflow-y: auto !important;
}

.comparison-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  font-size: 1.1rem !important;
  min-width: 900px !important;
}

.comparison-table thead th {
  position: sticky !important;
  top: 0 !important;
  background: #fdfdfd !important;
  z-index: 10 !important;
  padding: 30px 20px !important;
  border-bottom: 2px solid #eee !important;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05) !important;
}

.plan-header {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}

.plan-icon {
  font-size: 2rem !important;
}

.plan-name {
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  color: var(--secondary) !important;
}

.feature-label {
  text-align: left !important;
  padding-left: 30px !important;
  background: #fdfdfd !important;
  position: sticky !important;
  left: 0 !important;
  z-index: 12 !important;
}

.comparison-table td {
  padding: 20px !important;
  text-align: center !important;
  border-bottom: 1px solid #f0f0f0 !important;
  transition: background 0.3s ease !important;
}

.comparison-table td:first-child {
  text-align: left !important;
  padding-left: 30px !important;
  font-weight: 500 !important;
  color: #444 !important;
  position: sticky !important;
  left: 0 !important;
  background: white !important;
  z-index: 5 !important;
  border-right: 1px solid #eee !important;
}

.comparison-table td[colspan] {
  text-align: center !important;
  background-color: #fafffa !important;
}

.comparison-table tr:hover td {
  background-color: #f8fbff !important;
}

.row-highlight td {
  background-color: #f0f7ff !important;
  font-weight: 600 !important;
}

.comparison-table td:empty::after {
  content: "-";
  color: #ccc !important;
}

.check-icon {
  color: #28a745 !important;
  font-weight: bold !important;
  font-size: 1.4rem !important;
}

/* Secondary Tabs Navigation */
.secondary-tabs {
  display: flex !important;
  gap: 40px !important;
  margin-bottom: 40px !important;
  border-bottom: 2px solid #e2e8f0 !important;
  padding-bottom: 0 !important;
  overflow-x: auto !important;
  scrollbar-width: none !important;
  /* Hide scrollbar for cleaner look */
}

.secondary-tabs::-webkit-scrollbar {
  display: none !important;
}

.secondary-tab-btn {
  background: none !important;
  border: none !important;
  padding: 0 0 15px 0 !important;
  font-family: inherit !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: #9ca3af !important;
  /* Lighter grey */
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  position: relative !important;
  white-space: nowrap !important;
}

.secondary-tab-btn:hover {
  color: var(--primary) !important;
}

.secondary-tab-btn.active {
  color: #000000 !important;
  font-weight: 700 !important;
}

.secondary-tab-btn.active::after {
  content: "";
  position: absolute !important;
  bottom: -2px !important;
  /* Align with container border */
  left: 0 !important;
  width: 100% !important;
  height: 4px !important;
  background: #000000 !important;
  border-radius: 4px 4px 0 0 !important;
}

.secondary-tab-link {
  padding: 10px 20px !important;
  font-weight: 700 !important;
  color: var(--primary) !important;
  text-decoration: none !important;
  font-size: 14px !important;
  display: flex !important;
  align-items: center !important;
}

.secondary-tab-link:hover {
  text-decoration: underline !important;
}

/* Tab Views */
.tab-view {
  display: none !important;
}

.tab-view.active {
  display: block !important;
  animation: fadeIn 0.3s ease-out !important;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Skills Matrix Styling */
.skills-matrix-container {
  padding: 40px 0 !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}

.skills-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  background: white !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1) !important;
}

.skills-table th {
  background: #f8fafc !important;
  padding: 24px 16px !important;
  border-bottom: 2px solid #e2e8f0 !important;
  text-align: center !important;
}

.grade-label {
  display: block !important;
  font-weight: 800 !important;
  font-size: 16px !important;
  color: var(--primary) !important;
  letter-spacing: 1px !important;
}

.grade-range {
  display: block !important;
  font-size: 12px !important;
  color: var(--text-muted) !important;
  margin-top: 4px !important;
  font-weight: 400 !important;
}

.skill-row td {
  padding: 20px 16px !important;
  border-bottom: 1px solid #f1f5f9 !important;
}

.skill-label-cell {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  background: #f8fafc !important;
  width: 200px !important;
}

.skill-icon-wrapper {
  width: 40px !important;
  height: 40px !important;
  background: #eff6ff !important;
  border-radius: 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--primary) !important;
}

.skill-icon-wrapper svg {
  width: 24px !important;
  height: 24px !important;
}

.skill-title {
  font-weight: 700 !important;
  font-size: 14px !important;
  color: var(--text-main) !important;
}

.matrix-cell {
  font-size: 13px !important;
  line-height: 1.5 !important;
  color: #475569 !important;
  width: 20% !important;
}

.matrix-cell-empty {
  background: #fcfdfe !important;
}

.cell-primary {
  background: #fdf4ff !important;
  border-left: 2px solid #86198f !important;
}

.cell-junior {
  background: #f0f9ff !important;
  border-left: 2px solid #075985 !important;
}

.cell-intermediate {
  background: #f0fdf4 !important;
  border-left: 2px solid #166534 !important;
}

.cell-senior {
  background: #fffbeb !important;
  border-left: 2px solid #92400e !important;
}

/* Scope and Sequence Styling */
.scope-container {
  padding: 40px 0 !important;
}

.scope-group {
  margin-bottom: 60px !important;
  background: #fff !important;
  padding: 30px !important;
  border-radius: 16px !important;
  border: 1px solid var(--border) !important;
}

.scope-header {
  font-size: 24px !important;
  font-weight: 800 !important;
  color: var(--primary) !important;
  margin-bottom: 30px !important;
  padding-left: 20px !important;
  border-left: 4px solid var(--secondary) !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

.scope-subcategory-title {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--text-muted) !important;
  margin-bottom: 20px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid var(--border) !important;
}

.scope-cards-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 20px !important;
}

.scope-card {
  background: #f8fafc !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  padding: 20px !important;
  width: calc(25% - 15px) !important;
  transition: all 0.3s !important;
  display: flex !important;
  flex-direction: column !important;
}

.scope-card:hover {
  transform: translateY(-5px) !important;
  border-color: var(--primary) !important;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1) !important;
}

/* Confirmation Modal Styling */
.modal-overlay {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(15, 23, 42, 0.7) !important;
  backdrop-filter: blur(8px) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 9999 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.modal-overlay.active {
  opacity: 1 !important;
  visibility: visible !important;
}

.modal-content {
  background: #ffffff !important;
  width: 90% !important;
  max-width: 500px !important;
  border-radius: 24px !important;
  padding: 40px !important;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
  transform: scale(0.9) !important;
  transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
  text-align: center !important;
}

.modal-overlay.active .modal-content {
  transform: scale(1) !important;
}

.modal-icon {
  width: 80px !important;
  height: 80px !important;
  background: #fef3c7 !important;
  color: #d97706 !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto 24px !important;
  font-size: 40px !important;
}

.modal-title {
  font-size: 24px !important;
  font-weight: 800 !important;
  color: #1e293b !important;
  margin-bottom: 16px !important;
  line-height: 1.2 !important;
}

.modal-message {
  font-size: 16px !important;
  color: #64748b !important;
  line-height: 1.6 !important;
  margin-bottom: 32px !important;
}

.modal-actions {
  display: flex !important;
  gap: 16px !important;
  justify-content: center !important;
}

.modal-btn {
  padding: 14px 28px !important;
  border-radius: 12px !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  flex: 1 !important;
  border: none !important;
}

.modal-btn-no {
  background: #f1f5f9 !important;
  color: #475569 !important;
}

.modal-btn-no:hover {
  background: #e2e8f0 !important;
}

.modal-btn-yes {
  background: var(--primary) !important;
  color: white !important;
}

.modal-btn-yes:hover {
  background: var(--primary-hover) !important;
  box-shadow: 0 10px 15px -3px rgba(37, 99, 235, 0.3) !important;
}

@keyframes modalShake {
  0%,
  100% {
    transform: scale(1);
  }

  25% {
    transform: scale(1.02) rotate(1deg);
  }

  75% {
    transform: scale(1.02) rotate(-1deg);
  }
}

.modal-content.shake {
  animation: modalShake 0.4s ease-in-out !important;
}

@keyframes cartBump {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.2);
  }

  100% {
    transform: scale(1);
  }
}

.cart-wrapper.bump {
  animation: cartBump 0.3s ease-out !important;
}

.card-top-icons {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #64748b !important;
  margin-bottom: 10px !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}

.stars {
  color: #f59e0b !important;
  font-size: 14px !important;
}

.scope-card h5 {
  font-size: 16px !important;
  font-weight: 800 !important;
  margin-bottom: 10px !important;
  color: var(--primary) !important;
}

.scope-card p {
  font-size: 13px !important;
  color: #475569 !important;
  line-height: 1.5 !important;
  margin-bottom: 20px !important;
  flex: 1 !important;
}

.card-software-footer {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding-top: 15px !important;
  border-top: 1px solid #e2e8f0 !important;
}

.sw-label {
  font-size: 11px !important;
  font-weight: 800 !important;
  background: #e2e8f0 !important;
  color: #475569 !important;
  padding: 4px 10px !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
}

/* How to Pick a Collection Styling */
.pick-container {
  max-width: 1000px !important;
  margin: 40px auto !important;
  padding: 0 20px !important;
}

.pick-header-wrapper {
  text-align: center !important;
  margin-bottom: 50px !important;
  background: linear-gradient(135deg, #f8fafc 0%, #eff6ff 100%) !important;
  padding: 40px !important;
  border-radius: 24px !important;
  border: 1px solid #e2e8f0 !important;
}

.pick-title {
  font-size: 32px !important;
  font-weight: 800 !important;
  color: var(--primary) !important;
  margin-bottom: 20px !important;
}

.pick-intro {
  font-size: 16px !important;
  color: var(--text-muted) !important;
  line-height: 1.6 !important;
  max-width: 800px !important;
  margin: 0 auto !important;
}

.pick-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 30px !important;
  margin-bottom: 40px !important;
}

.pick-section-title {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--text-main) !important;
  margin-bottom: 20px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.pick-section-desc {
  font-size: 14px !important;
  color: var(--text-muted) !important;
  margin-bottom: 15px !important;
}

.grade-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

.grade-item {
  display: flex !important;
  align-items: center !important;
  gap: 15px !important;
  background: white !important;
  padding: 12px !important;
  border-radius: 12px !important;
  border: 1px solid #e2e8f0 !important;
  transition: all 0.2s !important;
}

.grade-item:hover {
  border-color: var(--primary) !important;
  transform: translateX(5px) !important;
}

.grade-item.highlight {
  background: #f0fdf4 !important;
  border-color: #bbf7d0 !important;
}

.grade-tag {
  font-weight: 800 !important;
  font-size: 11px !important;
  padding: 4px 10px !important;
  border-radius: 6px !important;
  text-transform: uppercase !important;
  min-width: 100px !important;
  text-align: center !important;
}

.grade-tag.primary {
  background: #fdf4ff !important;
  color: #86198f !important;
}

.grade-tag.junior {
  background: #f0f9ff !important;
  color: #075985 !important;
}

.grade-tag.intermediate {
  background: #f0fdf4 !important;
  color: #166534 !important;
}

.grade-tag.senior {
  background: #fffbeb !important;
  color: #92400e !important;
}

.grade-tag.complete {
  background: var(--primary) !important;
  color: white !important;
}

.grade-meta {
  font-size: 13px !important;
  color: var(--text-muted) !important;
}

.pick-card {
  background: white !important;
  padding: 24px !important;
  border-radius: 20px !important;
  border: 1px solid #e2e8f0 !important;
  height: 100% !important;
}

.pick-card strong {
  display: block !important;
  font-size: 16px !important;
  color: var(--primary) !important;
  margin-bottom: 12px !important;
}

.pick-card p {
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: #475569 !important;
}

.value-card {
  background: var(--primary) !important;
  padding: 40px !important;
  border-radius: 24px !important;
  color: white !important;
  display: flex !important;
  gap: 30px !important;
  align-items: center !important;
  position: relative !important;
  overflow: hidden !important;
}

.value-card::before {
  content: "";
  position: absolute !important;
  top: -50px !important;
  right: -50px !important;
  width: 200px !important;
  height: 200px !important;
  background: rgba(255, 255, 255, 0.1) !important;
  border-radius: 50% !important;
}

.value-content {
  flex: 1 !important;
}

.value-content .pick-section-title {
  color: white !important;
}

.value-content p {
  font-size: 15px !important;
  line-height: 1.6 !important;
  opacity: 0.9 !important;
}

.value-visual {
  text-align: center !important;
  background: rgba(255, 255, 255, 0.1) !important;
  padding: 20px !important;
  border-radius: 20px !important;
  backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
}

.value-badge {
  background: var(--secondary) !important;
  color: var(--primary) !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  padding: 8px 16px !important;
  border-radius: 10px !important;
  margin-bottom: 10px !important;
}

.savings-text {
  font-weight: 700 !important;
  font-size: 18px !important;
}

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

  .value-card {
    flex-direction: column !important;
    padding: 30px !important;
  }
}

.pick-products-section {
  margin-top: 60px !important;
  padding-top: 40px !important;
  border-top: 2px dashed #e2e8f0 !important;
}

#pick-collection-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 25px !important;
  margin-top: 30px !important;
}

/* Schoolwide License Horizontal Layout */
.course-grid.schoolwide-active {
  grid-template-columns: 1fr !important;
  max-width: 1000px !important;
  margin: 0 auto !important;
}

.course-grid.schoolwide-active .course-card-grid-item {
  flex-direction: row !important;
  align-items: stretch !important;
  min-height: 280px !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-left: 6px solid var(--primary) !important;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.05) !important;
}

.course-grid.schoolwide-active .course-img-wrapper {
  width: 380px !important;
  aspect-ratio: auto !important;
  flex-shrink: 0 !important;
}

.course-grid.schoolwide-active .course-content {
  padding: 30px 40px !important;
  display: flex !important;
  flex-direction: column !important;
}

.course-grid.schoolwide-active .course-content h3 {
  font-size: 24px !important;
  margin-bottom: 12px !important;
}

.course-grid.schoolwide-active .course-content p {
  font-size: 15px !important;
  margin-bottom: 20px !important;
}

.course-grid.schoolwide-active .course-footer {
  margin-top: auto !important;
  padding-top: 0px !important;
  border-top: 1px solid #f1f5f9 !important;
}

.course-grid.schoolwide-active .add-to-cart-btn {
  padding: 14px 32px !important;
  font-size: 16px !important;
}

@media (max-width: 900px) {
  .course-grid.schoolwide-active .course-card-grid-item {
    flex-direction: column !important;
  }

  .course-grid.schoolwide-active .course-img-wrapper {
    width: 100% !important;
    aspect-ratio: 16/9 !important;
  }
}

/* Comprehensive Mobile Responsive Styles */
@media (max-width: 768px) {
  /* Page Layout */
  .page-content {
    padding: 20px 0 60px !important;
  }

  .tk-container {
    padding: 0 16px !important;
  }

  .license-filter-row {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
    padding: 0 16px !important;
  }

  .filter-toggle-btn {
    padding: 12px 24px !important;
  }

  /* Header */
  .container-header {
    padding: 12px 16px !important;
  }

  .buy-now-title {
    font-size: 24px !important;
  }

  .buy-now-subtitle {
    font-size: 14px !important;
    padding: 0 16px !important;
  }

  /* Tabs */
  .tab-buttons {
    gap: 8px !important;
    overflow-x: auto !important;
    padding: 0 16px !important;
  }

  .tab-btn {
    padding: 10px 16px !important;
    font-size: 13px !important;
    white-space: nowrap !important;
  }

  /* Search */
  .search-container {
    margin-bottom: 16px !important;
    padding: 0 16px !important;
  }

  .course-search-input {
    font-size: 14px !important;
    padding: 10px 10px 10px 36px !important;
  }

  /* Course Grid */
  .course-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    padding: 0 16px !important;
  }

  .course-card {
    padding: 16px !important;
  }

  .course-img-wrapper {
    height: 200px !important;
    border-radius: 8px !important;
  }

  /* Responsive Cards Layout */
  #individual-license-header,
  #collection-license-header,
  #schoolwide-license-header {
    display: none !important;
  }

  .individual-course-card,
  .col-card-wrapper {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 20px !important;
    padding: 20px 16px !important;
  }

  /* Info Column Container */
  .individual-course-card > div:first-child,
  .col-info-col {
    width: 100% !important;
    border-right: none !important;
    border-bottom: 1px solid #f1f5f9 !important;
    padding-bottom: 20px !important;
    align-items: flex-start !important;
  }

  .col-info-col {
    padding: 0 0 20px 0 !important;
  }

  /* Pricing Columns Wrapper */
  .ind-pricing-cols-wrapper {
    flex-direction: column !important;
    width: 100% !important;
  }

  /* Individual Pricing Columns */
  .ind-pricing-col,
  .col-pricing-col {
    width: 100% !important;
    border-right: none !important;
    border-bottom: 1px solid #f1f5f9 !important;
    padding: 15px 0 !important;
  }

  .col-pricing-col:last-child {
    border-bottom: none !important;
  }

  /* Add to Cart Container */
  .ind-add-cart-btn {
    width: 100% !important;
    margin-top: 10px !important;
  }

  .col-cart-col {
    width: 100% !important;
    border-left: none !important;
    padding: 15px 0 0 0 !important;
    border-top: 1px solid #f1f5f9 !important;
  }

  .col-add-cart-btn,
  .schoolwide-add-cart-btn {
    width: 100% !important;
  }

  .course-title {
    font-size: 16px !important;
    margin-bottom: 8px !important;
  }

  .course-price {
    font-size: 18px !important;
  }

  .per-student {
    font-size: 11px !important;
  }

  /* Dropdowns */
  .classroom-selector {
    padding: 8px !important;
    margin-bottom: 12px !important;
  }

  .class-dropdown,
  .collection-dropdown,
  .schoolwide-dropdown {
    padding: 8px !important;
    font-size: 12px !important;
    width: 100% !important;
  }

  /* Buttons */
  .add-to-cart-btn {
    padding: 12px 16px !important;
    font-size: 13px !important;
    gap: 6px !important;
  }

  .add-to-cart-btn svg {
    width: 18px !important;
    height: 18px !important;
  }

  /* Cart/Checkout Bar */
  .checkout-bar {
    padding: 12px 16px !important;
  }

  .checkout-container {
    flex-direction: column !important;
    gap: 12px !important;
  }

  .checkout-info {
    width: 100% !important;
    text-align: center !important;
  }

  .checkout-btn {
    width: 100% !important;
    padding: 12px !important;
    font-size: 14px !important;
  }

  /* Cart Items */
  .cart-item {
    padding: 12px !important;
    flex-direction: column !important;
    gap: 8px !important;
  }

  .cart-item-info {
    width: 100% !important;
  }

  .cart-item-title {
    font-size: 13px !important;
  }

  .cart-item-meta {
    font-size: 11px !important;
  }

  .cart-item-price-row {
    width: 100% !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
  }

  .cart-item-price {
    font-size: 13px !important;
  }

  .remove-item {
    padding: 4px !important;
  }

  .remove-item svg {
    width: 16px !important;
    height: 16px !important;
  }

  /* Summary */
  .summary-sidebar {
    padding: 16px !important;
    border-radius: 8px !important;
  }

  .summary-line {
    font-size: 13px !important;
    padding: 8px 0 !important;
  }

  .summary-line.total {
    font-size: 16px !important;
    margin-bottom: 16px !important;
  }

  /* Modal */
  .modal-content {
    width: 95% !important;
    max-width: 380px !important;
    padding: 24px !important;
  }

  .modal-title {
    font-size: 20px !important;
  }

  .modal-message {
    font-size: 14px !important;
  }

  .modal-btn {
    padding: 12px !important;
    font-size: 14px !important;
  }

  /* Comparison Table */
  .comparison-table {
    font-size: 0.9rem !important;
    min-width: 100% !important;
  }

  .comparison-table th,
  .comparison-table td {
    padding: 8px !important;
    font-size: 12px !important;
  }

  .comparison-title {
    font-size: 1.8rem !important;
    margin-bottom: 24px !important;
  }

  /* Schoolwide Grid */
  .course-grid.schoolwide-active {
    grid-template-columns: 1fr !important;
    max-width: 100% !important;
  }

  .course-grid.schoolwide-active .course-card-grid-item {
    flex-direction: column !important;
    padding: 12px !important;
  }

  .course-grid.schoolwide-active .course-img-wrapper {
    width: 100% !important;
    height: 200px !important;
  }
}

@media (max-width: 480px) {
  /* Extra Small Devices */
  .tk-container {
    padding: 0 12px !important;
  }

  .page-content {
    padding: 16px 0 50px !important;
  }

  .tab-btn {
    padding: 8px 12px !important;
    font-size: 12px !important;
  }

  .course-grid {
    gap: 12px !important;
    padding: 0 12px !important;
  }

  .course-card {
    padding: 12px !important;
  }

  .course-img-wrapper {
    height: 160px !important;
  }

  .course-title {
    font-size: 14px !important;
  }

  .course-price {
    font-size: 16px !important;
  }

  .add-to-cart-btn {
    padding: 10px 12px !important;
    font-size: 12px !important;
  }

  .checkout-bar {
    padding: 10px 12px !important;
  }

  .checkout-btn {
    padding: 10px !important;
    font-size: 12px !important;
  }

  .cart-item {
    padding: 10px !important;
  }

  .cart-item-title {
    font-size: 12px !important;
  }

  .cart-item-meta {
    font-size: 10px !important;
  }

  .summary-sidebar {
    padding: 12px !important;
  }

  .summary-line {
    font-size: 12px !important;
    padding: 6px 0 !important;
  }

  .summary-line.total {
    font-size: 14px !important;
    margin-bottom: 12px !important;
  }

  .modal-content {
    padding: 20px !important;
  }

  .modal-title {
    font-size: 18px !important;
  }

  .modal-message {
    font-size: 13px !important;
  }

  .comparison-title {
    font-size: 1.5rem !important;
  }

  .comparison-table th,
  .comparison-table td {
    padding: 6px !important;
    font-size: 11px !important;
  }
}

@media (max-width: 360px) {
  /* Very Small Devices */
  .tk-container {
    padding: 0 8px !important;
  }

  .course-grid {
    padding: 0 8px !important;
  }

  .course-card {
    padding: 8px !important;
  }

  .course-img-wrapper {
    height: 140px !important;
  }

  .course-title {
    font-size: 13px !important;
  }

  .course-price {
    font-size: 14px !important;
  }

  .add-to-cart-btn {
    padding: 8px 10px !important;
    font-size: 11px !important;
  }

  .tab-btn {
    padding: 6px 10px !important;
    font-size: 11px !important;
  }
}

/* -- Purchase Page Notification Popup ----------------------------- */
.pk-popup-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.45) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 99999 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 0.2s ease !important;
}

.pk-popup-overlay.pk-popup-visible {
  opacity: 1 !important;
  pointer-events: all !important;
}

.pk-popup-box {
  background: #fff !important;
  border-radius: 14px !important;
  padding: 36px 32px 28px !important;
  max-width: 380px !important;
  width: 90% !important;
  text-align: center !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18) !important;
  transform: translateY(16px) scale(0.97) !important;
  transition:
    transform 0.22s ease,
    opacity 0.22s ease;
  opacity: 0 !important;
}

.pk-popup-overlay.pk-popup-visible .pk-popup-box {
  transform: translateY(0) scale(1) !important;
  opacity: 1 !important;
}

.pk-popup-icon {
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  background: #fff4ec !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto 16px !important;
}

.pk-popup-icon svg {
  color: #f37421 !important;
}

.pk-popup-title {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: #1f2937 !important;
  margin-bottom: 8px !important;
}

.pk-popup-message {
  font-size: 14px !important;
  color: #6b7280 !important;
  line-height: 1.55 !important;
  margin-bottom: 24px !important;
}

.pk-popup-btn {
  background: #0060a9 !important;
  color: #fff !important;
  border: none !important;
  padding: 11px 32px !important;
  border-radius: 8px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: background 0.15s !important;
}

.pk-popup-btn:hover {
  background: #004d88 !important;
}

.breakdown-per-course {
  color: var(--accent-orange) !important;
}

/* Live-safe purchase page overrides for aggressive theme/plugin styles */
.purchase-page-wrap,
.purchase-page-wrap * {
  box-sizing: border-box !important;
}

.purchase-page-wrap .course-card,
.purchase-page-wrap .course-card-grid-item {
  background: #ffffff !important;
  border: 1px solid #dbe5f1 !important;
  border-radius: 14px !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
  overflow: hidden !important;
}

.purchase-page-wrap .course-content {
  padding: 18px 20px 16px !important;
  background: #ffffff !important;
}

.purchase-page-wrap .course-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding-top: 14px !important;
  margin-top: 14px !important;
  border-top: 1px solid #e5e7eb !important;
}

.purchase-page-wrap .summary-card,
.purchase-page-wrap .summary-card.sticky {
  background: #ffffff !important;
  border: 1px solid #dbe5f1 !important;
  border-radius: 16px !important;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08) !important;
  padding: 26px 22px !important;
  position: sticky !important;
  top: 110px !important;
}

.purchase-page-wrap .summary-card h3,
.purchase-page-wrap .cart-item-title,
.purchase-page-wrap .course-title {
  color: #0f172a !important;
}

.purchase-page-wrap .cart-items-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  margin-bottom: 18px !important;
}

.purchase-page-wrap .cart-item {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 0 0 12px !important;
  border-bottom: 1px solid #edf2f7 !important;
}

.purchase-page-wrap .cart-item-price-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  white-space: nowrap !important;
}

.purchase-page-wrap .remove-item {
  width: 32px !important;
  height: 32px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 8px !important;
  background: #f8fafc !important;
  color: #334155 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
}

.purchase-page-wrap .summary-card input[type="email"] {
  width: 100% !important;
  min-height: 42px !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: 8px !important;
  padding: 10px 12px !important;
  background: #ffffff !important;
}

.purchase-page-wrap .summary-card .buy-btn,
.purchase-page-wrap .summary-card button,
.purchase-page-wrap .add-to-cart-btn {
  border-radius: 10px !important;
}

/* -- Page Loader Styling ------------------------------------------ */
.purchase-page-192-products-loader {
  position: fixed !important;
  inset: 0 !important;
  background: #ffffff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 999999 !important;
  transition: opacity 0.4s ease !important;
}

.purchase-page-133-loader-content {
  text-align: center !important;
}

.purchase-page-238-spinner {
  width: 48px !important;
  height: 48px !important;
  border: 4px solid #f1f5f9 !important;
  border-top-color: #0060a9 !important;
  border-radius: 50% !important;
  animation: pk-spin 0.8s linear infinite !important;
  margin: 0 auto 20px !important;
}

.purchase-page-134-loader-text {
  color: #64748b !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  letter-spacing: 0.5px !important;
}

@keyframes pk-spin {
  to {
    transform: rotate(360deg);
  }
}

/* ========================================
   SLIDE-IN ORDER SUMMARY SIDEBAR
   ======================================== */

/* Cart Toggle Button (Hamburger) */
.cart-toggle-btn {
  position: fixed !important;
  top: 120px !important;
  right: 20px !important;
  width: 56px !important;
  height: 56px !important;
  border-radius: 50% !important;
  background: #0060a9 !important;
  border: none !important;
  box-shadow: 0 4px 12px rgba(0, 96, 169, 0.3) !important;
  cursor: pointer !important;
  z-index: 1001 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.3s ease !important;
}

.cart-toggle-btn:hover {
  background: #004d8a !important;
  transform: scale(1.05) !important;
  box-shadow: 0 6px 16px rgba(0, 96, 169, 0.4) !important;
}

.cart-toggle-btn svg {
  color: white !important;
  transition: all 0.3s ease !important;
}

.cart-toggle-btn .hamburger-icon {
  display: block !important;
}

.cart-toggle-btn .close-icon {
  display: none !important;
}

.cart-toggle-btn.active .hamburger-icon {
  display: none !important;
}

.cart-toggle-btn.active .close-icon {
  display: block !important;
}

/* Cart Count Badge removed */

/* Order Summary Sidebar */
.order-summary-sidebar {
  position: fixed !important;
  top: 0 !important;
  right: -400px !important;
  width: 400px !important;
  height: 100vh !important;
  background: white !important;
  box-shadow: -4px 0 20px rgba(0, 0, 0, 0.15) !important;
  z-index: 1002 !important;
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  overflow-y: auto !important;
}

.order-summary-sidebar.open {
  right: 0 !important;
}

/* Close Button */
.close-sidebar-btn {
  background: transparent !important;
  border: none !important;
  padding: 8px !important;
  cursor: pointer !important;
  color: #6b7280 !important;
  transition: all 0.2s !important;
  border-radius: 8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.close-sidebar-btn:hover {
  background: #f3f4f6 !important;
  color: #1f2937 !important;
}

/* Overlay */
.sidebar-overlay {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(0, 0, 0, 0.5) !important;
  z-index: 1000 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transition: all 0.3s ease !important;
}

.sidebar-overlay.show {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
  .order-summary-sidebar {
    width: 100% !important;
    right: -100% !important;
  }

  .cart-toggle-btn {
    top: 80px !important;
    right: 15px !important;
    width: 50px !important;
    height: 50px !important;
  }
}

@media (max-width: 480px) {
  .order-summary-sidebar {
    width: 100% !important;
  }

  .cart-toggle-btn {
    width: 48px !important;
    height: 48px !important;
  }
}

/* Ensure sidebar is always on top */
body.sidebar-open {
  overflow: hidden !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Individual Tab — 3-Column License Cards
   ═══════════════════════════════════════════════════════════════════════════ */

/* Header row for Individual tab */
#individual-license-header {
  position: sticky;
  top: 0;
  z-index: 10;
}

/* License header columns — informational only, not interactive */
.ind-hdr-col {
  transition: none !important;
  cursor: default !important;
  pointer-events: none !important;
}

/* Individual course card row */
.individual-course-card {
  border-bottom: 1px solid #f1f5f9 !important;
  border-radius: 0 !important;
  margin-bottom: 0 !important;
  transition: background 0.15s ease !important;
}
.individual-course-card:last-child {
  border-bottom: none !important;
}
.individual-course-card:hover {
  background: #fafbff !important;
}

/* Pricing column inside each card */
.ind-pricing-col {
  transition: all 0.2s ease !important;
  user-select: none !important;
}
.ind-pricing-col:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 16px rgba(29, 78, 216, 0.12) !important;
}

/* Selected state for pricing column */
.ind-pricing-col[data-selected="true"] {
  background: #1d4ed8 !important;
  border-color: #1d4ed8 !important;
  color: #fff !important;
}

/* Class dropdown inside ind-pricing-col */
.ind-class-dropdown {
  appearance: auto !important;
  outline: none !important;
}
.ind-class-dropdown:focus {
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.4) !important;
}

/* Select button inside col */
.ind-select-btn {
  transition: all 0.15s ease !important;
  outline: none !important;
}
.ind-select-btn:hover {
  opacity: 0.85 !important;
  transform: scale(1.02) !important;
}

/* Tooltip info icon */
.ind-pricing-col [title] {
  text-decoration: none !important;
}

/* Col-12 wrapper in individual mode: remove padding so cards are flush */
#course-grid.g-0 > .col-12 {
  padding: 0 !important;
}
#course-grid.g-0 > .col-12.mb-3 {
  margin-bottom: 0 !important;
}

/* Responsive: full-width pricing cols on smaller screens */
/* Responsive: full-width pricing cols on smaller screens */
@media (max-width: 768px) {
  .individual-course-card,
  .collection-course-card {
    flex-direction: column !important;
    align-items: stretch !important;
    padding: 16px !important;
    position: relative !important;
  }
  .individual-course-card > div:first-child,
  .collection-course-card > div:first-child {
    padding-right: 50px !important; /* Make room for the absolute cart icon */
  }
  .ind-pricing-cols-wrapper,
  .col-pricing-cols-wrapper {
    flex-direction: column !important;
    width: 100% !important;
    gap: 12px !important;
  }
  .ind-pricing-col,
  .col-pricing-col {
    width: 100% !important;
    max-width: none !important;
    padding: 14px !important;
  }
  .ind-add-cart-btn,
  .col-add-cart-btn {
    position: absolute !important;
    top: 60px !important;
    right: 16px !important;
    margin: 0 !important;
  }
}

/* ── Individual tab: Add-to-Cart (orange) button ─────────────────────── */
.ind-add-cart-btn {
  flex-shrink: 0 !important;
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px !important;
  border: none !important;
  background: #f37421 !important;
  color: #fff !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 4px 14px rgba(243, 116, 33, 0.38) !important;
  transition: all 0.2s ease !important;
  outline: none !important;
}
.ind-add-cart-btn:hover {
  background: #e0641a !important;
  transform: translateY(-2px) scale(1.06) !important;
  box-shadow: 0 8px 20px rgba(243, 116, 33, 0.45) !important;
}
.ind-add-cart-btn:active {
  transform: scale(0.96) !important;
}
.ind-add-cart-btn:disabled {
  background: #e2e8f0 !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: not-allowed !important;
}

/* ── Dropdown: always show options in black on white ─────────────────── */
.ind-class-dropdown option {
  background: #ffffff !important;
  color: #1e293b !important;
  font-weight: 600 !important;
}

/* ── License Conflict Popup extra button colours ─────────────────────── */
.btn-conflict-replace {
  background: #ef4444 !important;
  border-color: #ef4444 !important;
}
.btn-conflict-replace:hover {
  background: #dc2626 !important;
}
.btn-conflict-both {
  background: #0060a9 !important;
  border-color: #0060a9 !important;
}
.btn-conflict-both:hover {
  background: #004d88 !important;
}
.btn-conflict-cancel {
  background: #f3f4f6 !important;
  color: #4b5563 !important;
  border-color: #e5e7eb !important;
}
.btn-conflict-cancel:hover {
  background: #e5e7eb !important;
}

/* Collection course card row */
.collection-course-card {
  margin-bottom: 0 !important; /* Stack without gaps, relying on border-bottom */
}
.collection-course-card:hover {
  background: #f8fafc !important;
}

/* Pricing columns inside collection card */
.col-pricing-col {
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.col-pricing-col:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

/* Responsive: on mobile shrink cart button and cols */
@media (max-width: 576px) {
  .ind-add-cart-btn,
  .col-add-cart-btn {
    width: 40px !important;
    height: 40px !important;
    border-radius: 10px !important;
  }
  .ind-pricing-col,
  .col-pricing-col {
    min-width: 80px !important;
    padding: 10px 8px !important;
  }
  .ind-col-price,
  .col-col-price {
    font-size: 18px !important;
  }
}
/* =========================================================
   FINAL FORCE FIX – ADD TO CART BUTTON (LIVE OVERRIDE)
   ========================================================= */

.purchase-page-wrap button.add-to-cart-btn,
.purchase-page-wrap .add-to-cart-btn,
.purchase-page-wrap a.add-to-cart-btn,
.purchase-page-wrap .add-to-cart-btn.elementor-button {
  /* Reset everything coming from theme/elementor */
  all: unset !important;

  /* Layout */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  /* Size */
  width: 48px !important;
  height: 48px !important;

  /* Design */
  background: #f37421 !important;
  color: #ffffff !important;
  border-radius: 12px !important;

  /* Behavior */
  cursor: pointer !important;
  transition: all 0.25s ease !important;

  /* Shadow */
  box-shadow: 0 4px 12px rgba(243, 116, 33, 0.3) !important;

  /* Prevent shrink issues */
  flex-shrink: 0 !important;
}

/* Icon fix */
.purchase-page-wrap .add-to-cart-btn svg {
  width: 22px !important;
  height: 22px !important;
  display: block !important;
  pointer-events: none !important;
}

/* Hover */
.purchase-page-wrap .add-to-cart-btn:hover {
  background: #e66a1a !important;
  transform: translateY(-2px) scale(1.05) !important;
  box-shadow: 0 8px 20px rgba(243, 116, 33, 0.4) !important;
}

/* Active click */
.purchase-page-wrap .add-to-cart-btn:active {
  transform: scale(0.95) !important;
}

/* Disabled */
.purchase-page-wrap .add-to-cart-btn:disabled {
  background: #e2e8f0 !important;
  color: #94a3b8 !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}

/* Ensure no weird inherited padding/margins */
.purchase-page-wrap .add-to-cart-btn * {
  margin: 0 !important;
  padding: 0 !important;
}
/* -- Geo-Restricted: Schoolwide Enrollment Dropdown Disabled State ---------
   Bootstrap's .form-select:disabled sets pointer-events:none which hides the
   cursor entirely. Override so cursor:not-allowed remains visible.
   ------------------------------------------------------------------------- */
.schoolwide-dropdown:disabled {
  pointer-events: auto !important;
  cursor: not-allowed !important;
  opacity: 0.6 !important;
}

#license-info-box {
  display: none !important;
}
#license-description,
.view-details-btn,
.woocommerce-error,
.view-details-btn {
  display: none;
}

