/* ============================================================
   site.css — SHARED CORE STYLES
   Loaded by every standard page (not our-work.html / review.html,
   which are standalone designs with their own tokens).
   Page-specific styles stay in each page's inline <style> block,
   which comes AFTER this link so page rules win the cascade.
   ============================================================ */

:root {
  --ink:    #120808;
  --paper:  #FAFAF7;
  --void:   #3A0B0B;
  --gold:   #FF6A3D;
  --amber:  #F0452E;
  --ember:  #E32222;
  --signal: #CA1212;
  --logo-a: #7E0C0C;
  --logo-b: #F42525;
  --fire:   #CA1212; /* flat brand red everywhere a gradient slot is referenced */
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background-color: var(--ink);
  color: var(--paper);
  font-family: 'Inter', sans-serif;
  font-size: .9rem;
  line-height: 1.7;
  margin: 0;
}

.font-display { font-family: 'Bebas Neue', sans-serif; }
.font-heading  { font-family: 'Rajdhani', sans-serif; font-weight: 700; }
.font-mono     { font-family: 'JetBrains Mono', monospace; }

.text-fire   { background: var(--fire); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.text-signal { color: var(--signal); }
.text-body   { color: rgba(250,250,247,.65); }

.card {
  background: rgba(250,250,247,.03);
  border: 1px solid rgba(250,250,247,.07);
  border-radius: 8px;
}
.divider { border-bottom: 1px solid rgba(250,250,247,.06); }

.btn {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: .65rem 1.5rem;
  border-radius: 4px;
  cursor: pointer;
  transition: transform .15s ease, opacity .15s ease;
  text-decoration: none;
}
.btn:hover  { transform: translateY(-1px); opacity: .92; }
.btn:active { transform: translateY(0); opacity: 1; }
.btn:focus-visible { outline: 2px solid var(--signal); outline-offset: 3px; }

.btn-primary { background: var(--signal); color: var(--paper); border: none; }
.btn-ghost   { background: transparent; color: var(--paper); border: 1px solid rgba(250,250,247,.25); }
.btn-ghost:hover { border-color: var(--signal); color: var(--signal); }

.nav-dropdown { display: none; }
.nav-item:focus-within .nav-dropdown { display: block; }

#mobile-menu { display: none; }
#mobile-menu.open { display: flex; flex-direction: column; gap: 1rem; }

.field {
  width: 100%;
  background: rgba(250,250,247,.05);
  border: 1px solid rgba(250,250,247,.12);
  border-radius: 4px;
  color: var(--paper);
  font-family: 'Inter', sans-serif;
  font-size: .9rem;
  padding: .75rem 1rem;
  transition: border-color .15s ease;
  outline: none;
}
.field::placeholder { color: rgba(250,250,247,.3); }
.field:focus { border-color: var(--signal); }

@keyframes btnSpin {
  to { transform: rotate(360deg); }
}

/* Responsive — navbar collapse (1100px so iPad-portrait/tablets get the hamburger,
   not a cramped wrapping desktop nav). */
@media (max-width: 1100px) {
  #navbar nav, #navbar .nav-phone { display: none !important; }
  #hamburger { display: block !important; }
}

/* Process timeline (BlackHawk-style numbered connector) */
.proc-timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin: 0 0 2.5rem;
}
.proc-track {
  position: absolute;
  top: 50%;
  left: 12.5%;
  right: 12.5%;
  height: 2px;
  background: rgba(202,18,18,.45);
  transform: translateY(-50%);
}
.proc-dot-cell { display: flex; justify-content: center; }
.proc-dot {
  position: relative;
  z-index: 1;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--signal);
  border: 2px solid rgba(255,106,61,.85);
  box-shadow: 0 0 18px rgba(202,18,18,.65);
  display: flex;
  align-items: center;
  justify-content: center;
}
.proc-dot span {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  color: var(--paper);
}
@media (max-width: 900px) { .proc-timeline { display: none; } }

/* Native select dropdown panels: render dark so options stay readable */
select { color-scheme: dark; }
select option { background-color: #1A0D0D; color: #FAFAF7; }
