:root{
  --orange:#FF7617; --charcoal:#323232; --ink:#1d1d1d;
  --muted:#6b7280; --line:#e6e6e6; --bg:#f6f7f9; --card:#fff;
  --ok:#15803d; --err:#b91c1c;
}
*{box-sizing:border-box} 
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.5}
a{color:var(--orange);text-decoration:none}

/* ---- Brand mark ---- */
.brand{font-weight:800;letter-spacing:.04em;color:var(--charcoal);display:flex;align-items:center;gap:.5rem;font-size:1.05rem}
.brand small{font-weight:600;color:var(--orange)}
.brand .dot{width:14px;height:14px;border-radius:50%;background:var(--orange);display:inline-block}

/* ---- Auth screens (login / install) ---- */
.auth-bg{min-height:100vh;display:grid;place-items:center;background:
  radial-gradient(1200px 500px at 50% -10%, #fff, var(--bg))}
.auth-card{background:var(--card);width:min(420px,92vw);padding:2rem;border:1px solid var(--line);
  border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.06)}
.auth-card h1{margin:1rem 0 .25rem;font-size:1.5rem;color:var(--charcoal)}
.auth-card form{margin-top:1rem;display:grid;gap:.85rem}
label{display:grid;gap:.3rem;font-size:.9rem;font-weight:600;color:var(--charcoal)}
input{padding:.7rem .8rem;border:1px solid var(--line);border-radius:10px;font-size:1rem}
input:focus{outline:2px solid var(--orange);border-color:var(--orange)}
button{background:var(--orange);color:#fff;border:0;padding:.8rem 1rem;border-radius:10px;
  font-weight:700;font-size:1rem;cursor:pointer}
button:hover{filter:brightness(.95)}
.muted{color:var(--muted)} .ok{color:var(--ok);font-weight:600} .err{color:var(--err);font-weight:600}
.steps,.steps li{margin:.4rem 0} code{background:#f1f1f1;padding:.1rem .35rem;border-radius:5px}

/* ---- App shell ---- */
.topbar{display:flex;justify-content:space-between;align-items:center;background:#fff;
  padding:.85rem 1.25rem;border-bottom:1px solid var(--line)}
.topbar-right{display:flex;align-items:center;gap:1rem}
.who{color:var(--muted);font-size:.9rem}
.btn-ghost{border:1px solid var(--line);padding:.45rem .8rem;border-radius:8px;color:var(--charcoal)}
.wrap{max-width:920px;margin:2rem auto;padding:0 1.25rem}
h1{color:var(--charcoal)} h2{color:var(--charcoal);margin-top:2rem}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin:1.25rem 0}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem}
.card-k{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
.card-v{font-size:1.4rem;font-weight:800;color:var(--charcoal);margin-top:.25rem}
.roadmap{list-style:none;padding:0;display:grid;gap:.5rem}
.roadmap li{background:#fff;border:1px solid var(--line);border-radius:10px;padding:.7rem .9rem;display:flex;gap:.7rem;align-items:center}
.roadmap .tick{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff;flex:none}
.roadmap li.ok .tick{background:var(--ok)} .roadmap li.todo .tick{background:#cbd5e1;color:#fff}
.roadmap li.todo{color:var(--muted)}
.note{margin-top:1.5rem;padding:1rem;background:#fff7f0;border:1px solid #ffd9b8;border-radius:10px}

/* ======================= PHASE 1: APP CHROME ======================= */
.app{background:var(--bg)}
.shell{display:flex;min-height:calc(100vh - 58px)}
.sidenav{width:210px;background:#fff;border-right:1px solid var(--line);padding:1rem .75rem;flex:none}
.sidenav a{display:block;padding:.6rem .8rem;border-radius:9px;color:var(--charcoal);font-weight:600;margin-bottom:.2rem}
.sidenav a:hover{background:#faf2ec}
.sidenav a.on{background:var(--orange);color:#fff}
.nav-sep{margin:1rem .4rem .4rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:#9aa1ab}
.nav-soon{display:block;padding:.5rem .8rem;color:#b6bcc4;font-size:.9rem}
.content{flex:1;padding:1.5rem 2rem;min-width:0}
.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}
.page-head h1{margin:0;font-size:1.5rem}
.head-actions{display:flex;gap:.5rem}
.count{background:#f0f1f3;color:var(--muted);font-size:.85rem;padding:.1rem .55rem;border-radius:20px;vertical-align:middle}
.btn{background:var(--orange);color:#fff;border:0;padding:.6rem .95rem;border-radius:9px;font-weight:700;cursor:pointer;font-size:.92rem}
.btn:hover{filter:brightness(.95)}
.btn-ghost{border:1px solid var(--line);background:#fff;padding:.55rem .85rem;border-radius:9px;color:var(--charcoal);font-weight:600;cursor:pointer;font-size:.9rem}
.flash{background:#ecfdf3;border:1px solid #bbf7d0;color:#15803d;padding:.7rem 1rem;border-radius:9px;margin-bottom:1rem;font-weight:600}
.hint{color:var(--muted);font-size:.9rem} .small{font-size:.82rem} .muted{color:var(--muted)}

/* panels & forms */
.panel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.25rem;margin-bottom:1.25rem}
.panel h3{margin:.1rem 0 .9rem;color:var(--charcoal)}
.collapsible{display:none} .collapsible.open{display:block}
.grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem}
.grid-form label{font-size:.82rem} .form-actions{grid-column:1/-1}
.filters{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
.filters input{flex:1;min-width:200px;padding:.55rem .7rem;border:1px solid var(--line);border-radius:9px}
.filters select{padding:.55rem;border:1px solid var(--line);border-radius:9px}

/* tables */
.tbl{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.tbl th{text-align:left;padding:.7rem .9rem;background:#fafafa;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:#8a909a;border-bottom:1px solid var(--line)}
.tbl td{padding:.75rem .9rem;border-bottom:1px solid #f1f1f1;font-size:.92rem}
.tbl tbody tr{cursor:pointer} .tbl tbody tr:hover{background:#fcf7f3}
.tbl .empty{text-align:center;color:var(--muted);padding:2rem}
.badge{display:inline-block;padding:.15rem .55rem;border-radius:20px;font-size:.75rem;font-weight:700}
.s-lead{background:#eef2ff;color:#4338ca}.s-enquiry{background:#fef9c3;color:#854d0e}
.s-paid{background:#dcfce7;color:#15803d}.s-lost{background:#fee2e2;color:#b91c1c}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.25rem}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem;display:block}
.card:hover{border-color:var(--orange)} .card.alert{border-color:#fca5a5;background:#fff5f5}
.card-k{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}
.card-v{font-size:1.5rem;font-weight:800;color:var(--charcoal);margin-top:.25rem}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@media(max-width:800px){.two-col{grid-template-columns:1fr}.sidenav{width:64px}.sidenav a{font-size:0;padding:.6rem}.content{padding:1rem}}
.webhook{display:block;background:#1d1d1d;color:#7CFFB2;padding:.7rem;border-radius:8px;font-size:.78rem;word-break:break-all;margin:.5rem 0}

/* profile 360 */
.profile{display:grid;grid-template-columns:280px 1fr;gap:1.25rem}
@media(max-width:800px){.profile{grid-template-columns:1fr}}
.profile-side{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.25rem}
.avatar{width:56px;height:56px;border-radius:50%;background:var(--orange);color:#fff;font-weight:800;font-size:1.5rem;display:grid;place-items:center}
.profile-side h1{font-size:1.25rem;margin:.6rem 0 .1rem}
.inline-status select{width:100%;margin:.6rem 0;padding:.5rem;border:1px solid var(--line);border-radius:8px}
.meta{font-size:.85rem;margin:.8rem 0}
.meta div{display:flex;justify-content:space-between;padding:.3rem 0;border-bottom:1px solid #f3f3f3}
.meta span{color:var(--muted)}
.tags{margin:.5rem 0}.tag{display:inline-block;background:#f0f1f3;border-radius:6px;padding:.1rem .5rem;font-size:.78rem;margin:.1rem}
.idents{list-style:none;padding:0;margin:.5rem 0;font-size:.85rem}
.idents li{padding:.35rem 0;border-bottom:1px solid #f3f3f3}
.ic{display:inline-block;min-width:62px;font-size:.68rem;text-transform:uppercase;color:#fff;background:#9aa1ab;border-radius:5px;padding:.05rem .35rem;text-align:center;margin-right:.4rem}
.ic-email{background:#3b82f6}.ic-phone{background:#22c55e}.ic-whatsapp{background:#16a34a}.ic-instagram{background:#d946ef}
.auto{color:var(--orange);font-style:normal;font-size:.7rem;font-weight:700;margin-left:.3rem}
.ident-add{display:flex;gap:.3rem;margin-top:.5rem}.ident-add select,.ident-add input{padding:.4rem;border:1px solid var(--line);border-radius:7px;font-size:.8rem}.ident-add input{flex:1;min-width:0}
.tab-cards{display:flex;gap:.75rem;margin-bottom:1rem}
.mini{background:#fff;border:1px solid var(--line);border-radius:10px;padding:.6rem .9rem;flex:1}
.mini span{color:var(--muted);font-size:.72rem;display:block}.mini strong{font-size:1.15rem}
.log-form textarea{width:100%;padding:.6rem;border:1px solid var(--line);border-radius:9px;margin:.5rem 0;font-family:inherit}
.log-row{display:flex;gap:.5rem}.log-row select{padding:.5rem;border:1px solid var(--line);border-radius:9px}.log-row input{flex:1;padding:.5rem;border:1px solid var(--line);border-radius:9px}
.deal-line{display:flex;gap:.6rem;align-items:center;padding:.4rem 0;border-bottom:1px solid #f3f3f3;font-size:.9rem}

/* timeline */
.timeline{list-style:none;padding:0;margin:0}
.tl{display:flex;gap:.8rem;padding:.2rem 0}
.tl-dot{width:11px;height:11px;border-radius:50%;background:#cbd5e1;margin-top:.35rem;flex:none;position:relative}
.tl::before{content:'';position:absolute;margin-left:5px;margin-top:1rem;width:1px;height:100%;background:#eee}
.tl-whatsapp .tl-dot{background:#16a34a}.tl-email .tl-dot{background:#3b82f6}.tl-call .tl-dot{background:#f59e0b}
.tl-task .tl-dot{background:#8b5cf6}.tl-system .tl-dot{background:#cbd5e1}.tl-note .tl-dot{background:var(--orange)}
.tl-body{padding-bottom:1rem;flex:1}.tl-text{font-size:.9rem;margin-top:.2rem;color:#374151}
.timeline.tight .tl-body{padding-bottom:.5rem}

/* kanban */
.kanban{display:flex;gap:.85rem;overflow-x:auto;padding-bottom:1rem}
.col{background:#f4f5f7;border-radius:11px;width:230px;flex:none;display:flex;flex-direction:column}
.col-head{padding:.65rem .8rem;font-weight:700;font-size:.85rem;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #e3e5e9}
.col-head.won{color:#15803d}.col-head.lost{color:#b91c1c}
.col-sum{font-weight:600;color:var(--muted);font-size:.72rem}
.col-body{padding:.6rem;min-height:80px;display:flex;flex-direction:column;gap:.5rem}
.card-deal{background:#fff;border:1px solid var(--line);border-radius:9px;padding:.6rem .7rem;cursor:grab;display:flex;flex-direction:column;gap:.15rem}
.card-deal:hover{border-color:var(--orange)}.card-deal strong{font-size:.88rem}
.deal-val{font-weight:700;color:var(--orange);font-size:.85rem}

/* dup review + tasks */
.dup-pair{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center;margin-bottom:.8rem}
.dup-vs{color:var(--muted);font-size:1.3rem}
.dup-actions{display:flex;gap:.5rem;align-items:center}
.task-list{display:flex;flex-direction:column;gap:.6rem}
.task{display:flex;gap:.8rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:10px;padding:.8rem 1rem}
.task.overdue{border-color:#fca5a5;background:#fff7f7}
.check{background:none;border:2px solid #cbd5e1;border-radius:50%;width:24px;height:24px;cursor:pointer;color:transparent}
.check:hover{border-color:var(--orange)}
.due-red{color:#b91c1c;font-weight:600}
.steps code{background:#f1f1f1;padding:.05rem .3rem;border-radius:4px}

/* ============ FIELDS SYSTEM UI ============ */
.tbl-scroll{overflow-x:auto}
.pill{display:inline-block;background:#fff3e9;color:var(--orange);border:1px solid #ffd9bd;border-radius:20px;font-size:.66rem;font-weight:700;padding:.05rem .45rem;vertical-align:middle}
.pill.sys{background:#eef2f7;color:#5b6b80;border-color:#dde3ea}
.chk{display:flex;align-items:center;gap:.4rem;font-size:.85rem}
.multi{display:flex;flex-wrap:wrap;gap:.4rem .9rem;border:1px solid var(--line);border-radius:9px;padding:.5rem}
.fields-tbl td{vertical-align:middle}
.fields-tbl .nowrap{white-space:nowrap}
.mini-btn{border:1px solid var(--line);background:#fff;border-radius:6px;padding:.2rem .5rem;font-size:.75rem;cursor:pointer;color:var(--charcoal)}
.mini-btn:hover{border-color:var(--orange)} .mini-btn.del{color:#b91c1c;border-color:#f3c4c4}
.switch{border:1px solid var(--line);background:#f3f4f6;color:#8a909a;border-radius:20px;padding:.2rem .7rem;font-size:.75rem;font-weight:700;cursor:pointer}
.switch.on{background:#dcfce7;color:#15803d;border-color:#bbf7d0}
.opt-row td{background:#faf7f4}
.opt-editor{padding:.4rem 0}
.opts{display:flex;flex-direction:column;gap:.35rem;margin:.5rem 0}
.opt{display:flex;gap:.4rem;align-items:center}
.opt-ren{display:flex;gap:.3rem;align-items:center}
.opt-ren input{padding:.3rem .5rem;border:1px solid var(--line);border-radius:6px;font-size:.85rem}
.opt-add{display:flex;gap:.4rem;margin-top:.4rem}
.opt-add input{padding:.4rem .5rem;border:1px solid var(--line);border-radius:7px}
.panel-head{display:flex;justify-content:space-between;align-items:center}
.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.7rem}
.detail{display:flex;flex-direction:column;border-bottom:1px solid #f3f3f3;padding:.3rem 0}
.detail .dl{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.detail .dv{font-size:.95rem;color:var(--charcoal)}
.idents .lbl{font-style:normal;font-size:.68rem;color:#5b6b80;background:#eef2f7;border-radius:5px;padding:.02rem .3rem;margin-left:.3rem}
.grid-form select,.grid-form input[type=text],.grid-form input[type=email],.grid-form input[type=number],.grid-form input[type=date],.grid-form textarea{width:100%;padding:.5rem;border:1px solid var(--line);border-radius:8px;font-family:inherit;margin-top:.2rem}

/* ============ REMARKS + CAMPAIGNS ============ */
.remark-form textarea{width:100%;padding:.6rem;border:1px solid var(--line);border-radius:9px;font-family:inherit}
.remark-actions{display:flex;gap:.5rem;align-items:center;margin-top:.4rem}
.remark-actions select{padding:.45rem;border:1px solid var(--line);border-radius:8px}
.remark-list{list-style:none;padding:0;margin:1rem 0 0}
.remark{border-left:3px solid var(--line);padding:.5rem .8rem;margin-bottom:.6rem;background:#fafafa;border-radius:0 8px 8px 0}
.remark.private{border-left-color:var(--orange);background:#fff7f0}
.remark-head{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.remark-tools{margin-left:auto;display:flex;gap:.3rem}
.remark-body{margin-top:.25rem;font-size:.92rem;color:#374151}
.vis-badge{background:var(--orange);color:#fff;border-radius:5px;padding:.02rem .35rem;font-size:.68rem;font-weight:700}
.remark-edit{margin-top:.5rem}
.remark-edit textarea{width:100%;padding:.5rem;border:1px solid var(--line);border-radius:8px;font-family:inherit}
.remark-edit select{padding:.4rem;border:1px solid var(--line);border-radius:8px;margin:.4rem .4rem 0 0}
.campaign-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}
.campaign-stat{text-align:center}.campaign-stat .big{display:block;font-size:1.6rem;font-weight:800;color:var(--orange)}
.camp-edit{margin-top:.6rem}.camp-edit summary{cursor:pointer;color:var(--muted);font-size:.85rem}

/* ============ WEBHOOK MAPPING + LEAD HISTORY ============ */
.map-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding:.5rem 0;border-bottom:1px solid #f3f3f3}
.map-row.inline{border:0;padding:0}
.map-key{display:flex;flex-direction:column;min-width:160px}
.map-arrow{color:var(--muted)}
.map-row select{padding:.45rem;border:1px solid var(--line);border-radius:8px}
.map-row .newlbl{padding:.45rem;border:1px solid var(--line);border-radius:8px;width:170px}
.subs{list-style:none;padding:0;margin:0}
.sub{border-left:3px solid var(--line);padding:.5rem .8rem;margin-bottom:.5rem;background:#fafafa;border-radius:0 8px 8px 0}
.sub.dup{border-left-color:#f59e0b;background:#fffbeb}
.sub-head{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.sub details{margin-top:.35rem}.sub summary{cursor:pointer}
.raw-tbl{width:100%;border-collapse:collapse;margin-top:.4rem;font-size:.82rem}
.raw-tbl td{border:1px solid #eee;padding:.25rem .5rem}
.raw-tbl .rk{color:var(--muted);width:38%;font-weight:600}

/* ============ CAMPAIGN ANALYTICS + PAGER ============ */
.card-sub{font-size:.72rem;color:var(--muted);margin-top:.15rem}
.campaign-link{display:block;text-decoration:none;color:inherit}
.campaign-link:hover{border-color:var(--orange)}
.del-btn{color:#b91c1c;border-color:#f3c4c4}
.bar-row{display:flex;align-items:center;gap:.6rem;margin:.35rem 0;font-size:.85rem}
.bar-label{width:90px;flex:none;color:var(--charcoal)}
.bar-track{flex:1;background:#f0f1f3;border-radius:6px;height:14px;overflow:hidden}
.bar-fill{display:block;height:100%;background:var(--orange);border-radius:6px}
.bar-n{width:34px;text-align:right;font-weight:700}
.velocity{margin-top:.8rem;padding-top:.6rem;border-top:1px solid #f1f1f1;font-size:.85rem;color:var(--muted)}
.velocity strong{color:var(--charcoal)}
.staff-row{display:flex;justify-content:space-between;padding:.25rem 0;border-bottom:1px solid #f3f3f3;font-size:.88rem}
.reassign{display:flex;gap:.4rem;margin-top:.7rem;flex-wrap:wrap}
.reassign select{padding:.4rem;border:1px solid var(--line);border-radius:8px}
.copy-wrap{display:flex;gap:.4rem;align-items:center}.copy-wrap .webhook{flex:1}
.pager{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:1rem;font-size:.85rem;color:var(--muted)}
.pager select{padding:.3rem .4rem;border:1px solid var(--line);border-radius:7px}
.pager-nav{display:flex;align-items:center;gap:.5rem}
.pager .disabled{opacity:.4;pointer-events:none}
.pager-pos{font-weight:600;color:var(--charcoal)}

/* ============ BRANDING + INVITES + SETTINGS ============ */
.brand-logo{height:30px;width:auto;display:block}
.topbar-right{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.invite-ok{border-color:#bbf7d0;background:#ecfdf3}
.invite-warn{border-color:#fde68a;background:#fffbeb}
.invite-creds{margin-top:.5rem;font-size:.88rem;display:flex;flex-direction:column;gap:.25rem}
.invite-creds code{background:#fff;border:1px solid var(--line);padding:.15rem .4rem;border-radius:5px;word-break:break-all}
input[type=color]{height:40px;padding:.2rem;border:1px solid var(--line);border-radius:8px;width:100%}

/* ============ PHASE 2: INBOX ============ */
.form-sec{grid-column:1/-1;font-weight:700;color:var(--charcoal);border-bottom:1px solid var(--line);padding-bottom:.3rem;margin-top:.5rem;font-size:.85rem}
.tbl tr.unseen td{font-weight:700;background:#fffdf7}
.tbl tr.unseen td:first-child{box-shadow:inset 3px 0 0 var(--orange)}
.thread{display:flex;flex-direction:column;gap:.8rem;margin-top:.5rem}
.msg{border:1px solid var(--line);border-radius:10px;padding:.8rem 1rem;max-width:90%}
.msg.in{background:#fafafa;align-self:flex-start;border-bottom-left-radius:2px}
.msg.out{background:#fff7f0;align-self:flex-end;border-bottom-right-radius:2px;border-color:#ffd9bd}
.msg-head{display:flex;gap:.6rem;align-items:baseline;margin-bottom:.35rem}
.msg-body{font-size:.92rem;line-height:1.5;color:#374151;word-wrap:break-word}
.grid-form textarea{width:100%;padding:.5rem;border:1px solid var(--line);border-radius:8px;font-family:inherit}
