/* ============================================================
   Fly GACA — Landing page (flygaca.html)
   Load order: tokens.css -> base.css -> landing.css
   ============================================================ */

/* Disclaimer strip styles now live in base.css — it appears on every page. */

/* --- Hero --- */
.hero { position: relative; overflow: hidden; }
.hero::before { /* ambient teal glow, top-trailing */
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(620px 420px at 88% 8%, rgba(45,110,138,0.22), transparent 70%),
    radial-gradient(520px 380px at 10% 90%, rgba(143,201,168,0.10), transparent 70%);
  pointer-events: none;
}
.hero-grid {
  position: relative;
  display: grid; grid-template-columns: 1.05fr 0.95fr;
  gap: var(--space-10); align-items: center;
  padding-block: var(--space-8);
}
.hero-copy { max-width: 36rem; }
.hero h1 {
  font-size: var(--fs-display);
  margin-block: var(--space-4) var(--space-5);
  overflow-wrap: break-word;
}
.hero h1 .accent {
  background: var(--grad-brand);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero-sub { font-size: var(--fs-lg); color: var(--text-muted); margin-block-end: var(--space-6); }
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.hero-proof {
  margin-block-start: var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.03em;
  line-height: var(--lh-snug);
  color: var(--text-muted);
  max-width: 40rem;
}
.hero-trust {
  margin-block-start: var(--space-6);
  display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-5);
  color: var(--text-dim); font-size: var(--fs-sm);
}
.hero-trust span { display: inline-flex; align-items: center; gap: var(--space-2); }
.hero-trust .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--accent); }

/* Hero demo — a Captain Adel example exchange; a different one each visit
   (assets/js/hero.js). Demonstrates the cited-answer pattern up front. */
.hero-demo { position: relative; width: 100%; }
.hero-demo::before { /* glow bed */
  content: ""; position: absolute; inset: 4% 6%;
  background: var(--glow-teal);
  filter: blur(12px); pointer-events: none;
}
.hero-demo-card {
  position: relative;
  display: flex; flex-direction: column; gap: var(--space-3);
  background:
    radial-gradient(120% 120% at 85% 0%, rgba(45,110,138,0.16), transparent 60%),
    var(--falcon-deep);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop);
  padding: var(--space-5);
}
.hd-top { display: flex; align-items: center; gap: var(--space-3); }
.hd-avatar {
  width: 40px; height: 40px; border-radius: 50%; flex: none;
  border: 1px solid var(--border-bright); object-fit: cover;
}
.hd-id { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.hd-name { font-weight: var(--fw-bold); font-size: var(--fs-sm); }
.hd-role {
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-dim);
}
.hd-tag {
  margin-inline-start: auto; flex: none;
  font-family: var(--font-mono); font-size: var(--fs-xs);
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim);
  border: 1px solid var(--border-bright); border-radius: var(--radius-pill);
  padding: 0.15rem 0.6rem;
}
.hd-q {
  font-weight: var(--fw-semibold); font-size: var(--fs-base); color: var(--text);
  line-height: var(--lh-snug);
  padding-inline-start: var(--space-3);
  border-inline-start: 2px solid var(--teal-bright);
}
.hd-a {
  font-size: var(--fs-sm); color: var(--text-muted); line-height: var(--lh-body);
}
.hd-cite {
  align-self: flex-start;
  font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.03em;
  color: var(--accent-bright);
  background: rgba(143,201,168,0.08);
  border: 1px solid var(--border-bright); border-radius: var(--radius-pill);
  padding: 0.32rem 0.75rem;
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.hd-cite::before { content: "§ "; font-weight: var(--fw-bold); }
.hd-cite:hover { border-color: var(--accent); color: var(--accent-bright); }
.hd-cta {
  font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--link);
  margin-block-start: var(--space-1);
}
.hd-cta:hover { color: var(--accent-bright); }

/* --- Section heading block --- */
.section-head { max-width: var(--container-narrow); margin-block-end: var(--space-8); }
.section-head h2 { margin-block: var(--space-3); }
.section-head p { color: var(--text-muted); font-size: var(--fs-lg); }

/* --- Feature grid --- */
.features { background: #080B0F; border-block: 1px solid var(--border); }
.feature-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5);
}
.feature {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: var(--space-5);
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.feature:hover { border-color: var(--border-bright); transform: translateY(-3px); }
.feature .icon {
  width: 44px; height: 44px; border-radius: var(--radius-md);
  display: grid; place-items: center;
  background: rgba(45,110,138,0.16);
  border: 1px solid rgba(74,156,184,0.28);
  color: var(--accent-bright);
  margin-block-end: var(--space-4);
}
.feature .icon svg { width: 22px; height: 22px; }
.feature h3 { margin-block-end: var(--space-2); }
.feature p { color: var(--text-muted); font-size: var(--fs-sm); }

/* --- Captain Adel teaser --- */
.captain {
  position: relative; overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-xl);
  padding: var(--space-10);
}
.captain::before {
  content: ""; position: absolute; inset-inline-end: -120px; inset-block-start: -120px;
  width: 380px; height: 380px; background: var(--glow-sage); filter: blur(10px);
  pointer-events: none;
}
.captain-inner { position: relative; max-width: 40rem; }
.captain h2 { margin-block: var(--space-3) var(--space-4); }
.captain p { color: var(--text-muted); font-size: var(--fs-lg); }

/* --- Captain Adel CTA row --- */
.captain-cta {
  display: flex; flex-wrap: wrap; gap: var(--space-3);
  margin-block-start: var(--space-6);
}

/* --- Plans (embedded pricing) --- */
.plans .section-head { margin-inline: auto; text-align: center; }
.plan-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5); align-items: stretch;
}
.plan {
  position: relative;
  display: flex; flex-direction: column;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: var(--space-6);
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.plan:hover { border-color: var(--border-bright); transform: translateY(-3px); }
.plan-featured {
  border-color: var(--brand);
  box-shadow: 0 0 0 1px var(--brand), var(--shadow-card);
}
.plan-featured:hover { border-color: var(--brand); }
.plan-flag {
  position: absolute;
  inset-block-start: calc(-1 * var(--space-3));
  inset-inline-start: 50%; transform: translateX(-50%);
  background: var(--grad-brand); color: var(--falcon-night);
  font-size: var(--fs-xs); font-weight: var(--fw-bold);
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.25rem 0.7rem; border-radius: var(--radius-pill);
  white-space: nowrap;
}
.plan-name { font-size: var(--fs-h3); font-weight: var(--fw-bold); }
.plan-tagline {
  color: var(--text-dim); font-size: var(--fs-sm);
  margin-block: var(--space-1) var(--space-4);
}
.plan-price { display: flex; align-items: baseline; gap: 0.3rem; }
.plan-price .cur { color: var(--text-muted); font-size: var(--fs-base); font-weight: var(--fw-semibold); }
.plan-price .amt { font-size: 2.6rem; font-weight: var(--fw-black); line-height: 1; }
.plan-price .per { color: var(--text-muted); font-size: var(--fs-sm); }
.plan-price-sub {
  color: var(--text-dim); font-size: var(--fs-sm);
  min-height: 1.2em;
  margin-block: var(--space-1) var(--space-5);
}
.plan-list {
  list-style: none; margin: 0 0 var(--space-5); padding: 0;
  display: flex; flex-direction: column; gap: var(--space-2); flex: 1;
}
.plan-list li {
  position: relative; padding-inline-start: 1.6rem;
  font-size: var(--fs-sm); line-height: var(--lh-snug); color: var(--text);
}
.plan-list li::before {
  content: ""; position: absolute;
  inset-inline-start: 0; inset-block-start: 0.15em;
  width: 1rem; height: 1rem; border-radius: var(--radius-pill);
  background:
    var(--accent)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%230A0E12' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")
    center / 0.7rem no-repeat;
}
.plan .btn { width: 100%; margin-block-start: auto; }
.plans-foot { text-align: center; margin-block-start: var(--space-6); font-size: var(--fs-sm); }
.plans-foot a { color: var(--link); font-weight: var(--fw-semibold); }
.plans-foot a:hover { color: var(--accent-bright); }

/* --- Final conversion band --- */
.cta-band {
  border-block-start: 1px solid var(--border);
  background:
    radial-gradient(620px 300px at 82% 0%, rgba(45,110,138,0.20), transparent 70%),
    var(--surface);
}
.cta-band-inner {
  display: flex; flex-wrap: wrap;
  gap: var(--space-6); align-items: center; justify-content: space-between;
  padding-block: var(--space-10);
}
.cta-band-copy { max-width: 38rem; }
.cta-band-copy h2 { margin-block: var(--space-3) var(--space-3); }
.cta-band-copy p { color: var(--text-muted); font-size: var(--fs-lg); }
.cta-band-actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* --- Responsive --- */
@media (max-width: 900px) {
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
  .plan-grid { grid-template-columns: 1fr; }
  .plan-featured { order: -1; }
}
@media (max-width: 760px) {
  .hero-grid { grid-template-columns: 1fr; gap: var(--space-6); padding-block: var(--space-8); }
  .hero-demo { max-width: 32rem; }
  .captain { padding: var(--space-6); }
  .cta-band-actions .btn { flex: 1; }
}
@media (max-width: 480px) {
  .feature-grid { grid-template-columns: 1fr; }
  .hero-cta .btn { flex: 1; }
}
