
:root {
  --color-navy: #12324a;
  --color-navy-deep: #0b2235;
  --color-blue: #467ea3;
  --color-blue-soft: #b8d7ea;
  --color-sky: #e4f1f8;
  --color-sky-light: #f7fbfd;
  --color-cloud: #f2f6f9;
  --color-accent: #f15b24;
  --color-accent-dark: #c94716;
  --color-accent-soft: #fff0e8;
  --color-desert: #d9b784;
  --color-sand: #faf4ec;
  --color-surface: #ffffff;
  --color-ink: #182b3b;
  --color-muted: #617282;
  --color-line: #d9e5ed;
  --shadow-soft: 0 20px 50px rgba(18, 50, 74, 0.12);
  --shadow-air: 0 24px 70px rgba(70, 126, 163, 0.16);
  --radius-lg: 1.5rem;
  --radius-md: 1rem;
  --container: 1120px;
}

*, *::before, *::after { box-sizing: border-box; }
html { color-scheme: light; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--color-ink);
  background: linear-gradient(180deg, #ffffff 0%, var(--color-sky-light) 46%, #ffffff 100%);
  line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
.container { width: min(100% - 2rem, var(--container)); margin-inline: auto; }
.skip-link { position: absolute; top: -100px; left: 1rem; z-index: 100; background: var(--color-accent); color: #fff; padding: 0.75rem 1rem; border-radius: 0 0 0.75rem 0.75rem; }
.skip-link:focus { top: 0; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0); }
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255, 255, 255, 0.94); border-bottom: 1px solid rgba(217, 229, 237, 0.86); backdrop-filter: blur(18px); }
.header-inner { min-height: 74px; display: flex; align-items: center; gap: 1rem; }
.brand { display: inline-flex; align-items: center; text-decoration: none; color: var(--color-navy); white-space: nowrap; }
.brand-logo { width: auto; height: 52px; max-width: 190px; object-fit: contain; }
.nav-toggle { margin-left: auto; display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border: 1px solid var(--color-line); border-radius: 999px; background: #fff; }
.nav-toggle-line, .nav-toggle-line::before, .nav-toggle-line::after { width: 18px; height: 2px; display: block; background: var(--color-accent); position: relative; }
.nav-toggle-line::before, .nav-toggle-line::after { content: ""; position: absolute; left: 0; }
.nav-toggle-line::before { top: -6px; } .nav-toggle-line::after { top: 6px; }
.primary-nav { display: contents; }
.nav-list { position: absolute; inset: 74px 1rem auto 1rem; margin: 0; padding: 1rem; list-style: none; display: none; background: #fff; border: 1px solid var(--color-line); border-radius: var(--radius-md); box-shadow: var(--shadow-soft); }
.nav-list.is-open { display: grid; gap: 0.25rem; }
.nav-list a { display: block; padding: 0.75rem 0.85rem; border-radius: 0.75rem; text-decoration: none; color: var(--color-ink); font-weight: 650; font-size: 0.95rem; }
.nav-list a:hover, .nav-list a:focus-visible, .nav-list a[aria-current="page"] { background: var(--color-accent-soft); color: var(--color-accent-dark); }
.header-cta { display: none; }
.hero { padding: 4rem 0 3rem; background: radial-gradient(circle at 88% 18%, rgba(241, 91, 36, 0.10), transparent 20rem), radial-gradient(circle at 8% 12%, rgba(70, 126, 163, 0.20), transparent 30rem), linear-gradient(180deg, #ffffff 0%, var(--color-sky-light) 100%); }
.hero-grid, .split, .contact-layout { display: grid; gap: 2rem; }
.hero-copy h1 { margin: 0; font-size: clamp(2.35rem, 10vw, 4.8rem); line-height: 0.95; letter-spacing: -0.06em; color: var(--color-navy); }
.hero-subheadline { max-width: 62ch; margin: 1.15rem 0 0; color: var(--color-muted); font-size: clamp(1.05rem, 2vw, 1.25rem); }
.eyebrow { margin: 0 0 0.8rem; color: var(--color-accent-dark); font-size: 0.77rem; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 800; }
.hero-media img, .rounded-image { border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); border: 1px solid rgba(13, 37, 56, 0.08); }
.button-row { display: flex; flex-wrap: wrap; gap: 0.85rem; margin-top: 1.5rem; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 0.82rem 1.1rem; border-radius: 999px; font-weight: 800; text-decoration: none; border: 1px solid transparent; cursor: pointer; }
.button-primary { background: linear-gradient(135deg, var(--color-navy), #214e70); color: #fff; box-shadow: 0 14px 30px rgba(18, 50, 74, 0.20); position: relative; overflow: hidden; }
.button-primary::before { content: ""; width: 0.45rem; align-self: stretch; margin: -0.82rem 0.65rem -0.82rem -0.45rem; background: var(--color-accent); border-radius: 999px; }
.button-primary:hover, .button-primary:focus-visible { background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark)); box-shadow: 0 14px 30px rgba(241, 91, 36, 0.22); }
.button-secondary { background: #fff; color: var(--color-navy); border-color: var(--color-line); }
.button-secondary:hover, .button-secondary:focus-visible { border-color: var(--color-accent); color: var(--color-accent-dark); }
.button-light { background: #fff; color: var(--color-navy); }
.button-on-dark { background: transparent; color: #fff; border-color: rgba(255,255,255,0.42); }
.full-width { width: 100%; margin-bottom: 0.7rem; }
.hero-stats { display: flex; flex-wrap: wrap; gap: 0.5rem; margin: 1.4rem 0 0; padding: 0; list-style: none; }
.hero-stats li { padding: 0.45rem 0.7rem; border: 1px solid rgba(77, 135, 173, 0.22); border-radius: 999px; background: rgba(255,255,255,0.82); font-size: 0.9rem; color: var(--color-navy); font-weight: 700; }
.section { padding: 4rem 0; }
.section-alt { background: linear-gradient(180deg, var(--color-sky-light), var(--color-cloud)); }
.section-heading { max-width: 760px; margin-bottom: 2rem; }
.section-heading h2 { margin: 0; font-size: clamp(1.75rem, 5vw, 3rem); line-height: 1.05; letter-spacing: -0.04em; color: var(--color-navy); }
.section-heading p { color: var(--color-muted); font-size: 1.05rem; }
.card-grid, .pathway-grid, .steps-grid { display: grid; gap: 1rem; }
.card, .pathway-card, .step-card, .info-panel, .notice-card, .contact-form, .map-placeholder, .mini-card { background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-md); box-shadow: 0 12px 32px rgba(13, 37, 56, 0.07); }
.card, .pathway-card, .step-card, .info-panel, .notice-card, .contact-form { padding: 1.25rem; }
.card h3, .pathway-card h3, .step-card h3, .info-panel h2, .notice-card h3 { margin-top: 0; color: var(--color-navy); line-height: 1.15; }
.card p, .pathway-card p, .step-card p, .info-panel p, .notice-card p { color: var(--color-muted); }
.card-kicker { color: var(--color-accent-dark) !important; font-weight: 800; font-size: 0.92rem; }
.pathway-card { text-decoration: none; transition: transform 180ms ease, border-color 180ms ease; }
.pathway-card:hover, .pathway-card:focus-visible { transform: translateY(-3px); border-color: var(--color-accent); }
.pathway-card span, .step-card span { display: inline-grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; background: var(--color-accent-soft); color: var(--color-accent-dark); font-weight: 900; margin-bottom: 1rem; }
.text-link { display: inline-flex; margin-top: 0.75rem; color: var(--color-accent-dark); font-weight: 800; text-decoration: none; }
.text-link:hover, .text-link:focus-visible { text-decoration: underline; }
.check-list { padding-left: 1.15rem; color: var(--color-muted); }
.check-list li + li { margin-top: 0.45rem; }
.timeline { display: grid; gap: 1rem; list-style: none; padding: 0; counter-reset: timeline; }
.timeline li { counter-increment: timeline; }
.timeline a { display: grid; gap: 0.25rem; padding: 1.25rem; background: #fff; border: 1px solid var(--color-line); border-radius: var(--radius-md); text-decoration: none; position: relative; height: 100%; }
.timeline a::before { content: counter(timeline); display: inline-grid; place-items: center; width: 36px; height: 36px; margin-bottom: 0.4rem; border-radius: 999px; background: var(--color-navy); color: #fff; font-weight: 800; }
.timeline strong { color: var(--color-navy); font-size: 1.1rem; }
.timeline span { color: var(--color-muted); }
.stacked-cards { display: grid; gap: 0.85rem; }
.mini-card { display: grid; gap: 0.15rem; padding: 1rem; text-decoration: none; }
.mini-card strong { color: var(--color-navy); }
.mini-card span { color: var(--color-muted); }
.mini-card:hover, .mini-card:focus-visible { border-color: var(--color-accent); }
.feature-card img, .fleet-card img, .instructor-card img { border-radius: 1rem; margin-bottom: 1rem; border: 1px solid var(--color-line); }
.cta-band { background: linear-gradient(135deg, var(--color-navy-deep), var(--color-navy) 62%, #244f70); color: #fff; padding: 3rem 0; position: relative; overflow: hidden; }
.cta-band::after { content: ""; position: absolute; inset: auto -5rem -6rem auto; width: 16rem; height: 16rem; background: radial-gradient(circle, rgba(241, 91, 36, 0.24), rgba(241, 91, 36, 0)); pointer-events: none; }
.cta-band-inner { display: grid; gap: 1.2rem; }
.cta-band h2 { margin: 0 0 0.4rem; font-size: clamp(1.7rem, 5vw, 3rem); line-height: 1.05; letter-spacing: -0.04em; }
.cta-band p { margin: 0; color: rgba(255,255,255,0.82); }
.faq-list { display: grid; gap: 0.75rem; }
details { background: #fff; border: 1px solid var(--color-line); border-radius: var(--radius-md); padding: 0.2rem 1rem; }
summary { cursor: pointer; padding: 1rem 0; font-weight: 800; color: var(--color-navy); }
details p { margin-top: 0; color: var(--color-muted); }
.detail-list { display: grid; gap: 0.8rem; }
.detail-list dt { font-weight: 900; color: var(--color-navy); }
.detail-list dd { margin: 0; color: var(--color-muted); }
.table-wrap { overflow-x: auto; background: #fff; border: 1px solid var(--color-line); border-radius: var(--radius-md); box-shadow: 0 12px 32px rgba(13, 37, 56, 0.07); }
.rates-table { width: 100%; border-collapse: collapse; min-width: 700px; }
.rates-table caption { text-align: left; padding: 1rem; font-weight: 800; color: var(--color-navy); }
.rates-table th, .rates-table td { padding: 1rem; border-top: 1px solid var(--color-line); text-align: left; }
.rates-table th { color: var(--color-navy); background: linear-gradient(180deg, var(--color-accent-soft), #fff7f2); }
.rates-table td { color: var(--color-muted); }
.resource-list { display: grid; gap: 0.75rem; }
.resource-list a { padding: 1rem; background: #fff; border: 1px solid var(--color-line); border-radius: var(--radius-md); color: var(--color-navy); text-decoration: none; font-weight: 800; }
.resource-list a:hover, .resource-list a:focus-visible { border-color: var(--color-accent); color: var(--color-accent-dark); }
.contact-form label { display: block; margin: 1rem 0 0.35rem; font-weight: 800; color: var(--color-navy); }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; min-height: 46px; border: 1px solid var(--color-line); border-radius: 0.75rem; padding: 0.75rem; font: inherit; }
.contact-form textarea { resize: vertical; }
.form-note { color: var(--color-muted); }
.contact-sidebar { display: grid; gap: 1rem; align-content: start; }
.map-placeholder { display: grid; place-items: center; min-height: 280px; background: linear-gradient(135deg, var(--color-sky-light), var(--color-sand)); color: var(--color-navy); font-weight: 900; text-align: center; }
.site-footer { background: linear-gradient(180deg, var(--color-navy), var(--color-navy-deep)); color: #fff; padding: 3rem 0 1.5rem; }
.footer-logo { width: auto; height: 72px; max-width: 100%; margin-bottom: 1rem; background: #fff; padding: 0.5rem 0.75rem; border-radius: 0.9rem; }
.footer-grid { display: grid; gap: 2rem; }
.site-footer h2 { font-size: 1rem; margin: 0 0 0.8rem; }
.site-footer p, .site-footer a, .footer-note { color: rgba(255,255,255,0.76); }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li + li { margin-top: 0.45rem; }
.site-footer a { text-decoration: none; }
.site-footer a:hover, .site-footer a:focus-visible { color: #fff; text-decoration: underline; }
.footer-bottom { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,0.16); display: grid; gap: 0.4rem; }
.footer-bottom p { margin: 0; font-size: 0.9rem; }

@media (min-width: 720px) {
  .card-grid.two, .pathway-grid, .steps-grid, .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .card-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .cta-band-inner { grid-template-columns: 1fr auto; align-items: center; }
  .timeline { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}

@media (min-width: 980px) {
  .brand-logo { height: 60px; max-width: 235px; }
  .header-cta:hover, .header-cta:focus-visible { background: var(--color-navy); }
  .nav-toggle { display: none; }
  .nav-list { position: static; display: flex; align-items: center; gap: 0.1rem; padding: 0; border: 0; box-shadow: none; background: transparent; }
  .nav-list a { font-size: 0.88rem; padding: 0.55rem 0.65rem; }
  .header-cta { display: inline-flex; align-items: center; justify-content: center; margin-left: auto; min-height: 44px; padding: 0.65rem 1rem; border-radius: 999px; background: var(--color-navy); color: #fff; font-weight: 800; text-decoration: none; white-space: nowrap; box-shadow: 0 12px 28px rgba(18, 50, 74, 0.18); border: 1px solid rgba(241, 91, 36, 0.32); }
  .brand { margin-right: auto; }
  .hero { padding: 5.8rem 0 4.8rem; }
  .hero-grid, .split, .contact-layout { grid-template-columns: 1.06fr 0.94fr; align-items: center; }
  .split.reverse { grid-template-columns: 0.94fr 1.06fr; }
  .split.reverse > :first-child { order: 2; }
  .card-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .card-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .card-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition: none !important; }
}


/* FlightSchedulePro integration additions */
.fsp-section { background: #fff; }
.fsp-card { border-color: rgba(243, 109, 33, 0.28); }
.fsp-card h2 { margin-top: 0; color: var(--color-navy); }
.compact-row { margin-top: 1rem; }
.nav-list a[target="_blank"]::after, .site-footer a[target="_blank"]::after { content: " ↗"; font-size: 0.8em; }
@media (min-width: 980px) {
  .brand-logo { height: 60px; max-width: 235px; }
  .header-cta:hover, .header-cta:focus-visible { background: var(--color-navy); }
  .compact-row .button { min-height: 42px; padding: 0.7rem 0.95rem; font-size: 0.92rem; }
}


/* Homepage brand showcase */
.hero-brand-showcase {
  min-height: 360px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 84% 14%, rgba(241, 91, 36, 0.13), transparent 12rem),
    linear-gradient(145deg, rgba(255,255,255,0.94), rgba(228,241,248,0.72));
  border: 1px solid rgba(70,126,163,0.18);
  box-shadow: var(--shadow-air);
  padding: 1.2rem;
}

.brand-showcase-card {
  width: min(100%, 520px);
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(217,229,237,0.9);
  border-radius: var(--radius-lg);
  box-shadow: 0 24px 70px rgba(18,50,74,0.10);
  padding: clamp(1.25rem, 4vw, 2.2rem);
  position: relative;
  overflow: hidden;
}

.brand-showcase-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 5px;
  background: linear-gradient(90deg, var(--color-blue), var(--color-blue-soft), var(--color-accent));
}

.home-feature-logo {
  width: min(100%, 440px);
  height: auto;
  margin: 0.5rem auto 1rem;
  border-radius: 1rem;
}

.brand-showcase-copy {
  margin: 0;
  color: var(--color-muted);
  max-width: 42ch;
}

.brand-showcase-route {
  display: flex;
  gap: 0.4rem;
  margin-top: 1.3rem;
  align-items: center;
}

.brand-showcase-route span {
  display: block;
  height: 4px;
  border-radius: 999px;
  background: var(--color-blue-soft);
}

.brand-showcase-route span:nth-child(1) { width: 36%; }
.brand-showcase-route span:nth-child(2) { width: 18%; background: var(--color-desert); }
.brand-showcase-route span:nth-child(3) { width: 10%; background: var(--color-accent); }

.brand-anchor-section {
  background:
    linear-gradient(180deg, #ffffff 0%, var(--color-sky-light) 100%);
}

.brand-anchor-panel {
  display: grid;
  place-items: center;
  min-height: 260px;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 80% 20%, rgba(241, 91, 36, 0.12), transparent 12rem),
    linear-gradient(135deg, #ffffff, var(--color-sky));
  border: 1px solid rgba(70,126,163,0.16);
  box-shadow: var(--shadow-air);
  padding: 1.5rem;
}

.brand-anchor-logo {
  width: min(100%, 440px);
  border-radius: 1rem;
}

@media (max-width: 520px) {
  .hero-brand-showcase { min-height: auto; padding: 0.75rem; }
  .brand-showcase-card { padding: 1rem; }
}


/* Tail-number fleet additions */
.aircraft-tail-card .button-row {
  align-items: stretch;
}

.fleet-tail-summary {
  margin-bottom: 1rem;
  border-color: rgba(70, 126, 163, 0.22);
  background: linear-gradient(135deg, #ffffff, var(--color-sky-light));
}

.fleet-tail-summary h3 {
  margin-bottom: 0.4rem;
}

@media (max-width: 520px) {
  .aircraft-tail-card .button-row .button {
    width: 100%;
  }
}


.photo-credit {
  margin: 0.35rem 0 0.9rem;
  font-size: 0.82rem;
  color: var(--color-muted);
}

.aircraft-tail-card img,
.fleet-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 0.9rem;
  display: block;
}

.compact-row {
  gap: 0.6rem;
}
