@layer components {
:root {
  --mc-ed-font-family: 'Inter', 'Segoe UI', sans-serif;
  --mc-ed-bg: var(--mc-lit-c-f6f8fb);
  --mc-ed-bg-2: var(--mc-lit-c-eef2f8);
  --mc-ed-surface: var(--mc-lit-c-ffffff);
  --mc-ed-surface-2: var(--mc-lit-c-f3f6fb);
  --mc-ed-surface-3: var(--mc-lit-c-eef2f7);
  --mc-ed-surface-highlight: var(--mc-lit-c-f8fbff);
  --mc-ed-text: var(--mc-lit-c-111827);
  --mc-ed-text-strong: var(--mc-lit-c-1f2937);
  --mc-ed-text-soft: var(--mc-lit-c-334155);
  --mc-ed-muted: var(--mc-lit-c-64748b);
  --mc-ed-muted-strong: var(--mc-lit-c-475569);
  --mc-ed-muted-disabled: var(--mc-lit-c-94a3b8);
  --mc-ed-border: var(--mc-lit-c-d8e0eb);
  --mc-ed-border-strong: var(--mc-lit-c-c3cfdd);
  --mc-ed-border-active: var(--mc-lit-c-a7b6c9);
  --mc-ed-primary: var(--mc-lit-c-4f46e5);
  --mc-ed-primary-strong: var(--mc-lit-c-4338ca);
  --mc-ed-primary-ink: var(--mc-lit-c-312e81);
  --mc-ed-primary-2: var(--mc-lit-c-0ea5e9);
  --mc-ed-primary-soft: var(--mc-lit-c-e9edff);
  --mc-ed-focus-border: var(--mc-lit-c-8b92f5);
  --mc-ed-on-primary: var(--mc-lit-c-ffffff);
  --mc-ed-danger: var(--mc-lit-c-dc2626);
  --mc-ed-danger-strong: var(--mc-lit-c-b91c1c);
  --mc-ed-danger-accent: var(--mc-lit-c-f97316);
  --mc-ed-on-danger: var(--mc-lit-c-ffffff);
  --mc-ed-danger-soft: var(--mc-lit-c-fee2e2);
  --mc-ed-danger-soft-bg: var(--mc-lit-c-fff7f7);
  --mc-ed-success: var(--mc-lit-c-059669);
  --mc-ed-info-border: var(--mc-lit-c-bfdbfe);
  --mc-ed-info-bg: var(--mc-lit-c-eff6ff);
  --mc-ed-info-text: var(--mc-lit-c-1e3a8a);

  --mc-ed-accent: #6366f1;

  --mc-ed-chip-border: var(--mc-lit-c-cfdaea);
  --mc-ed-chip-bg: var(--mc-ed-surface-2);
  --mc-ed-chip-status-border: var(--mc-lit-c-c7d2fe);
  --mc-ed-chip-status-bg: rgba(79,70,229,0.06);
  --mc-ed-chip-muted-border: var(--mc-lit-c-dbe4ef);
  --mc-ed-chip-muted-bg: var(--mc-lit-c-f6f8fc);

  --mc-ed-radius-sm: 6px;
  --mc-ed-radius-md: 8px;
  --mc-ed-radius-lg: 12px;

  --mc-ed-space-1: var(--mc-lit-m-4px);
  --mc-ed-space-2: var(--mc-lit-m-8px);
  --mc-ed-space-3: var(--mc-lit-m-12px);
  --mc-ed-space-4: var(--mc-lit-m-16px);
  --mc-ed-space-5: 24px;
  --mc-ed-space-6: 32px;
  --mc-ed-space-7: 40px;
  --mc-ed-space-8: 48px;
  --mc-ed-space-9: 64px;

  --mc-ed-type-1: 0.8125rem;
  --mc-ed-type-2: 0.875rem;
  --mc-ed-type-3: 0.9375rem;
  --mc-ed-type-4: 1rem;
  --mc-ed-type-card-title: clamp(1.0625rem, 1rem + 0.15vw, 1.125rem);
  --mc-ed-type-5: 1.125rem;
  --mc-ed-type-section-title: clamp(1.25rem, 1.15rem + 0.25vw, 1.5rem);
  --mc-ed-type-page-title: clamp(1.75rem, 1.5rem + 0.5vw, 2.25rem);

  --mc-ed-shadow-1: 0 1px 3px rgba(15,23,42,0.04), 0 1px 2px rgba(15,23,42,0.06);
  --mc-ed-shadow-2: 0 4px 12px rgba(15,23,42,0.08);
  --mc-ed-focus: 0 0 0 3px var(--mc-lit-c-rgba-79-70-229-0-22);
  --mc-ed-shadow-primary: none;
}

.mc-body {
  --mc-bg: var(--mc-ed-bg);
  --mc-card: var(--mc-ed-surface);
  color: var(--mc-ed-text);
  font-family: var(--mc-ed-font-family);
  background:
    radial-gradient(900px 520px at 7% -9%, var(--mc-lit-c-rgba-79-70-229-0-1), transparent 58%),
    radial-gradient(760px 440px at 95% 3%, var(--mc-lit-c-rgba-14-165-233-0-11), transparent 55%),
    linear-gradient(180deg, var(--mc-ed-bg), var(--mc-ed-bg-2));
}

h1,
h2,
h3,
h4,
h5,
h6,
.mcH2,
.mc-auth-title,
.mc-auth-card h1,
.mc-auth-card h2,
.mc-auth-card h3 {
  font-family: var(--mc-ed-font-family);
  color: var(--mc-ed-text);
  letter-spacing: var(--mc-lit-m-0_012em);
}

.mc-logo {
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.mc-auth-shell .mc-logo {
  width: 80px;
  height: 80px;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
span,
li,
a,
label,
input,
select,
textarea,
button,
th,
td,
small,
strong,
em,
.btn,
.dropdown-item,
.nav-link,
.modal-title {
  font-family: var(--mc-ed-font-family);
}

p,
span,
li,
.mc-profile-section__subtitle,
.mc-inline-card__subtitle,
.mcSub,
.mcLead,
.mcMuted,
small,
.text-muted,
.text-secondary {
  color: var(--mc-ed-muted);
}

a {
  color: var(--mc-ed-primary);
}

a:hover,
a:focus {
  color: var(--mc-ed-primary-strong);
}

.mc-nav-signup {
  color: var(--mc-ed-on-primary);
}

.mc-nav-signup:hover,
.mc-nav-signup:focus {
  color: var(--mc-ed-on-primary);
}

.mc-social-btn {
  background: var(--mc-ed-surface-2);
  border-color: var(--mc-ed-border);
  color: var(--mc-ed-text);
}

.mc-social-btn:hover,
.mc-social-btn:focus {
  color: var(--mc-ed-primary);
  border-color: var(--mc-ed-primary);
}

.mc-main {
  padding-top: var(--mc-lit-m-96px);
}

.mc-dashboard-shell {
  max-width: var(--mc-lit-m-1120px);
  margin-inline: auto;
  gap: var(--mc-ed-space-5);
}

.mc-profile-shell {
  max-width: var(--mc-lit-m-980px);
  margin-inline: auto;
}

.mc-nav {
  background: color-mix(in srgb, var(--mc-ed-surface) 90%, transparent);
  border-bottom: var(--mc-lit-m-1px) solid var(--mc-ed-border);
  box-shadow: var(--mc-ed-shadow-1);
  backdrop-filter: blur(10px);
}

.mc-menu-btn,
.mc-logo-link,
.mc-nav-user,
.mc-dropdown-menu,
.dropdown-menu,
.modal-content {
  border-color: var(--mc-ed-border);
  background: var(--mc-ed-surface);
  color: var(--mc-ed-text);
}

.mc-nav-user__name,
.mc-brand-text,
.mc-nav-link,
.dropdown-item,
.mc-menu-line {
  color: var(--mc-ed-text);
}

.mc-nav-link:hover,
.mc-nav-link:focus,
.dropdown-item:hover,
.dropdown-item:focus {
  background: var(--mc-ed-surface-2);
  color: var(--mc-ed-text);
}

.mc-nav-menu .dropdown-item {
  font-family: var(--mc-ed-font-family);
  font-size: var(--mc-ed-type-3);
  font-weight: 500;
  line-height: var(--mc-lit-m-1_35);
  letter-spacing: var(--mc-lit-m-0_005em);
  padding: var(--mc-lit-m-8px) var(--mc-lit-m-12px);
}

.mc-nav-menu .dropdown-divider {
  margin: var(--mc-lit-m-6px) 0;
  border-top-color: var(--mc-ed-border);
}

/* Desktop inline nav */
.mc-nav-primary {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
}

.mc-nav-primary .mc-nav-link {
  font-weight: 500;
  padding: 8px 14px;
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: var(--mc-ed-type-3);
  color: var(--mc-ed-text-soft);
  text-decoration: none !important;
  white-space: nowrap;
  transition: background-color 0.16s ease, color 0.16s ease, border-color 0.16s ease;
}

.mc-nav-primary .mc-nav-link:hover,
.mc-nav-primary .mc-nav-link:focus {
  background: var(--mc-ed-surface-2);
  color: var(--mc-ed-text);
  text-decoration: none !important;
}

.mc-nav-primary .mc-nav-link.is-active {
  background: var(--mc-ed-surface-2);
  color: var(--mc-ed-text-strong);
  text-decoration: none !important;
}

.mc-nav-link i,
.mc-nav-menu .dropdown-item i {
  margin-right: 6px;
  font-size: 1em;
  vertical-align: -1px;
}

@media (max-width: 991.98px) {
  .mc-nav-primary .mc-nav-link {
    padding: 6px 8px;
    font-size: var(--mc-ed-type-2);
  }
}

.mc-auth-card,
.mc-profile-card,
.mc-profile-section,
.mc-inline-card,
.mc-route-panel,
.mc-ride-directions-panel,
.mc-dashboard-bio,
.mc-ride-map-wrapper,
.mc-route-builder-sidebar,
.mc-card,
.card,
.mcSection,
.mcCard,
.mcMock,
.mcQuote,
.mcDemoPanel,
.mcDemoMapMock,
.mcExploreDialog,
.mcExploreRideCard,
.mcRideRow,
.mcStatCard,
.accordion-item {
  border: 1px solid var(--mc-ed-border);
  background: var(--mc-ed-surface);
  box-shadow: var(--mc-ed-shadow-1);
  color: var(--mc-ed-text);
}

/* Login form + social blocks on hero: no panel, light copy for dark imagery */
.mc-auth-card.mc-auth-card--bare {
  background: transparent;
  border: none;
  box-shadow: none;
  color: #fff;
}

.mc-auth-card.mc-auth-card--bare .form-label,
.mc-auth-card.mc-auth-card--bare label {
  color: #fff;
}

.mc-auth-card.mc-auth-card--bare .text-secondary,
.mc-auth-card.mc-auth-card--bare .text-muted {
  color: rgba(255, 255, 255, 0.88);
}

.mc-auth-card.mc-auth-card--bare .mc-auth-actions a {
  color: rgba(255, 255, 255, 0.92);
}

.mc-auth-card.mc-auth-card--bare .mc-auth-actions a:hover {
  color: #fff;
}

.mc-auth-card,
.mc-profile-section,
.mc-inline-card,
.mcSection,
.mcCard,
.mcMock,
.mcQuote,
.accordion-item {
  border-radius: var(--mc-ed-radius-lg);
}

.accordion-button {
  color: var(--mc-ed-text);
  background: var(--mc-ed-surface);
}

.accordion-button:not(.collapsed) {
  color: var(--mc-ed-primary-ink);
  background: var(--mc-ed-primary-soft);
}

.btn {
  border-radius: var(--mc-ed-radius-sm);
  font-weight: 600;
  font-size: var(--mc-ed-type-3);
  letter-spacing: var(--mc-lit-m-0_01em);
  box-shadow: none;
  transition:
    box-shadow 0.16s ease,
    background-color 0.16s ease,
    border-color 0.16s ease;
}

.btn:focus-visible {
  box-shadow: var(--mc-ed-focus);
}

.btn-primary,
.mc-btn-gradient {
  border-color: var(--mc-ed-primary-strong);
  color: var(--mc-ed-on-primary);
  background: var(--mc-ed-primary);
  box-shadow: none;
}

.btn-primary:hover,
.btn-primary:focus,
.mc-btn-gradient:hover,
.mc-btn-gradient:focus {
  border-color: var(--mc-ed-primary-ink);
  background: var(--mc-ed-primary-strong);
  box-shadow: var(--mc-ed-shadow-1);
}

.btn-outline-secondary,
.mc-btn-outline {
  color: var(--mc-ed-text-soft);
  border-color: var(--mc-ed-border-strong);
  background: var(--mc-ed-surface-2);
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus,
.mc-btn-outline:hover,
.mc-btn-outline:focus {
  color: var(--mc-ed-text-strong);
  border-color: var(--mc-ed-border-active);
  background: var(--mc-ed-surface-3);
}

.mc-btn-danger {
  color: var(--mc-ed-on-danger);
  border-color: var(--mc-ed-danger-strong);
  background: var(--mc-ed-danger);
}

.mc-btn-muted {
  color: var(--mc-ed-muted-strong);
  border-color: var(--mc-ed-border);
  background: var(--mc-ed-surface-3);
}

.btn.mc-icon-btn {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  transform: none;
}

.btn.mc-icon-btn:hover,
.btn.mc-icon-btn:focus,
.btn.mc-icon-btn:focus-visible,
.btn.mc-icon-btn:active {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.mc-icon-btn.mc-btn-gradient {
  color: var(--mc-ed-primary);
}

.mc-icon-btn.mc-btn-outline {
  color: var(--mc-ed-text-soft);
}

.mc-icon-btn.mc-btn-danger {
  color: var(--mc-ed-danger);
}

.mc-icon-btn[disabled],
.mc-icon-btn.disabled {
  color: var(--mc-ed-muted-disabled);
  opacity: var(--mc-lit-m-0_6);
}

.form-control,
.form-select,
textarea.form-control,
input.form-control {
  border-radius: var(--mc-ed-radius-sm);
  border: 1px solid var(--mc-ed-border);
  color: var(--mc-ed-text);
  background: var(--mc-ed-surface);
}

.form-control::placeholder {
  color: var(--mc-ed-muted-disabled);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--mc-ed-focus-border);
  background: var(--mc-ed-surface);
  box-shadow: var(--mc-ed-focus);
}

.form-label,
label,
.table,
.table *,
.mc-inline-card__title,
.mc-profile-section__title,
.mcRideRow__name,
.mcStatValue,
.mcQuote__name {
  color: var(--mc-ed-text);
}

.mc-profile-section__title {
  font-family: var(--mc-ed-font-family);
  font-size: var(--mc-ed-type-section-title);
  font-weight: 700;
  line-height: var(--mc-lit-m-1_25);
  letter-spacing: var(--mc-lit-m-0_01em);
}

.mc-inline-card__title,
.mcCard h4,
.mcCard h5,
.mcCard h6,
.mcRideRow__name,
.mcExploreRideName,
.mcQuote__name,
.mcStatValue {
  font-family: var(--mc-ed-font-family);
  font-size: var(--mc-ed-type-card-title);
  font-weight: 600;
  line-height: var(--mc-lit-m-1_3);
  letter-spacing: var(--mc-lit-m-0_01em);
}

.mc-inline-card__subtitle,
.mcRideRow__meta,
.mcExploreRideMeta,
.mcQuote__text {
  font-family: var(--mc-ed-font-family);
  font-size: var(--mc-ed-type-2);
  font-weight: 500;
  line-height: var(--mc-lit-m-1_4);
}

.mc-status-chip,
.mc-inline-chip,
.mcPill,
.mcPillSmall,
.mcChip {
  border-color: var(--mc-ed-chip-border);
  background: var(--mc-ed-chip-bg);
  color: var(--mc-ed-text-soft);
}

.alert,
.mc-alert {
  border-color: var(--mc-ed-info-border);
  background: var(--mc-ed-info-bg);
  color: var(--mc-ed-info-text);
}

.mc-footer,
.mcFooter {
  border-top: var(--mc-lit-m-1px) solid var(--mc-ed-border);
}

.mc-profile-section__header {
  margin-bottom: var(--mc-ed-space-5);
  padding-bottom: var(--mc-ed-space-4);
  border-bottom: 1px solid var(--mc-ed-border);
}

.mc-profile-card {
  gap: var(--mc-ed-space-3);
}

.mc-profile-section {
  padding: var(--mc-ed-space-6);
}

.mc-profile-section__header--inline {
  align-items: flex-start;
  gap: var(--mc-ed-space-3);
}

.mc-profile-section__header--inline > * {
  min-width: var(--mc-lit-m-0);
}

.mc-profile-section__subtitle {
  font-size: var(--mc-ed-type-3);
}

.mc-explore-control span {
  color: var(--mc-ed-text-soft);
}

.mc-explore-control input,
.mc-explore-control select {
  border: 1px solid var(--mc-ed-border);
  background: var(--mc-ed-surface);
  color: var(--mc-ed-text);
}

.mc-list-stack {
  gap: var(--mc-ed-space-3);
}

.mc-inline-card--ride {
  border-color: var(--mc-ed-border);
  background: var(--mc-ed-surface);
  border-radius: var(--mc-ed-radius-md);
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.mc-inline-card--ride::before {
  width: var(--mc-lit-m-4px);
  background: var(--mc-ed-primary);
  opacity: 0.7;
}

.mc-list-stack--zebra .mc-inline-card--ride:nth-child(odd),
.mc-list-stack--zebra .mc-inline-card--ride:nth-child(even) {
  background: var(--mc-ed-surface);
}

.mc-inline-card--ride:hover {
  border-color: var(--mc-ed-primary);
  box-shadow: var(--mc-ed-shadow-2);
}

.mc-entity-card {
  flex: 1;
  min-width: var(--mc-lit-m-0);
  display: grid;
  gap: var(--mc-ed-space-2);
}

.mc-entity-card__title-row {
  display: flex;
  gap: var(--mc-ed-space-2);
  align-items: center;
  justify-content: space-between;
}

.mc-entity-card__route {
  color: var(--mc-ed-text-soft);
  font-size: var(--mc-ed-type-4);
  font-weight: 700;
}

.mc-entity-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mc-lit-m-6px);
}

.mc-chip {
  display: inline-flex;
  align-items: center;
  padding: var(--mc-lit-m-4px) var(--mc-lit-m-10px);
  border: 1px solid var(--mc-ed-chip-border);
  border-radius: var(--mc-lit-m-999px);
  background: var(--mc-ed-chip-bg);
  color: var(--mc-ed-text-soft);
  font-size: var(--mc-ed-type-1);
  font-weight: 500;
  line-height: var(--mc-lit-m-1_3);
}

.mc-chip--status {
  border-color: var(--mc-ed-chip-status-border);
  background: var(--mc-ed-chip-status-bg);
  color: var(--mc-ed-primary-strong);
}

.mc-chip--muted {
  border-color: var(--mc-ed-chip-muted-border);
  background: var(--mc-ed-chip-muted-bg);
  color: var(--mc-ed-muted);
}

.mc-entity-card__meta-row {
  color: var(--mc-ed-muted);
  font-size: var(--mc-ed-type-2);
  line-height: var(--mc-lit-m-1_35);
}

.mc-entity-card__label {
  color: var(--mc-ed-text-soft);
  font-weight: 700;
  margin-right: var(--mc-lit-m-4px);
}

.mc-entity-card__waypoints {
  display: grid;
  gap: 2px;
}

.mc-waypoint {
  display: flex;
  align-items: center;
  gap: var(--mc-lit-m-6px);
  color: var(--mc-ed-text-soft);
  font-size: var(--mc-ed-type-2);
}

.mc-waypoint i { font-size: 0.7rem; flex-shrink: 0; }

.mc-entity-card__host {
  color: var(--mc-ed-muted);
  font-size: var(--mc-ed-type-1);
  display: flex;
  align-items: center;
  gap: var(--mc-lit-m-4px);
}

.mc-entity-card__restriction {
  color: var(--mc-ed-warning, #c47b00);
  font-size: var(--mc-ed-type-1);
  display: flex;
  align-items: center;
  gap: var(--mc-lit-m-4px);
}

.mc-entity-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mc-lit-m-4px);
}

.mc-chip--tag {
  border-color: var(--mc-ed-primary-soft, var(--mc-ed-chip-border));
  background: var(--mc-ed-primary-soft, var(--mc-ed-chip-bg));
  color: var(--mc-ed-primary-strong);
  font-size: var(--mc-ed-type-1);
}

.mc-chip--exp {
  border-color: var(--mc-ed-chip-muted-border, var(--mc-ed-chip-border));
  background: var(--mc-ed-chip-muted-bg, var(--mc-ed-chip-bg));
  color: var(--mc-ed-text-soft);
  font-size: var(--mc-ed-type-1);
  text-transform: capitalize;
}

.mc-entity-card__detail {
  color: var(--mc-ed-muted);
  font-size: var(--mc-ed-type-1);
  display: flex;
  align-items: center;
  gap: var(--mc-lit-m-4px);
}

.mc-next-ride-date__dow {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.7;
}

.mc-entity-card__chips i {
  font-size: 0.7rem;
  margin-right: 2px;
}

.mc-rider-card {
  gap: var(--mc-ed-space-2);
}

.mc-inline-card--rider-contact {
  padding: var(--mc-ed-space-4) var(--mc-ed-space-5);
  border-radius: var(--mc-lit-m-10px);
  border-color: color-mix(in srgb, var(--mc-ed-border-active) 45%, var(--mc-ed-border));
  background: var(--mc-ed-surface);
}

.mc-inline-card--rider-contact::before {
  display: none;
}

.mc-inline-card--rider-contact:hover {
  transform: none;
  border-color: var(--mc-ed-border-active);
  box-shadow: var(--mc-ed-shadow-1);
}

.mc-rider-card--mobile {
  gap: var(--mc-lit-m-2px);
}

.mc-inline-card--rider-contact .mc-inline-card__title {
  margin-bottom: var(--mc-lit-m-2px);
  font-size: var(--mc-lit-m-0_875rem);
  line-height: var(--mc-lit-m-1_35);
}

.mc-rider-card__line {
  color: var(--mc-ed-text-soft);
  font-size: var(--mc-ed-type-2);
  line-height: var(--mc-lit-m-1_35);
}

.mc-rider-card__line-label {
  color: var(--mc-ed-text-strong);
  font-weight: 700;
}

.mc-rider-card__bio {
  color: var(--mc-ed-muted-strong);
  font-size: var(--mc-ed-type-3);
  line-height: var(--mc-lit-m-1_45);
}

.mc-rider-card__group {
  display: grid;
  gap: var(--mc-lit-m-4px);
}

.mc-rider-card__group-label {
  color: var(--mc-ed-text-soft);
  font-size: var(--mc-ed-type-1);
  font-weight: 700;
  letter-spacing: var(--mc-lit-m-0_02em);
  text-transform: capitalize;
}

.table {
  --bs-table-bg: var(--mc-ed-surface);
  --bs-table-color: var(--mc-ed-text);
  --bs-table-border-color: var(--mc-ed-border);
  --bs-table-striped-bg: var(--mc-ed-surface-2);
  --bs-table-striped-color: var(--mc-ed-text);
  --bs-table-hover-bg: var(--mc-ed-primary-soft);
  --bs-table-hover-color: var(--mc-ed-text);
}

.table thead th {
  color: var(--mc-ed-text-soft);
  font-size: var(--mc-ed-type-2);
  font-weight: 700;
  letter-spacing: var(--mc-lit-m-0_01em);
  text-transform: capitalize;
  border-bottom-width: var(--mc-lit-m-1px);
}

.table tbody td,
.table tbody th {
  padding-top: var(--mc-ed-space-2);
  padding-bottom: var(--mc-ed-space-2);
  vertical-align: middle;
}

.form-check-input {
  border-color: var(--mc-ed-border-strong);
  background-color: var(--mc-ed-surface);
}

.form-check-input:focus {
  border-color: var(--mc-ed-focus-border);
  box-shadow: var(--mc-ed-focus);
}

.form-check-input:checked {
  border-color: var(--mc-ed-primary);
  background-color: var(--mc-ed-primary);
}

.nav-tabs {
  border-bottom-color: var(--mc-ed-border);
}

.nav-tabs .nav-link {
  color: var(--mc-ed-text-soft);
  border-color: transparent;
  border-radius: var(--mc-ed-radius-sm) var(--mc-ed-radius-sm) 0 0;
}

.nav-tabs .nav-link:hover,
.nav-tabs .nav-link:focus {
  color: var(--mc-ed-text);
  background: var(--mc-ed-surface-2);
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
  color: var(--mc-ed-primary-ink);
  border-color: var(--mc-ed-border) var(--mc-ed-border) transparent;
  background: var(--mc-ed-surface);
}

.nav-pills .nav-link {
  color: var(--mc-ed-text-soft);
  border-radius: var(--mc-lit-m-999px);
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  color: var(--mc-ed-on-primary);
  background: var(--mc-ed-primary);
}

.mc-inline-card--ride .mc-ride-point-actions {
  margin-top: var(--mc-lit-m-0);
  margin-left: auto;
  align-self: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.mc-ride-point-actions {
  gap: var(--mc-ed-space-2);
  align-items: center;
}

.mc-pagination-controls {
  justify-content: center;
}

.mc-btn-sm {
  font-size: var(--mc-ed-type-2);
  line-height: var(--mc-lit-m-1_25);
  padding: var(--mc-lit-m-6px) var(--mc-lit-m-11px);
}

.mc-icon-btn {
  width: var(--mc-lit-m-32px);
  height: var(--mc-lit-m-32px);
  padding: var(--mc-lit-m-0);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.mc-icon-btn .bi {
  font-size: var(--mc-lit-m-0_95rem);
  line-height: var(--mc-lit-m-1);
}

.mc-inline-card {
  transition:
    border-color 0.16s ease,
    box-shadow 0.16s ease;
}

.mc-inline-card:hover,
.mc-inline-card:focus-within {
  border-color: var(--mc-ed-border-active);
  box-shadow: var(--mc-ed-shadow-1);
}

.mc-empty-state {
  display: grid;
  gap: var(--mc-ed-space-2);
  border: 1px dashed var(--mc-ed-border-strong);
  border-radius: var(--mc-ed-radius-md);
  padding: var(--mc-ed-space-4);
  background: var(--mc-ed-surface-highlight);
}

.mc-empty-state__title {
  color: var(--mc-ed-text);
  font-size: var(--mc-ed-type-5);
  font-weight: 700;
  line-height: var(--mc-lit-m-1_3);
}

.mc-empty-state__body {
  color: var(--mc-ed-muted);
  font-size: var(--mc-ed-type-3);
}

.mc-empty-state__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mc-ed-space-2);
}

.mc-empty-state--compact {
  padding: var(--mc-ed-space-3);
  background: var(--mc-ed-surface);
}

.mc-empty-state--compact .mc-empty-state__title {
  font-size: var(--mc-ed-type-4);
}

.mc-empty-state--compact .mc-empty-state__body {
  font-size: var(--mc-ed-type-2);
}

.mc-explore-mode-btn {
  background: var(--mc-ed-surface-2);
  border-color: var(--mc-ed-border);
  color: var(--mc-ed-primary-2);
}

.mc-explore-mode-btn--active {
  background: var(--mc-ed-primary);
  border-color: var(--mc-ed-primary);
  color: var(--mc-ed-surface);
}

.mc-explore-mode-btn:not(.mc-explore-mode-btn--active):hover {
  border-color: var(--mc-ed-primary-2);
  color: var(--mc-ed-text);
}

.mc-explore-map-wrap {
  border-color: var(--mc-ed-border);
}

.mc-explore-map {
  background: var(--mc-ed-surface);
}

.mc-explore-map-zoom {
  background: var(--mc-ed-surface-2);
  color: var(--mc-ed-text);
  border: 1px solid var(--mc-ed-border);
}

.mc-explore-map-zoom:hover {
  background: var(--mc-ed-surface-highlight);
}

.mc-explore-preview__card {
  background: var(--mc-ed-surface-2);
  border-color: var(--mc-ed-border);
}

.mc-explore-preview__title {
  color: var(--mc-ed-text);
}

.mc-explore-preview__close {
  color: var(--mc-ed-muted);
}

.mc-explore-preview__close:hover {
  color: var(--mc-ed-text);
}

@media (prefers-reduced-motion: reduce) {
  .btn,
  .mc-inline-card,
  .mc-inline-card--ride {
    transition: none;
  }

  .mc-skeleton-line,
  .mc-skeleton-dot {
    animation: none;
    background-position: 0 0;
  }
}

@media (max-width: var(--mc-lit-m-991px)) {
  .mc-profile-section__header--inline {
    flex-direction: column;
    align-items: stretch;
  }

  .mc-profile-section__header--inline .mc-ride-point-actions {
    width: var(--mc-lit-m-100pct);
    justify-content: flex-start;
  }
}

@media (max-width: var(--mc-lit-m-767px)) {
  .mc-main {
    padding-bottom: calc(var(--mc-ed-space-4) + env(safe-area-inset-bottom));
  }

  .mc-inline-card--ride {
    flex-direction: column;
    align-items: stretch;
  }

  .mc-inline-card--ride .mc-ride-point-actions {
    width: var(--mc-lit-m-100pct);
    justify-content: flex-start;
  }
}

/* ---------- dark-mode body / nav / typography ---------- */
[data-mc-theme="dark"] .mc-body {
  color: var(--mc-ed-text);
  background:
    radial-gradient(1200px 600px at 10% -10%, var(--mc-lit-c-rgba-30-129-176-0-3), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, var(--mc-lit-c-rgba-255-107-0-0-2), transparent 55%),
    var(--mc-ed-bg);
}

[data-mc-theme="dark"] .mc-nav {
  background: var(--mc-lit-c-rgba-10-15-28-0-7);
  border-bottom-color: var(--mc-ed-border);
  box-shadow: 0 1px 0 var(--mc-ed-border);
}

[data-mc-theme="dark"] .mc-menu-btn,
[data-mc-theme="dark"] .mc-logo-link {
  border-color: var(--mc-ed-border-strong);
  background: var(--mc-lit-c-rgba-15-23-42-0-82);
}

[data-mc-theme="dark"] .mc-nav-user {
  border-color: var(--mc-ed-border-strong);
  background: var(--mc-lit-c-rgba-15-23-42-0-72);
}

[data-mc-theme="dark"] .mc-nav-user__name,
[data-mc-theme="dark"] .mc-brand-text,
[data-mc-theme="dark"] .mc-menu-line {
  color: var(--mc-ed-text);
}

[data-mc-theme="dark"] .mc-dropdown-menu,
[data-mc-theme="dark"] .dropdown-menu {
  border-color: var(--mc-ed-border);
  background: var(--mc-lit-c-rgba-15-23-42-0-96);
  color: var(--mc-ed-text);
}

[data-mc-theme="dark"] .dropdown-item {
  color: var(--mc-ed-text);
}

[data-mc-theme="dark"] .dropdown-item:hover,
[data-mc-theme="dark"] .dropdown-item:focus {
  color: var(--mc-ed-text-strong);
  background: var(--mc-ed-surface-2);
}

[data-mc-theme="dark"] .dropdown-divider {
  border-top-color: var(--mc-ed-border);
}

[data-mc-theme="dark"] h1,
[data-mc-theme="dark"] h2,
[data-mc-theme="dark"] h3,
[data-mc-theme="dark"] h4,
[data-mc-theme="dark"] h5,
[data-mc-theme="dark"] h6 {
  color: var(--mc-ed-text);
}

[data-mc-theme="dark"] a {
  color: var(--mc-ed-primary);
}

[data-mc-theme="dark"] a:hover,
[data-mc-theme="dark"] a:focus {
  color: var(--mc-ed-primary-ink);
}

[data-mc-theme="dark"] .mc-nav-signup,
[data-mc-theme="dark"] .mc-nav-signup:hover,
[data-mc-theme="dark"] .mc-nav-signup:focus {
  color: var(--mc-ed-on-primary);
}

[data-mc-theme="dark"] .mc-social-btn {
  background: var(--mc-ed-surface-2);
  border-color: var(--mc-ed-border);
  color: var(--mc-ed-text-soft);
}

[data-mc-theme="dark"] .mc-social-btn:hover,
[data-mc-theme="dark"] .mc-social-btn:focus {
  color: var(--mc-ed-primary);
  border-color: var(--mc-ed-primary);
}

[data-mc-theme="dark"] .mc-auth-card,
[data-mc-theme="dark"] .mc-profile-card,
[data-mc-theme="dark"] .mc-profile-section,
[data-mc-theme="dark"] .mc-inline-card,
[data-mc-theme="dark"] .mc-route-panel,
[data-mc-theme="dark"] .mc-card,
[data-mc-theme="dark"] .card,
[data-mc-theme="dark"] .mcSection,
[data-mc-theme="dark"] .mcCard,
[data-mc-theme="dark"] .mcQuote,
[data-mc-theme="dark"] .accordion-item {
  border-color: var(--mc-ed-border);
  background: var(--mc-ed-surface);
  box-shadow: var(--mc-ed-shadow-1);
  color: var(--mc-ed-text);
}

[data-mc-theme="dark"] .mc-auth-card.mc-auth-card--bare {
  background: transparent;
  border: none;
  box-shadow: none;
  color: #fff;
}

[data-mc-theme="dark"] .modal-content {
  border-color: var(--mc-ed-border);
  background: var(--mc-ed-bg);
  color: var(--mc-ed-text);
}

[data-mc-theme="dark"] .modal-header {
  border-bottom-color: var(--mc-ed-border);
}

[data-mc-theme="dark"] .modal-footer {
  border-top-color: var(--mc-ed-border);
}

[data-mc-theme="dark"] .btn-primary,
[data-mc-theme="dark"] .mc-btn-gradient {
  border-color: var(--mc-ed-primary-strong);
  color: var(--mc-ed-on-primary);
  background: var(--mc-ed-primary);
  box-shadow: var(--mc-ed-shadow-primary);
}

[data-mc-theme="dark"] .btn-outline-secondary,
[data-mc-theme="dark"] .mc-btn-outline {
  color: var(--mc-ed-text-soft);
  border-color: var(--mc-ed-border-strong);
  background: var(--mc-ed-surface-2);
}

[data-mc-theme="dark"] .mc-btn-danger {
  color: var(--mc-ed-on-danger);
  border-color: var(--mc-ed-danger-strong);
  background: var(--mc-ed-danger);
}

[data-mc-theme="dark"] .mc-btn-muted {
  color: var(--mc-ed-muted);
  border-color: var(--mc-ed-border);
  background: var(--mc-ed-surface-2);
}

[data-mc-theme="dark"] .form-control,
[data-mc-theme="dark"] .form-select,
[data-mc-theme="dark"] textarea.form-control,
[data-mc-theme="dark"] input.form-control {
  border-color: var(--mc-ed-border);
  color: var(--mc-ed-text);
  background: var(--mc-ed-surface);
}

[data-mc-theme="dark"] .form-control:focus,
[data-mc-theme="dark"] .form-select:focus {
  border-color: var(--mc-ed-focus-border);
  box-shadow: var(--mc-ed-focus);
}

[data-mc-theme="dark"] .form-control::placeholder {
  color: var(--mc-ed-muted-disabled);
}

[data-mc-theme="dark"] .form-label,
[data-mc-theme="dark"] label {
  color: var(--mc-ed-text);
}

[data-mc-theme="dark"] .form-check-input {
  border-color: var(--mc-ed-border-strong);
  background-color: var(--mc-ed-surface);
}

[data-mc-theme="dark"] .form-check-input:checked {
  border-color: var(--mc-ed-primary);
  background-color: var(--mc-ed-primary);
}

[data-mc-theme="dark"] .accordion-button {
  color: var(--mc-ed-text);
  background: var(--mc-ed-surface);
}

[data-mc-theme="dark"] .accordion-button:not(.collapsed) {
  color: var(--mc-ed-primary-ink);
  background: var(--mc-ed-primary-soft);
}

[data-mc-theme="dark"] .accordion-button::after {
  filter: invert(1);
}

[data-mc-theme="dark"] .mc-explore-toolbar {
  border-color: var(--mc-ed-border);
  background: var(--mc-lit-c-rgba-15-23-42-0-85);
  box-shadow: var(--mc-ed-shadow-1);
  backdrop-filter: blur(12px);
}

[data-mc-theme="dark"] .mc-explore-map .leaflet-tile-pane {
  filter: brightness(0.7) contrast(1.1) saturate(0.8);
}

[data-mc-theme="dark"] .mc-explore-map .leaflet-control-attribution {
  background: var(--mc-ed-surface-2) !important;
  color: var(--mc-ed-muted) !important;
}

[data-mc-theme="dark"] .mc-explore-map .leaflet-control-attribution a {
  color: var(--mc-ed-primary-2) !important;
}

[data-mc-theme="dark"] .table {
  --bs-table-bg: var(--mc-ed-surface);
  --bs-table-color: var(--mc-ed-text);
  --bs-table-border-color: var(--mc-ed-border);
  --bs-table-striped-bg: var(--mc-ed-surface-2);
  --bs-table-hover-bg: var(--mc-ed-primary-soft);
}

[data-mc-theme="dark"] .nav-tabs {
  border-bottom-color: var(--mc-ed-border);
}

[data-mc-theme="dark"] .nav-tabs .nav-link {
  color: var(--mc-ed-text-soft);
}

[data-mc-theme="dark"] .nav-tabs .nav-link.active {
  color: var(--mc-ed-primary-ink);
  border-color: var(--mc-ed-border) var(--mc-ed-border) transparent;
  background: var(--mc-ed-surface);
}

[data-mc-theme="dark"] .mc-alert,
[data-mc-theme="dark"] .alert {
  border-color: var(--mc-ed-info-border);
  background: var(--mc-ed-info-bg);
  color: var(--mc-ed-info-text);
}

[data-mc-theme="dark"] .mc-inline-card--ride:hover {
  border-color: var(--mc-ed-primary);
}

[data-mc-theme="dark"] .mc-confirm-modal__target {
  color: var(--mc-ed-text-strong);
}

/* skeleton pulse — dark palette */
[data-mc-theme="dark"] .mc-skeleton-line {
  background: linear-gradient(90deg, var(--mc-lit-c-1e293b) 0%, var(--mc-lit-c-334155) 35%, var(--mc-lit-c-1e293b) 70%);
  background-size: 220% 100%;
}

[data-mc-theme="dark"] .mc-skeleton-dot {
  background: linear-gradient(90deg, var(--mc-lit-c-1e293b) 0%, var(--mc-lit-c-334155) 35%, var(--mc-lit-c-1e293b) 70%);
  background-size: 220% 100%;
}

/* ---------- theme toggle button ---------- */
.mc-theme-toggle {
  width: var(--mc-lit-m-36px);
  height: var(--mc-lit-m-36px);
  border-radius: var(--mc-lit-m-10px);
  border: 1px solid var(--mc-ed-border-strong);
  background: var(--mc-ed-surface-2);
  color: var(--mc-ed-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color 0.16s ease, background-color 0.16s ease, transform 0.16s ease;
  padding: var(--mc-lit-m-0);
  font-size: var(--mc-lit-m-1_1rem);
  line-height: 1;
  flex-shrink: 0;
}

.mc-theme-toggle:hover,
.mc-theme-toggle:focus-visible {
  border-color: var(--mc-ed-primary);
  background: var(--mc-ed-primary-soft);
  transform: scale(1.05);
}

.mc-theme-toggle:focus-visible {
  outline: none;
  box-shadow: var(--mc-ed-focus);
}

.mc-theme-toggle .bi-sun-fill { display: none; }
.mc-theme-toggle .bi-moon-stars-fill { display: inline; }

[data-mc-theme="dark"] .mc-theme-toggle .bi-sun-fill { display: inline; }
[data-mc-theme="dark"] .mc-theme-toggle .bi-moon-stars-fill { display: none; }

/* ================================================================
   Priority 3: Micro-interactions & Transitions
   ================================================================ */

/* button press scale */
.btn:active:not(:disabled) {
  transform: scale(0.97);
}

/* card hover elevation — applies to all card-like elements */
.mc-auth-card,
.mc-profile-section,
.mc-inline-card {
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}

/* page entry fade-in */
@keyframes mcFadeInUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.mc-main {
  animation: mcFadeInUp 0.35s ease-out;
}

/* smooth scroll */
html {
  scroll-behavior: smooth;
}

/* ================================================================
   Priority 5: Enhanced Skeleton Loaders
   ================================================================ */

.mc-skeleton-card--wide {
  grid-template-columns: 1fr;
}

.mc-skeleton-card--row {
  display: flex;
  gap: var(--mc-ed-space-3);
  align-items: center;
}

.mc-skeleton-avatar {
  width: var(--mc-lit-m-40px);
  height: var(--mc-lit-m-40px);
  border-radius: var(--mc-lit-m-999px);
  flex-shrink: 0;
  background: linear-gradient(90deg, var(--mc-lit-c-eef3fa) 0%, var(--mc-lit-c-f6f9fd) 35%, var(--mc-lit-c-eef3fa) 70%);
  background-size: 220% 100%;
  animation: mcSkeletonPulse 1.35s ease-in-out infinite;
}

[data-mc-theme="dark"] .mc-skeleton-avatar {
  background: linear-gradient(90deg, var(--mc-lit-c-1e293b) 0%, var(--mc-lit-c-334155) 35%, var(--mc-lit-c-1e293b) 70%);
  background-size: 220% 100%;
}

/* ================================================================
   Priority 6: Accessibility
   ================================================================ */

/* skip-to-content link */
.mc-skip-link {
  position: absolute;
  top: -100%;
  left: var(--mc-lit-m-16px);
  z-index: 10000;
  padding: var(--mc-lit-m-8px) var(--mc-lit-m-16px);
  border-radius: var(--mc-ed-radius-sm);
  background: var(--mc-ed-primary);
  color: var(--mc-ed-on-primary);
  font-weight: 700;
  font-size: var(--mc-lit-m-0_9rem);
  text-decoration: none;
  transition: top 0.2s ease;
}

.mc-skip-link:focus {
  top: var(--mc-lit-m-8px);
  outline: var(--mc-lit-m-2px) solid var(--mc-ed-focus-border);
  outline-offset: var(--mc-lit-m-2px);
}

/* enhanced focus-visible for all interactive elements */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: var(--mc-lit-m-2px) solid var(--mc-ed-focus-border);
  outline-offset: var(--mc-lit-m-2px);
}

/* ================================================================
   Card keyboard focus outlines
   ================================================================ */

.mc-ridehub-ride-card:focus-visible,
.mc-inline-card--ride:focus-visible,
.mc-rider-card:focus-visible {
  outline: var(--mc-lit-m-2px) solid var(--mc-ed-focus-border);
  outline-offset: var(--mc-lit-m-2px);
  border-color: var(--mc-ed-primary);
}

/* ================================================================
   Toast notification queue
   ================================================================ */

.mc-toast-container {
  position: fixed;
  top: var(--mc-lit-m-80px);
  right: var(--mc-lit-m-16px);
  z-index: 10100;
  display: flex;
  flex-direction: column;
  gap: var(--mc-lit-m-8px);
  max-width: var(--mc-lit-m-380px);
  pointer-events: none;
}

.mc-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--mc-lit-m-8px);
  padding: var(--mc-lit-m-10px) var(--mc-lit-m-14px);
  border-radius: var(--mc-ed-radius-sm);
  border: 1px solid var(--mc-ed-border);
  border-left: var(--mc-lit-m-4px) solid var(--mc-ed-primary);
  background: var(--mc-ed-surface);
  color: var(--mc-ed-text);
  font-size: var(--mc-ed-type-3);
  font-weight: 600;
  box-shadow: var(--mc-ed-shadow-2);
  pointer-events: auto;
  animation: mcToastIn 0.28s ease-out;
}

.mc-toast--success { border-left-color: var(--mc-ed-success); }
.mc-toast--error { border-left-color: var(--mc-ed-danger); }
.mc-toast--warning { border-left-color: var(--mc-ed-danger-accent); }
.mc-toast--info { border-left-color: var(--mc-ed-primary); }

.mc-toast__text {
  flex: 1;
  min-width: 0;
}

.mc-toast__close {
  flex-shrink: 0;
  background: none;
  border: none;
  color: var(--mc-ed-muted);
  font-size: var(--mc-lit-m-1_1rem);
  line-height: 1;
  cursor: pointer;
  padding: var(--mc-lit-m-0) var(--mc-lit-m-2px);
}

.mc-toast__close:hover {
  color: var(--mc-ed-text);
}

.mc-toast--exit {
  animation: mcToastOut 0.26s ease-in forwards;
}

@keyframes mcToastIn {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes mcToastOut {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(20px); }
}

/* ================================================================
   Form validation UX
   ================================================================ */

[x-cloak] { display: none; }

.mc-validation-bar {
  height: var(--mc-lit-m-4px);
  border-radius: var(--mc-lit-m-2px);
  margin-top: var(--mc-lit-m-6px);
  transition: width 0.3s ease, background-color 0.3s ease;
}

.mc-strength--weak { background-color: var(--mc-ed-danger); width: 25%; }
.mc-strength--fair { background-color: var(--mc-ed-danger-accent); width: 50%; }
.mc-strength--good { background-color: var(--mc-ed-primary); width: 75%; }
.mc-strength--strong { background-color: var(--mc-ed-success); width: 100%; }

/* ================================================================
   Priority 8: Responsive improvements
   ================================================================ */

/* responsive table wrapper */
.mc-table-responsive {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ensure minimum touch target size */
@media (pointer: coarse) {
  .btn,
  .mc-icon-btn,
  .dropdown-item,
  .nav-link,
  .mc-filter-chip,
  .mc-saved-view-chip {
    min-height: var(--mc-lit-m-44px);
    min-width: var(--mc-lit-m-44px);
  }
}

/* improved mobile spacing */
@media (max-width: 575px) {
  .mc-main {
    padding-left: var(--mc-lit-m-12px);
    padding-right: var(--mc-lit-m-12px);
  }

  .mc-profile-section {
    padding: var(--mc-lit-m-12px);
  }

  .mc-profile-section__title {
    font-size: var(--mc-lit-m-1rem);
  }

  .mc-entity-card__chips {
    gap: var(--mc-lit-m-4px);
  }

  .mc-chip {
    font-size: var(--mc-lit-m-0_68rem);
    padding: var(--mc-lit-m-2px) var(--mc-lit-m-7px);
  }
}

/* ================================================================
   Priority 10: Performance — content-visibility for below-fold
   ================================================================ */

.mc-content-lazy {
  content-visibility: auto;
  contain-intrinsic-size: auto 400px;
}

/* ================================================================
   Priority 9: Alpine.js transition utilities
   ================================================================ */

.transition { transition-property: all; transition-timing-function: ease; transition-duration: 0.2s; }
.ease-in { transition-timing-function: ease-in; }
.ease-out { transition-timing-function: ease-out; }
.duration-200 { transition-duration: 200ms; }
.duration-300 { transition-duration: 300ms; }
.opacity-0 { opacity: 0; }
.opacity-100 { opacity: 1; }
.transform { transform: translateZ(0); }
.translate-y-0 { transform: translateY(0); }
.-translate-y-1 { transform: translateY(-4px); }

/* reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
  .mc-main {
    animation: none;
  }

  html {
    scroll-behavior: auto;
  }

  .mc-theme-toggle {
    transition: none;
  }
}
/* ================================================================
   Print Stylesheet
   ================================================================ */

@media print {
  :root,
  [data-mc-theme="dark"] {
    --mc-ed-bg: var(--mc-lit-c-f6f8fb);
    --mc-ed-bg-2: var(--mc-lit-c-eef2f8);
    --mc-ed-surface: var(--mc-lit-c-ffffff);
    --mc-ed-surface-2: var(--mc-lit-c-f3f6fb);
    --mc-ed-surface-3: var(--mc-lit-c-eef2f7);
    --mc-ed-surface-highlight: var(--mc-lit-c-f8fbff);
    --mc-ed-text: var(--mc-lit-c-111827);
    --mc-ed-text-strong: var(--mc-lit-c-1f2937);
    --mc-ed-text-soft: var(--mc-lit-c-334155);
    --mc-ed-muted: var(--mc-lit-c-64748b);
    --mc-ed-muted-strong: var(--mc-lit-c-475569);
    --mc-ed-muted-disabled: var(--mc-lit-c-94a3b8);
    --mc-ed-border: var(--mc-lit-c-d8e0eb);
    --mc-ed-border-strong: var(--mc-lit-c-c3cfdd);
    --mc-ed-border-active: var(--mc-lit-c-a7b6c9);
    --mc-ed-primary: var(--mc-lit-c-4f46e5);
    --mc-ed-primary-strong: var(--mc-lit-c-4338ca);
    --mc-ed-primary-ink: var(--mc-lit-c-312e81);
    --mc-ed-primary-2: var(--mc-lit-c-0ea5e9);
    --mc-ed-primary-soft: var(--mc-lit-c-e9edff);
    --mc-ed-focus-border: var(--mc-lit-c-8b92f5);
    --mc-ed-on-primary: var(--mc-lit-c-ffffff);
    --mc-ed-danger: var(--mc-lit-c-dc2626);
    --mc-ed-danger-strong: var(--mc-lit-c-b91c1c);
    --mc-ed-danger-accent: var(--mc-lit-c-f97316);
    --mc-ed-on-danger: var(--mc-lit-c-ffffff);
    --mc-ed-danger-soft: var(--mc-lit-c-fee2e2);
    --mc-ed-danger-soft-bg: var(--mc-lit-c-fff7f7);
    --mc-ed-success: var(--mc-lit-c-059669);
    --mc-ed-info-border: var(--mc-lit-c-bfdbfe);
    --mc-ed-info-bg: var(--mc-lit-c-eff6ff);
    --mc-ed-info-text: var(--mc-lit-c-1e3a8a);
    --mc-ed-chip-border: var(--mc-lit-c-cfdaea);
    --mc-ed-chip-bg: var(--mc-lit-c-eff5ff);
    --mc-ed-chip-status-border: var(--mc-lit-c-c7d2fe);
    --mc-ed-chip-status-bg: var(--mc-lit-c-e8ecff);
    --mc-ed-chip-muted-border: var(--mc-lit-c-dbe4ef);
    --mc-ed-chip-muted-bg: var(--mc-lit-c-f6f8fc);
  }

  .mc-nav,
  .mc-theme-toggle,
  .mc-skip-link,
  .mc-flash-stack,
  .mc-toast-container,
  .mc-explore-toolbar,
  .mc-pagination-controls,
  .mc-ride-point-actions,
  .mc-view-bottom,
  .mc-empty-state__actions,
  .modal,
  .modal-backdrop,
  .btn,
  button {
    display: none;
  }

  body,
  .mc-body {
    background: var(--mc-lit-c-ffffff);
    color: var(--mc-lit-c-0f172a);
  }

  .mc-main {
    padding-top: 0;
    animation: none;
  }

  .mc-auth-card,
  .mc-profile-section,
  .mc-inline-card,
  .mc-card,
  .card {
    border: 1px solid var(--mc-ed-border);
    box-shadow: none;
    page-break-inside: avoid;
  }

  a[href]::after {
    content: " (" attr(href) ")";
    font-size: var(--mc-lit-m-0_8rem);
    color: var(--mc-ed-muted);
  }

  a[href^="#"]::after,
  a[href^="javascript:"]::after {
    content: "";
  }
}

.mc-next-ride-date { background: var(--mc-ed-primary-soft); color: var(--mc-ed-primary-strong); }
.mc-next-ride-card { border-left: 4px solid var(--mc-ed-primary); }
.mc-dashboard-banner .mc-profile-section__subtitle i { color: var(--mc-ed-primary); margin-right: 4px; }
.mc-rider-card__stars { color: var(--mc-ed-warning, #f59e0b); }
} /* end @layer components */
