/* =============================================================
   Expert Witness Directory — premium theme
   Light (default) + dark via [data-theme="dark"]
   Display: Cormorant Garamond · UI: Inter
   ============================================================= */

:root {
  --bg:          #faf8f4;
  --bg-alt:      #f1ede5;
  --surface:     #ffffff;
  --surface-2:   #f6f3ec;
  --text:        #1d1c1a;
  --text-soft:   #5c5850;
  --line:        #e3ddd1;
  --accent:      #8d6b2e;   /* aged brass */
  --accent-ink:  #ffffff;
  --accent-soft: #f0e7d4;
  --danger:      #a33a2e;
  --ok:          #2e6b46;
  --shadow:      0 1px 2px rgba(30,25,15,.05), 0 8px 28px rgba(30,25,15,.07);
  --radius:      10px;
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-ui:      'Inter', -apple-system, system-ui, sans-serif;

  --bronze:   #a97142;
  --silver:   #7e8a99;
  --gold:     #b3891d;
  --platinum: #6c7fdd;
}

[data-theme="dark"] {
  --bg:          #12100d;
  --bg-alt:      #191611;
  --surface:     #1f1b15;
  --surface-2:   #262119;
  --text:        #ece7dc;
  --text-soft:   #a89f8e;
  --line:        #352e24;
  --accent:      #c9a44e;
  --accent-ink:  #171310;
  --accent-soft: #2e2718;
  --danger:      #d96a5c;
  --ok:          #6fbb8e;
  --shadow:      0 1px 2px rgba(0,0,0,.4), 0 10px 32px rgba(0,0,0,.45);

  --silver:   #9aa5b4;
  --gold:     #d4af37;
  --platinum: #8d9ef0;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3 { font-family: var(--font-display); font-weight: 600; line-height: 1.15; margin: 0 0 .4em; }
h1 { font-size: 2.6rem; }
h2 { font-size: 1.9rem; }
h3 { font-size: 1.25rem; }
.container { max-width: 1160px; margin: 0 auto; padding: 0 24px; }
.muted { color: var(--text-soft); }
.mono { font-family: ui-monospace, Menlo, Consolas, monospace; font-size: .85em; word-break: break-all; }

/* --------------- header --------------- */
.site-header {
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 50;
}
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 68px; gap: 16px; }
.brand { display: flex; align-items: center; gap: 10px; color: var(--text); font-family: var(--font-display); font-size: 1.35rem; font-weight: 700; }
.brand:hover { text-decoration: none; }
.brand-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 8px;
  background: var(--accent); color: var(--accent-ink);
  font-size: 1.1rem; font-family: var(--font-display);
}
.brand small { font-family: var(--font-ui); font-size: .65rem; color: var(--text-soft); letter-spacing: .12em; text-transform: uppercase; }
.main-nav { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.main-nav a { color: var(--text); font-weight: 500; font-size: .93rem; }
.main-nav a:hover { color: var(--accent); text-decoration: none; }
.nav-cta {
  background: var(--accent); color: var(--accent-ink) !important;
  padding: 9px 18px; border-radius: 100px; font-weight: 600;
}
.nav-cta:hover { filter: brightness(1.08); }
.theme-toggle {
  background: none; border: 1px solid var(--line); color: var(--text);
  width: 34px; height: 34px; border-radius: 50%; cursor: pointer; font-size: .95rem;
}
.theme-toggle:hover { border-color: var(--accent); color: var(--accent); }

/* --------------- hero --------------- */
.hero { padding: 88px 0 64px; background:
  radial-gradient(1000px 400px at 70% -10%, var(--accent-soft), transparent 65%), var(--bg); text-align: center; }
.hero h1 { font-size: clamp(2.4rem, 5.5vw, 4rem); }
.hero h1 em { font-style: italic; color: var(--accent); }
.hero-sub { max-width: 620px; margin: 0 auto 32px; color: var(--text-soft); font-size: 1.1rem; }
.hero-search {
  display: flex; gap: 10px; max-width: 780px; margin: 0 auto;
  background: var(--surface); padding: 10px; border-radius: 14px;
  border: 1px solid var(--line); box-shadow: var(--shadow);
}
.hero-search input {
  flex: 1; border: none; background: transparent; color: var(--text);
  font-size: 1rem; padding: 10px 12px; outline: none; min-width: 0;
}
.hero-loc { max-width: 180px; border-left: 1px solid var(--line) !important; border-radius: 0; }
.hero-stats { margin-top: 26px; color: var(--text-soft); font-size: .95rem; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.hero-stats strong { color: var(--text); }
.dot { opacity: .5; }

/* --------------- buttons --------------- */
.btn {
  display: inline-block; padding: 11px 22px; border-radius: 100px;
  font-weight: 600; font-size: .95rem; font-family: var(--font-ui);
  border: 1px solid transparent; cursor: pointer; text-align: center;
  transition: filter .15s, background .15s;
}
.btn:hover { text-decoration: none; filter: brightness(1.06); }
.btn-primary { background: var(--accent); color: var(--accent-ink); }
.btn-ghost { background: transparent; color: var(--text); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); }
.btn-lg { padding: 14px 30px; font-size: 1.05rem; }
.btn-block { display: block; width: 100%; }

/* --------------- sections --------------- */
.section { padding: 56px 0; }
.section-alt { background: var(--bg-alt); }
.section-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 28px; }
.see-all { font-weight: 600; font-size: .92rem; }
.page-head { padding: 44px 0 8px; }
.page-head h1 { margin-bottom: .2em; }

/* --------------- cards / grids --------------- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 22px; }
.expert-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px; color: var(--text); box-shadow: var(--shadow);
  transition: transform .15s, border-color .15s; display: block;
}
.expert-card:hover { transform: translateY(-3px); border-color: var(--accent); text-decoration: none; }
.expert-card-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 14px; }
.expert-card-top img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; border: 2px solid var(--line); }
.expert-card h3 { margin-bottom: 2px; }
.creds { color: var(--text-soft); font-family: var(--font-ui); font-size: .8em; font-weight: 500; }
.expert-title { color: var(--text-soft); font-size: .92rem; margin: 0 0 4px; }
.expert-loc { color: var(--text-soft); font-size: .88rem; margin: 0; }

.tag-row { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.tag {
  background: var(--surface-2); border: 1px solid var(--line); color: var(--text-soft);
  font-size: .78rem; padding: 3px 10px; border-radius: 100px; white-space: nowrap;
}
a.tag:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }
.tag-row-wrap { max-width: 100%; }

.category-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 18px; }
.category-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 20px; color: var(--text); display: block; transition: border-color .15s;
}
.category-card:hover { border-color: var(--accent); text-decoration: none; }
.category-card h3 { margin-bottom: 4px; }
.category-count { color: var(--text-soft); font-size: .85rem; }
.category-card-lg a { color: var(--text); }

.cta-band { background: var(--bg-alt); }
.cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.cta-inner p { color: var(--text-soft); max-width: 560px; }

/* --------------- tier badges --------------- */
.badge {
  display: inline-block; font-size: .72rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; padding: 4px 11px; border-radius: 100px; color: #fff;
}
.badge-free     { background: var(--text-soft); }
.badge-bronze   { background: var(--bronze); }
.badge-silver   { background: var(--silver); }
.badge-gold     { background: var(--gold); }
.badge-platinum { background: var(--platinum); }

/* --------------- search page --------------- */
.search-layout { display: grid; grid-template-columns: 260px 1fr; gap: 36px; align-items: start; }
.filters {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 20px; position: sticky; top: 88px;
}
.filters label, .auth-box label, .edit-form label, .dash-panel label, .side-card label {
  display: block; font-size: .85rem; font-weight: 600; color: var(--text-soft); margin-bottom: 14px;
}
input[type=text], input[type=email], input[type=password], input[type=number], select, textarea {
  width: 100%; margin-top: 5px; padding: 10px 12px;
  border: 1px solid var(--line); border-radius: 8px;
  background: var(--bg); color: var(--text); font-family: var(--font-ui); font-size: .95rem;
}
input:focus, select:focus, textarea:focus { outline: 2px solid var(--accent); outline-offset: 0; border-color: var(--accent); }
input[type=file] { margin-top: 6px; font-size: .88rem; color: var(--text-soft); }

.results { min-width: 0; }
.result-row {
  display: flex; gap: 20px; background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 20px; margin-bottom: 16px; color: var(--text);
  transition: border-color .15s; box-shadow: var(--shadow);
}
.result-row:hover { border-color: var(--accent); text-decoration: none; }
.result-row > img { width: 86px; height: 86px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2px solid var(--line); }
.result-body { min-width: 0; flex: 1; }
.result-name { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.result-name h3 { margin: 0; }
.result-excerpt { color: var(--text-soft); font-size: .92rem; margin: 6px 0; }
.result-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.empty-state { text-align: center; padding: 60px 20px; color: var(--text-soft); }
.pagination { display: flex; justify-content: center; align-items: center; gap: 18px; padding: 24px 0; color: var(--text-soft); }

/* --------------- profile page --------------- */
.profile-hero { background: var(--surface); border-bottom: 1px solid var(--line); padding: 48px 0; }
.profile-hero-inner { display: flex; gap: 32px; align-items: flex-start; flex-wrap: wrap; }
.profile-photo { width: 148px; height: 148px; border-radius: 50%; object-fit: cover; border: 3px solid var(--line); box-shadow: var(--shadow); }
.profile-id { flex: 1; min-width: 260px; }
.profile-name-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.profile-name-row h1 { margin: 0; font-size: 2.3rem; }
.profile-title { font-size: 1.12rem; color: var(--text-soft); margin: 6px 0 2px; }
.profile-company { color: var(--text-soft); margin: 0 0 6px; }
.profile-actions { display: flex; flex-direction: column; gap: 10px; min-width: 220px; }
.unclaimed-note { font-size: .82rem; color: var(--text-soft); max-width: 230px; }

.profile-layout { display: grid; grid-template-columns: 1fr 330px; gap: 36px; align-items: start; }
.profile-main { min-width: 0; }
.profile-block {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px; margin-bottom: 24px; box-shadow: var(--shadow);
}
.profile-block h2 { font-size: 1.5rem; border-bottom: 1px solid var(--line); padding-bottom: 10px; margin-bottom: 18px; }
.richtext p { margin: 0 0 1em; }
.sub-head { font-family: var(--font-ui); font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text-soft); margin: 18px 0 8px; }
.struct-list { padding-left: 18px; margin: 0; }
.struct-list li { margin-bottom: 8px; }
.struct-list.compact li { margin-bottom: 4px; font-size: .92rem; }
.pub-type {
  font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em;
  background: var(--surface-2); border: 1px solid var(--line); border-radius: 4px;
  padding: 1px 6px; margin-right: 6px; color: var(--text-soft);
}

.case-item { border-left: 3px solid var(--accent); padding: 4px 0 4px 18px; margin-bottom: 22px; }
.case-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.case-head h3 { margin: 0; }
.case-meta { color: var(--text-soft); font-size: .88rem; margin: 4px 0 8px; }
.case-outcome { font-size: .92rem; }
.case-role { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 3px 10px; border-radius: 100px; color: #fff; }
.role-plaintiff  { background: #7d4b9e; }
.role-defense    { background: #365f8c; }
.role-neutral    { background: #4f7350; }
.role-consulting { background: #8a6d3b; }

.testimonial { margin: 0 0 20px; border-left: 3px solid var(--accent); padding-left: 18px; }
.testimonial p { font-family: var(--font-display); font-size: 1.15rem; font-style: italic; margin: 0 0 6px; }
.testimonial cite { color: var(--text-soft); font-style: normal; font-size: .9rem; }

.video-wrap { position: relative; padding-top: 56.25%; border-radius: 8px; overflow: hidden; margin-bottom: 8px; }
.video-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.video-caption { color: var(--text-soft); font-size: .88rem; margin: 0 0 16px; }

.profile-side { position: sticky; top: 88px; }
.side-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px; margin-bottom: 18px; box-shadow: var(--shadow);
}
.side-card h3 { margin-bottom: 12px; }
.side-line { margin: 0 0 8px; }
.rate-line { font-size: 1.25rem; font-weight: 600; font-family: var(--font-display); margin: 0 0 4px; }

/* honeypot */
.hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; }

/* --------------- pricing --------------- */
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 18px; align-items: stretch; }
.price-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px 22px; position: relative; display: flex; flex-direction: column;
  box-shadow: var(--shadow);
}
.price-card-featured { border-color: var(--accent); border-width: 2px; }
.price-card-current { outline: 2px solid var(--accent); }
.ribbon {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--accent); color: var(--accent-ink); font-size: .7rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase; padding: 4px 14px; border-radius: 100px; white-space: nowrap;
}
.price { font-family: var(--font-display); font-size: 2.2rem; font-weight: 700; margin: 6px 0; }
.per { font-size: .95rem; color: var(--text-soft); font-family: var(--font-ui); font-weight: 400; }
.price-blurb { color: var(--text-soft); font-size: .88rem; min-height: 2.6em; }
.feature-list { list-style: none; padding: 0; margin: 0 0 22px; flex: 1; }
.feature-list li { padding: 6px 0 6px 24px; position: relative; font-size: .9rem; border-bottom: 1px dashed var(--line); }
.feature-list li:before { content: '✓'; position: absolute; left: 2px; color: var(--ok); font-weight: 700; }
.feature-list li.muted-li { color: var(--text-soft); }
.feature-list li.muted-li:before { content: '·'; }
.tier-bronze   h3 { color: var(--bronze); }
.tier-silver   h3 { color: var(--silver); }
.tier-gold     h3 { color: var(--gold); }
.tier-platinum h3 { color: var(--platinum); }
.pricing-notes { margin-top: 48px; max-width: 800px; }
.how-list li { margin-bottom: 12px; }

/* --------------- auth / small forms --------------- */
.auth-box { max-width: 460px; background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 36px; box-shadow: var(--shadow); }
.auth-alt { font-size: .9rem; color: var(--text-soft); margin-top: 18px; }
.claim-preview { background: var(--surface-2); border: 1px solid var(--line); border-radius: 8px; padding: 14px 16px; margin-bottom: 18px; }

/* --------------- flash --------------- */
.flash { max-width: 1160px; margin: 16px auto 0; padding: 12px 20px; border-radius: 8px; font-size: .93rem; }
.flash-success { background: color-mix(in srgb, var(--ok) 12%, var(--surface)); border: 1px solid var(--ok); color: var(--ok); }
.flash-error   { background: color-mix(in srgb, var(--danger) 12%, var(--surface)); border: 1px solid var(--danger); color: var(--danger); }

/* --------------- dashboard --------------- */
.dash-head { background: var(--surface); border-bottom: 1px solid var(--line); padding-bottom: 0; }
.dash-head-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; flex-wrap: wrap; }
.dash-head-actions { display: flex; gap: 10px; }
.dash-nav { display: flex; gap: 4px; margin-top: 18px; flex-wrap: wrap; }
.dash-nav a {
  color: var(--text-soft); font-weight: 600; font-size: .92rem;
  padding: 10px 16px; border-bottom: 2px solid transparent;
}
.dash-nav a:hover { color: var(--accent); text-decoration: none; border-bottom-color: var(--accent); }

.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 16px; margin-bottom: 28px; }
.stat-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 20px; display: flex; flex-direction: column; box-shadow: var(--shadow);
}
.stat-num { font-family: var(--font-display); font-size: 2rem; font-weight: 700; }
.stat-sub { font-size: 1rem; color: var(--text-soft); }
.stat-label { color: var(--text-soft); font-size: .82rem; }

.upsell-band {
  display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap;
  background: var(--accent-soft); border: 1px solid var(--accent); border-radius: var(--radius);
  padding: 18px 24px; margin-bottom: 28px;
}
.upsell-band p { margin: 0; max-width: 720px; }

.dash-panel {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px; margin-bottom: 24px; box-shadow: var(--shadow);
}
.dash-panel h2 { font-size: 1.35rem; margin-bottom: 14px; }
.panel-locked { opacity: .75; }
.panel-head { display: flex; justify-content: space-between; align-items: center; gap: 14px; flex-wrap: wrap; }
.lock-pill {
  font-size: .78rem; font-weight: 600; background: var(--surface-2);
  border: 1px solid var(--line); padding: 4px 12px; border-radius: 100px; color: var(--text-soft);
}
.lock-pill:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }

.todo-list { list-style: none; padding: 0; margin: 0; }
.todo-list li { padding: 8px 0 8px 26px; position: relative; border-bottom: 1px dashed var(--line); }
.todo-list li:before { content: '→'; position: absolute; left: 2px; color: var(--accent); }

.msg-item { border-bottom: 1px solid var(--line); padding: 12px 0; }
.msg-item:last-child { border-bottom: none; }
.msg-meta { font-size: .85rem; color: var(--text-soft); margin: 0 0 4px; }

.form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0 20px; }
.span-2 { grid-column: 1 / -1; }
.thumb { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; }
.check-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 4px 16px; margin-bottom: 10px; }
.check { display: flex !important; align-items: center; gap: 8px; font-weight: 500 !important; margin-bottom: 6px !important; }
.check input { width: auto; margin: 0; }

.entry-list { list-style: none; padding: 0; margin: 0 0 14px; }
.entry-list li {
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
  padding: 9px 0; border-bottom: 1px dashed var(--line); font-size: .93rem;
}
.inline-form { display: inline; }
.btn-x { background: none; border: none; color: var(--danger); cursor: pointer; font-size: .95rem; padding: 2px 6px; }
.add-entry summary { cursor: pointer; font-weight: 600; color: var(--accent); margin-bottom: 12px; }
.module-list { list-style: none; padding: 0; margin: 0 0 18px; }
.module-list li { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px dashed var(--line); }
.module-list li.locked { color: var(--text-soft); }

/* --------------- tables / pills --------------- */
.data-table { width: 100%; border-collapse: collapse; font-size: .9rem; margin-bottom: 14px; }
.data-table th {
  text-align: left; font-size: .72rem; text-transform: uppercase; letter-spacing: .08em;
  color: var(--text-soft); padding: 8px 10px; border-bottom: 2px solid var(--line);
}
.data-table td { padding: 9px 10px; border-bottom: 1px solid var(--line); vertical-align: top; }
.data-table input[type=text], .data-table input[type=number] { margin-top: 0; padding: 6px 8px; }

.pill { display: inline-block; font-size: .72rem; font-weight: 700; padding: 2px 10px; border-radius: 100px; text-transform: uppercase; letter-spacing: .05em; }
.pill-paid, .pill-sent, .pill-active   { background: color-mix(in srgb, var(--ok) 18%, transparent); color: var(--ok); }
.pill-pending, .pill-queued, .pill-unclaimed { background: color-mix(in srgb, var(--gold) 20%, transparent); color: var(--gold); }
.pill-failed, .pill-suspended, .pill-removed, .pill-refunded { background: color-mix(in srgb, var(--danger) 16%, transparent); color: var(--danger); }

/* --------------- admin --------------- */
.admin-body { background: var(--bg); }
.admin-header .main-nav a { font-size: .88rem; }
.admin-main { padding: 32px 0 64px; }
.admin-title { font-size: 2rem; margin: 12px 0 24px; }
.admin-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.filter-bar { display: flex; gap: 10px; align-items: center; margin-bottom: 20px; flex-wrap: wrap; }
.filter-bar input, .filter-bar select { width: auto; margin: 0; }
.row-actions { white-space: nowrap; }
.btn-mini {
  display: inline-block; font-size: .78rem; font-weight: 600; padding: 3px 10px;
  border: 1px solid var(--line); border-radius: 100px; background: var(--surface);
  color: var(--text); cursor: pointer; margin: 1px;
}
.btn-mini:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }
.btn-mini-danger { color: var(--danger); }
.btn-mini-danger:hover { border-color: var(--danger); color: var(--danger); }

.bar-chart { display: flex; align-items: flex-end; gap: 2px; height: 140px; }
.bar { flex: 1; background: var(--accent); border-radius: 2px 2px 0 0; min-width: 3px; opacity: .85; }
.bar:hover { opacity: 1; }

/* --------------- footer --------------- */
.site-footer { background: var(--surface); border-top: 1px solid var(--line); margin-top: 56px; }
.footer-inner { display: grid; grid-template-columns: 2fr 1fr 1fr 1.4fr; gap: 32px; padding: 44px 24px; }
.footer-col h4 { font-size: .78rem; text-transform: uppercase; letter-spacing: .1em; color: var(--text-soft); margin: 0 0 12px; }
.footer-col a { display: block; color: var(--text); font-size: .92rem; margin-bottom: 8px; }
.footer-tag { color: var(--text-soft); font-size: .9rem; }
.footer-fine { color: var(--text-soft); font-size: .82rem; }
.footer-legal { border-top: 1px solid var(--line); padding: 18px 24px; font-size: .8rem; color: var(--text-soft); }

/* --------------- responsive --------------- */
@media (max-width: 900px) {
  .search-layout, .profile-layout, .admin-cols { grid-template-columns: 1fr; }
  .filters, .profile-side { position: static; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .hero-search { flex-direction: column; }
  .hero-loc { max-width: none; border-left: none !important; }
  .header-inner { height: auto; padding: 12px 0; flex-wrap: wrap; }
}
