/* =====================================================================
   Outreach CRM — ClickUp-inspired design system
   Palette: ClickUp purple → pink, clean light sidebar, soft surfaces.
   ===================================================================== */
:root{
  --brand:#7B68EE;          /* ClickUp purple */
  --brand-d:#5f4fd6;
  --brand-soft:#f1eefe;     /* light purple wash */
  --pink:#FD71AF;
  --grad:linear-gradient(135deg,#7B68EE 0%,#FD71AF 100%);

  --canvas:#f7f8fa;         /* page background */
  --surface:#ffffff;
  --sidebar:#ffffff;
  --ink:#1d2330;            /* primary text */
  --ink-soft:#6b7280;       /* muted text */
  --ink-faint:#9aa1ad;
  --line:#ebedf0;
  --line-soft:#f1f2f4;

  --green:#16a34a;  --green-bg:#e7f8ee;
  --orange:#f59e0b; --orange-bg:#fff4e0;
  --red:#ef4444;    --red-bg:#fdecec;
  --gray:#d8dce2;

  --radius:12px;
  --radius-lg:16px;
  --shadow:0 1px 2px rgba(29,35,48,.04), 0 4px 16px rgba(29,35,48,.05);
  --shadow-lg:0 8px 30px rgba(29,35,48,.10);
  --font:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);color:var(--ink);background:var(--canvas);font-size:14.5px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0 0 .4em;letter-spacing:-.01em}

/* ---------- Layout ---------- */
.layout{display:flex;min-height:100vh}
.sidebar{width:252px;flex:0 0 252px;background:var(--sidebar);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{padding:28px 32px;max-width:1280px;width:100%}

/* ---------- Brand + nav ---------- */
.brand{display:flex;align-items:center;gap:11px;padding:22px 20px 18px;font-weight:800;color:var(--ink);font-size:17px;letter-spacing:-.02em}
.brand-dot{width:30px;height:30px;border-radius:9px;background:var(--grad);box-shadow:0 4px 12px rgba(123,104,238,.35);flex:0 0 auto}
.nav{display:flex;flex-direction:column;gap:3px;padding:8px 12px;flex:1}
.nav-link{display:flex;align-items:center;gap:12px;padding:10px 13px;border-radius:10px;color:var(--ink-soft);font-weight:600;font-size:14px;transition:.13s}
.nav-link:hover{background:var(--line-soft);color:var(--ink);text-decoration:none}
.nav-link.active{background:var(--brand-soft);color:var(--brand-d)}
.nav-ico{width:20px;text-align:center;font-size:15px;opacity:.95;flex:0 0 auto}
.nav{overflow-y:auto}
/* Accordion sections */
.nav-group{margin-top:6px}
.nav-group-head{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:0;cursor:pointer;
  padding:9px 14px 5px;font-family:inherit;font-size:10.5px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-faint)}
.nav-group-head:hover{color:var(--ink-soft)}
.nav-caret{font-size:13px;opacity:.7;transition:transform .16s ease}
.nav-group.open .nav-caret{transform:rotate(90deg)}
.nav-group-body{display:none;flex-direction:column;gap:3px;margin-top:2px}
.nav-group.open .nav-group-body{display:flex}
.sidebar-foot{padding:14px 18px;border-top:1px solid var(--line);font-size:12.5px}
.who-mini{color:var(--ink);font-weight:700}
.who-email{color:var(--ink-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---------- Section sub-tabs ---------- */
.subtabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:22px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.subtab{flex:0 0 auto;padding:10px 15px;font-weight:700;font-size:13.5px;color:var(--ink-soft);border-bottom:2px solid transparent;white-space:nowrap}
.subtab:hover{color:var(--ink);text-decoration:none}
.subtab.active{color:var(--brand-d);border-bottom-color:var(--brand)}

/* ---------- Sale allocation preview ---------- */
.sale-preview{background:var(--brand-soft);border-radius:10px;padding:6px 12px;margin:0 0 14px}
.sale-preview:empty{display:none}
.sp-row{display:flex;justify-content:space-between;padding:5px 0;font-size:13.5px;border-bottom:1px solid rgba(123,104,238,.12)}
.sp-row:last-child{border-bottom:0}
.sp-row.muted strong{font-weight:600}

/* ---------- Topbar ---------- */
.topbar{display:flex;align-items:center;gap:14px;padding:15px 32px;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.page-title{font-size:19px;margin:0;flex:1;font-weight:800;letter-spacing:-.02em}
.topbar-user{display:flex;align-items:center;gap:12px}
.who{font-weight:700;font-size:13.5px}
.hamburger{display:flex;align-items:center;justify-content:center;background:none;border:0;font-size:22px;cursor:pointer;color:var(--ink);line-height:1}

/* Desktop: collapse the whole sidebar to reclaim space (toggled by the ☰ button). */
.sidebar{transition:margin-left .2s ease}
@media(min-width:821px){
  .layout.nav-collapsed .sidebar{margin-left:-253px}
}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}
.badge-admin{background:var(--brand-soft);color:var(--brand-d)}
.badge-agent{background:#e6f7f0;color:#0f9d58}
.badge-owner{background:#fff1e6;color:#c2410c}

.pill{display:inline-block;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:700}
.pill.discovery{background:#e6f0ff;color:#2563eb}
.pill.proposal{background:#efeafe;color:#7c3aed}
.pill.negotiation{background:#fff4e0;color:#b45309}
.pill.closed_won{background:var(--green-bg);color:var(--green)}
.pill.closed_lost{background:var(--red-bg);color:var(--red)}
.pill.no_show{background:#eef1f5;color:#475569}
.pill.rescheduled{background:#e8ebff;color:#4f46e5}
.pill.nurture{background:#fdeaf4;color:#be185d}

/* ---------- Cards / grid ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:26px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px 22px;box-shadow:var(--shadow);transition:.15s}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}
.stat .stat-label{color:var(--ink-soft);font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.stat .stat-value{font-size:32px;font-weight:800;margin-top:8px;letter-spacing:-.03em}
.stat .stat-sub{color:var(--ink-soft);font-size:12.5px;margin-top:5px}
.stat-accent{height:4px;border-radius:4px;margin-top:14px;background:var(--grad)}

.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:26px;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:17px 22px;border-bottom:1px solid var(--line-soft)}
.panel-head h2{font-size:16px;margin:0;font-weight:800;letter-spacing:-.02em}
.panel-body{padding:20px 22px}
.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:26px;align-items:start}
@media(max-width:900px){.grid-2{grid-template-columns:1fr}}

/* ---------- Tables ---------- */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;color:var(--ink-faint);font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;padding:12px 14px;border-bottom:1px solid var(--line)}
.table td{padding:13px 14px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tbody tr{transition:.1s}
.table tr:hover td{background:#fafbfc}
.table .num{text-align:right;font-variant-numeric:tabular-nums}
.muted{color:var(--ink-soft)}
.right{text-align:right}

/* ---------- Forms ---------- */
.form-row{margin-bottom:15px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
label{display:block;font-weight:700;font-size:13px;margin-bottom:7px;color:var(--ink)}
input,select,textarea{width:100%;padding:11px 13px;border:1.5px solid var(--gray);border-radius:10px;font:inherit;font-size:14px;background:#fff;color:var(--ink);transition:.13s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(123,104,238,.16)}
textarea{min-height:92px;resize:vertical}
.help{font-size:12.5px;color:var(--ink-soft);margin-top:5px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 17px;border-radius:10px;border:1.5px solid transparent;font-weight:700;font-size:14px;cursor:pointer;transition:.13s;font-family:inherit}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 2px 8px rgba(123,104,238,.3)}
.btn-primary:hover{background:var(--brand-d);box-shadow:0 4px 14px rgba(123,104,238,.4)}
.btn-ghost{background:#fff;border-color:var(--gray);color:var(--ink)}
.btn-ghost:hover{background:var(--line-soft);border-color:var(--ink-faint)}
.btn-danger{background:#fff;border-color:#f3b4b4;color:var(--red)}
.btn-danger:hover{background:var(--red-bg)}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-block{width:100%;justify-content:center}
.actions{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Flash ---------- */
.flash{padding:13px 17px;border-radius:11px;margin-bottom:18px;font-weight:600;font-size:14px}
.flash-success{background:var(--green-bg);color:#15803d}
.flash-error{background:var(--red-bg);color:#b91c1c}
.flash-info{background:var(--brand-soft);color:var(--brand-d)}

/* ---------- Heatmap ---------- */
.heatmap{display:flex;gap:4px;overflow-x:auto;padding:6px 0}
.heatmap .week{display:flex;flex-direction:column;gap:4px}
.hcell{width:15px;height:15px;border-radius:4px;background:#eef0f3}
.hcell.green{background:var(--green)}
.hcell.orange{background:var(--orange)}
.hcell.red{background:var(--red)}
.hcell.off{background:#e4e7ec}
.hcell.future{background:#f7f8fa;border:1px dashed #e0e3e8}
.hcell.none{background:transparent}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--ink-soft);margin-top:12px}
.legend i{display:inline-block;width:12px;height:12px;border-radius:4px;margin-right:6px;vertical-align:-1px}

/* day grid (calendar month) */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}
.cal .dow{font-size:11px;color:var(--ink-faint);text-align:center;font-weight:700;text-transform:uppercase}
.cal .cell{aspect-ratio:1;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:12px;border:1px solid var(--line);background:#fff}
.cal .cell.green{background:var(--green-bg);border-color:#bbf0cf}
.cal .cell.orange{background:var(--orange-bg);border-color:#fde0ad}
.cal .cell.red{background:var(--red-bg);border-color:#f8c9c9}
.cal .cell.off{background:#f4f5f7;color:#9aa1ad}
.cal .cell.future{background:#fff;color:#cbd0d8}
.cal .cell .dnum{font-weight:700}
.cal .cell .dval{font-size:10px;color:var(--ink-soft)}

/* funnel */
.funnel{display:flex;flex-direction:column;gap:10px}
.funnel .frow{display:flex;align-items:center;gap:12px}
.funnel .fbar{height:36px;border-radius:9px;background:var(--grad);display:flex;align-items:center;padding:0 13px;color:#fff;font-weight:800;min-width:42px}
.funnel .flabel{width:135px;font-size:13px;color:var(--ink-soft);font-weight:700}

/* misc */
.empty{padding:34px;text-align:center;color:var(--ink-faint)}
.streaks{display:flex;gap:18px}
.streak-box{flex:1;text-align:center;background:var(--canvas);border-radius:13px;padding:16px;border:1px solid var(--line)}
.streak-box .n{font-size:28px;font-weight:800}
.streak-box .l{font-size:11.5px;color:var(--ink-soft);text-transform:uppercase;font-weight:700;letter-spacing:.04em}
.fire{color:var(--pink)}
.toolbar{display:flex;gap:11px;flex-wrap:wrap;align-items:flex-end;margin-bottom:20px}
.toolbar .form-row{margin:0}
.section-title{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);font-weight:700;margin:24px 0 10px}

/* ---------- Progress bars (per-channel) ---------- */
.prog-list{display:flex;flex-direction:column;gap:16px}
.prog-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px}
.prog-name{font-weight:700;font-size:14px}
.prog-val{font-size:13px;color:var(--ink-soft);font-variant-numeric:tabular-nums;font-weight:600}
.prog-track{height:9px;border-radius:999px;background:var(--line);overflow:hidden}
.prog-fill{height:100%;border-radius:999px;background:var(--grad);transition:width .4s ease}
.prog-fill.is-hit{background:var(--green)}

/* status dot */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:7px;vertical-align:middle}
.dot-green{background:var(--green)}
.dot-amber{background:var(--orange)}

/* channel target inputs (employee form) */
.channel-targets{display:flex;flex-direction:column;gap:8px;margin:8px 0 6px}
.ct-row{display:flex;align-items:center;gap:12px}
.ct-label{flex:1;font-weight:600;font-size:14px}
.ct-row input{width:120px}

/* scroll wrapper for wide tables on small screens */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.log-table input{width:84px}

/* key/value rows (profile + pay panels) */
.kv{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line-soft);font-size:14px}
.kv:last-child{border-bottom:0}
.kv span{color:var(--ink-soft)}
.kv strong{text-align:right}
.kv-total{border-top:2px solid var(--line);border-bottom:0;margin-top:4px;padding-top:12px;font-size:16px}
.kv-total strong{color:var(--brand-d)}

/* ---------- Auth page ---------- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(900px 500px at 12% -10%,rgba(123,104,238,.55),transparent),
             radial-gradient(800px 500px at 110% 110%,rgba(253,113,175,.5),transparent),
             #14121f}
.auth-card{width:100%;max-width:410px;background:var(--surface);border-radius:20px;padding:38px;box-shadow:0 24px 70px rgba(0,0,0,.35)}
.auth-card .brand{color:var(--ink);padding:0 0 8px}
.auth-sub{color:var(--ink-soft);margin-bottom:24px;font-size:14px}

/* ---------- Mobile sidebar backdrop ---------- */
.nav-backdrop{display:none;position:fixed;inset:0;background:rgba(20,18,31,.45);z-index:40;opacity:0;transition:opacity .2s}
.nav-backdrop.show{display:block;opacity:1}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .grid-2{grid-template-columns:1fr}
  .cards{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
}
@media(max-width:820px){
  .sidebar{position:fixed;z-index:50;left:-280px;transition:left .22s ease;height:100vh;width:264px;box-shadow:var(--shadow-lg)}
  .sidebar.open{left:0}
  .hamburger{display:block}
  .content{padding:16px}
  .topbar{padding:12px 16px}
  .who{display:none}                 /* keep topbar tidy on phones */
  .page-title{font-size:17px}
  .card{padding:16px}
  .stat .stat-value{font-size:27px}
  .panel-head{padding:14px 16px}
  .panel-body{padding:16px}
}
@media(max-width:560px){
  .cards{grid-template-columns:1fr 1fr}
  .topbar-user .badge{display:none}
  /* let any wide table scroll horizontally inside its panel on phones */
  .panel-body{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .table{min-width:520px}
  .log-table{min-width:0}      /* log table stacks instead of scrolls */
  .form-grid{grid-template-columns:1fr}
  .channel-targets .ct-row{justify-content:space-between}
  .auth-card{padding:26px}
  .toolbar{gap:8px}
  .toolbar .form-row,.toolbar input,.toolbar select{width:100%}
  .toolbar form{width:100%;flex-direction:column;align-items:stretch}

  /* Daily-log table → stacked cards so agents can log easily on a phone */
  .log-table thead{display:none}
  .log-table,.log-table tbody,.log-table tr,.log-table td{display:block;width:100%}
  .log-table tr{border:1px solid var(--line);border-radius:12px;padding:8px 12px;margin-bottom:12px;background:#fff}
  .log-table tr:hover td{background:transparent}
  .log-table td{border:0;padding:7px 0;display:flex;align-items:center;justify-content:space-between}
  .log-table td:first-child{font-size:15px;border-bottom:1px solid var(--line-soft);padding-bottom:9px;margin-bottom:3px}
  .log-table td[data-label]::before{content:attr(data-label);color:var(--ink-soft);font-weight:600;font-size:13px}
  .log-table input{width:120px}
  .ct-row input{width:100px}
}

/* =====================================================================
   Team Chat — WhatsApp-style messenger
   ===================================================================== */
/* The [hidden] attribute must always win, even over our display:flex classes
   (otherwise the chat room / recording bar / menus show when they shouldn't). */
.chat [hidden],.msg-menu[hidden],.msg-menu-backdrop[hidden]{display:none!important}

/* Sidebar unread badge */
.nav-link{position:relative}
.nav-badge{margin-left:auto;background:var(--pink);color:#fff;font-size:11px;font-weight:800;line-height:1;
  padding:3px 7px;border-radius:999px;min-width:18px;text-align:center}

/* Full-bleed chat page: fill the viewport, no page padding */
body.page-chat .main{height:100vh}
body.page-chat .content{padding:0;max-width:none;flex:1;min-height:0;display:flex}

.chat{flex:1;display:flex;min-height:0;background:var(--surface)}

/* ---------- Conversation list (left) ---------- */
.chat-list{flex:0 0 332px;display:flex;flex-direction:column;border-right:1px solid var(--line);min-height:0;background:var(--surface)}
.chat-list-head{padding:16px 18px 10px;display:flex;align-items:baseline;gap:10px}
.chat-list-head h2{margin:0;font-size:20px;font-weight:800;letter-spacing:-.02em}
.chat-list-sub{color:var(--ink-faint);font-size:12.5px;font-weight:600}
.chat-search{padding:0 14px 12px}
.chat-search input{width:100%;border:1px solid var(--line);background:var(--canvas);border-radius:999px;
  padding:9px 15px;font-family:inherit;font-size:13.5px;outline:none}
.chat-search input:focus{border-color:var(--brand);background:#fff}
.chat-convos{flex:1;overflow-y:auto;min-height:0}
.chat-empty-list{padding:26px 18px;color:var(--ink-faint);font-size:13.5px;text-align:center}

.convo{display:flex;align-items:center;gap:12px;width:100%;border:0;background:none;cursor:pointer;
  padding:11px 16px;text-align:left;font-family:inherit;border-bottom:1px solid var(--line-soft);transition:.12s}
.convo:hover{background:var(--line-soft)}
.convo.active{background:var(--brand-soft)}
.convo-main{flex:1;min-width:0}
.convo-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.convo-name{font-weight:700;font-size:14.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.convo-time{color:var(--ink-faint);font-size:11.5px;flex:0 0 auto}
.convo-bot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:2px}
.convo-preview{color:var(--ink-soft);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.convo-muted{color:var(--ink-faint);font-style:italic}
.convo-badge{background:var(--green);color:#fff;font-size:11px;font-weight:800;line-height:1;
  padding:3px 7px;border-radius:999px;min-width:18px;text-align:center;flex:0 0 auto}

/* Avatar circle */
.chat-avatar{flex:0 0 auto;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--grad);color:#fff;font-weight:800;font-size:15px;letter-spacing:.02em;text-transform:uppercase}

/* ---------- Thread (right) ---------- */
.chat-thread{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;position:relative;
  background:#efeae2 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cg fill='%23000' fill-opacity='0.025'%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Ccircle cx='40' cy='30' r='2'/%3E%3Ccircle cx='20' cy='48' r='2'/%3E%3C/g%3E%3C/svg%3E")}

.chat-placeholder{margin:auto;text-align:center;color:var(--ink-soft);max-width:380px;padding:30px}
.chat-placeholder-art{font-size:54px;margin-bottom:10px}
.chat-placeholder h3{font-size:20px;color:var(--ink);margin-bottom:6px}
.chat-placeholder p{font-size:14px;line-height:1.6}

.chat-room{display:flex;flex-direction:column;flex:1;min-height:0}
.chat-room.drag,.chat-thread.drag .chat-room{outline:3px dashed var(--brand);outline-offset:-8px}
.chat-room-head{display:flex;align-items:center;gap:12px;padding:11px 18px;background:var(--surface);border-bottom:1px solid var(--line)}
.chat-room-head .chat-avatar{width:40px;height:40px;font-size:14px}
.chat-room-who{display:flex;flex-direction:column;min-width:0}
.chat-room-name{font-weight:800;font-size:15.5px;letter-spacing:-.01em}
.chat-room-role{color:var(--ink-faint);font-size:12px;font-weight:600}
.chat-back{display:none;background:none;border:0;font-size:26px;line-height:1;cursor:pointer;color:var(--ink);padding:0 4px 0 0}

/* Messages scroll area */
.chat-messages{flex:1;overflow-y:auto;min-height:0;padding:18px 8% 14px;display:flex;flex-direction:column;gap:3px}
.chat-day{align-self:center;margin:10px 0}
.chat-day span{background:#fff;color:var(--ink-soft);font-size:11.5px;font-weight:700;padding:4px 12px;border-radius:999px;box-shadow:var(--shadow)}

/* Bubbles */
.bubble{max-width:min(70%,560px);padding:7px 10px 5px;border-radius:12px;position:relative;box-shadow:0 1px .5px rgba(0,0,0,.08);
  font-size:14px;line-height:1.42;word-wrap:break-word;overflow-wrap:anywhere}
.bubble.in{align-self:flex-start;background:#fff;border-top-left-radius:4px}
.bubble.out{align-self:flex-end;background:#d9fdd3;border-top-right-radius:4px}
.bubble-text{white-space:pre-wrap}
.bubble a{color:var(--brand-d);text-decoration:underline}
.bubble-meta{display:block;text-align:right;font-size:10.5px;color:var(--ink-faint);margin-top:2px;user-select:none}
.ticks{margin-left:5px;color:#9aa1ad;font-weight:700}
.ticks.read{color:#34b7f1}

/* Attachments inside bubbles */
.bubble-img{display:block;margin:-1px 0 3px}
.bubble-img img{max-width:280px;max-height:340px;width:auto;border-radius:9px;display:block}
.bubble-video{max-width:300px;max-height:340px;border-radius:9px;display:block;margin-bottom:3px;background:#000}
.bubble-audio{display:block;margin:2px 0 4px;max-width:260px}
.bubble-file{display:flex;align-items:center;gap:10px;padding:9px 11px;background:rgba(0,0,0,.05);border-radius:9px;
  margin-bottom:3px;text-decoration:none;color:var(--ink)}
.bubble-file:hover{background:rgba(0,0,0,.09);text-decoration:none}
.file-ico{font-size:26px;line-height:1}
.file-meta{display:flex;flex-direction:column;min-width:0}
.file-name{font-weight:700;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.file-size{color:var(--ink-faint);font-size:11.5px}

/* Composer */
.chat-composer{display:flex;align-items:flex-end;gap:9px;padding:11px 16px;background:var(--surface);border-top:1px solid var(--line)}
.chat-attach{flex:0 0 auto;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink-soft);font-size:24px;font-weight:400;transition:.12s}
.chat-attach:hover{background:var(--line-soft);color:var(--brand-d)}
.chat-input-wrap{position:relative;flex:1;background:var(--canvas);border:1px solid var(--line);border-radius:22px;padding:0 14px;min-width:0}
.chat-input-wrap textarea{width:100%;border:0;background:none;resize:none;outline:none;font-family:inherit;font-size:14.5px;
  line-height:1.4;padding:9px 0;height:38px;min-height:38px;max-height:140px;display:block;overflow-y:auto}
.chat-file-chip{display:flex;align-items:center;gap:8px;background:var(--brand-soft);color:var(--brand-d);
  border-radius:8px;padding:5px 10px;margin:5px 0 2px;font-size:12.5px;font-weight:600}
.chat-file-chip button{background:none;border:0;color:var(--brand-d);cursor:pointer;font-size:13px;font-weight:800}
.chat-file-chip span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}
.chat-send{flex:0 0 auto;width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;background:var(--grad);color:#fff;
  font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(123,104,238,.35);transition:.12s}
.chat-send:hover{transform:scale(1.05)}
.chat-send:active{transform:scale(.96)}

/* Mobile: one pane at a time, like the WhatsApp phone app */
@media(max-width:820px){
  .chat-list{flex-basis:100%}
  .chat-thread{display:none}
  .chat.show-thread .chat-list{display:none}
  .chat.show-thread .chat-thread{display:flex}
  .chat-back{display:block}
  .bubble{max-width:82%}
  .bubble-img img,.bubble-video{max-width:72vw}
}

/* ---------- Chat: presence, in-chat search, voice notes ---------- */
/* Online dot on avatars + room header */
.chat-avatar{position:relative}
.presence-dot{position:absolute;right:-1px;bottom:-1px;width:12px;height:12px;border-radius:50%;
  background:#22c55e;border:2px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.04)}
.chat-room-head .presence-dot{right:0;bottom:0}
.chat-room-status{color:var(--ink-faint);font-size:12px;font-weight:600}
.chat-room-status.is-online{color:#16a34a}

/* Header icon button (search) */
.chat-icon-btn{margin-left:auto;background:none;border:0;cursor:pointer;font-size:17px;line-height:1;
  width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-soft)}
.chat-icon-btn:hover{background:var(--line-soft)}

/* In-conversation search bar */
.chat-search-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--surface);border-bottom:1px solid var(--line)}
.chat-search-bar input{flex:1;border:1px solid var(--line);background:var(--canvas);border-radius:999px;
  padding:8px 14px;font-family:inherit;font-size:13.5px;outline:none}
.chat-search-bar input:focus{border-color:var(--brand);background:#fff}
.chat-search-count{font-size:12px;color:var(--ink-soft);font-weight:700;min-width:34px;text-align:center}
.chat-search-bar button{background:none;border:0;cursor:pointer;font-size:14px;color:var(--ink-soft);
  width:30px;height:30px;border-radius:8px}
.chat-search-bar button:hover{background:var(--line-soft);color:var(--ink)}
mark.hit{background:#fff3a0;color:inherit;border-radius:2px;padding:0 1px}
mark.hit.current{background:#ffb01f;color:#1d2330}

/* Composer needs a positioning context for the recording overlay */
.chat-composer{position:relative}

/* The single trailing button morphs between mic (empty) and send (typing) */
.chat-send .ic-mic,.chat-send .ic-send{display:none;line-height:1}
.chat-send[data-mode="mic"]  .ic-mic {display:inline}
.chat-send[data-mode="send"] .ic-send{display:inline}
.chat-send[data-mode="mic"]{font-size:20px}

/* Recording bar — overlays the whole composer while recording */
.chat-rec{position:absolute;inset:0;display:flex;align-items:center;gap:12px;padding:11px 16px;
  background:var(--surface);border-top:1px solid var(--line);z-index:5}
.chat-rec .rec-spacer{flex:1}
.chat-rec button{background:none;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center}
.chat-rec .rec-trash{font-size:20px;color:var(--red);width:42px;height:42px;border-radius:50%}
.chat-rec .rec-trash:hover{background:var(--red-bg)}
.chat-rec .rec-pause{font-size:16px;color:var(--ink-soft);width:42px;height:42px;border-radius:50%}
.chat-rec .rec-pause:hover{background:var(--line-soft);color:var(--ink)}
.chat-rec .rec-dot{width:12px;height:12px;border-radius:50%;background:var(--red);animation:recpulse 1s infinite;flex:0 0 auto}
.chat-rec .rec-time{font-weight:800;font-size:15px;font-variant-numeric:tabular-nums;color:var(--ink)}
.chat-rec .rec-hint{color:var(--ink-faint);font-size:13px}
.chat-rec .rec-send{width:46px;height:46px;border-radius:50%;background:var(--grad);color:#fff;font-size:18px;
  box-shadow:0 4px 12px rgba(123,104,238,.35)}
@keyframes recpulse{0%,100%{opacity:1}50%{opacity:.25}}

/* Per-bubble options caret (hover to reveal; always tappable on touch) */
.bubble{position:relative}
.bubble-menu-btn{position:absolute;top:1px;right:2px;width:22px;height:20px;border:0;cursor:pointer;
  background:none;color:var(--ink-faint);font-size:15px;line-height:1;border-radius:6px;opacity:0;transition:.12s;padding:0}
.bubble.out .bubble-menu-btn{color:#3a8a4f}
.bubble:hover .bubble-menu-btn{opacity:.85}
.bubble-menu-btn:hover{opacity:1;background:rgba(0,0,0,.06)}
@media(hover:none){.bubble-menu-btn{display:none}}  /* touch uses long-press instead */

/* Deleted-message tombstone */
.bubble.deleted{opacity:.85}
.deleted-text{font-style:italic;color:var(--ink-soft)}

/* Message-actions popup */
.msg-menu-backdrop{position:fixed;inset:0;z-index:60}
.msg-menu{position:fixed;z-index:61;background:#fff;border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow-lg);padding:6px;min-width:190px;display:flex;flex-direction:column;gap:2px}
.msg-menu-item{background:none;border:0;text-align:left;padding:10px 14px;border-radius:8px;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:600;color:var(--ink)}
.msg-menu-item:hover{background:var(--line-soft)}
.msg-menu-item.danger{color:var(--red)}
.msg-menu-item.danger:hover{background:var(--red-bg)}
.msg-menu-item.cancel{color:var(--ink-soft)}

/* ---------- Chat: reply / quote ---------- */
.chat-reply-bar{display:flex;align-items:stretch;gap:0;margin:0 16px;background:var(--canvas);
  border-radius:10px 10px 0 0;border:1px solid var(--line);border-bottom:0;overflow:hidden}
.chat-reply-bar .reply-accent{width:4px;background:var(--brand);flex:0 0 auto}
.chat-reply-bar .reply-body{flex:1;min-width:0;padding:7px 12px;display:flex;flex-direction:column}
.chat-reply-bar .reply-author{font-size:12.5px;font-weight:800;color:var(--brand-d)}
.chat-reply-bar .reply-text{font-size:13px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-reply-bar .reply-close{background:none;border:0;cursor:pointer;color:var(--ink-soft);font-size:14px;padding:0 14px}
.chat-reply-bar .reply-close:hover{color:var(--ink)}

/* Quote shown at the top of a bubble that replies to another message */
.bubble-quote{display:flex;flex-direction:column;gap:1px;border-left:3px solid var(--brand);
  background:rgba(0,0,0,.05);border-radius:6px;padding:5px 9px;margin-bottom:5px;cursor:pointer;max-width:100%}
.bubble.out .bubble-quote{background:rgba(0,0,0,.06)}
.bubble-quote .quote-author{font-size:12px;font-weight:800;color:var(--brand-d)}
.bubble-quote .quote-text{font-size:12.5px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}
.bubble.flash{animation:bubbleflash 1.2s ease}
@keyframes bubbleflash{0%,100%{background:#d9fdd3}30%{background:#fff3a0}}
.bubble.in.flash{animation:bubbleflashin 1.2s ease}
@keyframes bubbleflashin{0%,100%{background:#fff}30%{background:#fff3a0}}

/* =====================================================================
   Service Packages (Module 3) — pricing tiers
   ===================================================================== */
.pkg-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.pkg-head h2{font-size:22px}
.pkg-head .muted{color:var(--ink-soft);font-weight:600;font-size:13.5px}
.pkg-desc{color:var(--ink-soft);font-size:13.5px;max-width:640px;margin:8px 0 0}
.pkg-head-actions{display:flex;gap:8px;flex-shrink:0}

.pkg-tiers{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:26px;align-items:start}
.tier-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:22px;box-shadow:var(--shadow);transition:.15s;display:flex;flex-direction:column}
.tier-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.tier-card.recommended{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand),var(--shadow-lg)}
.tier-card.inactive{opacity:.6}
.tier-flag{position:absolute;top:-11px;left:22px;background:var(--grad);color:#fff;font-size:11px;font-weight:800;
  letter-spacing:.03em;padding:4px 12px;border-radius:999px;box-shadow:0 4px 12px rgba(123,104,238,.35)}
.tier-name{font-size:20px;font-weight:800;letter-spacing:-.02em;margin-top:4px}
.tier-tag{color:var(--ink-soft);font-size:12.5px;font-weight:600;margin-top:2px;min-height:32px}

.tier-price{margin:14px 0 4px;padding-bottom:14px;border-bottom:1px solid var(--line-soft)}
.tp-onetime{font-size:30px;font-weight:800;letter-spacing:-.03em}
.tp-unit{color:var(--ink-faint);font-size:13px;font-weight:600}
.tp-monthly{font-size:18px;font-weight:800;color:var(--brand-d);margin-top:4px}

.tier-meta{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0 6px}
.chip{display:inline-block;background:var(--line-soft);color:var(--ink-soft);font-size:11px;font-weight:700;
  padding:4px 10px;border-radius:999px}
.chip-geo.geo-included{background:var(--green-bg);color:var(--green)}
.chip-geo.geo-addon{background:var(--orange-bg);color:#b45309}
.chip-off{background:var(--red-bg);color:var(--red)}
.tier-firstmonths{font-size:12.5px;color:var(--ink-soft);margin-bottom:6px}
.tier-firstmonths strong{color:var(--ink)}

.tier-sec{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--brand-d);margin:14px 0 6px}
.tier-sec.muted{color:var(--ink-faint)}
.tier-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px}
.tier-list li{position:relative;padding-left:20px;font-size:13px;line-height:1.4;color:var(--ink)}
.tier-list li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}
.tier-list-no li{color:var(--ink-faint)}
.tier-list-no li::before{content:"✕";color:var(--ink-faint)}

.tier-actions{display:flex;gap:6px;margin-top:auto;padding-top:16px}
.check{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer}
.check input{width:auto}

/* =====================================================================
   Clients (Module 2) — toolbar, kanban, table, detail
   ===================================================================== */
.clients-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.view-toggle{display:flex;background:var(--line-soft);border-radius:9px;padding:3px}
.view-toggle .vt{padding:6px 13px;border-radius:7px;font-size:13px;font-weight:700;color:var(--ink-soft)}
.view-toggle .vt:hover{text-decoration:none;color:var(--ink)}
.view-toggle .vt.active{background:#fff;color:var(--brand-d);box-shadow:var(--shadow)}
.clients-filters{display:flex;gap:8px;flex:1;min-width:220px}
.clients-filters input[type=search]{flex:1;min-width:140px;border:1px solid var(--line);border-radius:9px;padding:8px 13px;font-family:inherit;font-size:13.5px}
.clients-filters select{border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-family:inherit;font-size:13.5px}

/* Stage pill / kanban colors */
.kc-gray{background:#eef1f5;color:#475569}
.kc-blue{background:#e6f0ff;color:#2563eb}
.kc-purple{background:#efeafe;color:#7c3aed}
.kc-orange{background:var(--orange-bg);color:#b45309}
.kc-green{background:var(--green-bg);color:var(--green)}
.kc-teal{background:#d8f5ee;color:#0d9488}
.kc-red{background:var(--red-bg);color:var(--red)}

/* Health dot */
.health-dot{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  font-size:12px;font-weight:800;color:#fff}
.health-green{background:var(--green)}
.health-orange{background:var(--orange)}
.health-red{background:var(--red)}

/* Kanban board */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px;-webkit-overflow-scrolling:touch}
.kcol{flex:0 0 260px;background:var(--canvas);border:1px solid var(--line);border-radius:var(--radius-lg);display:flex;flex-direction:column;max-height:calc(100vh - 320px)}
.kcol-head{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;font-size:12.5px;font-weight:800;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:sticky;top:0}
.kcount{background:rgba(255,255,255,.6);border-radius:999px;padding:1px 9px;font-size:11px}
.kcol-body{padding:10px;display:flex;flex-direction:column;gap:9px;overflow-y:auto;min-height:60px;flex:1}
.kcol-body.drop{background:var(--brand-soft);outline:2px dashed var(--brand);outline-offset:-4px;border-radius:0 0 var(--radius-lg) var(--radius-lg)}
.kcard{background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 12px;box-shadow:var(--shadow);cursor:grab}
.kcard:hover{box-shadow:var(--shadow-lg)}
.kcard.dragging{opacity:.5;cursor:grabbing}
.kcard-name{font-weight:700;font-size:14px;color:var(--ink)}
.kcard-name:hover{text-decoration:none;color:var(--brand-d)}
.kcard-sub{color:var(--ink-soft);font-size:12px;margin-top:1px}
.kcard-foot{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.kcard-mrr{font-size:12.5px;font-weight:700;color:var(--ink-soft)}
.kcard-foot .health-dot{width:22px;height:22px;font-size:11px}

/* Detail page */
.detail-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.detail-actions{display:flex;gap:8px}
.kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 18px}
.kv-grid > div{display:flex;flex-direction:column}
.kv-l{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint)}
.kv-v{font-size:14px;color:var(--ink);margin-top:2px}
.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.tag{background:var(--brand-soft);color:var(--brand-d);font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px}
.client-summary{margin:14px 0 0;color:var(--ink-soft);font-size:13.5px;border-top:1px solid var(--line-soft);padding-top:12px}

.health-big{font-size:48px;font-weight:800;letter-spacing:-.03em;line-height:1}
.health-big span{font-size:20px;color:var(--ink-faint);font-weight:700}
.health-big.health-green{color:var(--green)}.health-big.health-orange{color:var(--orange)}.health-big.health-red{color:var(--red)}
.health-bar{height:8px;border-radius:999px;background:var(--line);overflow:hidden;margin-top:12px}
.health-bar span{display:block;height:100%}
.health-bar .health-green{background:var(--green)}.health-bar .health-orange{background:var(--orange)}.health-bar .health-red{background:var(--red)}

/* Notes timeline */
.timeline{display:flex;flex-direction:column}
.tl-item{display:flex;gap:12px;padding-bottom:14px;position:relative}
.tl-item:not(:last-child)::before{content:"";position:absolute;left:5px;top:14px;bottom:0;width:2px;background:var(--line)}
.tl-dot{width:12px;height:12px;border-radius:50%;background:var(--brand);flex:0 0 auto;margin-top:3px;z-index:1}
.tl-meta{font-size:11.5px;color:var(--ink-faint);font-weight:600}
.tl-text{font-size:13.5px;color:var(--ink);margin-top:2px}
.section-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);margin:18px 0 10px}

/* Invoices */
.od{color:var(--red);font-weight:800;font-size:11px}
.ltv-row{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;border-bottom:1px solid var(--line-soft);background:var(--brand-soft)}
.ltv-row span{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--brand-d)}
.ltv-row strong{font-size:18px;letter-spacing:-.02em}

/* =====================================================================
   Recurring Revenue Analytics (Module 6) — alerts + lightweight charts
   ===================================================================== */
.alert{padding:12px 16px;border-radius:11px;font-size:13.5px;font-weight:600;margin-bottom:14px;border:1px solid transparent}
.alert-red{background:var(--red-bg);color:#b91c1c;border-color:#f6c9c9}
.alert-orange{background:var(--orange-bg);color:#b45309;border-color:#f5dca6}
.stat-sub.up{color:var(--green)}
.stat-sub.down{color:var(--red)}

/* Vertical bar charts */
.bars{display:flex;align-items:flex-end;gap:8px;height:170px;padding-top:10px}
.bars-wide{gap:16px;justify-content:space-around}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;min-width:0}
.bar-col-2{justify-content:flex-end}
.bar{width:60%;max-width:34px;background:var(--grad);border-radius:5px 5px 0 0;transition:.15s;min-height:2px}
.bar-col:hover .bar{filter:brightness(1.08)}
.bar-pair{display:flex;align-items:flex-end;gap:3px;height:calc(100% - 18px);width:100%;justify-content:center}
.bar-pair .bar{width:11px}
.bar-green{background:var(--green)}
.bar-red{background:var(--red)}
.bar-orange{background:linear-gradient(180deg,#fbbf24,#f59e0b)}
.bar-x{font-size:10.5px;color:var(--ink-faint);font-weight:700;margin-top:6px;white-space:nowrap}
.legend{display:flex;gap:18px;justify-content:center;margin-top:12px;font-size:12px;color:var(--ink-soft)}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}

/* Horizontal bars (MRR by tier) */
.hbar-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.hbar-label{flex:0 0 90px;font-size:13px;font-weight:700}
.hbar{flex:1;height:14px;background:var(--line);border-radius:999px;overflow:hidden}
.hbar span{display:block;height:100%;background:var(--grad);border-radius:999px}
.hbar-val{flex:0 0 auto;font-size:13px;font-weight:700;color:var(--ink-soft);min-width:70px;text-align:right}

/* =====================================================================
   CEO Dashboard (Module 8)
   ===================================================================== */
.ceo-summary{display:flex;gap:16px;align-items:flex-start;background:var(--grad);color:#fff;border-radius:var(--radius-lg);
  padding:22px 24px;margin-bottom:20px;box-shadow:var(--shadow-lg)}
.ceo-sun{font-size:30px;line-height:1}
.ceo-greeting{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.85}
.ceo-line{margin:6px 0 0;font-size:18px;font-weight:700;line-height:1.45;letter-spacing:-.01em;max-width:880px}

.ceo-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.qa{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:11px;
  padding:10px 16px;font-weight:700;font-size:13.5px;color:var(--ink);box-shadow:var(--shadow);transition:.13s}
.qa:hover{text-decoration:none;border-color:var(--brand);color:var(--brand-d);transform:translateY(-1px)}
.qa span{font-size:16px;color:var(--brand)}

.ceo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}
.ceo-block{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);
  padding:18px 20px;display:flex;flex-direction:column}
.ceo-block-head{font-size:14px;font-weight:800;letter-spacing:-.01em;margin-bottom:8px}
.ceo-rows{display:flex;flex-direction:column}
.ceo-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:14px}
.ceo-row:last-child{border-bottom:0}
.ceo-row span{color:var(--ink-soft)}
.ceo-row span em{font-style:normal;color:var(--ink-faint);font-size:11.5px}
.ceo-row strong{font-weight:800;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.ceo-row.bad strong{color:var(--red)}
.ceo-row.good strong{color:var(--green)}
.run-green{color:var(--green)}.run-orange{color:var(--orange)}.run-red{color:var(--red)}
.ceo-link{margin-top:12px;font-size:13px;font-weight:700;color:var(--brand-d)}

/* =====================================================================
   Onboarding questionnaire (Module 10) + portal panels
   ===================================================================== */
.copy-field{display:flex;gap:8px;margin-top:12px}
.copy-field input{flex:1;border:1px solid var(--line);border-radius:9px;padding:8px 11px;font-size:12.5px;background:var(--canvas);font-family:inherit;color:var(--ink-soft)}
.file-chip-link{display:inline-block;background:var(--brand-soft);color:var(--brand-d);border-radius:8px;padding:3px 10px;margin:2px 6px 2px 0;font-size:12.5px;font-weight:600}
.q-section-title{font-size:16px;font-weight:800;letter-spacing:-.01em;margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--line-soft)}

/* Public onboarding page */
.onb-body{background:linear-gradient(160deg,#f3f1fe 0%,#fdf2f8 100%);min-height:100vh}
.onb-wrap{max-width:680px;margin:0 auto;padding:40px 20px 60px}
.onb-head{text-align:center;margin-bottom:22px}
.onb-brand{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:15px;margin-bottom:14px}
.onb-head h1{font-size:30px;letter-spacing:-.03em;margin:0 0 8px}
.onb-head p{color:var(--ink-soft);font-size:14.5px;max-width:520px;margin:0 auto;line-height:1.55}
.onb-progress{height:8px;background:#fff;border-radius:999px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:8px}
.onb-progress-bar{height:100%;background:var(--grad);width:20%;transition:width .3s ease}
.onb-steplabel{text-align:right;font-size:12px;font-weight:700;color:var(--ink-soft);margin-bottom:14px}
.onb-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:26px 28px}
.q-step{display:none}
.q-step.active{display:block;animation:qfade .25s ease}
@keyframes qfade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.q-field{margin-bottom:16px}
.q-field > label{display:block;font-weight:700;font-size:13.5px;margin-bottom:6px}
.q-field .req{color:var(--pink)}
.q-field input[type=text],.q-field input[type=url],.q-field input[type=number],.q-field textarea{width:100%;border:1px solid var(--line);
  border-radius:10px;padding:10px 13px;font-family:inherit;font-size:14px;outline:none;background:var(--canvas)}
.q-field input:focus,.q-field textarea:focus{border-color:var(--brand);background:#fff}
.q-opts{display:flex;flex-direction:column;gap:8px}
.q-opt{display:flex;align-items:center;gap:9px;font-size:14px;padding:9px 12px;border:1px solid var(--line);border-radius:10px;cursor:pointer;background:var(--canvas)}
.q-opt:hover{border-color:var(--brand)}
.q-opt input{width:auto}
.q-files{border:1px dashed var(--line);border-radius:10px;padding:12px;background:var(--canvas)}
.q-file-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.q-file-list:empty{margin-bottom:0}
.q-file-chip{background:var(--brand-soft);color:var(--brand-d);border-radius:8px;padding:3px 10px;font-size:12.5px;font-weight:600}
.q-upload{display:inline-block;cursor:pointer;color:var(--brand-d);font-weight:700;font-size:13.5px}
.q-upload-status{margin-left:10px;font-size:12.5px;color:var(--ink-soft)}
.onb-nav{display:flex;align-items:center;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line-soft)}
.onb-nav .onb-saved{flex:1;text-align:center;font-size:12.5px;color:var(--green);font-weight:700}
.onb-msg{text-align:center;padding:48px 32px}
.onb-art{font-size:48px;margin-bottom:12px}
.onb-msg h1{font-size:25px;letter-spacing:-.02em;margin:0 0 10px}
.onb-msg p{color:var(--ink-soft);max-width:440px;margin:0 auto;line-height:1.6}
.onb-foot{text-align:center;color:var(--ink-faint);font-size:11.5px;margin-top:24px;letter-spacing:.03em}

/* =====================================================================
   Client Portal (Module 11) — premium, mobile-first client dashboard
   ===================================================================== */
.portal-body{background:linear-gradient(180deg,#f6f5fe 0%,#f7f8fa 220px);min-height:100vh}
.portal-top{background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.portal-top-in{max-width:920px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 20px}
.portal-top-right{display:flex;align-items:center;gap:12px}
.portal-who{font-weight:700;font-size:13.5px}
.portal-main{max-width:920px;margin:0 auto;padding:24px 20px 48px}
.portal-foot{text-align:center;color:var(--ink-faint);font-size:11.5px;padding:20px;letter-spacing:.03em}

.pcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px 22px;margin-bottom:18px}
.pcard-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.pcard-head h2{font-size:16px;font-weight:800;letter-spacing:-.02em;margin:0}
.pmuted{color:var(--ink-soft);font-size:13.5px}
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:720px){.pgrid{grid-template-columns:1fr}}

.pwelcome{background:var(--grad);color:#fff;border:0}
.pw-hello{font-size:24px;font-weight:800;letter-spacing:-.02em}
.pw-sub{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:8px;font-size:13px;opacity:.92}
.tier-badge{background:rgba(255,255,255,.22);border-radius:999px;padding:3px 12px;font-weight:800;font-size:12px}

.pprog-pct{font-size:13px;font-weight:800;color:var(--brand-d)}
.pprog{height:10px;background:var(--line);border-radius:999px;overflow:hidden}
.pprog span{display:block;height:100%;background:var(--grad);border-radius:999px;transition:width .4s ease}

/* Deliverable expanders */
.deliv-list{display:flex;flex-direction:column;gap:8px}
.deliv{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface)}
.deliv.attn{border-color:var(--orange);box-shadow:0 0 0 1px var(--orange-bg)}
.deliv summary{display:flex;align-items:center;gap:11px;padding:13px 16px;cursor:pointer;list-style:none;font-weight:700;font-size:14px}
.deliv summary::-webkit-details-marker{display:none}
.deliv-name{flex:1;min-width:0}
.deliv-dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.dot-gray{background:var(--gray)}.dot-blue{background:#2563eb}.dot-orange{background:var(--orange)}.dot-green{background:var(--green)}.dot-red{background:var(--red)}
.deliv-body{padding:0 16px 16px;border-top:1px solid var(--line-soft)}
.deliv-desc{color:var(--ink-soft);font-size:13.5px;margin:12px 0}
.deliv-files{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}
.deliv-feedback{background:var(--red-bg);border-radius:9px;padding:9px 12px;font-size:13px;margin:10px 0}
.deliv-meta{font-size:12px;color:var(--ink-faint);margin:8px 0}
.deliv-review{margin-top:10px}
.deliv-review textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-family:inherit;font-size:13.5px;resize:vertical}
.deliv-review-btns{display:flex;gap:8px;margin-top:8px}
.deliv-ok{color:var(--green);font-weight:700;font-size:13.5px;margin-top:8px}

.ltv-line{font-size:13.5px;color:var(--ink-soft);margin-bottom:8px}
.ltv-line strong{color:var(--ink)}
.ptable td{padding:10px 6px}
.pupcoming,.preports{list-style:none;margin:0;padding:0}
.pupcoming li,.preports li{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line-soft);font-size:13.5px}
.pupcoming li:last-child,.preports li:last-child{border-bottom:0}
.pupcoming span{color:var(--ink-soft)}

.q-readonly summary{cursor:pointer;font-weight:700;color:var(--brand-d);font-size:13.5px}
.qa-row{display:flex;flex-direction:column;padding:9px 0;border-bottom:1px solid var(--line-soft)}
.qa-q{font-size:12px;font-weight:700;color:var(--ink-faint)}
.qa-a{font-size:13.5px;margin-top:2px}
.btn-block{display:block;width:100%;text-align:center}

/* Module 12 — admin deliverable management + queues */
.dm-files{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}
.dm-file{display:inline-flex;align-items:center;gap:6px;background:var(--brand-soft);color:var(--brand-d);border-radius:8px;padding:4px 8px 4px 11px;font-size:12.5px;font-weight:600}
.dm-file a{color:var(--brand-d)}
.dm-x{background:none;border:0;cursor:pointer;color:var(--brand-d);font-size:12px;opacity:.6}
.dm-x:hover{opacity:1}
.dm-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.dm-row input[type=url],.dm-row input[name=link_name]{border:1px solid var(--line);border-radius:9px;padding:7px 11px;font-family:inherit;font-size:13px}
.qcount{display:inline-block;background:var(--brand-soft);color:var(--brand-d);border-radius:999px;padding:1px 9px;font-size:12px;font-weight:800;margin-left:6px;vertical-align:middle}
.qfeedback{font-size:12.5px;color:var(--ink-soft);font-style:italic;margin-top:4px;background:var(--red-bg);border-radius:8px;padding:6px 10px}

/* Module 13 — email template editor */
.var-box{background:var(--canvas);border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-top:14px}
.var-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);margin-bottom:8px}
.var-chip{display:inline-block;background:#fff;border:1px solid var(--line);border-radius:7px;padding:3px 8px;margin:0 5px 5px 0;
  font-family:ui-monospace,monospace;font-size:12px;color:var(--brand-d);cursor:help}

/* ---- Partner permission picker (admin/partners.php) ---- */
.perm-grid{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.perm-check{display:flex;align-items:flex-start;gap:9px;cursor:pointer;font-size:13px;line-height:1.35;
  padding:9px 11px;border:1px solid var(--line);border-radius:10px;background:var(--card);transition:border-color .15s,background .15s}
.perm-check:hover{border-color:var(--brand)}
.perm-check input{margin-top:2px;flex:0 0 auto;width:16px;height:16px;accent-color:var(--brand)}
.perm-check input:checked + span{color:var(--ink);font-weight:600}
.perm-badges{display:flex;flex-wrap:wrap;gap:5px}
