/* ============================================================
   Jetsites — Components
   Buttons, fields, cards, badges, inputs, navigation.
   Pair with colors_and_type.css.
   ============================================================ */

/* ── BUTTONS ──────────────────────────────────────────────── */

.btn {
  --btn-bg:     var(--jet-navy);
  --btn-fg:     var(--jet-cream);
  --btn-border: var(--jet-navy);
  --btn-bg-hover: var(--jet-navy-700);
  --btn-press: 0.985;

  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: var(--fw-semibold);
  letter-spacing: -0.005em;
  line-height: 1;
  white-space: nowrap;
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 1px solid var(--btn-border);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition:
    background var(--dur-fast) var(--ease-out),
    transform   var(--dur-fast) var(--ease-out),
    box-shadow  var(--dur-base) var(--ease-out);
  box-shadow: var(--shadow-rest);
}
.btn:hover  { background: var(--btn-bg-hover); box-shadow: var(--shadow-raised); }
.btn:active { transform: scale(var(--btn-press)); }

.btn .arrow {
  display: inline-block;
  transition: transform var(--dur-base) var(--ease-out);
}
.btn:hover .arrow { transform: translateX(3px); }

/* Variants */
.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--jet-ink);
  --btn-border: var(--jet-line);
  --btn-bg-hover: var(--jet-cream-200);
}
.on-navy .btn--ghost {
  --btn-fg: var(--jet-cream);
  --btn-border: rgba(244,241,235,0.24);
  --btn-bg-hover: rgba(244,241,235,0.06);
}

.btn--accent {
  --btn-bg: var(--jet-champagne);
  --btn-fg: var(--jet-ink);
  --btn-border: var(--jet-champagne);
  --btn-bg-hover: var(--jet-champagne-300);
}

.btn--link {
  --btn-bg: transparent;
  --btn-fg: var(--jet-champagne-700);
  --btn-border: transparent;
  --btn-bg-hover: transparent;
  padding: 6px 0;
  box-shadow: none;
  border-bottom: 1.5px solid var(--jet-champagne);
  border-radius: 0;
}
.on-navy .btn--link { --btn-fg: var(--jet-champagne); }
.btn--link:hover { opacity: 0.8; box-shadow: none; }

.btn--sm { padding: 10px 18px; font-size: 13px; }
.btn--lg { padding: 18px 30px; font-size: 16px; }

/* ── FIELDS ──────────────────────────────────────────────── */

.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.field label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: var(--fw-medium);
  color: var(--fg-2);
  letter-spacing: 0.01em;
}
.input, .textarea, .select {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--fg);
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--r-field);
  padding: 14px 16px;
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.input::placeholder { color: var(--fg-3); }
.input:focus, .textarea:focus, .select:focus {
  border-color: var(--jet-navy);
  box-shadow: 0 0 0 4px rgba(10,31,68,0.08);
}
.on-navy .input, .on-navy .textarea, .on-navy .select {
  background: rgba(244,241,235,0.04);
  border-color: rgba(244,241,235,0.18);
  color: var(--jet-cream);
}
.on-navy .input::placeholder { color: rgba(244,241,235,0.42); }
.on-navy .input:focus { border-color: var(--jet-champagne); box-shadow: 0 0 0 4px rgba(212,178,122,0.18); }

/* ── CARDS ───────────────────────────────────────────────── */

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 28px;
  box-shadow: var(--shadow-rest);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.card--raised  { box-shadow: var(--shadow-raised); }
.card--premium { box-shadow: var(--shadow-premium); border-color: transparent; }
.card--navy {
  background: var(--jet-navy);
  color: var(--jet-cream);
  border-color: var(--jet-navy-500);
}

.card:hover { transform: translateY(-2px); box-shadow: var(--shadow-raised); }

/* ── BADGES ──────────────────────────────────────────────── */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: var(--surface-2);
  color: var(--fg-2);
  border-radius: var(--r-pill);
  border: 1px solid var(--border);
}
.badge--accent {
  background: transparent;
  color: var(--jet-champagne-700);
  border-color: var(--jet-champagne);
}
.on-navy .badge {
  background: rgba(244,241,235,0.06);
  color: var(--fg-on-navy-2);
  border-color: rgba(244,241,235,0.16);
}
.on-navy .badge--accent {
  background: transparent;
  color: var(--jet-champagne);
  border-color: var(--jet-champagne);
}

/* ── DIVIDERS ────────────────────────────────────────────── */

.hr-line {
  height: 1px;
  background: var(--border);
  border: 0;
  margin: var(--s-7) 0;
}
.on-navy .hr-line { background: var(--border-on-navy); }

.hr-trail {
  width: 56px;
  height: 1.5px;
  background: var(--accent);
  border: 0;
  margin: 0 0 var(--s-5) 0;
}

/* ── METRICS / KPI ───────────────────────────────────────── */

.metric {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.metric .value {
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 1;
  font-weight: var(--fw-black);
  letter-spacing: -0.02em;
  color: var(--jet-navy);
}
.on-navy .metric .value { color: var(--jet-cream); }
.metric .value em {
  font-style: italic;
  font-weight: var(--fw-light);
  color: var(--accent);
}
.metric .label {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--fg-2);
  letter-spacing: 0.02em;
}
.on-navy .metric .label { color: var(--fg-on-navy-2); }

/* ── NAV ─────────────────────────────────────────────────── */

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 0;
}
.nav__links { display: flex; gap: 32px; align-items: center; }
.nav__links a {
  background-image: none;
  font-size: 14px;
  font-weight: var(--fw-medium);
  color: var(--fg);
}
.on-navy .nav__links a { color: var(--fg-on-navy); }

/* ── UTILS ───────────────────────────────────────────────── */

.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.container--wide { max-width: var(--container-wide); }
.stack > * + * { margin-top: var(--s-5); }
.row { display: flex; gap: var(--s-5); }
.row--wrap { flex-wrap: wrap; }
.center { display: flex; align-items: center; justify-content: center; }

.surface-cream { background: var(--surface); }
.surface-navy  { background: var(--surface-inverse); color: var(--fg-on-navy); }
.surface-cream-2 { background: var(--surface-2); }
