/* FranchiseFrontline shared styles.
   Every page links this file. Tokens defined here are the only place
   colors / spacing / type sizes are declared; pages do not hand-write
   hex codes or px values. See BRAND.md for the rationale. */

:root {
  /* Color tokens (BRAND.md) */
  --ff-navy:        #15243C;
  --ff-ember:       #C5573B;
  --ff-ember-deep:  #9F3F26;
  --ff-cream:       #F6F1E5;
  --ff-paper:       #FFFBF4;
  --ff-slate:       #1F242C;
  --ff-sage:        #4A8F6F;
  --ff-rust:        #A23B1F;
  --ff-stone:       #C7BFB1;
  --ff-stone-soft:  #E8E0D1;

  /* Spacing scale */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;
  --sp-8: 64px;
  --sp-9: 96px;

  /* Type */
  --ff-display: "Fraunces", Georgia, serif;
  --ff-body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;

  /* Surfaces */
  --ff-shadow-sm: 0 1px 2px rgba(21, 36, 60, 0.06);
  --ff-shadow:    0 8px 28px rgba(21, 36, 60, 0.08);
  --ff-radius:    8px;
  --ff-radius-lg: 12px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--ff-cream);
  color: var(--ff-slate);
  font-family: var(--ff-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--ff-ember-deep); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Top navigation ---- */
.ff-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--ff-cream);
  border-bottom: 1px solid var(--ff-stone-soft);
}
.ff-nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--sp-4) var(--sp-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
}
.ff-brand {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 22px;
  color: var(--ff-navy);
  letter-spacing: -0.01em;
}
.ff-brand a { color: inherit; text-decoration: none; }
.ff-brand .ff-mark-front { letter-spacing: -0.04em; }
.ff-nav-links {
  display: flex;
  gap: var(--sp-5);
  align-items: center;
  flex-wrap: wrap;
}
.ff-nav-links a {
  color: var(--ff-slate);
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
}
.ff-nav-links a:hover { color: var(--ff-ember-deep); text-decoration: none; }
.ff-nav-cta {
  background: var(--ff-ember);
  color: var(--ff-paper);
  padding: 9px 16px;
  border-radius: var(--ff-radius);
  font-weight: 600;
  font-size: 14px;
}
.ff-nav-cta:hover { background: var(--ff-ember-deep); text-decoration: none; color: var(--ff-paper); }

/* ---- Page chrome ---- */
.ff-main {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--sp-8) var(--sp-6);
}
.ff-main--wide { max-width: 1200px; }
.ff-main--narrow { max-width: 740px; }

/* ---- Typography ---- */
.ff-hero-h1 { font-family: var(--ff-display); font-weight: 600; font-size: 56px; line-height: 1.08; color: var(--ff-navy); letter-spacing: -0.015em; }
h1 { font-family: var(--ff-display); font-weight: 400; font-size: 36px; line-height: 1.15; color: var(--ff-navy); margin-bottom: var(--sp-4); }
h2 { font-family: var(--ff-display); font-weight: 400; font-size: 26px; line-height: 1.2; color: var(--ff-navy); margin: var(--sp-7) 0 var(--sp-4); }
h3 { font-family: var(--ff-body); font-weight: 600; font-size: 18px; line-height: 1.3; color: var(--ff-navy); margin-bottom: var(--sp-3); }
p { margin-bottom: var(--sp-4); color: var(--ff-slate); }
.ff-lede { font-size: 18px; line-height: 1.5; color: var(--ff-slate); margin-bottom: var(--sp-5); max-width: 60ch; }
.ff-eyebrow { font-family: var(--ff-body); font-size: 12px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ff-ember); margin-bottom: var(--sp-3); }
.ff-num { font-family: var(--ff-body); font-weight: 600; font-size: 22px; color: var(--ff-navy); font-variant-numeric: tabular-nums; }
.ff-muted { color: var(--ff-slate); opacity: 0.7; }
.ff-small { font-size: 13px; }

/* ---- Buttons ---- */
.ff-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 12px 22px;
  background: var(--ff-ember);
  color: var(--ff-paper);
  font-family: var(--ff-body);
  font-size: 15px;
  font-weight: 600;
  border: 1px solid var(--ff-ember);
  border-radius: var(--ff-radius);
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.ff-btn:hover { background: var(--ff-ember-deep); border-color: var(--ff-ember-deep); text-decoration: none; color: var(--ff-paper); }
.ff-btn--outline { background: transparent; color: var(--ff-navy); border-color: var(--ff-navy); }
.ff-btn--outline:hover { background: var(--ff-navy); color: var(--ff-paper); border-color: var(--ff-navy); }
.ff-btn--ghost { background: transparent; color: var(--ff-navy); border-color: transparent; padding-left: 0; padding-right: 0; }
.ff-btn--ghost:hover { color: var(--ff-ember-deep); background: transparent; border-color: transparent; }

/* ---- Hero ---- */
.ff-hero {
  padding: var(--sp-9) var(--sp-6) var(--sp-8);
  text-align: left;
  max-width: 1200px;
  margin: 0 auto;
}
.ff-hero p { font-size: 19px; line-height: 1.5; max-width: 60ch; margin-top: var(--sp-4); margin-bottom: var(--sp-6); }
.ff-hero-actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; align-items: center; }

/* ---- Cards / tiles ---- */
.ff-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--sp-5);
}
.ff-tile {
  background: var(--ff-paper);
  border: 1px solid var(--ff-stone);
  border-radius: var(--ff-radius-lg);
  padding: var(--sp-6) var(--sp-5);
  box-shadow: var(--ff-shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.ff-tile h3 { margin-bottom: 0; }
.ff-tile p { margin-bottom: 0; }
.ff-tile .ff-tile-bullets { margin: var(--sp-3) 0 0; padding-left: var(--sp-4); color: var(--ff-slate); }
.ff-tile .ff-tile-bullets li { margin-bottom: var(--sp-2); }

/* ---- Pricing table ---- */
.ff-price-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--sp-5); }
.ff-price-card {
  background: var(--ff-paper);
  border: 1px solid var(--ff-stone);
  border-radius: var(--ff-radius-lg);
  padding: var(--sp-7) var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.ff-price-card--featured {
  border-color: var(--ff-ember);
  border-width: 2px;
  box-shadow: var(--ff-shadow);
}
.ff-price-card .ff-price-tier { font-family: var(--ff-display); font-size: 22px; color: var(--ff-navy); }
.ff-price-card .ff-price-num { font-family: var(--ff-display); font-size: 44px; color: var(--ff-navy); line-height: 1; font-weight: 600; }
.ff-price-card .ff-price-unit { font-size: 13px; color: var(--ff-slate); }
.ff-price-card ul { list-style: none; padding: 0; }
.ff-price-card ul li { padding: var(--sp-2) 0; border-top: 1px solid var(--ff-stone-soft); font-size: 14px; }
.ff-price-card ul li:first-child { border-top: none; }

/* ---- Forms ---- */
.ff-form {
  background: var(--ff-paper);
  border: 1px solid var(--ff-stone);
  border-radius: var(--ff-radius-lg);
  padding: var(--sp-6) var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.ff-field { display: flex; flex-direction: column; gap: var(--sp-2); }
.ff-field label { font-size: 13px; font-weight: 500; color: var(--ff-slate); }
.ff-field input, .ff-field select, .ff-field textarea {
  padding: 11px 14px;
  border: 1px solid var(--ff-stone);
  border-radius: var(--ff-radius);
  font-family: var(--ff-body);
  font-size: 15px;
  color: var(--ff-slate);
  background: var(--ff-paper);
  width: 100%;
}
.ff-field input:focus, .ff-field select:focus, .ff-field textarea:focus {
  outline: none;
  border-color: var(--ff-ember);
  box-shadow: 0 0 0 3px rgba(197, 87, 59, 0.15);
}
.ff-field .ff-hint { font-size: 12px; color: var(--ff-slate); opacity: 0.7; }
.ff-form-status { font-size: 14px; padding: var(--sp-3); border-radius: var(--ff-radius); }
.ff-form-status.ok { background: rgba(74, 143, 111, 0.12); color: var(--ff-sage); }
.ff-form-status.err { background: rgba(162, 59, 31, 0.10); color: var(--ff-rust); }

/* Honeypot */
.ff-hp { position: absolute; left: -9999px; opacity: 0; height: 1px; width: 1px; }

/* ---- Footer ---- */
.ff-footer {
  background: var(--ff-navy);
  color: var(--ff-cream);
  padding: var(--sp-8) var(--sp-6);
  margin-top: var(--sp-9);
}
.ff-footer-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--sp-7); }
.ff-footer h4 { font-family: var(--ff-display); font-size: 16px; font-weight: 400; color: var(--ff-cream); margin-bottom: var(--sp-3); }
.ff-footer a { color: var(--ff-cream); opacity: 0.85; font-size: 14px; display: block; margin-bottom: var(--sp-2); text-decoration: none; }
.ff-footer a:hover { opacity: 1; color: var(--ff-ember); text-decoration: none; }
.ff-footer .ff-footer-brand { font-family: var(--ff-display); font-size: 22px; color: var(--ff-cream); margin-bottom: var(--sp-3); display: block; }
.ff-footer-legal {
  max-width: 1200px;
  margin: var(--sp-7) auto 0;
  padding-top: var(--sp-4);
  border-top: 1px solid rgba(255,255,255,0.08);
  color: var(--ff-cream);
  opacity: 0.75;
  font-size: 12px;
  text-align: center;
  line-height: 1.7;
}
.ff-footer-legal a {
  color: var(--ff-cream);
  text-decoration: underline;
  opacity: 0.95;
}
.ff-footer-legal a:hover { color: var(--ff-ember); opacity: 1; text-decoration: underline; }
.ff-co-flag { width: 14px; height: auto; display: inline-block; vertical-align: middle; margin: 0 4px 0 6px; }

/* ---- Responsive ---- */
@media (max-width: 800px) {
  .ff-hero { padding: var(--sp-7) var(--sp-5) var(--sp-6); }
  .ff-hero-h1 { font-size: 38px; }
  h1 { font-size: 28px; }
  h2 { font-size: 22px; }
  .ff-main { padding: var(--sp-6) var(--sp-5); }
  .ff-footer-inner { grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
  .ff-nav-inner { padding: var(--sp-3) var(--sp-4); }
  .ff-nav-links { gap: var(--sp-3); }
  .ff-nav-links a:not(.ff-nav-cta) { display: none; }
}

@media (max-width: 500px) {
  .ff-footer-inner { grid-template-columns: 1fr; }
}
