/*
  TERRA FIRMA — PNT Central Brain Design System
  Applied to booking-intake.html
  Version: 2026.04 — 1AltX LLC

  FONT IMPORTS (add to <head>):
  <link rel="preconnect" href="https://fonts.googleapis.com">
  <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
  <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=DM+Sans:wght@300;400;500;600&display=swap" rel="stylesheet">
*/

/* ── TOKENS ──────────────────────────────────────────────── */
:root {
  --pine:        #1C3829;
  --pine-dim:    rgba(28,56,41,0.06);
  --moss:        #2D5A3D;
  --fern:        #4A7C5B;
  --fern-light:  #6FAB82;
  --terra:       #C05B35;
  --terra-light: #D9826A;
  --gold:        #C8943A;
  --parch:       #F5ECDA;
  --parch-dim:   #EDE4D0;
  --paper:       #FDFAF4;
  --stone:       #9C8B79;
  --stone-light: #C4B8A9;
  --bark:        #2E2318;
  --ink:         #1A1410;
  --white:       #FFFFFF;

  --radius-sm:   4px;
  --radius-md:   6px;
  --radius-lg:   10px;
  --radius-xl:   14px;

  --shadow-card: 0 2px 12px rgba(28,56,41,0.06);
  --shadow-hover:0 6px 24px rgba(28,56,41,0.10);

  --transition: 0.18s ease;
}

/* ── GLOBAL ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'DM Sans', -apple-system, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--ink);
  background: var(--parch);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  line-height: 1.15;
  color: var(--pine);
  letter-spacing: -0.01em;
}

/* ── HEADER ──────────────────────────────────────────────── */
.header, #header {
  background: var(--pine) !important;
  height: 56px !important;
  padding: 0 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 50 !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

.header-logo, .logo {
  filter: brightness(0) invert(1) !important;
  height: 26px !important;
  opacity: 0.9 !important;
}

.booking-id-display {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  color: rgba(255,255,255,0.45) !important;
  letter-spacing: 0.04em !important;
}

.save-indicator {
  font-size: 11px !important;
  color: rgba(255,255,255,0.35) !important;
}

/* ── PROGRESS BAR ────────────────────────────────────────── */
.progress-bar, #progress-bar, .stepper {
  background: var(--paper) !important;
  border-bottom: 1px solid var(--parch-dim) !important;
  padding: 0 32px !important;
}

.step, .progress-step {
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--stone-light) !important;
  padding: 14px 0 !important;
  border-bottom: 2px solid transparent !important;
  transition: color var(--transition), border-color var(--transition) !important;
}

.step.active, .progress-step.active {
  color: var(--white) !important;
  background: var(--pine) !important;
  border-bottom-color: var(--terra) !important;
  border-radius: 6px !important;
}

.step.complete, .progress-step.complete {
  color: var(--fern) !important;
}

/* ── MAIN LAYOUT ─────────────────────────────────────────── */
.page-content, .form-page, #page-content {
  max-width: 860px !important;
  margin: 0 auto !important;
  padding: 36px 32px 80px !important;
}

/* ── PAGE TITLE ──────────────────────────────────────────── */
.page-title, h2.page-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 36px !important;
  font-weight: 500 !important;
  color: var(--pine) !important;
  margin-bottom: 4px !important;
  letter-spacing: -0.02em !important;
}

.page-subtitle {
  font-size: 13px !important;
  font-weight: 300 !important;
  color: var(--stone) !important;
  margin-bottom: 32px !important;
  letter-spacing: 0.02em !important;
}

/* ── SECTION CARDS ───────────────────────────────────────── */
.section-card, .card, .form-section {
  background: var(--paper) !important;
  border: 1px solid var(--parch-dim) !important;
  border-radius: var(--radius-xl) !important;
  padding: 28px 28px 24px !important;
  margin-bottom: 16px !important;
  box-shadow: var(--shadow-card) !important;
}

.section-title, .card-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 20px !important;
  font-weight: 500 !important;
  color: var(--pine) !important;
  margin-bottom: 20px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--parch-dim) !important;
}

/* ── FORM FIELDS ─────────────────────────────────────────── */
label, .field-label {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--stone) !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  display: block !important;
  margin-bottom: 6px !important;
}

input[type=text],
input[type=email],
input[type=tel],
input[type=date],
input[type=time],
input[type=number],
input[type=password],
select,
textarea {
  width: 100% !important;
  padding: 10px 14px !important;
  background: var(--white) !important;
  border: 1px solid var(--parch-dim) !important;
  border-radius: var(--radius-md) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  line-height: 1.4 !important;
  transition: border-color var(--transition), box-shadow var(--transition) !important;
  outline: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

input:focus, select:focus, textarea:focus {
  border-color: var(--fern) !important;
  box-shadow: 0 0 0 3px rgba(74,124,91,0.12) !important;
}

input::placeholder, textarea::placeholder {
  color: var(--stone-light) !important;
  font-weight: 300 !important;
}

select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%239C8B79' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1l5 5 5-5'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  padding-right: 32px !important;
}

.form-grid {
  display: grid !important;
  gap: 16px !important;
}

.form-row-2 { grid-template-columns: 1fr 1fr !important; }
.form-row-3 { grid-template-columns: 1fr 1fr 1fr !important; }

/* ── TYPE-AHEAD / SEARCH INPUT ───────────────────────────── */
.type-ahead-wrap { position: relative !important; }

.type-ahead-results {
  position: absolute !important;
  top: calc(100% + 4px) !important;
  left: 0 !important; right: 0 !important;
  background: var(--white) !important;
  border: 1px solid var(--parch-dim) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: 0 8px 32px rgba(28,56,41,0.12) !important;
  max-height: 260px !important;
  overflow-y: auto !important;
  z-index: 100 !important;
}

.type-ahead-item {
  padding: 10px 14px !important;
  font-size: 13px !important;
  cursor: pointer !important;
  border-bottom: 1px solid var(--parch-dim) !important;
  transition: background var(--transition) !important;
}

.type-ahead-item:hover, .type-ahead-item.selected {
  background: var(--pine-dim) !important;
  color: var(--pine) !important;
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn, button.btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  padding: 10px 20px !important;
  border-radius: var(--radius-md) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  border: 1px solid transparent !important;
  line-height: 1 !important;
}

.btn-primary {
  background: var(--pine) !important;
  color: var(--white) !important;
}
.btn-primary:hover {
  background: var(--moss) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 16px rgba(28,56,41,0.20) !important;
}

.btn-secondary {
  background: var(--terra) !important;
  color: var(--white) !important;
}
.btn-secondary:hover {
  background: var(--terra-light) !important;
  transform: translateY(-1px) !important;
}

.btn-outline {
  background: transparent !important;
  border-color: var(--parch-dim) !important;
  color: var(--ink) !important;
}
.btn-outline:hover {
  border-color: var(--stone) !important;
  background: var(--pine-dim) !important;
}

.btn-ghost {
  background: transparent !important;
  border-color: transparent !important;
  color: var(--stone) !important;
}
.btn-ghost:hover {
  color: var(--ink) !important;
  background: var(--pine-dim) !important;
}

.btn-danger {
  background: transparent !important;
  border-color: #C8362A !important;
  color: #C8362A !important;
}
.btn-danger:hover { background: rgba(200,54,42,0.06) !important; }

.btn:disabled {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
  transform: none !important;
}

.btn-sm { padding: 7px 14px !important; font-size: 12px !important; }
.btn-lg { padding: 13px 28px !important; font-size: 15px !important; }

/* ── PAGE ACTION BAR ─────────────────────────────────────── */
.page-actions {
  position: fixed !important;
  bottom: 0 !important; left: 0 !important; right: 0 !important;
  background: rgba(253,250,244,0.94) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-top: 1px solid var(--parch-dim) !important;
  padding: 16px 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  z-index: 40 !important;
}

/* ── INLINE RECORDS (Hotels, Travelers, Bikes) ───────────── */
.record-row {
  background: var(--parch) !important;
  border: 1px solid var(--parch-dim) !important;
  border-radius: var(--radius-lg) !important;
  padding: 16px 18px !important;
  margin-bottom: 10px !important;
  position: relative !important;
}

.record-row-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 14px !important;
}

.record-row-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 17px !important;
  font-weight: 500 !important;
  color: var(--pine) !important;
}

.record-row-number {
  width: 24px !important; height: 24px !important;
  background: var(--pine) !important;
  border-radius: 50% !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-size: 11px !important; font-weight: 600 !important;
  color: var(--white) !important;
}

/* ── STATUS BADGES ───────────────────────────────────────── */
.badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 3px 9px !important;
  border-radius: 20px !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
}

.badge-confirmed { background: rgba(74,124,91,0.12) !important; color: var(--moss) !important; }
.badge-pending   { background: rgba(200,148,58,0.12) !important; color: var(--gold) !important; }
.badge-draft     { background: rgba(156,139,121,0.12) !important; color: var(--stone) !important; }
.badge-released  { background: rgba(192,91,53,0.12) !important;  color: var(--terra) !important; }

/* ── TOAST NOTIFICATIONS ─────────────────────────────────── */
.toast {
  position: fixed !important;
  bottom: 80px !important; right: 24px !important;
  padding: 12px 18px !important;
  border-radius: var(--radius-lg) !important;
  font-size: 13px !important; font-weight: 400 !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12) !important;
  z-index: 200 !important;
  animation: slideUp 0.3s ease !important;
  max-width: 320px !important;
}

.toast-success { background: var(--pine) !important; color: var(--white) !important; }
.toast-warn    { background: var(--gold) !important; color: var(--bark) !important; }
.toast-error   { background: #C8362A !important; color: var(--white) !important; }

@keyframes slideUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── GENERATE PDFS SECTION ───────────────────────────────── */
.pdf-section {
  margin-top: 24px !important;
  padding-top: 20px !important;
  border-top: 1px solid var(--parch-dim) !important;
}

.pdf-section-title {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--stone) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin-bottom: 12px !important;
}

.pdf-links-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 10px !important;
}

.pdf-link-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 14px !important;
  background: var(--parch) !important;
  border: 1px solid var(--parch-dim) !important;
  border-radius: var(--radius-md) !important;
  font-size: 12px !important; font-weight: 500 !important;
  color: var(--pine) !important;
  text-decoration: none !important;
  transition: all var(--transition) !important;
}
.pdf-link-btn:hover {
  background: var(--pine) !important;
  color: var(--white) !important;
  border-color: var(--pine) !important;
}

/* ── DIVIDERS / SEPARATORS ───────────────────────────────── */
hr, .divider {
  border: none !important;
  border-top: 1px solid var(--parch-dim) !important;
  margin: 20px 0 !important;
}

/* ── EMPTY STATE ─────────────────────────────────────────── */
.empty-state {
  text-align: center !important;
  padding: 40px 20px !important;
  color: var(--stone) !important;
}

.empty-state-icon { font-size: 32px !important; margin-bottom: 10px !important; }
.empty-state-title { font-family: 'Cormorant Garamond', serif !important; font-size: 20px !important; color: var(--pine) !important; margin-bottom: 6px !important; }
.empty-state-desc { font-size: 13px !important; color: var(--stone) !important; }

/* ── LOADING SPINNER ─────────────────────────────────────── */
.spinner {
  width: 18px !important; height: 18px !important;
  border: 2px solid var(--parch-dim) !important;
  border-top-color: var(--pine) !important;
  border-radius: 50% !important;
  animation: spin 0.7s linear infinite !important;
  display: inline-block !important;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 680px) {
  .page-content, .form-page { padding: 24px 16px 80px !important; }
  .form-row-2, .form-row-3  { grid-template-columns: 1fr !important; }
  .section-card, .card       { padding: 20px 18px !important; }
  .header, #header           { padding: 0 16px !important; }
  .page-actions              { padding: 12px 16px !important; }
}
