/* ============================================================
   Hawthorn Intelligence — Modern CRM Stylesheet v2
   Palette: deep forest green · warm cream · antique gold
   Type: Inter (UI) · Georgia (brand / headings)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;1,14..32,400&display=swap');

/* ─── Design tokens ──────────────────────────────────────── */
:root {
  /* Brand palette */
  --g900: #0d1f15; --g800: #132b1d; --g700: #1a3826; --g600: #1f4530;
  --g500: #2a5c3f; --g400: #3d7252; --g300: #5a9070; --g200: #98c4ab;
  --g100: #d0e8db; --g50:  #edf5f0;

  --gold-dk:   #7a5e1e;
  --gold:      #b8965a;
  --gold-lt:   #d4b87e;
  --gold-pale: #f5edd8;
  --gold-ultra:#faf6ee;

  --cream:     #f6f3ec;
  --cream-lt:  #faf8f3;
  --white:     #ffffff;

  /* Semantic */
  --bg:        var(--cream);
  --bg-sub:    var(--cream-lt);
  --surface:   var(--white);
  --surface-2: #faf8f4;
  --border:    #e6e0d4;
  --border-2:  #cec7b8;

  --text:   #18221a;
  --text-2: #3d4a3e;
  --text-3: #7a8872;

  --ok:       #2a7a4a; --ok-bg:  #e6f4ed; --ok-bd:  #b0d8be;
  --warn:     #8c6408; --warn-bg:#fef3db; --warn-bd:#f0d080;
  --danger:   #b83228; --danger-bg:#fde8e6; --danger-bd:#f0b0a8;

  /* Layout */
  --sidebar-w:   240px;
  --sidebar-min: 64px;

  /* Radius */
  --r-xs: 4px;  --r-sm: 6px;  --r: 10px;
  --r-md: 12px; --r-lg: 16px; --r-xl: 20px;

  /* Shadows */
  --sh-xs: 0 1px 2px rgba(18,34,26,.04);
  --sh-sm: 0 1px 3px rgba(18,34,26,.06), 0 2px 8px rgba(18,34,26,.05);
  --sh:    0 2px 6px rgba(18,34,26,.07), 0 8px 24px rgba(18,34,26,.06);
  --sh-lg: 0 4px 16px rgba(18,34,26,.10), 0 24px 64px rgba(18,34,26,.08);

  /* Motion */
  --t:     160ms cubic-bezier(.4,0,.2,1);
  --t-sl:  280ms cubic-bezier(.4,0,.2,1);
}

/* ─── Reset ─────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:14px; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body {
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg); color:var(--text); font-size:14px; line-height:1.55; letter-spacing:-.01em;
}
h1,h2,h3 { font-family:Georgia,'Times New Roman',serif; font-weight:600; letter-spacing:-.02em; }
button { font:inherit; cursor:pointer; border:none; background:none; letter-spacing:inherit; }
input,select,textarea { font:inherit; letter-spacing:inherit; }
a { color:var(--g500); text-decoration:none; }
a:hover { color:var(--g700); }

/* ─── Auth ───────────────────────────────────────────────── */
#authScreen {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(145deg, var(--g700) 0%, #0d2018 55%, var(--g800) 100%);
  padding:24px;
}
.authCard {
  background:var(--white); border-radius:var(--r-xl);
  box-shadow:var(--sh-lg); width:100%; max-width:420px; padding:44px 40px;
}
.brandMark { text-align:center; margin-bottom:32px; }
.brandMark .leaf {
  width:48px; height:48px; border-radius:14px; background:var(--g700);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--gold-lt); font-family:Georgia,serif; font-size:24px;
  margin-bottom:14px; box-shadow:0 4px 14px rgba(26,56,38,.35);
}
.brandMark h1 { font-size:20px; color:var(--g700); }
.brandMark p  { color:var(--text-3); font-size:11.5px; margin-top:3px; text-transform:uppercase; letter-spacing:1.8px; }
.brandMark em { display:block; font-size:11.5px; color:var(--text-3); margin-top:6px; font-style:italic; }

.authTabs { display:flex; border-bottom:1px solid var(--border); margin-bottom:24px; gap:2px; }
.authTabs button { flex:1; padding:10px 8px; color:var(--text-3); font-weight:600; font-size:13.5px; border-bottom:2px solid transparent; transition:color var(--t),border-color var(--t); }
.authTabs button.on { color:var(--g600); border-bottom-color:var(--gold); }
.authTabs button:not(.on):hover { color:var(--text-2); }

.field { margin-bottom:15px; }
.field label { display:block; font-size:11.5px; font-weight:600; color:var(--text-3); margin-bottom:5px; text-transform:uppercase; letter-spacing:.6px; }
.field input,.field select {
  width:100%; padding:10px 12px; border:1.5px solid var(--border);
  border-radius:var(--r-sm); background:var(--bg-sub); color:var(--text);
  transition:border-color var(--t),box-shadow var(--t);
}
.field input:focus,.field select:focus {
  outline:none; border-color:var(--g400); background:var(--white);
  box-shadow:0 0 0 3px rgba(61,114,82,.12);
}
.hint { font-size:11.5px; color:var(--text-3); margin-top:4px; }

.btnPrimary {
  width:100%; padding:12px; background:var(--g700); color:var(--white);
  border-radius:var(--r-sm); font-weight:600; font-size:14px; margin-top:6px;
  transition:background var(--t),box-shadow var(--t),transform 80ms;
}
.btnPrimary:hover  { background:var(--g600); box-shadow:0 2px 10px rgba(26,56,38,.28); }
.btnPrimary:active { transform:scale(.99); }
.btnPrimary:disabled { opacity:.6; cursor:not-allowed; }

.authErr {
  background:var(--danger-bg); color:var(--danger); border:1px solid var(--danger-bd);
  border-radius:var(--r-sm); padding:10px 12px; font-size:13px; margin-bottom:14px; display:none;
}
.authOk {
  background:var(--ok-bg); color:var(--ok); border:1px solid var(--ok-bd);
  border-radius:var(--r-sm); padding:10px 12px; font-size:13px; margin-bottom:14px; display:none;
}
.authNote { font-size:11.5px; color:var(--text-3); text-align:center; margin-top:20px; line-height:1.5; }

/* ─── App shell ──────────────────────────────────────────── */
#app { display:none; min-height:100vh; }
.shell { display:flex; min-height:100vh; }

/* ─── Sidebar ────────────────────────────────────────────── */
.side {
  width:var(--sidebar-w); background:var(--g700); flex-shrink:0;
  display:flex; flex-direction:column; position:sticky; top:0; height:100vh;
  overflow:hidden; transition:width var(--t-sl);
  border-right:1px solid rgba(255,255,255,.06);
}
.side .logo { padding:22px 18px 20px; border-bottom:1px solid rgba(255,255,255,.1); flex-shrink:0; }
.logo-wordmark { display:flex; align-items:center; gap:11px; }
.logo-icon {
  width:34px; height:34px; border-radius:9px; background:rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold-lt); font-family:Georgia,serif; font-size:18px; flex-shrink:0;
  border:1px solid rgba(255,255,255,.14);
}
.logo-text h2  { font-size:14px; color:#fff; line-height:1.2; font-family:Georgia,serif; }
.logo-text span { font-size:9px; letter-spacing:1.8px; text-transform:uppercase; color:var(--gold-lt); opacity:.75; }

.nav { padding:10px 8px; flex:1; overflow-y:auto; }
.nav-label {
  font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:1.3px;
  color:rgba(255,255,255,.28); padding:10px 12px 4px; white-space:nowrap;
}
.nav button {
  display:flex; align-items:center; gap:10px; width:100%; text-align:left;
  padding:8.5px 11px; border-radius:var(--r-sm); color:rgba(255,255,255,.6);
  font-weight:500; margin-bottom:1px; font-size:13.5px;
  transition:background var(--t),color var(--t); position:relative;
}
.nav button:hover { background:rgba(255,255,255,.08); color:rgba(255,255,255,.9); }
.nav button.on  { background:rgba(255,255,255,.13); color:#fff; }
.nav button.on::before {
  content:''; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:3px; height:18px; background:var(--gold); border-radius:0 3px 3px 0;
}
.nav .ico { width:17px; height:17px; flex-shrink:0; opacity:.8; }
.nav button.on .ico, .nav button:hover .ico { opacity:1; }
.nav .txt { white-space:nowrap; }

.sideFoot { padding:13px 15px; border-top:1px solid rgba(255,255,255,.1); flex-shrink:0; }
.sideFoot .who  { color:#fff; font-weight:600; font-size:13px; }
.sideFoot .role { color:rgba(255,255,255,.42); font-size:11px; margin-bottom:9px; }
.sideFoot button { color:var(--gold-lt); font-size:12px; padding:0; opacity:.8; transition:opacity var(--t); }
.sideFoot button:hover { opacity:1; }

/* ─── Main ───────────────────────────────────────────────── */
.main { flex:1; padding:28px 32px; min-width:0; }

.topRow { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:24px; gap:16px; flex-wrap:wrap; }
.topRow h1   { font-size:24px; color:var(--g700); }
.topRow .sub { color:var(--text-3); font-size:13px; margin-top:3px; }

/* ─── KPI cards ──────────────────────────────────────────── */
.cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:14px; margin-bottom:24px; }
.kpi {
  background:var(--surface); border-radius:var(--r-md); box-shadow:var(--sh-sm);
  border:1px solid var(--border); padding:18px 20px; position:relative; overflow:hidden;
  transition:box-shadow var(--t),border-color var(--t);
}
.kpi:hover { box-shadow:var(--sh); border-color:var(--border-2); }
.kpi::after {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--g500),var(--g300)); opacity:0; transition:opacity var(--t);
}
.kpi:hover::after { opacity:1; }
.kpi .lbl { font-size:10.5px; text-transform:uppercase; letter-spacing:1px; color:var(--text-3); font-weight:600; }
.kpi .val { font-size:28px; font-family:Georgia,serif; color:var(--g700); margin-top:6px; line-height:1.1; }
.kpi .delta { font-size:12px; margin-top:5px; display:flex; align-items:center; gap:4px; }

.up   { color:var(--ok); }
.down { color:var(--danger); }
.flat { color:var(--text-3); }

/* ─── Panel ──────────────────────────────────────────────── */
.panel {
  background:var(--surface); border-radius:var(--r-md); box-shadow:var(--sh-sm);
  border:1px solid var(--border); padding:20px 22px; margin-bottom:18px;
}
.panel>h3 {
  font-size:15px; color:var(--g700); margin-bottom:14px;
  display:flex; align-items:center; gap:8px;
  padding-bottom:12px; border-bottom:1px solid var(--border);
}

.twoCol   { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.threeCol { display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; }

/* ─── Score pills ────────────────────────────────────────── */
.scorePill {
  display:inline-flex; align-items:center; gap:5px;
  font-weight:700; font-size:12.5px; padding:3px 10px; border-radius:20px;
}
.s-good { background:var(--ok-bg);     color:var(--ok);     }
.s-mid  { background:var(--warn-bg);   color:var(--warn);   }
.s-bad  { background:var(--danger-bg); color:var(--danger); }

/* ─── Bars ───────────────────────────────────────────────── */
.bar { height:6px; background:var(--g100); border-radius:4px; overflow:hidden; }
.bar i { display:block; height:100%; border-radius:4px; transition:width var(--t-sl); }

/* ─── Tags ───────────────────────────────────────────────── */
.tag {
  display:inline-flex; align-items:center; gap:4px;
  font-size:10px; font-weight:700; letter-spacing:.5px;
  text-transform:uppercase; padding:2px 8px; border-radius:4px;
}
.t-red   { background:var(--danger-bg); color:var(--danger); }
.t-amber { background:var(--warn-bg);   color:var(--warn);   }
.t-green { background:var(--ok-bg);     color:var(--ok);     }
.t-grey  { background:#f0ede5;          color:var(--text-3); }
.t-blue  { background:#e8f0fe;          color:#3050a8;       }
.t-gold  { background:var(--gold-pale); color:var(--gold-dk);}

/* ─── Tables ─────────────────────────────────────────────── */
table { width:100%; border-collapse:collapse; }
th {
  text-align:left; font-size:10.5px; text-transform:uppercase;
  letter-spacing:.8px; color:var(--text-3); font-weight:600;
  padding:9px 12px; border-bottom:1.5px solid var(--border);
  white-space:nowrap; background:var(--surface);
}
td { padding:11px 12px; border-bottom:1px solid #f0ece2; font-size:13.5px; vertical-align:middle; }
tr.click:hover td { background:var(--bg-sub); cursor:pointer; }
tr:last-child td  { border-bottom:none; }
.addr { font-weight:600; color:var(--text); }
.addr small { display:block; color:var(--text-3); font-weight:400; font-size:12px; margin-top:1px; }

/* ─── Attention items ────────────────────────────────────── */
.attn { display:flex; gap:12px; padding:13px 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.attn:last-child { border-bottom:none; }
.attn .dot { width:8px; height:8px; border-radius:50%; margin-top:6px; flex-shrink:0; }
.attn .body { flex:1; }
.attn .body b { display:block; font-size:13.5px; font-weight:600; }
.attn .body p { color:var(--text-3); font-size:12.5px; margin-top:2px; }
.attn button { color:var(--g500); font-weight:600; font-size:12.5px; white-space:nowrap; transition:color var(--t); }
.attn button:hover { color:var(--g700); }

/* ─── Property detail ────────────────────────────────────── */
.back {
  color:var(--g500); font-weight:600; font-size:13px; margin-bottom:16px;
  display:inline-flex; align-items:center; gap:6px; transition:color var(--t);
}
.back:hover { color:var(--g700); }

.propHead {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:20px; flex-wrap:wrap; margin-bottom:20px;
  background:var(--surface); border-radius:var(--r-md);
  padding:20px 24px; border:1px solid var(--border); box-shadow:var(--sh-sm);
}
.propHead h1  { font-size:22px; color:var(--g700); }
.propHead .meta { color:var(--text-3); margin-top:4px; font-size:13.5px; }

.ring { position:relative; width:88px; height:88px; flex-shrink:0; }
.ring svg { transform:rotate(-90deg); }
.ring .num { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.ring .num b    { font-size:22px; font-family:Georgia,serif; color:var(--g700); }
.ring .num span { font-size:8.5px; text-transform:uppercase; letter-spacing:.8px; color:var(--text-3); }

.metricRow { display:grid; grid-template-columns:repeat(auto-fit,minmax(110px,1fr)); gap:12px; margin-bottom:18px; }
.metric {
  background:var(--surface); border-radius:var(--r); box-shadow:var(--sh-sm);
  border:1px solid var(--border); padding:14px 16px; text-align:center;
  transition:box-shadow var(--t);
}
.metric:hover { box-shadow:var(--sh); }
.metric .v { font-size:22px; font-family:Georgia,serif; color:var(--g700); }
.metric .l { font-size:10px; text-transform:uppercase; letter-spacing:.7px; color:var(--text-3); margin-top:3px; font-weight:600; }
.metric .d { font-size:11.5px; margin-top:3px; }

/* ─── Benchmarks ─────────────────────────────────────────── */
.bench { margin-bottom:14px; }
.bench .row { display:flex; justify-content:space-between; font-size:12.5px; margin-bottom:5px; }
.bench .row b { font-weight:600; }

/* ─── Timeline ───────────────────────────────────────────── */
.tl { position:relative; padding-left:26px; }
.tl::before { content:''; position:absolute; left:7px; top:6px; bottom:6px; width:2px; background:var(--border); border-radius:2px; }
.tlItem { position:relative; padding-bottom:20px; }
.tlItem:last-child { padding-bottom:0; }
.tlItem .pin {
  position:absolute; left:-26px; top:2px; width:16px; height:16px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:8px; color:#fff; box-shadow:0 0 0 3px var(--surface);
}
.tlItem .day { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; color:var(--text-3); }
.tlItem .msg { font-size:13.5px; margin-top:2px; }
.tlItem .rec {
  margin-top:8px; background:var(--gold-ultra); border:1px solid var(--gold-pale);
  border-left:3px solid var(--gold); border-radius:var(--r-sm);
  padding:10px 13px; font-size:13px;
}
.tlItem .rec b { color:var(--g700); }
.tlItem .impact { font-size:12px; color:var(--ok); margin-top:4px; font-weight:600; }
.evid { margin-top:8px; border-top:1px dashed var(--border); padding-top:7px; }
.evid b { font-size:10px; text-transform:uppercase; letter-spacing:.8px; color:var(--text-3); }
.evid ul { margin:5px 0 0 16px; }
.evid li { font-size:12px; color:var(--text-2); margin-bottom:3px; }
.evH { font-size:10.5px; text-transform:uppercase; letter-spacing:.9px; color:var(--text-3); margin:16px 0 5px; font-weight:700; }

/* ─── Pricing engine ─────────────────────────────────────── */
.priceTable td,.priceTable th { padding:9px 12px; }
.probBar { display:flex; align-items:center; gap:10px; }
.probBar .bar { flex:1; }
.confRange {
  background:linear-gradient(135deg,var(--gold-ultra) 0%,var(--gold-pale) 100%);
  border:1px solid var(--gold-lt); border-radius:var(--r);
  padding:16px 20px; text-align:center; margin-bottom:16px;
}
.confRange .l { font-size:10.5px; text-transform:uppercase; letter-spacing:1.1px; color:var(--text-3); font-weight:600; }
.confRange .r { font-size:24px; font-family:Georgia,serif; color:var(--g700); margin-top:4px; }

/* ─── Sparkline ──────────────────────────────────────────── */
.spark { width:100%; height:64px; }

/* ─── Feed items ─────────────────────────────────────────── */
.feedItem { display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--border); font-size:13.5px; align-items:flex-start; }
.feedItem:last-child { border-bottom:none; }
.feedItem .fi {
  width:32px; height:32px; border-radius:8px; background:var(--g50);
  border:1px solid var(--g100); display:flex; align-items:center; justify-content:center;
  flex-shrink:0; font-size:15px;
}
.feedItem small { display:block; color:var(--text-3); font-size:11.5px; margin-top:2px; }

/* ─── Connection rows ────────────────────────────────────── */
.connRow { display:flex; justify-content:space-between; align-items:center; padding:14px 0; border-bottom:1px solid var(--border); gap:14px; flex-wrap:wrap; }
.connRow:last-child { border-bottom:none; }
.connRow .cn b     { display:block; font-size:14px; font-weight:600; }
.connRow .cn small { color:var(--text-3); font-size:12px; }

/* ─── Buttons ────────────────────────────────────────────── */
.btnGhost {
  border:1.5px solid var(--g400); color:var(--g600);
  padding:8px 16px; border-radius:var(--r-sm); font-weight:600; font-size:13px;
  transition:background var(--t),color var(--t),border-color var(--t);
}
.btnGhost:hover { background:var(--g700); border-color:var(--g700); color:#fff; }

.btnAction {
  background:var(--g700); color:#fff; padding:8px 16px; border-radius:var(--r-sm);
  font-weight:600; font-size:13px; transition:background var(--t),box-shadow var(--t);
}
.btnAction:hover { background:var(--g600); box-shadow:0 2px 8px rgba(26,56,38,.25); }

.btnSm { padding:5px 11px; font-size:12px; }

/* ─── Settings / weights ─────────────────────────────────── */
.wRow { display:flex; align-items:center; gap:12px; margin-bottom:11px; }
.wRow label { width:200px; font-size:13px; color:var(--text-2); }
.wRow input[type=range] { flex:1; accent-color:var(--g500); }
.wRow .wv { width:46px; text-align:right; font-weight:700; color:var(--g700); font-size:13px; }
.secBox { background:var(--g50); border:1px solid var(--g100); border-radius:var(--r); padding:14px 16px; font-size:12.5px; color:var(--text-2); line-height:1.6; }
.lockNote { display:flex; gap:8px; align-items:flex-start; color:var(--text-3); font-size:11.5px; margin-top:14px; line-height:1.5; }

/* ─── Toast ──────────────────────────────────────────────── */
.toast {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(10px);
  background:var(--g700); color:#fff; padding:12px 22px; border-radius:var(--r-lg);
  box-shadow:var(--sh-lg); font-size:13px; opacity:0; pointer-events:none;
  transition:opacity var(--t),transform var(--t); z-index:100; white-space:nowrap;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ─── Vendor draft ───────────────────────────────────────── */
.vendorDraft {
  width:100%; min-height:140px; border:1.5px solid var(--border); border-radius:var(--r-sm);
  padding:12px; resize:vertical; background:var(--surface-2); color:var(--text-2);
  font:12.5px/1.6 ui-monospace,'SF Mono',Menlo,monospace;
}
.vendorDraft:focus { outline:none; border-color:var(--g400); box-shadow:0 0 0 3px rgba(61,114,82,.1); }

/* ─── Filter row ─────────────────────────────────────────── */
.filterRow { display:flex; gap:10px; margin-bottom:16px; flex-wrap:wrap; align-items:center; }
.filterRow select,.filterRow input {
  padding:8px 12px; border:1.5px solid var(--border); border-radius:var(--r-sm);
  background:var(--white); font-size:13px; color:var(--text); transition:border-color var(--t);
}
.filterRow select:focus,.filterRow input:focus { outline:none; border-color:var(--g400); }

/* ─── RM reminder ────────────────────────────────────────── */
.rmBanner {
  background:var(--warn-bg); border:1px solid var(--warn-bd); border-radius:var(--r);
  padding:14px 18px; margin-bottom:18px; display:flex; justify-content:space-between;
  align-items:flex-start; gap:14px;
}
.rmBanner b { color:var(--warn); }
.rmBanner p { color:var(--text-2); font-size:12.5px; margin-top:3px; line-height:1.5; }

/* ─── Demo banner ────────────────────────────────────────── */
.demoBanner { background:var(--gold); color:#3a2e15; text-align:center; font-size:12.5px; font-weight:600; padding:7px 12px; position:sticky; top:0; z-index:40; }
.demoBanner code { background:rgba(255,255,255,.4); padding:1px 5px; border-radius:4px; }
.authNote { font-size:11.5px; color:var(--text-3); text-align:center; margin-top:20px; line-height:1.5; }
.loading { color:var(--text-3); padding:60px; text-align:center; font-size:14px; }

/* ─── Modal ──────────────────────────────────────────────── */
.modal-bg {
  position:fixed; inset:0; background:rgba(18,34,26,.45); z-index:200;
  display:flex; align-items:center; justify-content:center; padding:20px;
  opacity:0; pointer-events:none; transition:opacity var(--t);
}
.modal-bg.open { opacity:1; pointer-events:all; }
.modal {
  background:var(--white); border-radius:var(--r-xl); box-shadow:var(--sh-lg);
  width:100%; max-width:520px; max-height:90vh; overflow-y:auto;
  transform:translateY(16px); transition:transform var(--t-sl);
}
.modal-bg.open .modal { transform:translateY(0); }
.modal-hd { padding:22px 24px 16px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; }
.modal-hd h2 { font-size:17px; color:var(--g700); }
.modal-close { color:var(--text-3); font-size:22px; line-height:1; padding:2px 4px; transition:color var(--t); }
.modal-close:hover { color:var(--text); }
.modal-bd { padding:20px 24px; }
.modal-ft { padding:14px 24px; border-top:1px solid var(--border); display:flex; gap:10px; justify-content:flex-end; }

/* ─── Photo attribution ──────────────────────────────────── */
.photoLog { display:flex; flex-direction:column; gap:10px; }
.photoLogItem {
  background:var(--bg-sub); border:1px solid var(--border); border-radius:var(--r);
  padding:14px 16px; display:flex; gap:14px; align-items:flex-start;
  transition:border-color var(--t);
}
.photoLogItem:hover { border-color:var(--border-2); }
.plIcon { width:36px; height:36px; border-radius:8px; background:var(--gold-pale); border:1px solid var(--gold-lt); display:flex; align-items:center; justify-content:center; font-size:17px; flex-shrink:0; }
.plBody { flex:1; }
.plTitle { font-weight:600; font-size:13.5px; }
.plDate  { color:var(--text-3); font-size:11.5px; margin-top:1px; }
.impactGrid { display:flex; gap:10px; margin-top:10px; flex-wrap:wrap; }
.impactChip {
  display:flex; flex-direction:column; align-items:center;
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:8px 14px; min-width:78px;
}
.impactChip .icv { font-size:17px; font-family:Georgia,serif; font-weight:600; }
.impactChip .icl { font-size:9.5px; text-transform:uppercase; letter-spacing:.7px; color:var(--text-3); margin-top:2px; }
.impactChip.pos .icv { color:var(--ok); }
.impactChip.neg .icv { color:var(--danger); }
.impactChip.pend .icv { color:var(--text-3); font-size:13px; }

/* ─── Social cards ───────────────────────────────────────── */
.socialGrid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:16px; margin-bottom:20px; }
.socialCard { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); padding:18px 20px; box-shadow:var(--sh-sm); }
.socialCard .platform { display:flex; align-items:center; gap:10px; font-weight:700; font-size:14px; margin-bottom:14px; }
.platform .picon { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:16px; color:#fff; }
.picon-fb { background:#1877f2; }
.picon-ig { background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }
.socialMetrics { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.sMetric .sv { font-size:20px; font-family:Georgia,serif; color:var(--g700); }
.sMetric .sl { font-size:10px; text-transform:uppercase; letter-spacing:.6px; color:var(--text-3); margin-top:1px; }

/* ─── Market / area cards ────────────────────────────────── */
.marketSplit { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:20px; }
.areaCard { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); padding:18px 20px; box-shadow:var(--sh-sm); }
.areaCard h4 { font-size:13.5px; font-weight:700; color:var(--g700); margin-bottom:12px; font-family:'Inter',sans-serif; display:flex; align-items:center; gap:7px; }
.areaStat { display:flex; justify-content:space-between; align-items:baseline; padding:7px 0; border-bottom:1px solid var(--border); font-size:13px; }
.areaStat:last-child { border-bottom:none; }
.areaStat .asv { font-weight:700; font-size:17px; color:var(--g700); font-family:Georgia,serif; }

/* ─── National intel ─────────────────────────────────────── */
.nationalBand { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; margin-bottom:20px; }
.natCard { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); padding:16px 18px; box-shadow:var(--sh-sm); }
.natCard .src { font-size:10px; text-transform:uppercase; letter-spacing:.9px; color:var(--text-3); font-weight:700; margin-bottom:6px; }
.natCard .nv { font-size:24px; font-family:Georgia,serif; color:var(--g700); }
.natCard .nl { font-size:12px; color:var(--text-2); margin-top:4px; }
.natCard .nd { font-size:11.5px; margin-top:3px; }

/* ─── Upload zone ────────────────────────────────────────── */
.uploadZone {
  border:2px dashed var(--border-2); border-radius:var(--r);
  padding:30px 20px; text-align:center; cursor:pointer;
  transition:border-color var(--t),background var(--t);
}
.uploadZone:hover,.uploadZone.drag { border-color:var(--g400); background:var(--g50); }
.uploadZone .uzIco { font-size:30px; margin-bottom:8px; }
.uploadZone p { color:var(--text-2); font-size:13.5px; }
.uploadZone small { color:var(--text-3); font-size:12px; margin-top:3px; display:block; }

/* ─── Pricing accuracy ───────────────────────────────────── */
.accBand { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:14px; margin-bottom:18px; }
.accCard { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:16px 18px; box-shadow:var(--sh-sm); }
.accCard .acv { font-size:26px; font-family:Georgia,serif; color:var(--g700); }
.accCard .acl { font-size:10.5px; text-transform:uppercase; letter-spacing:.9px; color:var(--text-3); margin-bottom:4px; font-weight:600; }
.accCard .acs { font-size:12px; color:var(--text-3); margin-top:3px; }

/* ─── Divider ────────────────────────────────────────────── */
.divider { height:1px; background:var(--border); margin:16px 0; }

/* ─── Responsive ─────────────────────────────────────────── */
@media (max-width:1100px) { .twoCol { grid-template-columns:1fr; } .threeCol { grid-template-columns:1fr 1fr; } .marketSplit { grid-template-columns:1fr; } }
@media (max-width:880px)  {
  .side { width:var(--sidebar-min); }
  .logo-text,.nav .txt,.nav-label,.sideFoot .who,.sideFoot .role { display:none; }
  .nav button.on::before { display:none; }
  .nav button { justify-content:center; padding:10px; }
  .main { padding:18px 20px; }
  .threeCol { grid-template-columns:1fr; }
}
@media (max-width:600px) { .cards { grid-template-columns:1fr 1fr; } .metricRow { grid-template-columns:repeat(3,1fr); } }
