/* Soberpedia — Airbnb-style: white surfaces, Cereal-ish geometric sans, coral accent, soft rounded everything */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500&display=swap');

:root {
  /* Core palette — Airbnb-ish */
  --ink: #222222;            /* Airbnb hof black */
  --ink-2: #2B2B2B;
  --ink-3: #3A3A3A;
  --ink-line: #353535;

  --cream: #FFFFFF;          /* white surfaces */
  --cream-2: #F7F7F7;
  --paper: #FFFFFF;
  --paper-2: #F7F7F7;
  --paper-line: #EBEBEB;

  --rausch: #5B8DB8;         /* soft sky-blue primary */
  --rausch-deep: #3A6FA0;
  --babu: #7BA89C;           /* sage teal accent */
  --beach: #E8B86F;
  --arches: #5B8DB8;

  /* aliased to maintain old refs */
  --sage: #7BA89C;
  --sage-deep: #5A8478;
  --sand: #E8F0F7;
  --terracotta: #5B8DB8;
  --rose: #5B8DB8;

  --muted: #717171;
  --muted-cream: #B0B0B0;

  /* Type */
  --serif: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --sans: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, Menlo, monospace;

  /* Spacing scale */
  --s1: 4px; --s2: 8px; --s3: 12px; --s4: 16px; --s5: 24px;
  --s6: 32px; --s7: 48px; --s8: 64px; --s9: 96px; --s10: 128px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.5;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Headings now also use the geometric sans, but heavier */
.serif {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: -0.025em;
}
.mono { font-family: var(--mono); }
.italic { font-style: italic; }

/* Eyebrow — softer, less monospace-utility */
.eyebrow {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--rausch);
}
.eyebrow-cream { color: var(--sand); }

.divider { height: 1px; background: var(--paper-line); width: 100%; }
.divider-dark { height: 1px; background: var(--ink-line); width: 100%; }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, textarea { font-family: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.08); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,0.16); }

/* Buttons — pill, bold */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 24px;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.005em;
  transition: all 180ms ease;
  white-space: nowrap;
}
.btn-primary {
  background: linear-gradient(90deg, var(--rausch) 0%, var(--rausch-deep) 100%);
  color: #fff;
  box-shadow: 0 2px 8px rgba(91,141,184,0.3);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 4px 14px rgba(91,141,184,0.4); }
.btn-cream {
  background: #fff;
  color: var(--ink);
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}
.btn-cream:hover { background: var(--cream-2); }
.btn-ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid #DDDDDD;
}
.btn-ghost:hover { border-color: var(--ink); background: var(--cream-2); }
.btn-ghost-cream {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.4);
}
.btn-ghost-cream:hover { border-color: #fff; background: rgba(255,255,255,0.08); }

/* Chip — pill, soft */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  background: var(--paper-2);
  color: var(--ink);
  border: 1px solid var(--paper-line);
  transition: all 160ms;
}
.chip:hover { border-color: var(--ink); }
.chip-cream { background: rgba(255,255,255,0.08); color: #fff; border-color: rgba(255,255,255,0.18); }
.chip-sage { background: rgba(123,168,156,0.14); color: var(--sage-deep); border-color: rgba(123,168,156,0.35); }

/* Card — bigger radius, softer shadow */
.card {
  background: #fff;
  border: 1px solid var(--paper-line);
  border-radius: 20px;
  padding: 24px;
  transition: all 180ms;
}
.card:hover { box-shadow: 0 6px 24px rgba(0,0,0,0.08); transform: translateY(-2px); }
.card-cream {
  background: var(--ink-2);
  border: 1px solid var(--ink-line);
  border-radius: 20px;
  padding: 24px;
  color: #fff;
}

:focus-visible { outline: 2px solid var(--rausch); outline-offset: 2px; border-radius: 4px; }

.app-shell {
  width: 100%;
  min-height: 100vh;
  background: var(--paper);
}

/* =====================================================================
   Mobile responsive — phones and small tablets (<= 760px)
   Collapses fixed multi-col layouts to single-col, tightens spacing,
   hides elements that don't fit.
===================================================================== */
@media (max-width: 760px) {
  body { font-size: 15px; }
  .btn { padding: 12px 18px; font-size: 14px; }

  /* TopBar — hide the inline search; logo + crisis stay */
  .topbar-search { display: none !important; }

  /* Home hero */
  .home-hero { padding: 40px 18px !important; min-height: 520px !important; }
  .home-section { padding: 40px 18px !important; }

  /* Sober Buddy promo (was 2-col) */
  .home-companion-grid {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
    padding: 56px 18px !important;
  }

  /* Search results page */
  .search-layout {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .search-filter-rail {
    position: fixed !important;
    top: 73px !important;
    left: 0 !important; right: 0 !important; bottom: 0 !important;
    z-index: 60 !important;
    background: #fff !important;
    padding: 24px !important;
    overflow-y: auto !important;
    max-height: none !important;
    transform: translateX(-110%);
    transition: transform 220ms ease;
  }
  .search-filter-rail.is-open { transform: translateX(0); }
  .search-filters-toggle { display: inline-flex !important; }

  /* Facility detail */
  .facility-layout {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }
  .facility-photo-gallery {
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: 200px 100px !important;
    height: auto !important;
    gap: 6px !important;
  }
  .facility-photo-gallery > button:first-child {
    grid-row: 1 !important;
    grid-column: 1 / -1 !important;
  }
  .facility-photo-gallery > *:nth-child(n+4) { display: none !important; }
  .facility-stat-strip {
    grid-template-columns: 1fr 1fr !important;
  }
  .facility-sticky-sidebar {
    position: static !important;
    top: auto !important;
  }

  /* Verify modal */
  .verify-modal-card { padding: 20px !important; }
  .verify-card-photos { flex-direction: column !important; }

  /* Search modal */
  .search-modal-card { padding: 20px !important; gap: 20px !important; }
  .search-modal-locations { flex-wrap: wrap !important; gap: 8px !important; }
  .search-modal-locations > * { flex: 1 1 28% !important; min-width: 90px !important; }

  /* Sitewide footer (was 2fr 1fr 1fr 1fr — overflowed the home page) */
  .site-footer { padding: 48px 18px 32px !important; }
  .site-footer-grid { grid-template-columns: 1fr 1fr !important; gap: 28px 24px !important; }
  .site-footer-grid > div:first-child { grid-column: 1 / -1 !important; }
  .site-footer-bottom { flex-direction: column !important; gap: 12px !important; }
  .site-footer-legal { flex-wrap: wrap !important; gap: 8px 16px !important; }

  /* Support Circle / Recovery Record / Meetings — collapse fixed multi-col grids */
  .cr-page { padding: 40px 18px 72px !important; }
  .cr-collapse { grid-template-columns: 1fr !important; gap: 28px !important; align-items: stretch !important; }
  .cr-panel { padding: 24px !important; }
  .cr-grid-cards { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
  .cr-careteam { grid-template-columns: 1fr !important; gap: 0 !important; }
  .cr-careteam-item { border-right: none !important; padding-right: 0 !important; padding: 16px 0 !important; border-top: 1px solid var(--paper-line); }
  .cr-careteam-item:first-child { border-top: none !important; padding-top: 0 !important; }
  .cr-ledger-row { grid-template-columns: 1fr !important; gap: 3px !important; align-items: start !important; padding: 16px 0 !important; }
  .cr-ledger-row .chip { justify-self: start !important; margin-top: 4px; }
  .cr-meeting-row { grid-template-columns: 1fr !important; gap: 10px !important; align-items: flex-start !important; }
  .cr-meeting-row .btn { align-self: flex-start; }
}

@media (min-width: 761px) {
  .search-filters-toggle { display: none !important; }
}
