/*
 * index.css — TaxiCourse.uk home page
 * Page-specific styles only.
 * Brand tokens live in brand.css — do not redeclare :root here.
 * Shared layout/components live in shared.css — do not duplicate here.
 */

/* ── HERO LAYOUT ── */
.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

/* ── STAT CARDS ── */
.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.stat-card {
  background: var(--brand-white);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1rem;
  text-align: center;
}
.stat-card .num {
  font-family: 'DM Serif Display', serif;
  font-size: 2rem;
  color: var(--brand-dark);
  line-height: 1;
  margin-bottom: 0.3rem;
}
.stat-card .label {
  font-size: 13px;
  color: var(--brand-muted-text);
  line-height: 1.3;
}

/* ── COURSE CARDS ── */
.courses-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.5rem;
}
.course-card {
  background: var(--brand-white);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-lg);
  transition: border-color 0.2s, transform 0.2s;
  position: relative;
  overflow: visible;
  display: flex;
  flex-direction: column;
}
.course-card:hover { border-color: var(--brand-primary); transform: translateY(-3px); }
.course-card.featured { border-color: var(--brand-primary); border-width: 2px; }
.course-badge-feat {
  position: absolute;
  top: -12px; left: 1.5rem;
  background: var(--brand-primary);
  color: var(--brand-white);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 12px;
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.course-card-top { padding: 1.75rem 1.5rem 1.25rem; flex: 1; }
.course-card-bottom {
  background: var(--brand-light-bg);
  border-top: 1px solid var(--brand-muted);
  padding: 1.25rem 1.5rem 1.5rem;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}
.course-card h3 { font-size: 1.05rem; font-weight: 600; color: var(--brand-ink); margin-bottom: 0.4rem; }
.course-card p  { font-size: 1rem; color: var(--brand-muted-text); line-height: 1.5; margin-bottom: 0; }
.course-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 1.25rem; }
.tag {
  font-size: 12px;
  background: var(--brand-white);
  color: var(--brand-dark);
  border: 1px solid var(--brand-muted);
  padding: 3px 10px;
  border-radius: 100px;
  font-weight: 500;
}

/* ── COURSE CARD BUTTONS ── */
.btn-sm-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 18px;
  border-radius: var(--radius);
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-decoration: none;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.15s;
  background: var(--brand-gradient);
  color: #ffffff !important;
  border: 1.5px solid transparent;
  line-height: 1;
}
.btn-sm-primary:hover { opacity: 0.88; color: #ffffff !important; transform: translateY(-1px); }

/* ── COURSE CARD DROPDOWN ── */
.card-btn-wrap { position: relative; display: inline-block; }
.card-dropdown {
  display: none;
  position: absolute;
  bottom: calc(100% + 6px);
  left: 0;
  min-width: 220px;
  background: var(--brand-white);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius);
  box-shadow: 0 4px 16px rgba(0,0,0,0.10);
  z-index: 50;
  overflow: hidden;
}
.card-dropdown.open { display: block; }
.card-dropdown-item {
  display: block;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--brand-mid);
  text-decoration: none;
  border-bottom: 1px solid var(--brand-border);
  transition: background 0.15s, color 0.15s;
  white-space: nowrap;
}
.card-dropdown-item:last-child { border-bottom: none; }
.card-dropdown-item:hover { background: var(--brand-section-alt); color: var(--brand-dark); }
.card-btn-wrap.align-right .card-dropdown { left: auto; right: 0; }

/* ── AUDIENCES ── */
.audiences { background: var(--brand-section-alt); }
.audiences-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 1.5rem;
}
.audience-card {
  background: var(--brand-white);
  border-radius: var(--radius-lg);
  padding: 2rem 1.5rem;
  border: 1px solid var(--brand-border);
}
.audience-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 57px; height: 57px;
  background: var(--brand-section-alt);
  border-radius: var(--radius);
  margin-bottom: 1rem;
  padding: 12px;
}
.audience-icon svg { width: 32px; height: 32px; }
.audience-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: 0.5rem; color: var(--brand-ink); }
.audience-card p { font-size: 1rem; color: var(--brand-muted-text); line-height: 1.55; }
.audience-card a { color: var(--brand-dark); font-weight: 500; text-decoration: none; font-size: 14px; display: inline-block; margin-top: 0.75rem; }

/* ── ABOUT ── */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}
.about-grid .section-title { font-size: 1.75rem; }
.about-text p { color: var(--brand-mid); margin-bottom: 1rem; }
.about-text p:last-child { margin-bottom: 0; }
.creds-list { list-style: none; }
.creds-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--brand-border);
  font-size: 1rem;
  color: var(--brand-mid);
}
.creds-list li:last-child { border-bottom: none; }
.check {
  width: 20px; height: 20px;
  background: var(--brand-muted);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}
.check svg { width: 11px; height: 11px; stroke: var(--brand-dark); }

/* ── PARTNERS ── */
.partners { background: var(--brand-dark); padding: 3.5rem 1.5rem; }
.partners-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
}
.partners-eyebrow {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--brand-white);
}
.partners-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.25rem;
  width: 100%;
}
.partner-card {
  background: var(--brand-section-alt);
  border-radius: var(--radius-lg);
  padding: 1.75rem 1.25rem;
  text-align: center;
  box-shadow: 0 6px 20px rgba(26,26,26,0.18);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}
.partner-card-abbr { font-family: 'DM Serif Display', serif; font-size: 1.75rem; color: var(--brand-ink); line-height: 1; }
.partner-card-label { font-size: 12px; font-weight: 600; color: var(--brand-ink); letter-spacing: 0.03em; }

/* ── REVIEWS ── */
.reviews { background: var(--brand-white); border-top: 1px solid var(--brand-border); }
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
}
.review-card {
  background: var(--brand-white);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-lg);
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: border-color 0.2s, transform 0.2s;
}
.review-card:hover { border-color: var(--brand-primary); transform: translateY(-2px); }
.review-stars { display: flex; gap: 3px; }
.review-stars svg { width: 16px; height: 16px; fill: #f59e0b; }
.review-text { font-size: 0.95rem; color: var(--brand-mid); line-height: 1.6; font-style: italic; flex: 1; }
.review-author { display: flex; align-items: center; gap: 12px; }
.review-avatar {
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--brand-muted);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 600; color: var(--brand-dark);
  flex-shrink: 0; border: 2px solid var(--brand-border);
}
.review-name { font-size: 14px; font-weight: 600; color: var(--brand-ink); }
.review-role { font-size: 12px; color: var(--brand-muted-text); }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .hero-inner { gap: 2rem; }
  .hero h1 { font-size: clamp(1.8rem, 3.5vw, 2.5rem); }
  .hero-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.75rem; }
  .stat-card .num { font-size: 1.6rem; }
  .courses-grid { grid-template-columns: repeat(2, 1fr); }
  .audiences-grid { grid-template-columns: repeat(2, 1fr); }
  .about-grid { gap: 2rem; }
}
@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .about-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .hero-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .courses-grid { grid-template-columns: 1fr; }
  .audiences-grid { grid-template-columns: 1fr; }
  .partners-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .reviews-grid { grid-template-columns: 1fr; }
  .about-grid { grid-template-columns: 1fr; }
  .hero h1 { font-size: 1.8rem; }
}
