/* Foundation Market Intelligence — Seniors Housing (Canada). Demo build. */
:root{
  --navy:#1B3A5C; --navy-2:#274d76; --ink:#1a2230; --muted:#5b6b7e; --line:#e3e9f0;
  --bg:#f4f7fb; --card:#ffffff; --accent:#2f7d6b; --accent-2:#e8f3f0;
  --warn:#b4541f; --warn-bg:#fbeee5; --good:#2f7d6b; --good-bg:#e8f3f0;
  --bad:#b23b3b; --bad-bg:#f9eaea; --chip:#eef3f9;
  --shadow:0 1px 2px rgba(20,40,70,.06),0 8px 24px rgba(20,40,70,.06);
  --radius:14px; --r-sm:9px;
}
*{box-sizing:border-box}
html,body{margin:0}
.demo-banner{background:#fbeee5;color:#8a3d12;border-bottom:1px solid #f0d6c2;
  font-size:12px;text-align:center;padding:7px 16px;font-weight:500}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:var(--navy-2);text-decoration:none}
a:hover{text-decoration:underline}

/* Header */
.appbar{background:linear-gradient(120deg,var(--navy),var(--navy-2));color:#fff;padding:14px 26px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:13px}
.brand .mark{width:38px;height:38px;border-radius:9px;background:#fff;color:var(--navy);
  display:grid;place-items:center;font-weight:800;font-size:18px;letter-spacing:-1px}
.brand h1{font-size:16px;margin:0;font-weight:700;letter-spacing:.2px}
.brand .sub{font-size:11.5px;opacity:.8;margin-top:1px}
.appbar .right{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:flex-end}
.prepared{font-size:11.5px;opacity:.85;text-align:right;line-height:1.3}
.refreshed{font-size:11px;opacity:.7}
.btn{border:0;border-radius:9px;padding:9px 15px;font-size:13px;font-weight:600;cursor:pointer;
  background:#fff;color:var(--navy);transition:transform .05s,box-shadow .15s}
.btn:hover{box-shadow:0 3px 10px rgba(0,0,0,.18)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn.sm{padding:6px 11px;font-size:12px}
.btn.accent{background:var(--accent);color:#fff}

/* Tabs */
.tabs{display:flex;gap:4px;padding:0 26px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.tab{padding:14px 16px;font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:3px solid transparent}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--navy);border-bottom-color:var(--navy)}

main{max-width:1240px;margin:0 auto;padding:24px 26px 60px}
.view{display:none}.view.active{display:block}
.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin:26px 0 12px}
.section-title:first-child{margin-top:6px}

/* KPI cards */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.kpi .label{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.kpi .val{font-size:27px;font-weight:800;color:var(--navy);margin-top:6px;letter-spacing:-.5px}
.kpi .note{font-size:12px;color:var(--muted);margin-top:3px}
.kpi.good .val{color:var(--good)} .kpi.warn .val{color:var(--warn)}

/* Card / panels */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.card h3{margin:0 0 4px;font-size:15px;color:var(--ink)}
.card .hint{font-size:12px;color:var(--muted);margin:0 0 14px}

/* Bar chart */
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:130px 1fr 64px;align-items:center;gap:10px;font-size:12.5px}
.bar-row .name{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{background:var(--chip);border-radius:6px;height:18px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--navy-2),var(--navy));border-radius:6px}
.bar-row .v{text-align:right;font-weight:700;color:var(--ink)}

/* Signals */
.signal{padding:9px 0;border-bottom:1px dashed var(--line);font-size:13px;line-height:1.55}
.signal:last-child{border-bottom:0}
.signal .dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:9px;vertical-align:middle}
.dot.hi{background:var(--bad)} .dot.lo{background:var(--good)} .dot.mid{background:var(--muted)}

/* Controls */
.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.controls input[type=text],.controls select{padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#fff;color:var(--ink)}
.controls input[type=text]{min-width:230px}
.count{font-size:12.5px;color:var(--muted);margin-left:auto}

/* Table */
table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
th,td{text-align:left;padding:11px 14px;font-size:13px;border-bottom:1px solid var(--line);vertical-align:middle}
th{background:#fafbfd;color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;white-space:nowrap}
th:hover{color:var(--ink)}
tr:last-child td{border-bottom:0}
tbody tr{cursor:pointer}
tbody tr:hover{background:#f7faff}
.price{font-weight:700;color:var(--navy);white-space:nowrap}
.chip{display:inline-block;background:var(--chip);color:#3a4a5c;border-radius:20px;padding:2px 9px;font-size:11px;margin:1px 3px 1px 0;white-space:nowrap}
.muted{color:var(--muted)} .right{text-align:right} .center{text-align:center}
.pos{font-weight:700;border-radius:20px;padding:2px 10px;font-size:11.5px;display:inline-block}
.pos.below{background:var(--good-bg);color:var(--good)}
.pos.above{background:var(--bad-bg);color:var(--bad)}
.pos.at{background:var(--chip);color:var(--muted)}

/* Import */
.import-grid{display:grid;grid-template-columns:1fr 360px;gap:16px}
textarea{width:100%;min-height:120px;border:1px solid var(--line);border-radius:9px;padding:11px;font-family:ui-monospace,Menlo,monospace;font-size:12.5px;resize:vertical}
.addrow{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.addrow input,.addrow select{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:12.5px}

/* Dig deeper list */
.dig{counter-reset:d}
.dig li{list-style:none;padding:12px 0;border-bottom:1px solid var(--line);display:flex;gap:12px}
.dig li:last-child{border-bottom:0}
.dig li .rank{counter-increment:d;width:26px;height:26px;border-radius:7px;background:var(--navy);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:13px;flex:0 0 auto}
.dig li .rank::before{content:counter(d)}
.dig .opp{font-weight:800;color:var(--good)}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(20,35,55,.5);display:none;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:16px;max-width:680px;width:100%;max-height:88vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal .head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.modal .head h3{margin:0;font-size:18px}
.modal .body{padding:18px 22px}
.x{cursor:pointer;font-size:22px;color:var(--muted);line-height:1;border:0;background:0}

footer{text-align:center;color:var(--muted);font-size:12px;padding:24px;border-top:1px solid var(--line);margin-top:30px}
.tag{display:inline-block;background:var(--accent-2);color:var(--accent);font-size:10.5px;font-weight:700;
  padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle}
.empty{padding:40px;text-align:center;color:var(--muted)}
@media(max-width:900px){.grid2,.import-grid{grid-template-columns:1fr}.prepared{display:none}}
@media print{.appbar .right,.tabs,.controls,.btn{display:none!important}.view{display:block!important}}
