/* ============================================================
   HEROZ — Programs Page Styles
   ============================================================ */

/* ─── TABS BAR ─── */
.program-tabs-bar {
  background: var(--white);
  border-bottom: 2px solid var(--gray-200);
  position: sticky; top: var(--nav-height); z-index: 90;
}
.prog-tabs {
  display: flex; gap: 0; overflow-x: auto;
  scrollbar-width: none;
}
.prog-tabs::-webkit-scrollbar { display: none; }
.prog-tab {
  font-family: var(--font-display);
  font-size: 0.88rem; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--gray-600); padding: 16px 24px;
  border-bottom: 3px solid transparent;
  transition: all var(--transition); white-space: nowrap;
}
.prog-tab:hover { color: var(--blue); border-bottom-color: var(--blue-light); }
.prog-tab.active { color: var(--orange); border-bottom-color: var(--orange); }

/* ─── INCLUDED BANNER ─── */
.included-banner {
  background: var(--blue); padding: 14px 0;
}
.included-banner-inner {
  display: flex; align-items: center; gap: 24px;
  flex-wrap: wrap; font-size: 0.82rem;
}
.included-banner strong {
  color: var(--orange); font-family: var(--font-display);
  font-size: 0.88rem; letter-spacing: 0.05em;
}
.included-banner span { color: rgba(255,255,255,0.85); font-weight: 600; }

/* ─── PROGRAM DETAIL SECTIONS ─── */
.prog-section { scroll-margin-top: 130px; }
.featured-prog { position: relative; }
.prog-featured-label {
  position: absolute; top: 0; left: 0; right: 0;
  background: var(--orange); text-align: center;
  font-family: var(--font-display);
  font-size: 0.78rem; font-weight: 800; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--white);
  padding: 8px;
}
.featured-prog .section { padding-top: 112px; }

.prog-detail-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: start;
}
.prog-detail-grid.reverse { direction: rtl; }
.prog-detail-grid.reverse > * { direction: ltr; }

.prog-detail-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display);
  font-size: 0.75rem; font-weight: 800;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--blue); margin-bottom: 12px;
}
.prog-detail-tag::before {
  content: ''; width: 24px; height: 3px;
  background: var(--blue); border-radius: 2px; display: block;
}
.prog-detail-tag.orange { color: var(--orange); }
.prog-detail-tag.orange::before { background: var(--orange); }
.prog-detail-tag.blue { color: var(--blue); }

.prog-subtitle {
  font-size: 0.9rem; font-weight: 600;
  color: var(--orange); margin-bottom: 20px;
  font-family: var(--font-display); letter-spacing: 0.04em;
  text-transform: uppercase;
}
.prog-detail-text p {
  color: var(--gray-600); margin-bottom: 16px; font-size: 0.97rem; line-height: 1.75;
}

/* Hours breakdown */
.prog-hours-breakdown {
  display: flex; gap: 16px; margin: 28px 0;
}
.hours-block {
  flex: 1; background: var(--blue-light);
  border-radius: var(--radius); padding: 20px 16px;
  text-align: center; border: 2px solid transparent;
  transition: border-color var(--transition);
}
.hours-block:hover { border-color: var(--blue); }
.hours-block.orange { background: var(--orange-light); }
.hours-block.orange:hover { border-color: var(--orange); }
.hours-num {
  display: block;
  font-family: var(--font-display); font-size: 2rem;
  font-weight: 900; color: var(--blue); line-height: 1;
}
.hours-block.orange .hours-num { color: var(--orange); }
.hours-label {
  display: block; font-size: 0.72rem; font-weight: 700;
  color: var(--gray-600); text-transform: uppercase;
  letter-spacing: 0.08em; margin-top: 4px;
}

/* Price box (hidden — activate when ready) */
/*
.prog-price-box {
  display: flex; align-items: center; gap: 16px;
  background: var(--blue-light); border-radius: var(--radius);
  padding: 20px 24px; margin-bottom: 28px;
  border-left: 4px solid var(--blue);
}
.prog-price-label { font-size: 0.8rem; font-weight: 700; color: var(--gray-600); text-transform: uppercase; letter-spacing: 0.08em; }
.prog-price-amount { font-family: var(--font-display); font-size: 2rem; font-weight: 900; color: var(--blue); margin-left: auto; }
*/

.prog-ctas { display: flex; gap: 12px; flex-wrap: wrap; }

/* Features list */
.prog-detail-features h3 {
  font-family: var(--font-display); font-size: 1.3rem;
  font-weight: 800; color: var(--blue); margin-bottom: 20px;
  letter-spacing: 0.5px;
}
.learn-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.learn-list li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 0.9rem; color: var(--gray-700);
  padding: 10px 14px;
  background: var(--white); border-radius: var(--radius);
  border: 1px solid var(--gray-200);
  transition: border-color var(--transition);
}
.learn-list li:hover { border-color: var(--orange); }
.learn-list li::before {
  content: '✓'; color: var(--orange); font-weight: 800;
  font-size: 0.85rem; margin-top: 1px; flex-shrink: 0;
}

.prog-cert-box {
  display: flex; gap: 16px; align-items: center;
  background: linear-gradient(135deg, #fff8f2, var(--orange-light));
  border: 2px solid rgba(244,124,32,0.3);
  border-radius: var(--radius); padding: 20px;
}
.prog-cert-box.moto {
  background: linear-gradient(135deg, var(--blue-light), #e8f0fb);
  border-color: rgba(26,58,107,0.3);
}
.cert-icon { font-size: 2.2rem; }
.prog-cert-box strong { display: block; font-size: 0.95rem; color: var(--blue); margin-bottom: 4px; }
.prog-cert-box p { font-size: 0.82rem; color: var(--gray-600); }

/* ─── INSURANCE SECTION ─── */
.insurance-section { background: var(--blue); }
.insurance-section .section-tag { color: var(--orange); }
.insurance-section .section-title { color: var(--white); }
.insurance-section .section-lead { color: rgba(255,255,255,0.7); }
.insurance-grid {
  display: grid; grid-template-columns: 1fr 2fr;
  gap: 48px; margin-top: 48px; align-items: start;
}
.insurance-info-box {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-lg); padding: 40px 32px;
  text-align: center;
}
.ins-saving {
  font-family: var(--font-display); font-size: 4rem;
  font-weight: 900; color: var(--orange); line-height: 1;
  margin-bottom: 12px;
}
.insurance-info-box p { color: rgba(255,255,255,0.8); margin-bottom: 12px; }
.insurance-info-box small { font-size: 0.75rem; color: rgba(255,255,255,0.45); }
.insurance-steps-list { display: flex; flex-direction: column; gap: 20px; }
.ins-step-detail {
  display: flex; gap: 20px; align-items: flex-start;
  background: rgba(255,255,255,0.07);
  border-radius: var(--radius); padding: 20px 24px;
  border: 1px solid rgba(255,255,255,0.1);
}
.ins-step-num {
  font-family: var(--font-display); font-size: 2rem;
  font-weight: 900; color: rgba(244,124,32,0.5); line-height: 1;
  min-width: 40px;
}
.ins-step-detail h4 { font-size: 1rem; font-weight: 700; color: var(--white); margin-bottom: 6px; }
.ins-step-detail p { font-size: 0.85rem; color: rgba(255,255,255,0.6); }
.insurance-cta-row { text-align: center; margin-top: 48px; }

/* ─── COMPARE TABLE ─── */
.compare-table-wrap { overflow-x: auto; }
.compare-table {
  width: 100%; border-collapse: collapse;
  font-size: 0.88rem;
}
.compare-table thead th {
  font-family: var(--font-display); font-size: 0.85rem;
  font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--blue); padding: 16px 20px;
  background: var(--blue-light);
  border-bottom: 2px solid var(--blue);
  text-align: center;
}
.compare-table thead th:first-child { text-align: left; }
.compare-table thead th.highlight {
  background: var(--orange); color: var(--white);
}
.compare-table tbody td {
  padding: 14px 20px; border-bottom: 1px solid var(--gray-200);
  text-align: center; color: var(--gray-700);
}
.compare-table tbody td:first-child { text-align: left; font-weight: 600; }
.compare-table tbody td.highlight { background: rgba(244,124,32,0.06); }
.compare-table tbody tr:hover td { background: var(--off-white); }
.compare-table tbody tr:hover td.highlight { background: rgba(244,124,32,0.1); }

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  .prog-detail-grid { grid-template-columns: 1fr; gap: 40px; }
  .prog-detail-grid.reverse { direction: ltr; }
  .insurance-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .prog-hours-breakdown { flex-wrap: wrap; }
  .hours-block { min-width: calc(50% - 8px); }
  .prog-tabs { gap: 0; }
  .prog-tab { padding: 14px 16px; font-size: 0.8rem; }
}
