/* Abie's List — Craigslist-inspired layout, slightly warmer palette. */

:root {
  --bg: #fbfaf6;
  --bg-alt: #f3efe6;
  --ink: #1a1a1a;
  --muted: #666;
  --line: #d8d2c4;
  --link: #0a4a8a;
  --link-visited: #5b3a8a;
  --accent: #8a3a2a;        /* warm rust — picked to feel a little Sephardi/Levantine */
  --accent-dark: #6a2a1c;
  --gold: #b8862c;
  --success-bg: #e8f3e3;
  --success-ink: #2c5a23;
  --error-bg:  #fbe4e0;
  --error-ink: #8a2018;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.45;
}

a { color: var(--link); text-decoration: underline; }
a:visited { color: var(--link-visited); }
a:hover { color: var(--accent); }

h1, h2, h3, h4 { font-weight: 600; line-height: 1.2; margin: 0 0 .5em; }
h1 { font-size: 1.6rem; }
h2 { font-size: 1.2rem; }
h3 { font-size: 1.05rem; }

small { font-size: .85em; color: var(--muted); }
.muted { color: var(--muted); }
.req { color: var(--accent); }

/* ---- Layout ---- */
.page {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1rem 1.25rem 3rem;
}

.topbar {
  background: var(--accent);
  color: #fff;
  border-bottom: 3px solid var(--accent-dark);
}
.topbar a, .topbar a:visited { color: #fff; }
.topbar a:hover { color: #ffe2b3; }

.topbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: .65rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.brand {
  display: flex;
  align-items: center;
  gap: .55rem;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -.5px;
}
.brand-mark {
  background: var(--gold);
  color: #1a1a1a;
  width: 32px;
  height: 32px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-family: Georgia, serif;
}
.brand-name { font-family: Georgia, "Times New Roman", serif; }

.topnav { display: flex; gap: 1.25rem; font-size: .95rem; }
.topnav a { text-decoration: none; }

.locale {
  max-width: 1200px;
  margin: 0 auto;
  padding: .25rem 1.25rem .5rem;
  font-size: .8rem;
  color: rgba(255,255,255,.85);
  background: var(--accent);
}

.footer {
  border-top: 1px solid var(--line);
  margin-top: 2rem;
  background: var(--bg-alt);
}
.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1rem 1.25rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5rem;
  font-size: .85rem;
  color: var(--muted);
}

/* ---- Buttons ---- */
.btn {
  display: inline-block;
  padding: .45rem .9rem;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 3px;
  text-decoration: none;
  color: var(--ink);
  font-size: .95rem;
  cursor: pointer;
}
.btn:hover { background: var(--bg-alt); color: var(--ink); }
.btn-primary { background: var(--accent); color: #fff; border-color: var(--accent-dark); }
.btn-primary:hover { background: var(--accent-dark); color: #fff; }
.btn-danger { background: #b8362a; color: #fff; border-color: #8a2418; }
.btn-danger:hover { background: #8a2418; color: #fff; }

/* ---- Hero ---- */
.hero {
  background: var(--bg-alt);
  border: 1px solid var(--line);
  padding: 1.25rem 1.5rem;
  margin-bottom: 1.5rem;
  border-radius: 4px;
}
.hero h1 { margin-bottom: .35rem; }
.hero p { margin: .25rem 0; color: #444; }
.hero-actions { margin-top: .9rem; display: flex; gap: .5rem; flex-wrap: wrap; }

/* ---- Category grid (homepage + post-pick) ---- */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem 1.5rem;
  margin-bottom: 1.5rem;
}
.cat-col { }
.cat-section {
  margin: 0 0 .35rem;
  padding-bottom: .25rem;
  border-bottom: 2px solid var(--accent);
  font-size: 1rem;
  text-transform: lowercase;
}
.cat-section a { color: var(--accent-dark); text-decoration: none; font-weight: 700; }
.cat-section a:hover { color: var(--accent); }
.cat-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.cat-list li {
  padding: 1px 0;
  font-size: .92rem;
}
.cat-list a { text-decoration: none; }
.cat-list a:hover { text-decoration: underline; }

/* ---- Recent ---- */
.recent {
  border-top: 1px solid var(--line);
  padding-top: 1rem;
}
.recent h3 { margin-bottom: .6rem; color: var(--accent-dark); }
.recent-list { list-style: none; margin: 0; padding: 0; }
.recent-list li {
  padding: 4px 0;
  border-bottom: 1px dotted var(--line);
  font-size: .92rem;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: baseline;
}
.recent-date { color: var(--muted); font-variant-numeric: tabular-nums; min-width: 80px; }
.recent-price { color: var(--accent-dark); font-weight: 600; }
.recent-hood { color: var(--muted); }
.recent-cat { color: var(--muted); margin-left: auto; font-size: .85em; }

/* ---- Crumbs ---- */
.crumbs {
  font-size: .85rem;
  color: var(--muted);
  margin-bottom: .75rem;
}
.crumbs a { text-decoration: none; }
.crumbs a:hover { text-decoration: underline; }

.page-title {
  border-bottom: 2px solid var(--accent);
  padding-bottom: .35rem;
  margin-bottom: .9rem;
}
.page-title small {
  font-size: .7em;
  color: var(--muted);
  font-weight: 400;
  margin-left: .5rem;
}

/* ---- Filters ---- */
.filters {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  margin-bottom: 1rem;
  padding: .6rem .75rem;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: 4px;
}
.filters input[type="text"], .filters select {
  padding: .35rem .5rem;
  border: 1px solid var(--line);
  border-radius: 3px;
  background: #fff;
  font-size: .92rem;
}
.filters input[type="text"] { flex: 1; min-width: 180px; }
.filters button {
  padding: .35rem .85rem;
  background: var(--accent);
  color: #fff;
  border: 1px solid var(--accent-dark);
  border-radius: 3px;
  cursor: pointer;
  font-size: .92rem;
}
.filters button:hover { background: var(--accent-dark); }
.filters .clear { font-size: .85rem; color: var(--muted); }

/* ---- Subcats ---- */
.subcats {
  list-style: none;
  margin: 0 0 1.25rem;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .35rem .65rem;
}
.subcats li { font-size: .9rem; }
.subcats a {
  display: inline-block;
  padding: 3px 9px;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: 3px;
  text-decoration: none;
}
.subcats a:hover { background: #fff; }

/* ---- Listings (browse rows) ---- */
.listings { list-style: none; margin: 0; padding: 0; }
.listings .row { border-bottom: 1px dotted var(--line); }
.row-link {
  display: grid;
  grid-template-columns: 60px 90px 1fr auto auto auto;
  gap: .65rem;
  align-items: center;
  padding: .45rem 0;
  text-decoration: none;
  color: var(--ink);
}
.row-link:hover { background: var(--bg-alt); }
.row-thumb {
  width: 50px; height: 50px;
  background: var(--bg-alt) center/cover no-repeat;
  border: 1px solid var(--line);
  border-radius: 3px;
}
.row-thumb-empty {
  background-image:
    linear-gradient(45deg, transparent 48%, var(--line) 48%, var(--line) 52%, transparent 52%),
    linear-gradient(-45deg, transparent 48%, var(--line) 48%, var(--line) 52%, transparent 52%);
}
.row-date { color: var(--muted); font-variant-numeric: tabular-nums; font-size: .88rem; }
.row-title { color: var(--link); text-decoration: underline; }
.row-link:hover .row-title { color: var(--accent); }
.row-price { color: var(--accent-dark); font-weight: 600; }
.row-hood { color: var(--muted); font-size: .9rem; }
.row-cat { color: var(--muted); font-size: .82rem; font-style: italic; }

.empty { padding: 2rem; text-align: center; color: var(--muted); }
.count { color: var(--muted); font-size: .85rem; margin-top: .75rem; }

/* ---- Single listing ---- */
.listing-detail h1 { display: flex; align-items: baseline; gap: .75rem; flex-wrap: wrap; }
.listing-detail h1 .price { color: var(--accent-dark); font-weight: 700; font-size: 1.3rem; }
.listing-detail .meta { color: var(--muted); margin-top: -.25rem; margin-bottom: 1rem; font-size: .9rem; }

.listing-image { margin: 1rem 0; }
.listing-image img {
  max-width: 100%;
  max-height: 480px;
  border: 1px solid var(--line);
  border-radius: 4px;
  display: block;
}

.description {
  white-space: pre-wrap;
  word-wrap: break-word;
  background: #fff;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 4px;
  margin: 1rem 0 1.5rem;
}

.contact-block, .reply-block {
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 1rem 1.25rem;
  margin: 1rem 0;
}
.contact-block h2, .reply-block h2 {
  margin-top: 0;
  color: var(--accent-dark);
  border-bottom: 1px solid var(--line);
  padding-bottom: .25rem;
}

/* ---- Forms ---- */
form label {
  display: block;
  margin: .75rem 0 .25rem;
  font-weight: 600;
  font-size: .92rem;
}
form label small { font-weight: 400; }
form input[type="text"],
form input[type="email"],
form input[type="tel"],
form input[type="file"],
form select,
form textarea {
  width: 100%;
  padding: .45rem .55rem;
  border: 1px solid var(--line);
  border-radius: 3px;
  background: #fff;
  font: inherit;
}
form textarea { resize: vertical; }
form button { margin-top: 1rem; }
form fieldset {
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: .25rem 1rem 1rem;
  margin: 1.25rem 0;
}
form fieldset legend { padding: 0 .35rem; font-weight: 700; color: var(--accent-dark); }

label.checkbox {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-weight: 400;
  margin: .5rem 0 0;
}
label.checkbox input { width: auto; }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 600px) {
  .form-row { grid-template-columns: 1fr; }
}

.post-form { max-width: 720px; }

/* ---- Banners ---- */
.banner {
  padding: .75rem 1rem;
  border-radius: 4px;
  margin-bottom: 1rem;
  border: 1px solid;
}
.banner.success { background: var(--success-bg); border-color: #b8d9a8; color: var(--success-ink); }
.banner.error   { background: var(--error-bg);   border-color: #e8b9b1; color: var(--error-ink); }
.banner ul { margin: 0; padding-left: 1.25rem; }

/* ---- Manage ---- */
.listing-summary {
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
}
.manage-thumb { max-width: 200px; max-height: 150px; border: 1px solid var(--line); border-radius: 3px; }

.replies { margin-top: 1.5rem; }
.reply-list { list-style: none; padding: 0; margin: 0; }
.reply {
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: .75rem 1rem;
  margin-bottom: .65rem;
  background: #fff;
}
.reply-meta { font-size: .9rem; margin: 0 0 .35rem; }
.reply-body { white-space: pre-wrap; margin: 0; }

.danger-zone {
  margin-top: 2.5rem;
  border-top: 1px dashed var(--line);
  padding-top: 1.25rem;
}
.danger-zone h2 { color: #8a2418; }

/* ---- Prose ---- */
.prose { max-width: 720px; }
.prose h2 { margin-top: 1.5rem; color: var(--accent-dark); }
.prose ul, .prose ol { padding-left: 1.5rem; }

.error-message {
  background: var(--error-bg);
  color: var(--error-ink);
  padding: 1rem;
  border-radius: 4px;
  border: 1px solid #e8b9b1;
}

/* ---- Mobile niceties ---- */
@media (max-width: 720px) {
  .row-link {
    grid-template-columns: 50px 1fr auto;
    grid-template-areas:
      "thumb title price"
      "thumb meta meta";
    row-gap: 2px;
  }
  .row-thumb { grid-area: thumb; }
  .row-title { grid-area: title; }
  .row-price { grid-area: price; }
  .row-date, .row-hood, .row-cat {
    grid-area: meta;
    font-size: .82rem;
    display: inline;
    margin-right: .5rem;
  }
  .topnav { font-size: .9rem; gap: 1rem; }
  .brand { font-size: 1.2rem; }
}
