/* ============================================================
   Estate CRM — ink navy + brass premium real-estate theme
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --ink:#0E1726;
  --ink-2:#16213A;
  --ink-3:#1E2C49;
  --bg:#F5F3EE;
  --card:#FFFFFF;
  --line:#E8E4DB;
  --line-2:#F0ECE3;
  --text:#1B2230;
  --muted:#828B9E;
  --muted-2:#A8B0BF;
  --brass:#C29B40;
  --brass-d:#A8842F;
  --brass-soft:#F6EFDB;

  --s-new:#5B8DEF;   --s-contacted:#7C6FF0; --s-qualified:#E0A82E;
  --s-visit:#B061D6; --s-negotiation:#E8833A; --s-won:#1F9D6B; --s-lost:#E0506A;

  --r:14px; --r-sm:10px;
  --sh:0 1px 2px rgba(16,23,38,.04), 0 8px 24px rgba(16,23,38,.06);
  --sh-lg:0 24px 60px rgba(16,23,38,.18);
  --t:.18s cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg); color:var(--text);
  font-size:14px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.display{font-family:'Sora',sans-serif;letter-spacing:-.02em}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:14px}
.tabnum{font-variant-numeric:tabular-nums}

/* ---------- Layout ---------- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* ---------- Sidebar ---------- */
.sidebar{
  background:var(--ink); color:#C7CEDB;
  display:flex;flex-direction:column;
  padding:22px 16px; position:sticky;top:0;height:100vh;
}
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 22px}
.brand .mark{
  width:38px;height:38px;border-radius:11px;flex:0 0 38px;
  background:linear-gradient(140deg,var(--brass),#E0BE66);
  display:grid;place-items:center;color:var(--ink);
  box-shadow:0 6px 16px rgba(194,155,64,.35);
}
.brand .mark svg{width:20px;height:20px}
.brand .name{font-family:'Sora';font-weight:700;font-size:16px;color:#fff;letter-spacing:-.01em}
.brand .sub{font-size:11px;color:#6B7689;margin-top:1px}

.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav-label{font-size:10.5px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:#576174;padding:14px 10px 6px}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:10px;color:#AEB7C6;
  font-weight:500;font-size:13.5px;transition:var(--t);width:100%;text-align:left;
}
.nav-item svg{width:18px;height:18px;flex:0 0 18px;stroke-width:1.9}
.nav-item:hover{background:var(--ink-2);color:#fff}
.nav-item.active{background:var(--ink-3);color:#fff}
.nav-item.active svg{color:var(--brass)}

.side-cta{
  margin-top:14px;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:11px;border-radius:11px;font-weight:600;font-size:13.5px;
  background:linear-gradient(135deg,var(--brass),#D4AD52);color:var(--ink);
  transition:var(--t);box-shadow:0 8px 20px rgba(194,155,64,.28);
}
.side-cta:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(194,155,64,.4)}
.side-cta svg{width:17px;height:17px;stroke-width:2.3}

.side-foot{margin-top:auto;padding-top:16px}
.ai-chip{
  display:flex;align-items:center;gap:9px;padding:11px 12px;
  background:var(--ink-2);border-radius:11px;font-size:12px;color:#9AA4B5;
}
.dot{width:8px;height:8px;border-radius:50%;background:#5b6373;flex:0 0 8px;position:relative}
.dot.on{background:#34D399;box-shadow:0 0 0 4px rgba(52,211,153,.18)}
.dot.off{background:#E0506A}
.ai-chip .m{color:#fff;font-weight:600}

/* ---------- Main ---------- */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{
  display:flex;align-items:center;gap:18px;
  padding:18px 30px;background:rgba(245,243,238,.82);
  backdrop-filter:blur(10px);position:sticky;top:0;z-index:20;
  border-bottom:1px solid var(--line);
}
.topbar h1{font-size:20px;font-weight:700}
.topbar .crumb{font-size:12.5px;color:var(--muted);margin-top:2px}
.search{
  margin-left:auto;display:flex;align-items:center;gap:9px;
  background:var(--card);border:1px solid var(--line);border-radius:11px;
  padding:9px 13px;width:280px;transition:var(--t);
}
.search:focus-within{border-color:var(--brass);box-shadow:0 0 0 3px rgba(194,155,64,.13)}
.search svg{width:16px;height:16px;color:var(--muted);flex:0 0 16px}
.search input{border:none;outline:none;background:none;width:100%;color:var(--text)}
.avatars{display:flex}
.avatars .av{margin-left:-9px;border:2.5px solid var(--bg)}
.av{
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  font-size:12px;font-weight:700;color:#fff;font-family:'Sora';
}
.av.c0{background:#5B8DEF}.av.c1{background:#7C6FF0}.av.c2{background:#E8833A}.av.c3{background:#1F9D6B}

.content{padding:26px 30px 60px;flex:1}
.view{display:none;animation:fade .3s ease}
.view.show{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- KPI cards ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.kpi{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:18px 20px;box-shadow:var(--sh);position:relative;overflow:hidden;
}
.kpi .ico{
  width:40px;height:40px;border-radius:11px;display:grid;place-items:center;margin-bottom:14px;
}
.kpi .ico svg{width:20px;height:20px;stroke-width:2}
.kpi .lab{font-size:12.5px;color:var(--muted);font-weight:500}
.kpi .val{font-family:'Sora';font-size:27px;font-weight:700;margin-top:3px;letter-spacing:-.02em}
.kpi .delta{font-size:11.5px;font-weight:600;margin-top:7px;display:inline-flex;align-items:center;gap:4px}
.delta.up{color:var(--s-won)} .delta.down{color:var(--s-lost)}

.kpi.hero{background:linear-gradient(135deg,var(--ink),var(--ink-3));border:none;color:#fff}
.kpi.hero .lab{color:#9AA8C0}
.kpi.hero .ico{background:rgba(194,155,64,.2)}.kpi.hero .ico svg{color:var(--brass)}
.kpi.hero .val{color:#fff}
.kpi.hero::after{content:'';position:absolute;right:-30px;top:-30px;width:120px;height:120px;
  background:radial-gradient(circle,rgba(194,155,64,.25),transparent 70%)}

.ico.blue{background:#EAF1FE;color:var(--s-new)}
.ico.rose{background:#FDEEF1;color:var(--s-lost)}
.ico.green{background:#E7F6EF;color:var(--s-won)}

/* ---------- Panels / charts ---------- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.grid-feed{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:20px 22px}
.panel h3{font-size:15px;font-weight:600;margin-bottom:2px}
.panel .ph-sub{font-size:12.5px;color:var(--muted);margin-bottom:18px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.chart-wrap{position:relative;height:230px}

.feed{display:flex;flex-direction:column;gap:2px;max-height:300px;overflow-y:auto}
.feed-item{display:flex;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line-2)}
.feed-item:last-child{border:none}
.feed-dot{width:30px;height:30px;border-radius:9px;flex:0 0 30px;display:grid;place-items:center;background:var(--brass-soft)}
.feed-dot svg{width:15px;height:15px;color:var(--brass-d)}
.feed-item .ft{font-size:13px;font-weight:500}
.feed-item .fm{font-size:11.5px;color:var(--muted);margin-top:2px}

/* ---------- Pipeline / Kanban ---------- */
.board{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px}
.col{
  flex:0 0 270px;background:#EFEDE6;border-radius:var(--r);padding:12px;
  display:flex;flex-direction:column;max-height:calc(100vh - 180px);
}
.col-head{display:flex;align-items:center;gap:8px;padding:4px 6px 12px}
.col-head .pin{width:9px;height:9px;border-radius:3px;flex:0 0 9px}
.col-head .ct{font-family:'Sora';font-weight:600;font-size:13.5px}
.col-head .cc{margin-left:auto;font-size:11.5px;font-weight:700;color:var(--muted);
  background:#fff;padding:2px 9px;border-radius:20px}
.col-body{display:flex;flex-direction:column;gap:9px;overflow-y:auto;flex:1;min-height:30px}

.lcard{
  background:var(--card);border:1px solid var(--line);border-radius:11px;
  padding:13px 14px;box-shadow:0 1px 2px rgba(16,23,38,.05);
  cursor:grab;transition:var(--t);
}
.lcard:hover{box-shadow:var(--sh);transform:translateY(-1px);border-color:var(--brass)}
.lcard:active{cursor:grabbing}
.lcard .lc-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.lcard .lc-name{font-weight:600;font-size:13.5px}
.lcard .lc-meta{font-size:11.5px;color:var(--muted);margin-top:5px;display:flex;align-items:center;gap:6px}
.lcard .lc-budget{font-family:'Sora';font-weight:600;font-size:13px;margin-top:9px;color:var(--ink)}
.lc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:11px}
.rating{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.rating.Hot{background:#FDEEF1;color:var(--s-lost)}
.rating.Warm{background:#FBF1DA;color:var(--brass-d)}
.rating.Cold{background:#EAF1FE;color:var(--s-new)}
.mini-av{width:26px;height:26px;font-size:10px}
.sortable-ghost{opacity:.4}
.sortable-chosen{box-shadow:var(--sh-lg);border-color:var(--brass)}

/* ---------- Leads table ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.sel{
  background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:9px 13px;color:var(--text);font-weight:500;cursor:pointer;transition:var(--t);
}
.sel:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(194,155,64,.13)}
.table-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{
  text-align:left;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  color:var(--muted);padding:14px 18px;border-bottom:1px solid var(--line);background:#FAF8F3;
}
tbody td{padding:14px 18px;border-bottom:1px solid var(--line-2);font-size:13.5px}
tbody tr{cursor:pointer;transition:background .12s}
tbody tr:hover{background:#FBFAF6}
tbody tr:last-child td{border:none}
.cell-name{display:flex;align-items:center;gap:11px}
.cell-name .nm{font-weight:600}
.cell-name .ph{font-size:11.5px;color:var(--muted)}
.stage-tag{font-size:11px;font-weight:600;padding:4px 11px;border-radius:20px;display:inline-flex;align-items:center;gap:6px}
.stage-tag .pin{width:7px;height:7px;border-radius:50%}

/* ---------- Drawer ---------- */
.scrim{position:fixed;inset:0;background:rgba(14,23,38,.42);backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;transition:var(--t);z-index:40}
.scrim.show{opacity:1;visibility:visible}
.drawer{
  position:fixed;top:0;right:0;height:100vh;width:460px;max-width:94vw;
  background:var(--bg);box-shadow:var(--sh-lg);z-index:50;
  transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;overflow:hidden;
}
.drawer.show{transform:none}
.dr-head{padding:22px 24px;background:linear-gradient(135deg,var(--ink),var(--ink-3));color:#fff;position:relative}
.dr-close{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:9px;
  background:rgba(255,255,255,.12);display:grid;place-items:center;color:#fff;transition:var(--t)}
.dr-close:hover{background:rgba(255,255,255,.22)}
.dr-close svg{width:18px;height:18px}
.dr-head .dn{font-family:'Sora';font-size:21px;font-weight:700}
.dr-head .dm{font-size:12.5px;color:#9AA8C0;margin-top:4px;display:flex;gap:14px;flex-wrap:wrap}
.dr-head .dm a{color:#C9D3E3;text-decoration:none}
.dr-body{flex:1;overflow-y:auto;padding:22px 24px;display:flex;flex-direction:column;gap:18px}

.dr-stages{display:flex;gap:6px;flex-wrap:wrap}
.st-pill{font-size:11.5px;font-weight:600;padding:7px 12px;border-radius:9px;background:#fff;
  border:1px solid var(--line);color:var(--muted);transition:var(--t)}
.st-pill:hover{border-color:var(--brass)}
.st-pill.active{color:#fff;border-color:transparent}

.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.info{background:#fff;border:1px solid var(--line);border-radius:11px;padding:12px 14px}
.info .il{font-size:11px;color:var(--muted);font-weight:500}
.info .iv{font-family:'Sora';font-weight:600;font-size:14px;margin-top:3px}

.sec-title{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}

.ai-box{background:linear-gradient(135deg,#FBF6E9,#FCF9F1);border:1px solid var(--brass-soft);border-radius:var(--r);padding:16px}
.ai-box .aih{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.ai-box .aih svg{width:17px;height:17px;color:var(--brass-d)}
.ai-box .aih b{font-family:'Sora';font-size:14px}
.ai-btns{display:flex;gap:8px;flex-wrap:wrap}
.ai-btn{display:flex;align-items:center;gap:7px;padding:9px 13px;border-radius:9px;
  background:#fff;border:1px solid var(--line);font-weight:600;font-size:12.5px;color:var(--ink);transition:var(--t)}
.ai-btn:hover{border-color:var(--brass);background:var(--brass-soft)}
.ai-btn svg{width:15px;height:15px;color:var(--brass-d)}
.ai-out{margin-top:13px;background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:14px;font-size:13px;line-height:1.6;white-space:pre-wrap;display:none;color:var(--text)}
.ai-out.show{display:block}
.ai-out .copy{margin-top:10px;font-size:11.5px;font-weight:600;color:var(--brass-d);display:inline-flex;align-items:center;gap:5px}
.ai-loading{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:13px}
.spin{width:16px;height:16px;border:2.5px solid var(--brass-soft);border-top-color:var(--brass);border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

.timeline{display:flex;flex-direction:column}
.tl-item{display:flex;gap:12px;padding-bottom:16px;position:relative}
.tl-item:not(:last-child)::before{content:'';position:absolute;left:14px;top:30px;bottom:0;width:2px;background:var(--line)}
.tl-ico{width:30px;height:30px;border-radius:50%;flex:0 0 30px;display:grid;place-items:center;background:#fff;border:1px solid var(--line);z-index:1}
.tl-ico svg{width:14px;height:14px;color:var(--brass-d)}
.tl-item .tt{font-size:13px;font-weight:500}
.tl-item .tm{font-size:11px;color:var(--muted);margin-top:2px}

.act-add{display:flex;gap:8px;margin-top:12px}
.act-add input{flex:1;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 13px;outline:none}
.act-add input:focus{border-color:var(--brass);box-shadow:0 0 0 3px rgba(194,155,64,.13)}

.dr-foot{padding:14px 24px;border-top:1px solid var(--line);display:flex;gap:10px;background:var(--card)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:10px;font-weight:600;font-size:13.5px;transition:var(--t)}
.btn svg{width:16px;height:16px}
.btn-primary{background:linear-gradient(135deg,var(--brass),#D4AD52);color:var(--ink);box-shadow:0 6px 16px rgba(194,155,64,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(194,155,64,.35)}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--brass)}
.btn-danger{background:#fff;border:1px solid var(--line);color:var(--s-lost);margin-left:auto}
.btn-danger:hover{background:#FDEEF1;border-color:var(--s-lost)}

/* ---------- Modal (add/edit) ---------- */
.modal-scrim{position:fixed;inset:0;background:rgba(14,23,38,.5);backdrop-filter:blur(3px);
  display:none;align-items:center;justify-content:center;z-index:60;padding:20px}
.modal-scrim.show{display:flex;animation:fade .2s}
.modal{background:var(--bg);border-radius:18px;width:560px;max-width:100%;max-height:92vh;overflow:hidden;
  box-shadow:var(--sh-lg);display:flex;flex-direction:column}
.modal-head{padding:22px 26px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal-head h2{font-size:19px;font-weight:700}
.modal-body{padding:22px 26px;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;gap:15px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:12px;font-weight:600;color:var(--muted)}
.field input,.field select,.field textarea{
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 13px;outline:none;color:var(--text);transition:var(--t)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brass);box-shadow:0 0 0 3px rgba(194,155,64,.13)}
.field textarea{resize:vertical;min-height:74px}
.modal-foot{padding:18px 26px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px;background:var(--card)}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--ink);color:#fff;padding:13px 20px;border-radius:12px;font-weight:500;font-size:13.5px;
  box-shadow:var(--sh-lg);z-index:100;opacity:0;transition:var(--t);display:flex;align-items:center;gap:9px}
.toast.show{transform:translateX(-50%);opacity:1}
.toast svg{width:17px;height:17px;color:var(--brass)}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty svg{width:44px;height:44px;color:var(--muted-2);margin-bottom:14px;stroke-width:1.5}

/* ---------- Scrollbars ---------- */
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:#D6D1C5;border-radius:10px;border:2px solid var(--bg)}
.col-body::-webkit-scrollbar-thumb{border-color:#EFEDE6}

/* ---------- Responsive ---------- */
@media(max-width:1100px){.kpis{grid-template-columns:1fr 1fr}.grid2,.grid-feed{grid-template-columns:1fr}}
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;z-index:70;transform:translateX(-100%);transition:var(--t);width:248px}
  .sidebar.open{transform:none}
  .menu-btn{display:grid !important}
  .search{width:auto;flex:1}
  .content{padding:18px}
  .topbar{padding:14px 18px}
  .modal-body{grid-template-columns:1fr}
}
.menu-btn{display:none;width:38px;height:38px;border-radius:10px;background:var(--card);border:1px solid var(--line);place-items:center}
.menu-btn svg{width:20px;height:20px}

@media(prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}}
:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
