/* ===== Senzo CRM — mobile-first ===== */
:root{
  --navy:#0d1b2a; --navy2:#1b263b; --accent:#e0a458; --accent2:#c98a3c;
  --bg:#f4f6f9; --card:#fff; --line:#e6e9ef; --txt:#1c2430; --muted:#6b7785;
  --ok:#2e8b57; --danger:#c0392b; --radius:14px; --shadow:0 2px 10px rgba(13,27,42,.07);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--txt);font-size:16px;line-height:1.45;
  padding-top:56px;padding-bottom:64px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0 0 .4em}
.muted{color:var(--muted)}.center{text-align:center}
small{color:var(--muted)}

/* ---- top bar ---- */
.topbar{position:fixed;top:0;left:0;right:0;height:56px;z-index:40;background:var(--navy);
  color:#fff;display:flex;align-items:center;gap:12px;padding:0 14px;
  padding-top:env(safe-area-inset-top)}
.burger{background:none;border:0;color:#fff;font-size:22px;cursor:pointer;display:none}
.brand{font-weight:800;font-size:19px;letter-spacing:.3px}
.brand span{color:var(--accent)}
.topbar-user{margin-left:auto;text-align:right;font-size:13px;line-height:1.1}
.topbar-user small{display:block;color:var(--accent);text-transform:capitalize;font-size:11px}

/* ---- side nav (desktop) ---- */
.sidenav{position:fixed;top:56px;left:0;bottom:0;width:220px;background:var(--navy2);
  padding:14px 10px;display:flex;flex-direction:column;gap:4px;z-index:30;transform:translateX(-100%);
  transition:transform .25s}
.sidenav a{color:#cdd6e3;padding:12px 14px;border-radius:10px;display:flex;align-items:center;gap:12px;font-weight:600}
.sidenav a span{width:22px;text-align:center}
.sidenav a.on,.sidenav a:active{background:rgba(224,164,88,.16);color:#fff}
.sidenav a.logout{margin-top:auto;color:#9fb0c3}
.nav-scrim{display:none}

/* ---- content ---- */
.content{padding:18px 14px;max-width:1100px;margin:0 auto}
.content.auth{display:flex;min-height:70vh;align-items:center;justify-content:center}
.page-title{font-size:22px;font-weight:800}
.page-title .count,.count{display:inline-block;background:var(--navy);color:#fff;font-size:13px;
  padding:2px 9px;border-radius:20px;vertical-align:middle;margin-left:6px}
.section{font-size:15px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:22px 0 8px}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;margin-bottom:14px;box-shadow:var(--shadow)}
.card h3{font-size:16px}

/* ---- alerts / buttons ---- */
.alert{background:#fff3f0;border:1px solid #f4c7bd;color:var(--danger);padding:12px 14px;border-radius:10px;margin-bottom:14px}
.alert.ok{background:#eef8f1;border-color:#bfe3cd;color:var(--ok)}
button,.btn-primary{font:inherit;cursor:pointer}
button[type=submit],.btn-primary{background:var(--accent);color:#3a2a12;border:0;font-weight:700;
  padding:13px 18px;border-radius:11px;width:100%;font-size:16px}
button[type=submit]:active,.btn-primary:active{background:var(--accent2)}
.btn-primary{display:inline-block;width:auto;margin-bottom:12px}

/* ---- forms ---- */
label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin:10px 0 4px}
label.check{display:flex;align-items:center;gap:8px;color:var(--txt)}
input,select{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fff}
input:focus,select:focus{outline:2px solid var(--accent);border-color:var(--accent)}
label.check input{width:auto}

/* ---- login ---- */
.login-card{background:#fff;border-radius:18px;box-shadow:0 10px 40px rgba(13,27,42,.15);
  padding:30px 24px;width:100%;max-width:380px}
.login-logo{font-size:28px;font-weight:800;text-align:center;margin-bottom:18px}
.login-logo span{color:var(--accent)}

/* ---- stats ---- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:14px 0}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;
  box-shadow:var(--shadow);display:flex;flex-direction:column}
.stat b{font-size:26px;font-weight:800;color:var(--navy)}
.stat span{color:var(--muted);font-size:13px}

/* ---- bars ---- */
.bar-row{display:flex;align-items:center;gap:10px;margin:8px 0;font-size:14px}
.bar-label{flex:0 0 38%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar{flex:1;background:#eef1f6;border-radius:8px;height:12px;overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.bar-val{flex:0 0 36px;text-align:right;font-weight:700;color:var(--navy)}

/* ---- search ---- */
.searchbar{display:flex;gap:8px;margin-bottom:14px}
.searchbar input{flex:1}
.searchbar button{background:var(--navy);color:#fff;border:0;border-radius:10px;width:48px;font-size:18px}

/* ---- contact list ---- */
.contact-row{display:flex;align-items:center;gap:12px;padding:12px 14px}
.cr-main{flex:1;min-width:0}
.cr-main b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cr-main small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex:0 0 42px}
.avatar.lg{width:60px;height:60px;flex:0 0 60px;font-size:24px}
.chip{background:#eef1f6;color:var(--navy);padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600}

/* ---- contact detail ---- */
.back{display:inline-block;color:var(--accent2);font-weight:600;margin-bottom:8px}
.contact-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.quick-actions{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.qa{flex:1;min-width:90px;text-align:center;background:var(--navy);color:#fff;padding:12px;border-radius:11px;font-weight:600;font-size:14px}
.qa.wa{background:#25d366;color:#063}
.info-row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:15px}
.info-row:last-child{border:0}
.info-l{color:var(--muted);flex:0 0 40%}
.deal-row{padding:9px 0;border-bottom:1px solid var(--line)}
.deal-row:last-child{border:0}.deal-row b{display:block}

/* ---- agents ---- */
.form-card{display:none}.form-card.open{display:block}
.agent-list{display:grid;gap:12px;grid-template-columns:1fr}
.agent.inactive{opacity:.55}
.agent-head{display:flex;align-items:center;gap:12px}
.agent-head>div:nth-child(2){flex:1;min-width:0}
.agent-head b{display:block}.agent-head small{display:block;overflow:hidden;text-overflow:ellipsis}
.role-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase}
.r-super_admin{background:#3a2a12;color:var(--accent)}
.r-admin{background:#1b263b;color:#fff}
.r-agent{background:#e7eef9;color:#2c5282}
.r-lecture{background:#eee;color:#666}
.agent-meta{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin:10px 0 0}
.agent-meta .on{color:var(--ok);font-weight:700}.agent-meta .off{color:var(--danger);font-weight:700}
.agent-edit{margin-top:10px}.agent-edit summary{cursor:pointer;color:var(--accent2);font-weight:600;font-size:14px}

/* ---- pipelines ---- */
.pipe-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.pipe-tile{display:flex;flex-direction:column;justify-content:space-between;min-height:84px;font-weight:700}
.pipe-tile .count{align-self:flex-start;margin:8px 0 0}

/* ---- kanban ---- */
.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:14px;-webkit-overflow-scrolling:touch}
.kcol{flex:0 0 260px;background:#eef1f6;border-radius:12px;padding:10px}
.kcol-head{font-weight:700;font-size:14px;margin-bottom:8px;display:flex;justify-content:space-between}
.kcol-head span{background:#fff;border-radius:20px;padding:0 8px;font-size:12px}
.kcard{display:block;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:8px;box-shadow:var(--shadow)}
.kcard b{display:block;font-size:14px}
.kcard.won{border-left:3px solid var(--ok)}.kcard.lost{border-left:3px solid var(--danger);opacity:.7}
.kval{display:inline-block;margin-top:4px;font-size:12px;font-weight:700;color:var(--accent2)}
.kempty{color:#aab;text-align:center;padding:8px}

/* ---- pager ---- */
.pager{display:flex;align-items:center;justify-content:center;gap:16px;margin:16px 0}
.pager a{background:var(--navy);color:#fff;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px}

/* ---- bottom tab bar (mobile) ---- */
.tabbar{position:fixed;bottom:0;left:0;right:0;height:60px;background:#fff;border-top:1px solid var(--line);
  display:flex;z-index:35;padding-bottom:env(safe-area-inset-bottom)}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--muted);font-size:0}
.tabbar a span{font-size:20px}.tabbar a b{font-size:10px;font-weight:600}

/* ===== desktop ===== */
@media(min-width:860px){
  body{padding-bottom:0}
  .sidenav{transform:none}
  .content{margin-left:220px;padding:26px 30px}
  .tabbar{display:none}
  .stats{grid-template-columns:repeat(5,1fr)}
  .agent-list{grid-template-columns:repeat(2,1fr)}
  .pipe-grid{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:859px){
  .burger{display:block}
  body.nav-open .sidenav{transform:translateX(0)}
  body.nav-open .nav-scrim{display:block;position:fixed;inset:56px 0 0;background:rgba(0,0,0,.4);z-index:25}
}
