/* ============================================================
   Page-specific styles
   ============================================================ */

/* ============ HERO ============ */
.hero {
  padding: var(--space-6) 0 var(--space-10);
}
.hero-card {
  position: relative;
  background: var(--color-primary);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  min-height: 600px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: var(--space-16) var(--space-12);
  color: var(--color-white);
  gap: var(--space-8);
  align-items: center;
}
.hero-content { z-index: 2; }
.hero-badge {
  display: inline-block;
  background: rgba(255,255,255,0.15);
  color: var(--color-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--space-5);
}
.hero-title {
  font-size: 54px;
  font-weight: var(--fw-extrabold);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-5);
  color: var(--color-white);
}
.hero-text {
  font-size: var(--fs-lg);
  line-height: var(--lh-relaxed);
  opacity: 0.9;
  margin-bottom: var(--space-8);
  max-width: 520px;
}
.hero-meta {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
  margin-bottom: var(--space-8);
}
.hero-meta > div { display: flex; flex-direction: column; gap: 4px; }
.hero-meta .meta-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.5px; opacity: 0.7; }
.hero-meta .meta-value { font-size: var(--fs-lg); font-weight: var(--fw-bold); }

.hero-illustration {
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}
.hero-photo-placeholder {
  width: 100%;
  aspect-ratio: 1;
  max-width: 480px;
  background: linear-gradient(135deg, rgba(255,255,255,0.08) 0%, rgba(245,134,60,0.4) 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-nav {
  position: absolute;
  bottom: var(--space-8);
  left: var(--space-12);
  display: flex;
  gap: var(--space-3);
  z-index: 3;
}
.hero-arrow {
  width: 55px; height: 55px;
  border-radius: var(--radius-md);
  background: transparent;
  border: 2px solid rgba(255,255,255,0.4);
  color: var(--color-white);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.hero-arrow:hover { background: rgba(255,255,255,0.1); }
.hero-arrow.active {
  background: var(--color-white);
  color: var(--color-primary);
  border-color: var(--color-white);
}

@media (max-width: 1023px) {
  .hero-card { padding: var(--space-10) var(--space-8); }
  .hero-title { font-size: 40px; }
}
@media (max-width: 767px) {
  .hero-card { grid-template-columns: 1fr; padding: var(--space-8) var(--space-5); min-height: auto; }
  .hero-title { font-size: 30px; }
  .hero-text { font-size: var(--fs-base); }
  .hero-illustration { order: -1; }
  .hero-photo-placeholder { max-width: 240px; }
  .hero-nav { position: static; margin-top: var(--space-6); }
}

/* ============ Section soft bg ============ */
.section-soft {
  background: var(--color-bg-soft);
}

/* ============ Categories grid ============ */
.categories-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
.categories-grid.categories-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1023px) {
  .categories-grid,
  .categories-grid.categories-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .categories-grid,
  .categories-grid.categories-3 { grid-template-columns: 1fr; }
}

/* ============ Eyebrow (section label) ============ */
.eyebrow {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--color-primary);
  background: var(--color-primary-light);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
}

/* ============ Course card: short text + full-width btn ============ */
.course-short-text {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-4);
}
.course-btn-full {
  width: 100%;
  text-align: center;
  padding: var(--space-4) var(--space-5) !important;
}

/* ============ Formats (варіанти навчання) ============ */
.formats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}
.format-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
}
.format-icon {
  width: 64px; height: 64px;
  background: var(--color-primary-light);
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  margin-bottom: var(--space-4);
}
.format-card h3 {
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-3);
  color: var(--color-text);
}
.format-card p {
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
}
@media (max-width: 767px) { .formats-grid { grid-template-columns: 1fr; } }

/* ============ Programs (15 курсів в 3 топіках) ============ */
.programs-topic { margin-bottom: var(--space-10); }
.programs-topic:last-child { margin-bottom: 0; }
.programs-topic-head {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--color-primary);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-primary-light);
  margin-bottom: var(--space-5);
}
.programs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.program-link {
  display: block;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  transition: border-color var(--t-fast), transform 0.08s, box-shadow var(--t-fast);
  text-decoration: none;
  color: var(--color-text);
}
.program-link:hover {
  border-color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.program-name {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}
.program-desc {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
}
@media (max-width: 767px) { .programs-grid { grid-template-columns: 1fr; } }

/* ============ About block ============ */
.about-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  align-items: center;
}
.about-text h2 {
  font-size: var(--fs-5xl);
  font-weight: var(--fw-extrabold);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-6);
  color: var(--color-primary);
}
.about-text p {
  font-size: var(--fs-lg);
  color: var(--color-text);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-4);
}
.stats-grid.stats-3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
.stats-grid.stats-3 .stat-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6) var(--space-8);
  text-align: left;
}
.stats-grid.stats-3 .stat-num {
  font-size: 64px;
  margin-bottom: var(--space-2);
}
.stats-grid.stats-3 .stat-label {
  font-size: var(--fs-lg);
  color: var(--color-text-muted);
  font-weight: var(--fw-medium);
}
@media (max-width: 1023px) {
  .about-block { grid-template-columns: 1fr; }
  .about-text h2 { font-size: var(--fs-4xl); }
  .stats-grid.stats-3 .stat-num { font-size: 48px; }
}

/* ============ FAQ ============ */
.faq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  max-width: 1100px;
  margin: 0 auto;
}
.faq-grid .lesson {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg-card);
}
@media (max-width: 767px) { .faq-grid { grid-template-columns: 1fr; } }

/* ============ Admin consultation card ============ */
.admin-card {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--space-10);
  background: linear-gradient(135deg, var(--color-primary-light) 0%, #dfe8fb 100%);
  border-radius: var(--radius-2xl);
  padding: var(--space-10);
  align-items: center;
}
.admin-photo {
  width: 200px; height: 200px;
  border-radius: var(--radius-full);
  background: var(--color-white);
  overflow: hidden;
  margin: 0 auto;
}
.admin-body h2 {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-extrabold);
  line-height: 1.2;
  color: var(--color-text);
  margin-bottom: var(--space-5);
}
.admin-info {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  margin-bottom: var(--space-5);
}
.admin-name {
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
}
.admin-role {
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  margin-bottom: var(--space-3);
}
.admin-hours {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: var(--fs-sm);
  color: var(--color-text);
}
.admin-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .admin-card { grid-template-columns: 1fr; padding: var(--space-6); gap: var(--space-5); }
  .admin-photo { width: 140px; height: 140px; }
  .admin-body h2 { font-size: var(--fs-2xl); }
}

/* ============ Testimonials placeholder ============ */
.testimonials-empty {
  text-align: center;
  padding: var(--space-10) var(--space-6);
  background: var(--color-bg-soft);
  border-radius: var(--radius-2xl);
  max-width: 700px;
  margin: 0 auto;
}
.testimonials-empty p {
  color: var(--color-text-muted);
  font-size: var(--fs-base);
  margin-bottom: var(--space-5);
  line-height: var(--lh-relaxed);
}

/* ============ Checkout + Consultation forms ============ */
.checkout-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--space-10);
  align-items: start;
}
.checkout-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.checkout-form .field input[type=text],
.checkout-form .field input[type=email],
.checkout-form .field input[type=tel],
.checkout-form .field textarea,
.checkout-form .field select {
  font-family: inherit;
  font-size: var(--fs-base);
  padding: var(--space-3) var(--space-4);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-white);
  color: var(--color-text);
  width: 100%;
  outline: none;
  transition: border-color var(--t-fast);
}
.checkout-form .field select { cursor: pointer; min-height: 48px; }
.checkout-form .field textarea { resize: vertical; min-height: 100px; font-family: inherit; }
.checkout-form .field input:focus,
.checkout-form .field textarea:focus,
.checkout-form .field select:focus { border-color: var(--color-primary); }
.checkout-form .field label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-text);
  margin-bottom: var(--space-2);
  display: block;
}
.checkout-form .checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
  cursor: pointer;
}
.checkout-form .checkbox input {
  accent-color: var(--color-primary);
  width: 18px; height: 18px;
  margin-top: 3px;
  flex-shrink: 0;
}
.field-err {
  color: var(--color-error);
  font-size: var(--fs-sm);
  min-height: 1em;
}
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  opacity: 0 !important;
  height: 0; overflow: hidden;
}
.radio-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.radio-opt {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color var(--t-fast), background var(--t-fast);
  font-size: var(--fs-sm);
}
.radio-opt:hover { border-color: var(--color-primary); }
.radio-opt input { accent-color: var(--color-primary); }
.radio-opt:has(input:checked) {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
  color: var(--color-primary);
  font-weight: var(--fw-semibold);
}

/* Order summary sidebar */
.order-summary {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  position: sticky;
  top: var(--space-6);
}
.order-summary h3 {
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-5);
  color: var(--color-text);
}
.summary-course {
  padding: var(--space-4);
  background: var(--color-bg-soft);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-5);
}
.summary-course-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  color: var(--color-text-muted);
  letter-spacing: 0.5px;
  margin-bottom: var(--space-2);
}
.summary-course-title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  margin-bottom: var(--space-2);
  line-height: 1.3;
}
.summary-course-meta {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}
.summary-tariffs { margin-bottom: var(--space-5); }
.tariff-option {
  display: block;
  cursor: pointer;
  padding: var(--space-4);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  transition: border-color var(--t-fast), background var(--t-fast);
}
.tariff-option:hover { border-color: var(--color-primary); }
.tariff-option.selected {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
}
.tariff-option input { display: none; }
.tariff-option-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--space-1);
}
.tariff-option-name { font-weight: var(--fw-bold); font-size: var(--fs-base); color: var(--color-text); }
.tariff-option-price { font-weight: var(--fw-bold); color: var(--color-primary); font-size: var(--fs-base); }
.tariff-option-desc {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  line-height: 1.4;
}
.summary-total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-top: var(--space-4);
  border-top: 2px solid var(--color-border);
  font-size: var(--fs-lg);
  color: var(--color-text);
}
.summary-total strong {
  font-size: var(--fs-2xl);
  color: var(--color-primary);
  font-weight: var(--fw-extrabold);
}

@media (max-width: 1023px) {
  .checkout-grid { grid-template-columns: 1fr; }
  .order-summary { position: static; order: -1; }
}

/* ============ Thanks page ============ */
.thanks-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-12);
  text-align: center;
}
.thanks-icon {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: var(--color-success);
  color: var(--color-white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
  font-weight: var(--fw-extrabold);
  margin-bottom: var(--space-6);
}
.thanks-title {
  font-size: var(--fs-4xl);
  font-weight: var(--fw-extrabold);
  color: var(--color-primary);
  margin-bottom: var(--space-4);
  line-height: 1.2;
}
.thanks-lead {
  font-size: var(--fs-lg);
  color: var(--color-text);
  margin-bottom: var(--space-8);
  line-height: var(--lh-relaxed);
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.thanks-next {
  background: var(--color-bg-soft);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  margin-bottom: var(--space-8);
  text-align: left;
}
.thanks-next h3 { font-size: var(--fs-lg); margin-bottom: var(--space-4); color: var(--color-text); }
.thanks-next ol { padding-left: var(--space-5); }
.thanks-next li { margin-bottom: var(--space-3); color: var(--color-text); line-height: var(--lh-relaxed); }
.thanks-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--space-6);
}
.thanks-help {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}
.thanks-help a { color: var(--color-primary); font-weight: var(--fw-semibold); }

@media (max-width: 640px) {
  .thanks-card { padding: var(--space-8) var(--space-5); }
  .thanks-title { font-size: var(--fs-2xl); }
}

/* ============ About page ============ */
.about-hero {
  text-align: center;
  padding: var(--space-10) 0;
}
.about-hero .eyebrow { display: inline-block; margin-bottom: var(--space-4); }
.team-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-5);
}
.team-member {
  padding: var(--space-4) var(--space-5);
  background: var(--color-white);
  border-radius: var(--radius-md);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
}
.about-contact {
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}
.about-contact h2 {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-extrabold);
  margin-bottom: var(--space-8);
  color: var(--color-primary);
}
.contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-6);
  text-align: center;
}
.contact-grid > div { padding: var(--space-5); background: var(--color-white); border-radius: var(--radius-md); }
.contact-grid strong { color: var(--color-primary); font-weight: var(--fw-bold); }

/* ============ Article content ============ */
.article-content {
  font-size: var(--fs-base);
  line-height: 1.7;
  color: var(--color-text);
}
.article-content h2 {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  margin-top: var(--space-8);
  margin-bottom: var(--space-4);
}
.article-content h3 {
  font-size: var(--fs-xl);
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
}
.article-content p { margin-bottom: var(--space-4); }
.article-content ul, .article-content ol { padding-left: var(--space-6); margin-bottom: var(--space-4); }
.article-content li { margin-bottom: var(--space-2); }
.article-content a { color: var(--color-primary); text-decoration: underline; }

/* ============ Speakers page ============ */
.speaker-hero {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--space-8);
  align-items: center;
  padding: var(--space-8);
  background: linear-gradient(135deg, var(--color-primary-light) 0%, #dfe8fb 100%);
  border-radius: var(--radius-2xl);
  margin-bottom: var(--space-10);
}
.speaker-hero-photo {
  width: 240px; height: 240px;
  border-radius: 50%;
  background: var(--color-white);
  margin: 0 auto;
}
.speaker-hero h1 { font-size: var(--fs-4xl); color: var(--color-primary); margin-bottom: var(--space-3); }
.speaker-hero .tagline { font-size: var(--fs-lg); color: var(--color-text); margin-bottom: var(--space-5); line-height: var(--lh-relaxed); }
.speaker-hero .meta { display: flex; gap: var(--space-6); flex-wrap: wrap; color: var(--color-text-muted); font-size: var(--fs-sm); margin-bottom: var(--space-5); }

@media (max-width: 767px) {
  .speaker-hero { grid-template-columns: 1fr; padding: var(--space-5); text-align: center; }
  .speaker-hero-photo { width: 160px; height: 160px; }
}

/* ============ Blog listing ============ */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.blog-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.blog-cover {
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--color-primary-light), #c8d6f5);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 48px;
}
.blog-card-body { padding: var(--space-5); }
.blog-card .date {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: var(--space-2);
}
.blog-card .title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  margin-bottom: var(--space-3);
  line-height: 1.3;
}
.blog-card .excerpt {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
}

@media (max-width: 1023px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .blog-grid { grid-template-columns: 1fr; } }

/* ============ Courses grid ============ */
.courses-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
@media (max-width: 1023px) { .courses-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .courses-grid { grid-template-columns: 1fr; } }

/* ============ Image placeholders ============ */
.img-placeholder {
  width: 100%;
  height: 100%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.img-placeholder::after {
  content: "";
  width: 60%;
  height: 60%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.9;
}
.img-emotions  { background: linear-gradient(135deg, #9ca9ef 0%, #c8a3ef 100%); }
.img-business  { background: linear-gradient(135deg, #a7e3e3 0%, #7ec8c8 100%); }
.img-finance   { background: linear-gradient(135deg, #f9c08f 0%, #f5a66d 100%); }
.img-event     { background: linear-gradient(135deg, #e8eef3 0%, #c8d6f5 100%); }

.img-emotions::after  { content: "🧠"; font-size: 80px; background: none; }
.img-business::after  { content: "📈"; font-size: 80px; background: none; }
.img-finance::after   { content: "💰"; font-size: 80px; background: none; }
.img-event::after     { content: "🎤"; font-size: 80px; background: none; }

.avatar-placeholder {
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--color-primary-light) 0%, #c8d6f5 100%);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px;
}
.avatar-placeholder::before { content: "👤"; }
.avatar-placeholder.large { font-size: 60px; }
.avatar-placeholder.large::before { content: "👤"; }

/* ============ Schedule table ============ */
.schedule-table-wrap {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  overflow-x: auto;
}
.schedule-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}
.schedule-table th {
  background: var(--color-bg-soft);
  padding: var(--space-4) var(--space-6);
  text-align: left;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  border-bottom: 1px solid var(--color-border);
}
.schedule-table td {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
  font-size: var(--fs-base);
}
.schedule-table tr:last-child td { border-bottom: 0; }
.schedule-table tr:hover { background: var(--color-bg-soft); }
.schedule-table .course-name { font-weight: var(--fw-semibold); color: var(--color-text); }
.schedule-table .speaker { display: flex; align-items: center; gap: var(--space-3); }
.schedule-table .sp-avatar {
  width: 40px; height: 40px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--color-primary-light) 0%, #c8d6f5 100%);
  flex-shrink: 0;
}
.format-badge {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.format-online  { background: #d1fae5; color: #065f46; }
.format-offline { background: #fff3cd; color: #854d0e; }
.tbl-link {
  color: var(--color-primary);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
}
.tbl-link:hover { text-decoration: underline; }

/* ============ Event card ============ */
.event-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.event-image {
  aspect-ratio: 1;
  min-height: 380px;
}
.event-image .img-placeholder { width: 100%; height: 100%; }
.event-body {
  padding: var(--space-10);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-5);
}
.event-body h3 {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-extrabold);
  line-height: 1.2;
  color: var(--color-text);
}
.event-meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.event-meta li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--fs-base);
  color: var(--color-text);
}
.event-meta .ic { width: 24px; font-size: var(--fs-lg); }
.event-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-4); }

@media (max-width: 1023px) {
  .event-card { grid-template-columns: 1fr; }
  .event-image { min-height: 220px; }
  .event-body { padding: var(--space-6); }
  .event-body h3 { font-size: var(--fs-2xl); }
}

/* ============ Stats grid ============ */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}
@media (max-width: 1023px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .stats-grid { grid-template-columns: 1fr; } }

/* ============ Speakers grid ============ */
.speakers-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}
@media (max-width: 767px) { .speakers-grid { grid-template-columns: 1fr; } }

/* ============ Testimonials ============ */
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
.testimonial-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: transform var(--t-base);
}
.testimonial-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.tc-video {
  aspect-ratio: 9/16;
  background: linear-gradient(135deg, #e8eef3 0%, #c8d6f5 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.play-btn {
  width: 64px; height: 64px;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.9);
  color: var(--color-primary);
  font-size: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-left: 4px;
  box-shadow: var(--shadow-md);
  cursor: pointer;
}
.play-btn:hover { background: var(--color-white); }
.tc-body { padding: var(--space-4) var(--space-5); }
.tc-name { font-weight: var(--fw-bold); font-size: var(--fs-base); }
.tc-course { color: var(--color-text-muted); font-size: var(--fs-sm); }

@media (max-width: 1023px) { .testimonials-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .testimonials-grid { grid-template-columns: 1fr; } }

/* ============ Catalog page ============ */
.catalog-head {
  background: var(--color-white);
  padding: var(--space-10) 0 var(--space-6);
  border-bottom: 1px solid var(--color-border);
}
.breadcrumb {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-5);
  display: flex;
  gap: var(--space-2);
}
.breadcrumb a:hover { color: var(--color-primary); }
.breadcrumb .sep { opacity: 0.4; }

.catalog-head h1 {
  font-size: var(--fs-5xl);
  font-weight: var(--fw-extrabold);
  margin-bottom: var(--space-6);
}

.topic-tabs {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.topic-tab {
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-white);
  color: var(--color-text);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  cursor: pointer;
  transition: all var(--t-fast);
}
.topic-tab:hover { border-color: var(--color-primary); color: var(--color-primary); }
.topic-tab.active { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }

.catalog-body {
  padding: var(--space-10) 0 var(--space-16);
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--space-10);
}
.filters-panel {
  position: sticky;
  top: 160px;
  align-self: start;
  max-height: calc(100vh - 180px);
  overflow-y: auto;
}
.filter-group { margin-bottom: var(--space-6); }
.filter-group h3 {
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-3);
  color: var(--color-text);
}
.filter-list { display: flex; flex-direction: column; gap: var(--space-2); }
.filter-opt {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  cursor: pointer;
  font-size: var(--fs-sm);
  color: var(--color-text);
}
.filter-opt input[type="checkbox"],
.filter-opt input[type="radio"] {
  accent-color: var(--color-primary);
  width: 18px; height: 18px;
}
.filter-opt:hover { color: var(--color-primary); }

.catalog-sort {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-bottom: var(--space-5);
}
.sort-select {
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-white);
  font-size: var(--fs-sm);
  cursor: pointer;
}

.catalog-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}

.catalog-empty {
  text-align: center;
  padding: var(--space-16) var(--space-5);
  color: var(--color-text-muted);
  background: var(--color-bg-soft);
  border-radius: var(--radius-xl);
}

.pagination {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-10);
}
.page-btn {
  width: 40px; height: 40px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-white);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-text);
  cursor: pointer;
  transition: all var(--t-fast);
}
.page-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
.page-btn.active { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }

@media (max-width: 1023px) {
  .catalog-body { grid-template-columns: 1fr; }
  .filters-panel { position: static; max-height: none; }
  .filters-panel summary { cursor: pointer; font-weight: var(--fw-bold); padding: var(--space-4); background: var(--color-white); border-radius: var(--radius-md); border: 1px solid var(--color-border); }
}
@media (max-width: 640px) { .catalog-grid { grid-template-columns: 1fr; } }

/* ============ Course detail page ============ */
.course-head {
  padding: var(--space-10) 0;
  background: var(--color-bg-soft);
}
.course-head .course-head-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--space-10);
  align-items: stretch;
}
.course-head-main {
  background: var(--color-primary-light);
  border-radius: var(--radius-2xl);
  padding: var(--space-10);
  position: relative;
  min-height: 420px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.course-head-main .badge { position: relative; display: inline-block; margin-bottom: var(--space-4); }
.course-head-main h1 {
  font-size: var(--fs-5xl);
  font-weight: var(--fw-extrabold);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-text);
  margin-bottom: var(--space-5);
  max-width: 560px;
}
.course-head-main .lead {
  font-size: var(--fs-lg);
  line-height: var(--lh-relaxed);
  color: var(--color-text);
  max-width: 500px;
  margin-bottom: var(--space-6);
}
.course-head-main .meta-row {
  display: flex;
  gap: var(--space-8);
  flex-wrap: wrap;
  padding-top: var(--space-5);
  border-top: 1px solid rgba(0,68,205,0.15);
}
.course-head-main .meta-row > div { display: flex; flex-direction: column; gap: 4px; }

.buy-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  box-shadow: var(--shadow-sm);
}
.buy-card .author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.buy-card .author .ava {
  width: 56px; height: 56px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--color-primary-light) 0%, #c8d6f5 100%);
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 24px;
}
.buy-card .author .ava::before { content: "👤"; }
.buy-card .author-label { font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.3px; }
.buy-card .author-name { font-weight: var(--fw-bold); font-size: var(--fs-base); }
.buy-card .price-big {
  font-size: var(--fs-4xl);
  font-weight: var(--fw-extrabold);
  color: var(--color-text);
  letter-spacing: -0.02em;
}
.buy-card .price-label { font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: uppercase; }

.tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-top: var(--space-10);
  margin-bottom: var(--space-8);
  overflow-x: auto;
}
.tab-btn {
  padding: var(--space-4) var(--space-6);
  background: transparent;
  border: 0;
  border-bottom: 3px solid transparent;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-base);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: color var(--t-fast), border-color var(--t-fast);
  white-space: nowrap;
}
.tab-btn:hover { color: var(--color-text); }
.tab-btn.active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

.tab-panel { display: none; }
.tab-panel.active { display: block; }

.video-block {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
}
.video-frame {
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, #e8eef3 0%, #a9b8d8 100%);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-6);
  position: relative;
}
.video-frame .play-btn { width: 80px; height: 80px; font-size: 32px; }

.lessons {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-4);
}
.lesson {
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-2);
}
.lesson:last-child { margin-bottom: 0; }
.lesson summary {
  padding: var(--space-4) var(--space-6);
  background: var(--color-bg-soft);
  cursor: pointer;
  font-weight: var(--fw-semibold);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  list-style: none;
  transition: background var(--t-fast);
}
.lesson summary::-webkit-details-marker { display: none; }
.lesson summary:hover { background: var(--color-primary-light); }
.lesson summary .lesson-num { color: var(--color-primary); font-weight: var(--fw-bold); min-width: 70px; }
.lesson summary .lesson-title { flex: 1; }
.lesson summary .lesson-meta { color: var(--color-text-muted); font-size: var(--fs-sm); font-weight: var(--fw-regular); }
.lesson summary .chevron { transition: transform var(--t-fast); }
.lesson[open] summary .chevron { transform: rotate(180deg); }
.lesson .lesson-body {
  padding: var(--space-5) var(--space-6);
  background: var(--color-white);
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  border-top: 1px solid var(--color-border);
}

.benefits-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin: var(--space-8) 0;
}
.benefit-item {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  text-align: center;
}
.benefit-item .icon {
  width: 64px; height: 64px;
  border-radius: var(--radius-full);
  background: var(--color-primary-light);
  color: var(--color-primary);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 28px;
  margin-bottom: var(--space-4);
}
.benefit-item h4 { margin-bottom: var(--space-2); font-size: var(--fs-lg); }
.benefit-item p { color: var(--color-text-muted); font-size: var(--fs-sm); }

.reviews-list { display: flex; flex-direction: column; gap: var(--space-5); }
.review {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  display: flex;
  gap: var(--space-5);
}
.review .rev-ava {
  width: 56px; height: 56px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--color-primary-light) 0%, #c8d6f5 100%);
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 24px;
}
.review .rev-ava::before { content: "👤"; }
.review .rev-head {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
.review .rev-name { font-weight: var(--fw-bold); }
.review .rev-course { font-size: var(--fs-sm); color: var(--color-text-muted); }
.review .rev-body { color: var(--color-text); line-height: var(--lh-relaxed); }

.faq-list { display: flex; flex-direction: column; gap: var(--space-3); }

@media (max-width: 1023px) {
  .course-head .course-head-grid { grid-template-columns: 1fr; }
  .course-head-main h1 { font-size: var(--fs-3xl); }
  .benefits-row { grid-template-columns: 1fr; }
}
