/* ===========================================================
   Edial Finance — Design tokens
   Palette: deep navy / warm gold / cream paper / ledger ink
   Type: Fraunces (display) + Inter (body) + IBM Plex Mono (data)
   Signature: numbered ledger rows + dotted index leaders
   =========================================================== */
:root {
  --navy: #0B1E33;
  --navy-soft: #142B47;
  --gold: #C9A227;
  --gold-soft: #E8D38A;
  --cream: #FAF8F3;
  --paper: #FFFFFF;
  --ink: #20242B;
  --ink-muted: #5C7080;
  --line: #E4DFD3;
  --green: #2E7D5B;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'IBM Plex Mono', 'Courier New', monospace;

  --radius: 10px;
  --shadow: 0 6px 24px rgba(11, 30, 51, 0.08);
  --max-width: 1140px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--font-body);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--navy); text-decoration: none; }
a:hover { color: var(--gold); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }

.wrap { max-width: var(--max-width); margin: 0 auto; padding: 0 24px; }

h1, h2, h3 { font-family: var(--font-display); color: var(--navy); line-height: 1.15; margin: 0; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-body); font-weight: 600; font-size: 0.95rem;
  padding: 12px 22px; border-radius: 8px; border: none; cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}
.btn--gold { background: var(--gold); color: var(--navy); }
.btn--gold:hover { background: var(--gold-soft); transform: translateY(-1px); }
.btn--block { width: 100%; }

/* ---------- Header ---------- */
.site-header { background: var(--navy); position: sticky; top: 0; z-index: 50; }
.site-header__inner { display: flex; align-items: center; gap: 28px; padding: 14px 24px; }
.brand { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.brand__mark {
  width: 34px; height: 34px; border-radius: 7px; background: var(--gold);
  color: var(--navy); font-family: var(--font-mono); font-weight: 700;
  display: flex; align-items: center; justify-content: center; font-size: 0.8rem;
}
.brand__text { font-family: var(--font-display); font-size: 1.2rem; color: #fff; font-weight: 600; }
.brand__text em { color: var(--gold-soft); font-style: normal; }

.header-search { position: relative; flex: 1; max-width: 420px; display: flex; }
.header-search__input {
  width: 100%; padding: 10px 44px 10px 14px; border-radius: 8px; border: 1px solid transparent;
  background: rgba(255,255,255,0.1); color: #fff; font-family: var(--font-body); font-size: 0.92rem;
}
.header-search__input::placeholder { color: rgba(255,255,255,0.55); }
.header-search__input:focus { background: #fff; color: var(--ink); outline: none; }
.header-search__btn {
  position: absolute; right: 4px; top: 4px; bottom: 4px; width: 36px; border: none; border-radius: 6px;
  background: var(--gold); color: var(--navy); display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.site-nav { display: flex; gap: 20px; margin-left: auto; flex-shrink: 0; }
.site-nav a { color: rgba(255,255,255,0.8); font-size: 0.92rem; font-weight: 500; }
.site-nav a:hover { color: var(--gold-soft); }

.autocomplete-list {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0; background: #fff; border-radius: 10px;
  box-shadow: var(--shadow); list-style: none; margin: 0; padding: 6px; z-index: 60; max-height: 320px; overflow-y: auto;
}
.autocomplete-list li a {
  display: flex; justify-content: space-between; gap: 10px; padding: 10px 12px; border-radius: 7px; color: var(--ink); font-size: 0.92rem;
}
.autocomplete-list li a:hover, .autocomplete-list li a.is-active { background: var(--cream); color: var(--navy); }
.autocomplete-list .ac-count { font-family: var(--font-mono); font-size: 0.75rem; color: var(--ink-muted); }
.autocomplete-list .ac-empty { padding: 14px 12px; color: var(--ink-muted); font-size: 0.88rem; }

/* ---------- Hero ---------- */
.hero { background: linear-gradient(180deg, var(--navy) 0%, var(--navy-soft) 100%); color: #fff; padding: 72px 0 56px; }
.hero__inner { max-width: 760px; }
.hero__eyebrow { font-family: var(--font-mono); letter-spacing: .08em; text-transform: uppercase; font-size: 0.78rem; color: var(--gold-soft); margin: 0 0 16px; }
.hero__title { font-size: clamp(2.1rem, 4.4vw, 3.1rem); color: #fff; font-weight: 600; margin-bottom: 18px; }
.hero__sub { color: rgba(255,255,255,0.78); font-size: 1.05rem; max-width: 560px; margin-bottom: 32px; }

.hero-search { position: relative; display: flex; align-items: center; gap: 8px; background: #fff; border-radius: 12px; padding: 8px 8px 8px 18px; box-shadow: var(--shadow); }
.hero-search__icon { color: var(--ink-muted); flex-shrink: 0; }
.hero-search__input { flex: 1; border: none; font-size: 1rem; font-family: var(--font-body); padding: 10px 4px; color: var(--ink); }
.hero-search__input:focus { outline: none; }
.autocomplete-list--hero { top: calc(100% + 10px); }
.hero__hint { margin-top: 18px; font-size: 0.88rem; color: rgba(255,255,255,0.65); }
.hero__hint a { color: var(--gold-soft); }
.hero__hint a:hover { color: #fff; }

/* ---------- Sections ---------- */
.section { padding: 64px 0; }
.section--muted { background: #F3EFE3; }
.section__head { margin-bottom: 30px; }
.section__eyebrow { display: block; font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-muted); margin-bottom: 8px; }
.section__head h2 { font-size: clamp(1.6rem, 3vw, 2.1rem); }
.empty-note { color: var(--ink-muted); font-size: 1rem; }

/* ---------- City grid ---------- */
.city-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
.city-card {
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 20px;
  display: flex; flex-direction: column; gap: 6px; transition: border-color .15s, transform .15s;
}
.city-card:hover { border-color: var(--gold); transform: translateY(-2px); }
.city-card__name { font-family: var(--font-display); font-size: 1.2rem; font-weight: 600; color: var(--navy); }
.city-card__count { font-family: var(--font-mono); font-size: 0.78rem; color: var(--ink-muted); }

/* Square photo variant — used once a city has a homepage photo uploaded */
.city-card--photo {
  position: relative; aspect-ratio: 1 / 1; padding: 0; border: none; overflow: hidden;
  background-size: cover; background-position: center; justify-content: flex-end;
  box-shadow: 0 4px 14px rgba(11,30,51,0.12);
}
.city-card--photo:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(11,30,51,0.22); }
.city-card--photo::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(11,30,51,0) 45%, rgba(11,30,51,0.85) 100%);
}
.city-card--photo .city-card__name,
.city-card--photo .city-card__count { position: relative; z-index: 1; padding: 0 16px; }
.city-card--photo .city-card__name { color: #fff; }
.city-card--photo .city-card__count { color: rgba(255,255,255,0.85); margin-bottom: 16px; }

/* ---------- Recently added listings (homepage) ---------- */
.recent-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.recent-card {
  display: flex; align-items: center; gap: 14px; background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 14px 16px; transition: border-color .15s, transform .15s;
}
.recent-card:hover { border-color: var(--gold); transform: translateY(-2px); }
.recent-card__logo { width: 48px; height: 48px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.recent-card__logo--placeholder {
  display: flex; align-items: center; justify-content: center; background: var(--navy); color: var(--gold-soft);
  font-family: var(--font-display); font-weight: 600; font-size: 1.2rem;
}
.recent-card__body { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.recent-card__name { font-weight: 600; color: var(--navy); font-size: 0.96rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.recent-card__city { font-size: 0.82rem; color: var(--ink-muted); }
.recent-card__tag { font-family: var(--font-mono); font-size: 0.68rem; text-transform: uppercase; letter-spacing: .04em; color: var(--green); }

/* ---------- Category picker (city hub page) ---------- */
.category-grid { display: flex; flex-direction: column; gap: 14px; max-width: 640px; }
.category-card {
  display: flex; align-items: center; gap: 18px; background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 22px 24px; transition: border-color .15s, transform .15s, box-shadow .15s;
}
.category-card:hover { border-color: var(--gold); transform: translateY(-2px); box-shadow: var(--shadow); }
.category-card__icon {
  flex-shrink: 0; width: 46px; height: 46px; border-radius: 10px; background: var(--navy); color: var(--gold-soft);
  display: flex; align-items: center; justify-content: center;
}
.category-card__body { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.category-card__name { font-family: var(--font-display); font-size: 1.15rem; font-weight: 600; color: var(--navy); }
.category-card__count { font-family: var(--font-mono); font-size: 0.78rem; color: var(--ink-muted); }
.category-card__arrow { font-size: 1.3rem; color: var(--gold); flex-shrink: 0; transition: transform .15s; }
.category-card:hover .category-card__arrow { transform: translateX(4px); }

/* ---------- How it works ---------- */
.howit-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 28px; }
.howit-card__num { font-family: var(--font-mono); color: var(--gold); font-weight: 600; font-size: 0.85rem; }
.howit-card h3 { font-size: 1.15rem; margin: 8px 0 6px; }
.howit-card p { color: var(--ink-muted); margin: 0; font-size: 0.95rem; }

/* ---------- City hero (listicle page header) ---------- */
.city-hero { background: var(--navy); color: #fff; padding: 40px 0 36px; }
.city-hero__eyebrow { font-family: var(--font-mono); font-size: 0.8rem; color: rgba(255,255,255,0.6); margin: 0 0 10px; }
.city-hero__eyebrow a { color: var(--gold-soft); }
.city-hero h1 { color: #fff; font-size: clamp(1.7rem, 3.6vw, 2.5rem); }
.city-hero__sub { color: rgba(255,255,255,0.75); margin-top: 12px; max-width: 640px; }

/* ---------- Listicle (ledger rows) ---------- */
.listicle { list-style: none; margin: 0 0 56px; padding: 0; counter-reset: none; }
.listicle__item {
  display: flex; gap: 22px; padding: 28px 0; border-bottom: 1px dashed var(--line); scroll-margin-top: 90px;
}
.listicle__item:first-child { padding-top: 6px; }
.listicle__num {
  font-family: var(--font-mono); font-weight: 600; font-size: 1.4rem; color: var(--gold);
  min-width: 52px; flex-shrink: 0; padding-top: 4px;
}
.listicle__logo { width: 52px; height: 52px; object-fit: cover; border-radius: 8px; flex-shrink: 0; border: 1px solid var(--line); }
.listicle__body { flex: 1; min-width: 0; }
.listicle__name { font-size: 1.3rem; margin-bottom: 6px; }
.listicle__meta { font-family: var(--font-mono); font-size: 0.78rem; color: var(--ink-muted); margin: -2px 0 10px; }
.listicle__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.listicle__tag {
  display: inline-block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: .04em; text-transform: uppercase;
  background: rgba(46,125,91,0.1); color: var(--green); padding: 3px 9px; border-radius: 5px;
  transition: background .15s, color .15s;
}
.listicle__tag:hover { background: var(--green); color: #fff; }

.listicle__highlights { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.highlight-chip {
  font-size: 0.78rem; padding: 4px 10px; border-radius: 6px; background: var(--cream); border: 1px solid var(--line); color: var(--ink-muted);
}
.highlight-chip--yes { background: rgba(46,125,91,0.08); border-color: rgba(46,125,91,0.25); color: var(--green); font-weight: 500; }

.listicle__facts { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 28px; margin: 14px 0 0; }
.fact dt { font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-muted); margin-bottom: 5px; }
.fact dd { margin: 0; font-size: 0.96rem; }
.fact__muted { color: var(--ink-muted); font-style: italic; }

.reveal-btn {
  display: inline-flex; align-items: center; gap: 7px; background: var(--navy); color: #fff; border: none;
  padding: 8px 14px; border-radius: 7px; font-size: 0.86rem; font-weight: 500; cursor: pointer; font-family: var(--font-body);
  transition: background .15s;
}
.reveal-btn:hover { background: var(--navy-soft); }
.reveal-btn--ghost { background: transparent; color: var(--navy); border: 1px solid var(--line); }
.reveal-btn--ghost:hover { border-color: var(--gold); background: rgba(201,162,39,0.08); }
.reveal-btn[disabled] { opacity: 0.6; cursor: wait; }

.reveal-result { display: inline-flex; gap: 12px; align-items: center; font-size: 0.96rem; }
.reveal-result a { font-family: var(--font-mono); font-weight: 600; color: var(--navy); }
.reveal-result .wa-link { display: inline-flex; align-items: center; gap: 6px; color: var(--green); font-weight: 600; font-family: var(--font-body); font-size: 0.9rem; }
.reveal-result .wa-link svg { width: 15px; height: 15px; }

.website-result a { font-family: var(--font-mono); font-size: 0.92rem; color: var(--navy); word-break: break-all; }

/* ---------- Table of contents (bottom of listicle page) ---------- */
.toc { border-top: 2px solid var(--navy); padding-top: 28px; }
.toc__title { font-size: 1.3rem; margin-bottom: 18px; }
.toc__list { list-style: none; margin: 0; padding: 0; columns: 2; column-gap: 40px; }
.toc__list li { break-inside: avoid; margin-bottom: 4px; }
.toc__list a {
  display: flex; align-items: baseline; gap: 10px; padding: 9px 0; color: var(--ink);
  border-bottom: 1px dotted var(--line);
}
.toc__list a:hover { color: var(--navy); border-bottom-color: var(--gold); }
.toc__num { font-family: var(--font-mono); font-size: 0.78rem; color: var(--gold); flex-shrink: 0; }
.toc__name { flex: 1; font-size: 0.92rem; }

/* ---------- Modal ---------- */
.modal { position: fixed; inset: 0; z-index: 100; display: flex; align-items: center; justify-content: center; }
.modal[hidden] { display: none; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(11,30,51,0.55); }
.modal__panel {
  position: relative; background: #fff; border-radius: 14px; padding: 30px; max-width: 380px; width: 92%;
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
}
.modal__panel h3 { font-size: 1.2rem; margin-bottom: 8px; }
.modal__panel p { color: var(--ink-muted); font-size: 0.9rem; margin: 0 0 18px; }
.modal__close { position: absolute; top: 14px; right: 16px; background: none; border: none; font-size: 1.4rem; color: var(--ink-muted); cursor: pointer; line-height: 1; }
#revealForm input[type="tel"] {
  width: 100%; padding: 12px 14px; border: 1px solid var(--line); border-radius: 8px; font-size: 1rem; margin-bottom: 14px; font-family: var(--font-body);
}
#revealForm input[type="tel"]:focus { outline: none; border-color: var(--gold); }
.modal__error { color: #B3261E; font-size: 0.85rem; margin: -6px 0 12px; }

/* ---------- Footer ---------- */
.site-footer { background: var(--navy); color: rgba(255,255,255,0.75); margin-top: 40px; }
.site-footer__inner { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 36px; padding: 48px 24px 32px; }
.site-footer .brand__text { color: #fff; }
.site-footer__col h4 { color: #fff; font-family: var(--font-body); font-size: 0.9rem; margin: 0 0 12px; letter-spacing: .03em; }
.site-footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.site-footer__col a { color: rgba(255,255,255,0.7); font-size: 0.9rem; }
.site-footer__col a:hover { color: var(--gold-soft); }
.site-footer__col p { font-size: 0.88rem; margin: 10px 0 0; }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,0.12); padding: 16px 24px; font-size: 0.82rem; }

/* ---------- Admin (lightweight shared styling) ---------- */
.admin-body { background: #F0EEE6; font-family: var(--font-body); }
.admin-shell { display: flex; min-height: 100vh; }
.admin-side { width: 220px; background: var(--navy); color: #fff; padding: 26px 18px; flex-shrink: 0; }
.admin-side a { display: block; color: rgba(255,255,255,0.78); padding: 10px 12px; border-radius: 7px; font-size: 0.92rem; margin-bottom: 2px; }
.admin-side a.is-active, .admin-side a:hover { background: rgba(255,255,255,0.1); color: #fff; }
.admin-main { flex: 1; padding: 32px 36px; max-width: 1100px; }
.admin-main h1 { font-size: 1.6rem; margin-bottom: 22px; }
.admin-card { background: #fff; border-radius: 10px; padding: 24px; box-shadow: var(--shadow); margin-bottom: 24px; }
.admin-card h2 { font-size: 1.1rem; margin-bottom: 14px; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.admin-table th, .admin-table td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--line); }
.admin-table th { font-family: var(--font-mono); font-size: 0.74rem; text-transform: uppercase; letter-spacing: .04em; color: var(--ink-muted); }
.form-row { margin-bottom: 16px; }
.form-row label { display: block; font-size: 0.85rem; font-weight: 600; margin-bottom: 6px; color: var(--ink); }
.form-row input[type=text], .form-row input[type=password], .form-row input[type=file], .form-row select, .form-row textarea {
  width: 100%; padding: 10px 12px; border: 1px solid var(--line); border-radius: 7px; font-size: 0.92rem; font-family: var(--font-body);
}
.form-row textarea { resize: vertical; }
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 16px; margin-bottom: 24px; }
.stat-box { background: #fff; border-radius: 10px; padding: 18px 20px; box-shadow: var(--shadow); }
.stat-box .num { font-family: var(--font-mono); font-size: 1.7rem; color: var(--navy); font-weight: 600; }
.stat-box .label { font-size: 0.82rem; color: var(--ink-muted); }
.badge { display: inline-block; padding: 2px 9px; border-radius: 5px; font-size: 0.72rem; font-family: var(--font-mono); }
.badge--gold { background: rgba(201,162,39,0.15); color: #8a6e10; }
.badge--muted { background: #eee; color: var(--ink-muted); }
.alert { padding: 12px 16px; border-radius: 8px; font-size: 0.9rem; margin-bottom: 18px; }
.alert--success { background: rgba(46,125,91,0.1); color: var(--green); }
.alert--error { background: rgba(179,38,30,0.1); color: #B3261E; }
.btn--small { padding: 6px 12px; font-size: 0.82rem; }
.btn--outline { background: transparent; border: 1px solid var(--line); color: var(--ink); }
.btn--outline:hover { border-color: var(--gold); }
.icon-btn { background: none; border: none; cursor: pointer; color: var(--ink-muted); }
.icon-btn:hover { color: #B3261E; }

/* ---------- Responsive ---------- */
@media (max-width: 880px) {
  .site-header__inner { flex-wrap: wrap; }
  .header-search { order: 3; max-width: 100%; flex: 1 1 100%; }
  .site-nav { display: none; }
  .listicle__facts { grid-template-columns: 1fr; }
  .toc__list { columns: 1; }
  .site-footer__inner { grid-template-columns: 1fr; }
  .admin-shell { flex-direction: column; }
  .admin-side { width: 100%; display: flex; gap: 4px; overflow-x: auto; }
}
@media (max-width: 560px) {
  .hero-search { flex-wrap: wrap; padding: 12px; }
  .hero-search__input { flex: 1 1 100%; order: 1; }
  .hero-search__icon { order: 0; }
  .hero-search .btn { order: 2; width: 100%; }
}
