/* ============================================================
   NAV — mobile menu, dropdown, breadcrumb, pagination
   ============================================================ */

/* ── Breadcrumb ──────────────────────────────────────────── */
.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2xs);
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.breadcrumb__item {
  display: block;
  align-items: center;
  gap: var(--space-2xs);
}

.breadcrumb__item::before {
  content: '/';
  color: var(--gray-300);
}

.breadcrumb__item:first-child::before { display: none; }

.breadcrumb__link {
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.breadcrumb__link:hover { color: var(--primary); }

.breadcrumb__current {
  color: var(--color-text);
  font-weight: var(--font-medium);
}

/* ── Pagination ──────────────────────────────────────────── */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  flex-wrap: wrap;
  margin-top: var(--space-2xl);
}

.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  padding: 0 var(--space-sm);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  text-decoration: none;
  color: var(--gray-700);
  background: #ffffff;
  border: 1.5px solid var(--color-border);
  transition:
    background   var(--transition),
    border-color var(--transition),
    color        var(--transition),
    box-shadow   var(--transition),
    transform    var(--transition-fast);
  box-shadow: var(--shadow-sm);
}

.pagination .page-numbers:hover {
  border-color: var(--primary);
  color: var(--primary);
  background: var(--primary-xlight);
  transform: translateY(-1px);
}

.pagination .page-numbers.current {
  background: var(--primary);
  border-color: var(--primary);
  color: #ffffff;
  font-weight: var(--font-bold);
  box-shadow: var(--shadow-cta);
}

.pagination .page-numbers.dots {
  border: none;
  background: none;
  box-shadow: none;
}

/* ── Tabs ────────────────────────────────────────────────── */
.tabs {
  border-bottom: 2px solid var(--color-border);
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
}

.tabs::-webkit-scrollbar { display: none; }

.tab {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-md);
  font-size: var(--text-base);
  font-weight: var(--font-medium);
  color: var(--color-text-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  white-space: nowrap;
  background: none;
  border-radius: 0;
  transition:
    color        var(--transition-fast),
    border-color var(--transition-fast),
    background   var(--transition-fast);
  min-height: 44px;
}

.tab:hover { background: var(--primary-xlight); }

.tab:hover { color: var(--primary); }

.tab--active {
  color: var(--primary);
  border-bottom-color: var(--primary);
  font-weight: var(--font-semi);
}

/* ── Accordion (FAQ) ─────────────────────────────────────── */
.accordion {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.accordion__item {
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: #ffffff;
  box-shadow: var(--shadow-sm);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.accordion__item--open {
  border-color: var(--primary);
  box-shadow: 0 2px 16px rgba(29,122,74,0.10);
}

.accordion__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-lg);
  font-size: var(--text-base);
  font-weight: var(--font-semi);
  color: var(--gray-800);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  min-height: 56px;
  gap: var(--space-md);
  -webkit-tap-highlight-color: transparent;
  transition: color var(--transition-fast);
  letter-spacing: -0.01em;
}

.accordion__trigger:hover { color: var(--primary); }
.accordion__item--open .accordion__trigger { color: var(--primary); }

.accordion__icon {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  color: var(--primary);
  transition: transform var(--transition);
  background: var(--primary-xlight);
  border-radius: var(--radius-full);
  padding: 3px;
  box-sizing: border-box;
}

.accordion__item--open .accordion__icon {
  transform: rotate(180deg);
  background: var(--primary-light);
}

.accordion__body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--transition-slow);
}

.accordion__item--open .accordion__body {
  grid-template-rows: 1fr;
}

.accordion__content {
  overflow: hidden;
}

.accordion__content-inner {
  padding: 0 var(--space-lg) var(--space-lg);
  font-size: var(--text-sm);
  line-height: var(--leading-loose);
  color: var(--color-text-muted);
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-md);
  margin-top: 0;
}

/* ── Step indicator ──────────────────────────────────────── */
.steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.step {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
}

.step__number {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: var(--primary);
  color: #ffffff;
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}

.step__content { flex: 1; }

.step__title {
  font-size: var(--text-md);
  font-weight: var(--font-semi);
  margin-bottom: var(--space-xs);
}

.step__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
}

@media (min-width: 768px) {
  .steps { flex-direction: row; }
  .step  { flex-direction: column; align-items: flex-start; }
  .step__number { margin-bottom: var(--space-sm); }
}
