/* ============================================================
   River Forest Referrals — shared stylesheet
   Palette + base typography intentionally match the covenants site
   so the two read as siblings.
   ============================================================ */
:root{
  --pine:#1d3a2f;       /* deep golf-course green */
  --pine-soft:#2c5043;
  --paper:#f6f3ec;      /* warm parchment */
  --paper-2:#fbf9f4;
  --ink:#272420;        /* near-black text */
  --ink-soft:#5a554c;
  --river:#3f6b7d;      /* slate river blue accent */
  --brass:#a8854f;      /* muted gold */
  --line:#ddd6c6;
  --line-soft:#e8e2d4;
  --verified:#2c7a44;   /* forest-green "✓ Verified Resident" */
  --shadow:0 1px 2px rgba(29,58,47,.06),0 8px 24px rgba(29,58,47,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:Inter,system-ui,sans-serif;line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}

/* ---------- Header ---------- */
header{border-bottom:1px solid var(--line);background:var(--paper)}
.masthead{padding:46px 0 30px}
.eyebrow{
  font-size:15px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass);font-weight:600;margin:0 0 12px
}
h1{
  font-family:Spectral,Georgia,serif;font-weight:600;
  font-size:clamp(30px,5.4vw,46px);line-height:1.04;letter-spacing:-.01em;
  margin:0;color:var(--pine)
}
.sub{margin:18px 0 0;color:var(--ink-soft);font-size:16px;line-height:1.65;max-width:64ch}
.sub b{color:var(--ink);font-weight:600}
.sub a{color:var(--brass);text-decoration:none;font-weight:600;border-bottom:1px solid transparent;transition:border-color .15s}
.sub a:hover{border-bottom-color:var(--brass)}

/* ---------- Page layout (main + right rail) ---------- */
.layout{
  display:grid;grid-template-columns:1fr 340px;gap:40px;
  margin:30px auto 60px
}
@media(max-width:880px){
  .layout{grid-template-columns:1fr;gap:30px}
}

/* ---------- Natural-language search panel ---------- */
.search-panel{margin:0 0 20px}
.search-label{
  display:block;font-family:Spectral,Georgia,serif;font-weight:600;font-size:19px;
  color:var(--pine);margin:0 0 10px
}
.search-box-large{
  position:relative;display:flex;align-items:center;
  background:#fff;border:1.5px solid var(--brass);border-radius:12px;
  box-shadow:var(--shadow);transition:border-color .12s,box-shadow .15s
}
.search-box-large:focus-within{border-color:var(--pine);box-shadow:0 0 0 3px #1d3a2f22,var(--shadow)}
.search-box-large .search-icon{
  width:20px;height:20px;color:var(--brass);
  margin:0 4px 0 16px;flex-shrink:0
}
#qSearch{
  flex:1;min-width:0;font-family:Inter,sans-serif;font-size:16px;color:var(--ink);
  background:transparent;border:none;padding:16px 12px 16px 10px;outline:none
}
#qSearch::placeholder{color:#9a9384;font-style:italic}
#qSearchClear{right:12px}   /* re-uses .q-clear from earlier */
#qSearchClear svg{width:14px;height:14px}

.search-result-header{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin:0 0 16px;padding:10px 14px;
  background:var(--paper-2);border-left:3px solid var(--brass);border-radius:8px
}
.search-showing{color:var(--ink);font-size:14px;line-height:1.5}
.search-showing b{color:var(--pine);font-weight:600}
.search-result-header .btn-secondary{padding:6px 12px;font-size:12.5px;margin-left:auto}

.search-empty-category{
  background:var(--paper-2);border:1px solid var(--line);border-radius:10px;
  padding:16px 18px;color:var(--ink-soft);font-size:14px;line-height:1.55
}
.search-empty-category b{color:var(--ink)}
.search-empty-category a{color:var(--brass);text-decoration:none;font-weight:600;border-bottom:1px solid transparent}
.search-empty-category a:hover{border-bottom-color:var(--brass)}

/* ---------- Top CTA row above the directory ---------- */
.cta-row{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin:0 0 22px
}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;text-decoration:none;
  font-family:Inter,sans-serif;font-weight:600;font-size:14px;color:#22180a;
  background:var(--brass);border:none;border-radius:9px;padding:11px 18px;
  box-shadow:var(--shadow);transition:filter .15s,transform .05s;cursor:pointer
}
.btn-primary:hover{filter:brightness(1.07)}
.btn-primary:active{transform:translateY(1px)}
.btn-primary svg{width:15px;height:15px}
.btn-secondary{
  display:inline-flex;align-items:center;gap:7px;text-decoration:none;
  font-family:Inter,sans-serif;font-weight:600;font-size:13.5px;color:var(--pine);
  background:transparent;border:1.5px solid var(--pine);border-radius:9px;padding:9px 14px;
  transition:background .12s,color .12s;cursor:pointer
}
.btn-secondary:hover{background:var(--pine);color:#f3efe6}

/* ---------- Category sections (collapsible) ---------- */
.category{
  background:var(--paper-2);border:1px solid var(--line);border-radius:11px;
  margin:0 0 12px;overflow:hidden;transition:border-color .15s
}
.category > summary{
  list-style:none;cursor:pointer;padding:15px 18px;
  display:flex;align-items:baseline;gap:12px
}
.category > summary::-webkit-details-marker{display:none}
.category > summary::after{
  content:"+";margin-left:auto;color:var(--ink-soft);font-size:18px;line-height:1;
  transition:transform .15s
}
.category[open] > summary::after{content:"–"}
.cat-name{font-family:Spectral,serif;font-size:19px;font-weight:600;color:var(--pine)}
.cat-count{
  font-family:Inter,sans-serif;font-size:12px;color:#fff;background:var(--pine-soft);
  border-radius:6px;padding:3px 8px;white-space:nowrap;font-weight:600
}

.category > .cards{
  padding:4px 18px 18px;border-top:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:12px
}

/* ---------- Vendor card ---------- */
.vendor{
  background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:14px 16px;transition:border-color .15s,box-shadow .15s
}
.vendor:hover{border-color:var(--brass);box-shadow:var(--shadow)}
.vendor-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap;margin:0
}
.v-name{font-family:Spectral,serif;font-size:18px;font-weight:600;color:var(--ink);margin:0}
.v-meta{margin:6px 0 0;color:var(--ink-soft);font-size:14px;line-height:1.55}
.v-phone{font-weight:600;color:var(--ink)}
.v-contact{color:var(--ink-soft)}
/* Restaurant variant: stack hours on top, phone below, no "ask for" segment. */
.v-meta.v-restaurant{display:flex;flex-direction:column;gap:2px}
.v-hours{color:var(--ink);font-weight:500}
.v-ref{margin:8px 0 0;font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.v-ref-name{display:block;font-weight:500}
.v-verified{
  display:inline-flex;align-items:center;gap:5px;margin-top:3px;
  color:var(--verified);font-weight:600;font-size:13px;letter-spacing:.01em
}
.v-verified svg{width:14px;height:14px;flex-shrink:0}

/* Collapsible "N verified residents" (used when a card has 4+ referrers) */
.v-ref-many{display:inline}
.v-ref-many > summary{
  display:inline;cursor:pointer;color:var(--ink);font-weight:600;
  list-style:none;border-bottom:1px dotted var(--ink-soft)
}
.v-ref-many > summary::-webkit-details-marker{display:none}
.v-ref-many[open] > summary{border-bottom-color:transparent}
.v-ref-many > ul{
  margin:6px 0 0;padding:0 0 0 16px;color:var(--ink-soft);
  font-size:13px;line-height:1.6;list-style:disc
}

.v-actions{display:flex;gap:8px;margin-top:11px;flex-wrap:wrap}
.v-action{
  display:inline-flex;align-items:center;gap:6px;cursor:pointer;
  font-family:Inter,sans-serif;font-weight:600;font-size:12.5px;color:var(--pine);
  background:transparent;border:1px solid var(--line);border-radius:7px;
  padding:6px 11px;transition:border-color .12s,background .12s
}
.v-action:hover{border-color:var(--brass);background:#fff8ee}
.v-action svg{width:13px;height:13px}
.v-action.copied{background:var(--verified);color:#fff;border-color:var(--verified)}

/* ---------- Right sidebar rail ---------- */
.rail{display:flex;flex-direction:column;gap:14px;align-self:start;position:sticky;top:18px}
@media(max-width:880px){.rail{position:static}}
.rail-banners{display:flex;flex-direction:column;gap:14px}
.banner{
  width:300px;height:100px;background:var(--paper-2);
  border:1px solid var(--line);border-radius:10px;overflow:hidden;
  box-shadow:var(--shadow);position:relative;align-self:center
}
.banner img{display:block;width:100%;height:100%;object-fit:cover}
.banner a{display:block;width:100%;height:100%}

/* Placeholder — 300×100 (matches the actual banner size 3:1 aspect). */
.banner-placeholder{
  width:300px;height:100px;border-radius:10px;border:1px dashed var(--line);
  background:linear-gradient(135deg,#fbf9f4 0%,#f0eadb 100%);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-soft);font-size:13px;letter-spacing:.04em;align-self:center
}

/* Exterior-work / covenants cross-link notice under the header intro */
.exterior-notice{
  background:#fbf7ed;border-left:3px solid var(--brass);border-radius:8px;
  padding:12px 16px;margin:18px 0 0;
  font-size:13.5px;color:var(--ink-soft);line-height:1.55;
  max-width:68ch
}
.exterior-notice a{
  color:var(--brass);text-decoration:none;font-weight:600;
  border-bottom:1px solid transparent;transition:border-color .15s
}
.exterior-notice a:hover{border-bottom-color:var(--brass)}

.advertise-cta{
  width:300px;align-self:center;text-decoration:none;
  background:var(--pine);color:#f3efe6;border-radius:10px;padding:18px 18px 16px;
  box-shadow:var(--shadow);display:block;transition:filter .15s
}
.advertise-cta:hover{filter:brightness(1.08)}
.ad-eyebrow{
  display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass);font-weight:600;margin:0 0 6px
}
.ad-eyebrow::before{content:"";display:inline-block;width:14px;height:1px;background:var(--brass);vertical-align:middle;margin-right:8px}
.ad-title{display:block;font-family:Spectral,serif;font-size:20px;font-weight:600;margin:0 0 3px}
.ad-price{display:block;color:#cfe0d6;font-size:13.5px;margin:0 0 10px}
.ad-cta-btn{
  display:inline-flex;align-items:center;gap:6px;text-decoration:none;
  font-family:Inter,sans-serif;font-weight:600;font-size:13px;color:#22180a;
  background:var(--brass);border:none;border-radius:7px;padding:7px 13px
}

/* ---------- Forms (submit + advertise + admin) ---------- */
.form-card{
  background:var(--paper-2);border:1px solid var(--line);border-radius:12px;
  padding:24px 26px;box-shadow:var(--shadow);max-width:640px;margin:24px 0
}
.form-card h2{
  font-family:Spectral,serif;font-weight:600;font-size:22px;color:var(--pine);
  margin:0 0 6px
}
.form-card .form-sub{color:var(--ink-soft);font-size:14px;line-height:1.55;margin:0 0 18px}
.field{display:flex;flex-direction:column;gap:5px;margin:0 0 14px}
.field-row{display:flex;gap:12px;flex-wrap:wrap}
.field-row > .field{flex:1;min-width:180px}
.field label{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:.01em}
.field .req{color:var(--brass)}
.field input,
.field select,
.field textarea{
  font-family:Inter,sans-serif;font-size:15px;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:8px;
  padding:10px 12px;outline:none;transition:border-color .12s,box-shadow .12s
}
.field input:focus,
.field select:focus,
.field textarea:focus{border-color:var(--river);box-shadow:0 0 0 3px #3f6b7d22}
.field input[type=file]{padding:9px 10px;background:#fff}
.field .hint{font-size:12.5px;color:var(--ink-soft);margin-top:1px}
.field .hint.ok{color:var(--verified)}
.field .err{font-size:12.5px;color:#b04a3a;margin-top:1px}

.form-actions{display:flex;align-items:center;gap:12px;margin-top:8px}

/* ---------- Multi-select for categories (submit form) ---------- */
.ms{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:8px;
  padding:6px 10px 8px;transition:border-color .12s,box-shadow .12s;min-height:44px
}
.ms:focus-within{border-color:var(--river);box-shadow:0 0 0 3px #3f6b7d22}
.ms-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:2px}
.ms-chip{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--pine);color:#f3efe6;font-size:13px;font-weight:500;
  border-radius:7px;padding:4px 4px 4px 10px
}
.ms-chip button{
  background:transparent;border:none;color:#cfe0d6;cursor:pointer;
  font-size:16px;line-height:1;padding:0 6px;border-radius:5px;
  transition:color .1s,background .1s
}
.ms-chip button:hover{color:#fff;background:#ffffff1c}
#msInput{
  width:100%;border:none;background:transparent;padding:6px 2px;
  font-family:Inter,sans-serif;font-size:15px;color:var(--ink);outline:none
}
#msInput::placeholder{color:#9a9384}
.ms-dropdown{
  position:absolute;left:-1px;right:-1px;top:calc(100% + 4px);z-index:5;
  background:#fff;border:1px solid var(--line);border-radius:8px;
  max-height:260px;overflow-y:auto;
  box-shadow:0 6px 18px rgba(29,58,47,.10)
}
.ms-item{
  padding:9px 12px;cursor:pointer;font-size:14.5px;color:var(--ink);
  border-bottom:1px solid var(--line-soft)
}
.ms-item:last-child{border-bottom:none}
.ms-item:hover,.ms-item.active{background:var(--paper-2)}
.ms-empty{padding:12px;color:var(--ink-soft);font-size:13px;font-style:italic;text-align:center}
.price-callout{
  display:inline-flex;align-items:baseline;gap:7px;
  background:#fdf3df;border:1px solid #efd7a2;border-radius:9px;
  padding:9px 13px;margin:0 0 14px;font-size:13.5px;color:#5d4818
}
.price-callout b{font-size:16px;color:#22180a}

.form-success{
  background:#eef6ef;border:1px solid #c8e1cf;border-left:3px solid var(--verified);
  border-radius:10px;padding:16px 18px;color:#1f4a2e;margin:0 0 16px;
  font-size:14.5px;line-height:1.5
}
.form-success b{color:var(--verified)}

/* ---------- Disclaimer + footer ---------- */
.disclaimer{
  background:transparent;border-top:1px dashed var(--line);margin-top:32px;padding-top:18px;
  font-size:12.5px;color:var(--ink-soft);line-height:1.5;max-width:64ch
}

footer{border-top:1px solid var(--line);padding:24px 0 40px;color:var(--ink-soft);font-size:12.5px}
footer p{margin:0 0 6px;max-width:70ch}
footer a{color:inherit;border-bottom:1px solid var(--line)}
footer a:hover{color:var(--ink)}

/* ---------- Toast (Copy / Share feedback) ---------- */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--pine);color:#f3efe6;padding:11px 18px;border-radius:9px;
  font-size:14px;box-shadow:var(--shadow);opacity:0;pointer-events:none;
  transition:opacity .2s,transform .2s;z-index:50
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}

/* ---------- Multi-select share footer ---------- */
.share-tray{
  position:fixed;bottom:18px;left:50%;transform:translateX(-50%);
  background:var(--pine);color:#f3efe6;border-radius:12px;padding:10px 14px;
  display:none;align-items:center;gap:12px;box-shadow:var(--shadow);z-index:40
}
.share-tray.on{display:inline-flex}
.share-tray-count{font-size:13px;font-weight:600}
.share-tray-btn{
  background:var(--brass);color:#22180a;border:none;border-radius:7px;
  padding:7px 12px;font-family:Inter,sans-serif;font-weight:600;font-size:13px;cursor:pointer
}
.share-tray-btn.ghost{background:transparent;color:#cfe0d6;font-weight:500}

.vendor.selected{outline:2px solid var(--brass);outline-offset:-1px}
.v-select{
  display:inline-flex;align-items:center;gap:5px;cursor:pointer;
  font-family:Inter,sans-serif;font-weight:500;font-size:12.5px;color:var(--ink-soft);
  background:transparent;border:1px solid var(--line);border-radius:7px;
  padding:6px 10px;transition:border-color .12s,color .12s
}
.v-select.on{border-color:var(--brass);color:var(--brass);font-weight:600}

/* Empty / loading states */
.empty{text-align:center;color:var(--ink-soft);padding:40px 0;font-size:15px}

/* ---------- Text-Me-This SMS dialog ---------- */
.sms-dialog{
  border:none;border-radius:14px;padding:0;
  max-width:440px;width:calc(100vw - 32px);
  background:var(--paper-2);color:var(--ink);
  box-shadow:0 10px 40px rgba(29,58,47,.28),0 2px 6px rgba(29,58,47,.08)
}
.sms-dialog::backdrop{background:rgba(29,58,47,.44);backdrop-filter:blur(2px)}
.sms-dialog form{padding:22px 24px 20px}
.sms-title{font-family:Spectral,serif;font-weight:600;font-size:20px;color:var(--pine);margin:0 0 4px}
.sms-sub{color:var(--ink-soft);font-size:13px;margin:0 0 12px}
.sms-preview{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:12.5px;line-height:1.5;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:8px;
  padding:10px 12px;margin:0;max-height:160px;overflow:auto;white-space:pre-wrap;word-break:break-word
}
.sms-actions{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
.sms-actions .btn-primary,
.sms-actions .btn-secondary{padding:9px 15px;font-size:13.5px}

/* "Coming soon" mini-dialog for Text Me This while Twilio profile is under review */
.sms-soon-body{padding:22px 24px 20px}
.sms-soon-msg{color:var(--ink-soft);font-size:14.5px;line-height:1.55;margin:0 0 16px}
