  ﻿/* Apply -2em top spacing only inside the fyr-about component */
.fyr-about.spacing-top {
  margin-top: -1em;
}

/* ===== Weekend Programs / Deadlines Comparison (Foundation-friendly, no CSS Grid) ===== */

/* Base wrapper aligns to your existing 12-col container */
.cmp-wrap {
  width: 100%;
  max-width: 100%;
}

/* -------- Desktop / Table-like view (medium & up) -------- */
.cmp-table {
  display: table;
  width: 100%;
  border-collapse: collapse; /* remove extra spacing */
}

.cmp-row {
  display: table-row;
}

.cmp-cell {
  display: table-cell;
  padding: 0.875rem 1rem;
  vertical-align: top;
  line-height: 1.4;
  border-top: 1px solid #d9d9d9; /* horizontal dividers only */
}

.cmp-row .cmp-cell:first-child { border-left: none; }
.cmp-row .cmp-cell:last-child  { border-right: none; }

/* Header row styling (desktop only) */
@media screen and (min-width: 641px) {
  .cmp-header .cmp-cell {
    background-color: #041e42;
    color: #ffffff;
    border-top: none;
  }

  /* Larger header font */
  .cmp-header .cmp-cell.large-body {
    font-size: 1.1rem;
  }
}

/* Alternating row backgrounds */
.cmp-row:nth-child(odd):not(.cmp-header) .cmp-cell { background-color: #ffffff; }
.cmp-row:nth-child(even):not(.cmp-header) .cmp-cell { background-color: #efefef; }

.cmp-row:last-child .cmp-cell { border-bottom: none; }

.cmp-col-feature { width: 28%; }

.cmp-cell { color: #000000; }

/* -------- Base styles for HOW TO APPLY cards (all viewports) -------- */

.apply-card {
  border: 1px solid #dcdcdc;
  border-radius: 8px;
  margin-bottom: 1.25rem;
  background: #ffffff;
  padding: 1.25rem 1.5rem;
}

.apply-card .apply-icon {
  width: 40px;
  height: auto;
}

.apply-card h3,
.apply-card h4 {
  margin-top: 0;
  margin-bottom: 0.75rem;
  line-height: 1.25;
}

.apply-card .apply-body {
  margin: 0;
}

.apply-card p,
.apply-card ul,
.apply-card .small-body-copy {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

.apply-card .why-label {
  font-weight: 700;
  display: block;
  margin-top: 1rem;
  margin-bottom: 0.25rem;
}

/* -------- Mobile Cards (small only) -------- */
.cmp-cards { display: none; }

@media screen and (max-width: 640px) {
  .cmp-table { display: none; }
  .cmp-cards { display: block; }

  .cmp-card {
    border: 1px solid #e3e3e3;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 1rem;
    background: #ffffff;
    padding: 0; /* no side padding so stripes can go full width */
  }

  /* Full-width colored header */
  .cmp-card-title {
    margin: 0;
    padding: 0.75rem 1.25rem;
    background: #041e42;
    color: #ffffff;
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.2;
    text-align: left;
  }

  .cmp-card-body {
    margin: 0;
    padding: 0;
    list-style: none;
  }

  /* Each milestone row */
  .cmp-item {
    margin: 0;
    padding: 0;
    border-top: 1px solid #e9e9e9;
    background: #ffffff; /* base */
  }

  .cmp-item:first-child {
    border-top: none;
  }

  /* Zebra striping per card: full-width */
  .cmp-card-body .cmp-item:nth-child(even) {
    background: #f5f5f5;
  }

  .cmp-term,
  .cmp-def {
    display: block;
    margin: 0;
    padding: 0.75rem 1.25rem; /* side padding for text */
    line-height: 1.35;
    color: #000000;
    background: transparent; /* let li background show through */
  }

  .cmp-term {
    border-bottom: 1px solid #efefef;
  }

  .cmp-def {
    font-weight: 600;
    border-bottom: none;
  }

  /* -------- HOW TO APPLY cards — mobile tweaks -------- */

  .apply-card {
    padding: 1.25rem 1.5rem 1.5rem;
  }

  .apply-card .apply-icon {
    display: block;
    margin: 0 auto 0.75rem auto; /* center the icon above heading */
  }

  .apply-card h3,
  .apply-card h4 {
    text-align: center; /* center step title under icon */
  }

  .apply-card .apply-body {
    text-align: left;
  }

  .apply-card p,
  .apply-card ul,
  .apply-card .small-body-copy {
    padding-left: 0.25rem;
    padding-right: 0.25rem; /* keep text away from card edge */
  }
}

/* -------- Accessibility helpers -------- */
.show-for-sr {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  border: 0 !important;
}

/* Row hover highlight for tables */
.cmp-table .cmp-row:not(.cmp-header):hover .cmp-cell {
  background-color: #eef2f6;
}

.cmp-icon {
  width: 40px;
  height: auto;
  margin-right: 0.5rem;
  vertical-align: middle;
}

/* Icon + label alignment in desktop Step column */
.step-label {
  display: inline-flex;
  align-items: flex-start;
}

.step-label .img {
  flex: 0 0 auto;
  margin-right: 0.75rem;
}

/* ================================
   DEADLINES TABLE ONLY (tighter dates)
   ================================ */

@media screen and (min-width: 641px) {
  /* Add class "cmp-table--deadlines" to the deadlines table only */
  .cmp-table--deadlines .cmp-col-feature {
    width: 48%;
    max-width: 52%;
  }

  .cmp-table--deadlines .cmp-row > .cmp-cell:nth-child(2),
  .cmp-table--deadlines .cmp-row > .cmp-cell:nth-child(3) {
    width: 26%;
  }
}
