:root {
  --ftcc-gold: #f0b82d;
  --ftcc-black: #000000;
  --ftcc-white: #ffffff;
  --ftcc-slate: #53565a;
  --ftcc-silver: #e2e1dd;
  --ftcc-blue: #4298b5;
  --ftcc-success: #2b7d4b;
  --ftcc-warning: #9b6500;
  --ftcc-danger: #a93535;
  --font-sans: "Source Sans 3", Arial, sans-serif;
  --font-serif: "Source Serif 4", Georgia, serif;
  --ftcc-text: #111111;
  --ftcc-muted: var(--ftcc-slate);
  --ftcc-ink: var(--ftcc-text);
  --ftcc-ink-soft: var(--ftcc-muted);
  --ftcc-line: var(--ftcc-border);
  --ftcc-sand: var(--ftcc-surface-soft);
  --ftcc-surface: #ffffff;
  --ftcc-surface-soft: #f7f6f3;
  --ftcc-surface-muted: #f1f0ec;
  --ftcc-panel: var(--ftcc-surface);
  --ftcc-panel-strong: var(--ftcc-white);
  --ftcc-border: rgba(83, 86, 90, 0.22);
  --ftcc-border-strong: rgba(83, 86, 90, 0.35);
  --ftcc-focus: rgba(66, 152, 181, 0.28);
  --shadow-soft: 0 20px 45px rgba(0, 0, 0, 0.04);
  --shadow-tight: 0 12px 24px rgba(0, 0, 0, 0.05);
  --radius-sm: 10px;
  --radius-md: 14px;
  --radius-lg: 18px;
  --radius-xl: 24px;
  --bs-border-radius: var(--radius-md);
  --bs-border-radius-sm: var(--radius-sm);
  --bs-border-radius-lg: var(--radius-lg);
  --bs-border-radius-xl: var(--radius-xl);
  --bs-border-radius-xxl: var(--radius-xl);
  --bs-border-radius-pill: 999px;
  --bs-body-color: var(--ftcc-text);
  --bs-body-bg: #f7f6f3;
  --bs-primary: var(--ftcc-black);
  --bs-link-color: var(--ftcc-blue);
  --bs-link-hover-color: #2f748b;
  --bs-font-sans-serif: var(--font-sans);
}

html {
  font-size: 16px;
  min-height: 100%;
}

body {
  min-height: 100vh;
  margin: 0;
  color: var(--ftcc-text);
  font-family: var(--font-sans);
  line-height: 1.6;
  background: #f7f6f3;
}

img,
svg,
iframe {
  max-width: 100%;
}

.site-chrome {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.site-main {
  flex: 1 0 auto;
  padding: 2rem 0 4rem;
}

.site-main .container,
.site-header .container,
.site-footer .container {
  max-width: 1280px;
}

.site-main .container {
  padding-inline: 1rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  color: var(--ftcc-text);
  font-family: var(--font-sans);
  font-weight: 700;
  letter-spacing: -0.03em;
}

h1 {
  font-size: clamp(2rem, 3vw, 2.8rem);
  line-height: 1.08;
}

h2 {
  font-size: clamp(1.45rem, 2vw, 2rem);
  line-height: 1.15;
}

h3 {
  font-size: 1.15rem;
  line-height: 1.25;
}

p {
  margin: 0;
}

a {
  color: var(--ftcc-text);
  text-decoration-color: rgba(66, 152, 181, 0.35);
  text-underline-offset: 0.18em;
}

a:hover,
a:focus {
  color: var(--ftcc-blue);
}

small,
.small,
.muted-copy,
.muted-inline,
.text-muted,
.form-text {
  color: var(--ftcc-muted) !important;
}

.serif-display {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 600;
}

mark.ftcc-mark {
  padding: 0.06rem 0.4rem;
  border-radius: var(--radius-sm);
  background: rgba(240, 184, 45, 0.24);
  color: var(--ftcc-text);
}

:focus-visible {
  outline: 3px solid var(--ftcc-focus);
  outline-offset: 2px;
}

/* Header */

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
}

.site-topband {
  background: var(--ftcc-black);
  color: var(--ftcc-white);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.site-topband-shell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 2.35rem;
  font-size: 0.84rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.site-topband-school {
  font-weight: 700;
}

.site-topband-tagline {
  color: var(--ftcc-gold);
  font-weight: 700;
}

.navbar {
  padding: 1rem 0;
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid rgba(240, 184, 45, 0.5);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.04);
  backdrop-filter: blur(16px);
}

.navbar-shell {
  align-items: center;
  gap: 1rem;
}

.brand-group {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex: 0 0 auto;
  margin-right: 1.5rem;
}

.brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  text-decoration: none;
}

.logo {
  display: block;
  width: auto;
  height: 56px;
}

.brand-copy-block {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.brand-title {
  color: var(--ftcc-black);
  font-size: 1.45rem;
  font-weight: 800;
  letter-spacing: -0.04em;
  text-decoration: none;
}

.brand-title:hover,
.brand-title:focus {
  color: var(--ftcc-blue);
}

.brand-subtitle {
  color: var(--ftcc-slate);
  font-size: 0.9rem;
  font-weight: 600;
}

.navbar-toggler {
  color: var(--ftcc-black);
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-md);
  padding: 0.55rem 0.75rem;
  background: var(--ftcc-white);
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 0.22rem var(--ftcc-focus);
}

.nav-cluster {
  gap: 0.25rem;
}

.nav-link {
  position: relative;
  color: var(--ftcc-black);
  font-weight: 700;
  font-size: 0.96rem;
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: color 160ms ease, background-color 160ms ease;
}

.nav-link:hover,
.nav-link:focus {
  color: var(--ftcc-blue);
  background: rgba(66, 152, 181, 0.08);
}

.nav-link.active,
.nav-link.dropdown-toggle.show,
.navbar-nav .nav-link.active {
  color: var(--ftcc-black);
  background: rgba(240, 184, 45, 0.14);
}

.nav-link.active:not(.dropdown-toggle)::after {
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 0.35rem;
  height: 2px;
  border-radius: 999px;
  background: var(--ftcc-gold);
}

.nav-link.dropdown-toggle.active {
  box-shadow: inset 0 -2px 0 var(--ftcc-gold);
}

.nav-tools {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.nav-auth-list {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.nav-auth-button {
  min-width: 7.25rem;
  justify-content: center;
}

.nav-auth-button-secondary {
  border-color: var(--ftcc-border-strong);
  color: var(--ftcc-black);
  background: var(--ftcc-white);
}

.nav-auth-button-secondary:hover,
.nav-auth-button-secondary:focus {
  border-color: var(--ftcc-black);
  color: var(--ftcc-white);
  background: var(--ftcc-black);
}

.nav-user-trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.nav-user-label {
  color: var(--ftcc-slate);
  font-size: 0.8rem;
  font-weight: 600;
}

.nav-user-trigger strong {
  color: var(--ftcc-black);
  font-weight: 700;
}

.nav-cart .cart-link {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.72rem 1rem;
  border-radius: var(--radius-md);
  background: var(--ftcc-black);
  color: var(--ftcc-white);
  font-weight: 800;
  text-decoration: none;
  transition: background-color 160ms ease, color 160ms ease;
}

.nav-cart .cart-link:hover,
.nav-cart .cart-link:focus {
  background: #262626;
  color: var(--ftcc-white);
}

.cart-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.75rem;
  height: 1.75rem;
  padding: 0 0.45rem;
  border-radius: 999px;
  background: var(--ftcc-gold) !important;
  color: var(--ftcc-black);
  font-size: 0.84rem;
  font-weight: 800;
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.7rem;
  padding: 0.3rem 0.6rem;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
}

.badge.bg-success {
  background: rgba(43, 125, 75, 0.12) !important;
  color: var(--ftcc-success) !important;
}

.dropdown-menu {
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-md);
  padding: 0.55rem;
  box-shadow: var(--shadow-tight);
  background: rgba(255, 255, 255, 0.98);
}

.dropdown-item {
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 0.65rem 0.9rem;
  color: var(--ftcc-text);
  text-decoration: none;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background: rgba(66, 152, 181, 0.08);
  color: var(--ftcc-black);
}

.dropdown-divider {
  border-color: var(--ftcc-border);
  opacity: 1;
}

/* Footer */

.site-footer {
  margin-top: auto;
  border-top: 1px solid rgba(240, 184, 45, 0.45);
  background: #f1f0ec;
}

.site-footer-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) repeat(2, minmax(180px, 0.7fr));
  gap: 1.5rem;
  align-items: start;
  padding: 2rem 1rem 2.25rem;
}

.footer-brand {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.footer-logo {
  width: auto;
  height: 48px;
}

.footer-brand-copy {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.footer-brand-copy strong {
  font-size: 1rem;
  font-weight: 800;
}

.footer-brand-copy p {
  color: var(--ftcc-slate);
  max-width: 38ch;
}

.footer-link-group {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.footer-heading {
  color: var(--ftcc-slate);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

.footer-link-group a {
  color: var(--ftcc-black);
  font-weight: 600;
  width: fit-content;
}

/* Layout primitives */

.page-shell {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.compact-shell {
  max-width: 1080px;
  margin: 0 auto;
}

.page-header {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.page-header h1 {
  font-size: clamp(1.9rem, 2.8vw, 2.6rem);
}

.page-subtitle {
  font-size: 1rem;
  color: var(--ftcc-slate);
  max-width: 64ch;
}

.page-stats {
  display: flex;
  flex-wrap: wrap;
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-lg);
  background: var(--ftcc-surface);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.page-stat {
  flex: 1 1 150px;
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.page-stat + .page-stat {
  border-left: 1px solid var(--ftcc-border);
}

.stat-label,
.meta-label,
.summary-label {
  display: block;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ftcc-slate);
}

.page-stat strong,
.hero-meta-card strong,
.summary-card strong,
.price-tag,
.checkout-bar strong,
.hero-rail-card strong {
  font-size: 1.3rem;
  font-weight: 800;
  line-height: 1.12;
}

.page-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 0.9fr);
  gap: 1.75rem;
  padding: 1.75rem 1.8rem 1.75rem 2.1rem;
  background: var(--ftcc-surface);
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-soft);
  align-items: start;
}

.page-hero::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 0.7rem;
  background: var(--ftcc-gold);
}

.page-hero > * {
  position: relative;
  z-index: 1;
}

.page-hero .eyebrow,
.eyebrow {
  display: inline-flex;
  align-items: center;
  padding: 0.42rem 0.78rem;
  border-radius: 999px;
  background: rgba(240, 184, 45, 0.18);
  color: var(--ftcc-black);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.page-hero h1 {
  margin-top: 0.25rem;
}

.page-hero .serif-display {
  display: block;
  color: var(--ftcc-slate);
}

.hero-copy {
  max-width: 62ch;
  margin-top: 0.5rem;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ftcc-slate);
}

.hero-actions,
.quick-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-top: 1.35rem;
}

.hero-meta-grid,
.summary-grid,
.report-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.hero-meta-card,
.summary-card,
.hero-rail-card {
  padding: 0.95rem 1rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--ftcc-border);
  background: var(--ftcc-surface-soft);
}

.summary-card {
  background: var(--ftcc-surface);
}

.hero-rail-card p,
.meta-note {
  margin-top: 0.45rem;
  color: var(--ftcc-slate);
}

.home-grid {
    display: grid;
    gap: 1.5rem;
}
.auth-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.82fr);
    gap: 1.5rem;
}
.manage-layout {
  display: grid;
  gap: 1.5rem;
}

.home-side-rail,
.support-rail,
.manage-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.home-content-panel,
.auth-form-panel,
.manage-content {
  min-width: 0;
}

.ftcc-surface,
.panel-card,
.action-card,
.course-spotlight-card,
.schedule-card,
.selection-card,
.checkout-bar,
.card,
.modal-content,
.accordion-item {
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-lg);
  background: var(--ftcc-surface);
  box-shadow: var(--shadow-soft);
}

.ftcc-surface {
  overflow: hidden;
}

.panel-stack {
  padding: 1.65rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.section-heading-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
}

.section-heading-row.compact {
  margin-bottom: 0.15rem;
}

.panel-card,
.selection-card,
.course-spotlight-card,
.schedule-card {
  padding: 1.15rem;
}

.panel-card:not(.checkout-bar):not(.inline-option-form),
.course-spotlight-card {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.card {
  overflow: hidden;
}

.card-header,
.modal-header,
.card-header.bg-primary,
.modal-header.bg-primary {
  padding: 1rem 1.2rem;
  border-bottom: 1px solid var(--ftcc-border) !important;
  color: var(--ftcc-black) !important;
  background: var(--ftcc-surface-soft) !important;
}

.card-body,
.modal-body {
  padding: 1.4rem;
}

.modal-footer {
  padding: 1rem 1.4rem 1.3rem;
  border-top: 1px solid var(--ftcc-border);
}

.btn-close,
.btn-close-white {
  filter: none;
  opacity: 0.65;
}

.action-stack,
.recommendation-stack,
.timeline-list,
.lane-stack,
.quick-link-list,
.auth-links,
.manage-nav-list,
.compact-list,
.support-list,
.consent-list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.action-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.15rem 1.2rem;
}

.action-card p,
.timeline-entry p,
.selection-card p,
.recommendation-card p,
.course-spotlight-card p,
.panel-card p,
.support-card p {
  color: var(--ftcc-slate);
}

.action-needed-surface {
  border-color: rgba(240, 184, 45, 0.34);
  background:
    linear-gradient(180deg, rgba(240, 184, 45, 0.14) 0%, rgba(240, 184, 45, 0.04) 24%, var(--ftcc-surface) 24%);
}

.action-needed-banner {
  padding: 0.95rem 1rem;
  border: 1px solid rgba(240, 184, 45, 0.28);
  border-radius: var(--radius-md);
  background: rgba(240, 184, 45, 0.16);
}

.action-needed-banner p {
  color: var(--ftcc-text);
}

.action-card-urgent {
  border-color: rgba(240, 184, 45, 0.32);
  background: rgba(240, 184, 45, 0.14);
  box-shadow: inset 4px 0 0 rgba(240, 184, 45, 0.9);
}

.action-card-urgent p {
  color: var(--ftcc-text);
}

.compact-profile-card {
  padding: 1rem 1.1rem;
  gap: 0.85rem;
}

.compact-profile-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
}

.compact-profile-header h3 {
  margin-bottom: 0.2rem;
}

.compact-requirement-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.compact-requirement-card {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.85rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid rgba(83, 86, 90, 0.12);
  border-radius: var(--radius-md);
  background: var(--ftcc-surface-soft);
}

.compact-requirement-card-urgent {
  border-color: rgba(240, 184, 45, 0.32);
  background: rgba(240, 184, 45, 0.12);
}

.compact-requirement-card-urgent .muted-copy {
  color: var(--ftcc-text);
}

.compact-requirement-action {
  margin-top: 0.6rem;
}

.warning-stack {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.action-card-warning {
  border-color: rgba(240, 184, 45, 0.28);
  background: rgba(240, 184, 45, 0.1);
}

.action-card-warning p {
  color: var(--ftcc-text);
}

.warning-kicker {
  display: inline-block;
  margin-bottom: 0.35rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ftcc-warning);
}

.timeline-entry {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 1rem;
  align-items: start;
}

.timeline-stamp {
  padding: 0.65rem 0.8rem;
  border-radius: var(--radius-sm);
  background: rgba(240, 184, 45, 0.18);
  color: var(--ftcc-black);
  font-weight: 800;
  text-align: center;
}

.student-card-grid,
.explorer-card-grid,
.selection-grid,
.contact-summary-grid,
.account-links-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.student-card-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.student-card-header strong {
  display: block;
  font-size: 1rem;
  font-weight: 800;
}

.student-card-header .muted-inline {
  display: block;
  font-size: 0.85rem;
  margin-top: 0.1rem;
}

.student-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: rgba(240, 184, 45, 0.18);
  color: var(--ftcc-black);
  font-size: 1rem;
  font-weight: 800;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.dashboard-grid.two-column {
  grid-template-columns: 1.1fr 1fr;
}

.account-profile-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.92fr) minmax(0, 1.08fr);
  gap: 1rem;
  align-items: start;
}

.account-profile-grid > * {
  min-width: 0;
}

.account-identity-card {
  gap: 1rem;
}

.account-identity-name {
  display: block;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.1;
}

.account-detail-row {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.account-detail-row span {
  color: var(--ftcc-black);
  font-size: 0.98rem;
  font-weight: 700;
}

.account-child-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.child-record-card {
  gap: 0.9rem;
}

.child-record-card .status-pill {
  align-self: flex-start;
}

.child-record-card .sidebar-actions {
  margin-top: auto;
}

.quick-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1rem;
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-md);
  background: var(--ftcc-surface);
  box-shadow: var(--shadow-tight);
  text-decoration: none;
  transition: border-color 140ms ease, transform 140ms ease;
}

.quick-link:hover,
.quick-link:focus {
  border-color: rgba(66, 152, 181, 0.4);
  transform: translateY(-1px);
}

.quick-link.active {
  border-color: rgba(240, 184, 45, 0.45);
  background: rgba(240, 184, 45, 0.14);
}

.quick-link strong {
  font-size: 1rem;
  font-weight: 800;
}

.quick-link > div {
  min-width: 0;
}

.quick-link p {
  margin-top: 0.25rem;
  color: var(--ftcc-slate);
}

.quick-link span {
  color: var(--ftcc-blue);
  font-size: 0.92rem;
  font-weight: 700;
  white-space: nowrap;
}

.brand-copy {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  font-size: 1rem;
  line-height: 1.75;
}

.brand-copy > :first-child {
  margin-top: 0;
}

.brand-copy h1,
.brand-copy h2,
.brand-copy h3,
.brand-copy h4 {
  color: var(--ftcc-black);
  line-height: 1.15;
}

.brand-copy h1 {
  font-size: clamp(2rem, 3vw, 3rem);
}

.brand-copy h2 {
  padding-bottom: 0.45rem;
  border-bottom: 1px solid rgba(83, 86, 90, 0.18);
}

.brand-copy p,
.brand-copy li {
  color: var(--ftcc-slate);
}

.brand-copy a {
  color: var(--ftcc-blue);
  font-weight: 700;
}

.brand-copy ul,
.brand-copy ol {
  margin: 0;
  padding-left: 1.3rem;
  display: grid;
  gap: 0.55rem;
}

.brand-copy img,
.brand-copy iframe,
.brand-copy table {
  max-width: 100%;
}

.brand-copy table,
.table {
  width: 100%;
  margin: 0;
  color: var(--ftcc-text);
  --bs-table-bg: transparent;
}

.brand-copy blockquote {
  margin: 0;
  padding: 1rem 1.15rem;
  border-left: 4px solid var(--ftcc-gold);
  border-radius: var(--radius-md);
  background: rgba(240, 184, 45, 0.1);
  color: var(--ftcc-black);
  font-family: var(--font-serif);
  font-size: 1.08rem;
  line-height: 1.6;
}

.brand-copy hr {
  width: 100%;
  border: 0;
  border-top: 1px solid rgba(83, 86, 90, 0.18);
  opacity: 1;
}

.support-card {
  padding: 1.2rem;
}

.support-item {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 0;
  border-top: 1px solid rgba(83, 86, 90, 0.12);
}

.support-item:first-child {
  border-top: 0;
  padding-top: 0;
}

/* Status and chip language */

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.72rem;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.status-open {
  background: rgba(43, 125, 75, 0.12);
  color: var(--ftcc-success);
}

.status-warning {
  background: rgba(155, 101, 0, 0.12);
  color: var(--ftcc-warning);
}

.status-danger {
  background: rgba(169, 53, 53, 0.12);
  color: var(--ftcc-danger);
}

.status-muted {
  background: rgba(83, 86, 90, 0.12);
  color: var(--ftcc-slate);
}

.status-info {
  background: rgba(66, 152, 181, 0.12);
  color: var(--ftcc-blue);
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.compact-chip-row {
  gap: 0.4rem;
}

.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.42rem 0.75rem;
  border-radius: 999px;
  background: rgba(83, 86, 90, 0.09);
  color: var(--ftcc-black);
  font-weight: 700;
  font-size: 0.88rem;
}

.filter-chip.active,
.fit-chip {
  background: rgba(240, 184, 45, 0.18);
  color: var(--ftcc-black);
}

.conflict-chip {
  background: rgba(169, 53, 53, 0.12);
  color: var(--ftcc-danger);
}

/* Forms and controls */

.stack-form,
.grid-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.two-up-field,
.sync-actions,
.sidebar-actions,
.inline-option-form,
.course-card-footer,
.checkout-bar,
.course-card-topline,
.section-metric-row,
.register-submit-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
}

.inline-option-form {
  flex-wrap: wrap;
}

.form-control,
.form-select {
  min-height: 3.1rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--ftcc-border);
  padding: 0.76rem 0.95rem;
  background: rgba(255, 255, 255, 0.98);
  font-size: 1rem;
  color: var(--ftcc-text);
}

textarea.form-control {
  min-height: 8rem;
}

.form-control::placeholder {
  color: rgba(83, 86, 90, 0.72);
}

.form-control:focus,
.form-select:focus,
.form-check-input:focus,
.page-link:focus,
.accordion-button:focus,
.nav-link:focus,
.dropdown-item:focus {
  border-color: rgba(66, 152, 181, 0.42);
  box-shadow: 0 0 0 0.22rem var(--ftcc-focus);
}

.form-label {
  margin-bottom: 0.45rem;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--ftcc-black);
}

.form-check {
  margin-bottom: 0;
}

.form-check-input {
  margin-top: 0.1rem;
  border-color: rgba(83, 86, 90, 0.4);
}

.form-check-input:checked {
  background-color: var(--ftcc-black);
  border-color: var(--ftcc-black);
}

.modern-check {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.8rem 1rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--ftcc-border);
  background: var(--ftcc-surface);
  color: var(--ftcc-black);
  font-weight: 700;
}

.input-group-text {
  border-color: var(--ftcc-border);
  border-radius: var(--radius-md);
  background: var(--ftcc-surface-soft);
  color: var(--ftcc-slate);
}

.text-danger {
  display: block;
  margin-top: 0.35rem;
  color: #8d2525 !important;
}

.validation-summary-valid,
.field-validation-valid {
  display: none;
}

.form-intro,
.alert-info {
  background: rgba(66, 152, 181, 0.08);
  border: 1px solid rgba(66, 152, 181, 0.18);
  color: var(--ftcc-black);
}

.form-intro {
  padding: 1rem 1.1rem;
  border-radius: var(--radius-md);
}

.form-section-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.4rem;
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-lg);
  background: var(--ftcc-surface);
}

.form-section-heading {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.helper-note {
  padding: 0.95rem 1rem;
  border-radius: var(--radius-md);
  background: var(--ftcc-surface-soft);
  border: 1px solid rgba(83, 86, 90, 0.14);
  color: var(--ftcc-slate);
}

/* Buttons */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  border-radius: var(--radius-md);
  padding: 0.8rem 1.2rem;
  font-weight: 800;
  font-size: 0.95rem;
  border-width: 1px;
  text-decoration: none;
  transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease, transform 150ms ease;
}

.btn:hover,
.btn:focus {
  transform: translateY(-1px);
}

.btn:disabled,
.btn.disabled {
  opacity: 0.58;
  transform: none;
}

.btn-sm {
  padding: 0.55rem 0.8rem;
  font-size: 0.86rem;
}

.btn-lg {
  padding: 0.95rem 1.35rem;
}

.btn-primary {
  background: var(--ftcc-black);
  border-color: var(--ftcc-black);
  color: var(--ftcc-white);
}

.btn-primary:hover,
.btn-primary:focus {
  background: #262626;
  border-color: #262626;
  color: var(--ftcc-white);
}

.btn-outline-primary {
  color: var(--ftcc-black);
  border-color: rgba(17, 17, 17, 0.18);
  background: rgba(255, 255, 255, 0.95);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
  color: var(--ftcc-white);
  background: var(--ftcc-black);
  border-color: var(--ftcc-black);
}

.btn-secondary {
  color: var(--ftcc-black);
  background: rgba(240, 184, 45, 0.88);
  border-color: rgba(240, 184, 45, 0.88);
}

.btn-secondary:hover,
.btn-secondary:focus {
  background: var(--ftcc-gold);
  border-color: var(--ftcc-gold);
  color: var(--ftcc-black);
}

.btn-outline-secondary {
  color: var(--ftcc-slate);
  border-color: rgba(83, 86, 90, 0.2);
  background: var(--ftcc-white);
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
  color: var(--ftcc-black);
  border-color: var(--ftcc-black);
  background: var(--ftcc-surface-soft);
}

.btn-outline-danger {
  color: var(--ftcc-danger);
  border-color: rgba(169, 53, 53, 0.22);
  background: var(--ftcc-white);
}

.btn-outline-danger:hover,
.btn-outline-danger:focus {
  color: var(--ftcc-white);
  background: var(--ftcc-danger);
  border-color: var(--ftcc-danger);
}

.btn-light {
  color: var(--ftcc-black);
  border-color: rgba(17, 17, 17, 0.12);
  background: var(--ftcc-white);
}

.btn-light:hover,
.btn-light:focus {
  color: var(--ftcc-black);
  background: var(--ftcc-surface-soft);
  border-color: rgba(17, 17, 17, 0.2);
}

.btn-link {
  color: var(--ftcc-blue);
  border: 0;
  background: transparent;
  padding-inline: 0;
}

/* Alerts, ribbons, empty states */

.alert,
.soft-alert {
  border-radius: var(--radius-md);
  border-width: 1px;
}

.soft-alert {
  border-color: rgba(83, 86, 90, 0.12);
  color: var(--ftcc-text);
}

.alert-success {
  background: rgba(43, 125, 75, 0.08);
  border-color: rgba(43, 125, 75, 0.2);
  color: #1f5b37;
}

.alert-warning {
  background: rgba(240, 184, 45, 0.14);
  border-color: rgba(240, 184, 45, 0.24);
  color: var(--ftcc-black);
}

.alert-danger {
  background: rgba(169, 53, 53, 0.08);
  border-color: rgba(169, 53, 53, 0.2);
  color: #7a1f1f;
}

.alert-secondary {
  background: rgba(83, 86, 90, 0.08);
  border-color: rgba(83, 86, 90, 0.14);
  color: var(--ftcc-slate);
}

.info-ribbon {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 0.9rem 0.95rem;
  border-radius: var(--radius-md);
  background: rgba(240, 184, 45, 0.1);
  border: 1px solid rgba(240, 184, 45, 0.2);
}

.conflict-ribbon {
  background: rgba(169, 53, 53, 0.08);
  border-color: rgba(169, 53, 53, 0.16);
}

.conflict-row {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.conflict-row + .conflict-row {
  margin-top: 0.35rem;
  padding-top: 0.65rem;
  border-top: 1px solid rgba(169, 53, 53, 0.12);
}

.conflict-summary {
  color: var(--ftcc-black);
  font-weight: 800;
}

.empty-state-card,
.home-empty-state {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  text-align: left;
}

/* Filters, tabs, navigation patterns */

.explorer-layout {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 1.5rem;
}

.explorer-sidebar {
  padding: 1.35rem;
}

.sticky-panel {
  position: sticky;
  top: 8rem;
  align-self: start;
}

.explorer-filter-panel,
.explorer-filter-form,
.explorer-filter-days {
  gap: 1.25rem;
}

.explorer-filter-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  align-items: end;
}

.explorer-filter-keyword {
  grid-column: span 2;
}

.chip-toggle-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.day-chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3.6rem;
  padding: 0.48rem 0.72rem;
  border: 1px solid var(--ftcc-border);
  border-radius: 999px;
  background: var(--ftcc-white);
  color: var(--ftcc-black);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color 140ms ease, border-color 140ms ease;
}

.day-chip input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.day-chip.selected {
  background: rgba(240, 184, 45, 0.16);
  border-color: rgba(240, 184, 45, 0.45);
}

.nav-tabs,
.nav-pills {
  gap: 0.55rem;
  border-bottom: 0;
}

.nav-tabs .nav-link,
.nav-pills .nav-link {
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-md);
  padding: 0.8rem 1rem;
  background: var(--ftcc-white);
  color: var(--ftcc-black);
  font-weight: 700;
  text-decoration: none;
}

.nav-tabs .nav-link.active,
.nav-pills .nav-link.active,
.nav-tabs .nav-item.show .nav-link,
.nav-pills .show > .nav-link {
  border-color: rgba(240, 184, 45, 0.5);
  background: rgba(240, 184, 45, 0.16);
  color: var(--ftcc-black);
}

.tab-content {
  width: 100%;
}

.manage-nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.manage-nav-link small {
  display: block;
  margin-top: 0.15rem;
}

.list-group {
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.list-group-item {
  border-color: var(--ftcc-border);
  padding: 0.95rem 1rem;
  background: var(--ftcc-white);
}

.list-group-item-action:hover,
.list-group-item-action:focus {
  background: rgba(66, 152, 181, 0.06);
}

.accordion-button {
  font-weight: 700;
  color: var(--ftcc-black);
  background: var(--ftcc-surface);
}

.accordion-button:not(.collapsed) {
  color: var(--ftcc-black);
  background: rgba(240, 184, 45, 0.12);
  box-shadow: none;
}

.accordion-button::after {
  opacity: 0.7;
}

.accordion-body {
  padding: 1.1rem 1.2rem 1.2rem;
}

/* Tables, pagination, progress */

.table thead th {
  color: var(--ftcc-slate);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.75rem;
  border-bottom-color: var(--ftcc-border);
  font-weight: 800;
  background: rgba(83, 86, 90, 0.05);
}

.table thead th a {
  color: inherit;
  text-decoration: none;
}

.table > :not(caption) > * > * {
  padding: 0.9rem 1rem;
  border-bottom-color: rgba(83, 86, 90, 0.12);
  vertical-align: middle;
}

.table tbody tr:hover {
  background: rgba(240, 184, 45, 0.05);
}

.table-responsive {
  border-radius: var(--radius-lg);
}

.pagination {
  gap: 0.35rem;
}

.page-link {
  border-radius: var(--radius-sm);
  border-color: var(--ftcc-border);
  color: var(--ftcc-black);
}

.page-item.active .page-link {
  background: var(--ftcc-black);
  border-color: var(--ftcc-black);
  color: var(--ftcc-white);
}

.progress {
  height: 0.5rem;
  border-radius: 999px;
  background: rgba(83, 86, 90, 0.12);
  overflow: hidden;
}

.progress-bar {
  background: var(--ftcc-black);
}

.progress-bar.bg-success {
  background: var(--ftcc-black) !important;
}

.progress-bar.bg-warning {
  background: var(--ftcc-gold) !important;
}

.progress-bar.bg-danger {
  background: var(--ftcc-danger) !important;
}

/* Course and checkout helpers */

.course-description {
  min-height: 4.5rem;
  font-size: 0.96rem;
}

.price-tag {
  color: var(--ftcc-black);
}

.checkout-bar {
  padding: 1rem 1.2rem;
}

.registration-banner {
  margin-bottom: 0;
  padding: 1rem 1.1rem;
}

.registration-banner-content {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.registration-banner p {
  color: inherit;
}

/* Consent and profile flows */

.consent-shell {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.25rem;
  border: 1px solid var(--ftcc-border);
  border-radius: var(--radius-lg);
  background: var(--ftcc-surface-soft);
}

.consent-header {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.consent-grid {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.consent-form-card {
  gap: 1.15rem;
}

.consent-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 160px;
  gap: 1rem;
  align-items: start;
  padding: 1rem;
  border-radius: var(--radius-md);
  border: 1px solid rgba(83, 86, 90, 0.14);
  background: var(--ftcc-white);
}

.consent-statement {
  gap: 0.85rem;
}

.consent-item-copy {
  display: flex;
  gap: 0.75rem;
  align-items: start;
}

.consent-item-copy .form-check {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.consent-item-copy .form-check-label {
  display: block;
  color: var(--ftcc-black);
  font-weight: 600;
  line-height: 1.6;
}

.consent-initials {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.consent-option-checkbox {
  margin-top: 0.18rem;
}

.consent-initials label {
  margin-bottom: 0;
}

.initials-field {
  min-height: auto;
  max-width: 7rem;
  text-transform: uppercase;
  text-align: center;
  font-weight: 700;
}

.consent-initials-input {
  max-width: 8rem;
  text-transform: uppercase;
  text-align: center;
  font-weight: 700;
}

.signature-block {
  display: grid;
  gap: 0.75rem;
  padding-top: 0.5rem;
}

.consent-signature-card {
  gap: 0.7rem;
}

.contact-summary-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.contact-summary-card {
  padding: 1rem;
}

.detail-stack,
.definition-list {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.definition-list strong {
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ftcc-slate);
}

.section-divider {
  width: 100%;
  height: 1px;
  margin: 0.25rem 0;
  background: rgba(83, 86, 90, 0.14);
}

/* Misc helpers */

.clean-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.compact-list li,
.student-pill-list li {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.6rem;
}

.review-grid {
  grid-template-columns: 1fr;
}

.compact-gap {
  gap: 1rem;
}

.operations-shell .panel-card h3,
.page-shell h3 {
  font-size: 1.05rem;
}

/* Responsive */

@media (max-width: 1200px) {
  .explorer-card-grid,
  .selection-grid,
  .student-card-grid,
  .dashboard-grid,
  .dashboard-grid.two-column,
  .account-profile-grid,
  .explorer-layout,
  .page-hero,
  .home-grid,
  .auth-layout,
  .manage-layout,
  .site-footer-shell {
    grid-template-columns: 1fr;
  }

  .sticky-panel {
    position: static;
  }

  .explorer-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .explorer-filter-keyword {
    grid-column: span 2;
  }
}

@media (max-width: 991.98px) {
  .brand-group {
    margin-right: auto;
  }

  .navbar-collapse {
    margin-top: 1rem;
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: rgba(241, 240, 236, 0.96);
    border: 1px solid var(--ftcc-border);
  }

  .nav-tools,
  .nav-auth-list {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .nav-cart .cart-link,
  .nav-auth-button,
  .nav-user-trigger {
    width: 100%;
    justify-content: center;
  }

  .consent-item {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767.98px) {
  .site-topband-shell,
  .section-heading-row,
  .compact-profile-header,
  .two-up-field,
  .sync-actions,
  .sidebar-actions,
  .inline-option-form,
  .course-card-footer,
  .checkout-bar,
  .action-card,
  .register-submit-row,
  .quick-action-row,
  .registration-banner-content,
  .footer-brand {
    flex-direction: column;
    align-items: stretch;
  }

  .hero-meta-grid,
  .summary-grid,
  .report-grid,
  .explorer-filter-grid,
  .explorer-card-grid,
  .selection-grid,
  .account-links-grid,
  .compact-requirement-grid {
    grid-template-columns: 1fr;
  }

  .explorer-filter-keyword {
    grid-column: auto;
  }

  .site-main {
    padding-top: 1.35rem;
  }

  .brand-title {
    font-size: 1.22rem;
  }

  .brand-subtitle {
    font-size: 0.84rem;
  }

  .logo {
    height: 46px;
  }

  .page-hero {
    padding: 1.35rem 1.2rem 1.35rem 1.7rem;
  }

  .panel-stack,
  .card-body,
  .modal-body {
    padding: 1.25rem;
  }

  .page-stat + .page-stat {
    border-left: 0;
    border-top: 1px solid var(--ftcc-border);
  }
}
