/* ================================================================
   Pulsewave App — Dashboard & Auth Styles
   Reuses tokens from ../../assets/css/style.css (linked first)
   ================================================================ */

/* ===== Auth (split-screen) ===== */
.auth-layout{
  min-height:100vh;display:grid;grid-template-columns:1fr 1fr;
  background:var(--bg);
}
@media (max-width:980px){.auth-layout{grid-template-columns:1fr}}

.auth-main{
  display:flex;align-items:center;justify-content:center;
  padding:40px 32px;
}
.auth-card{width:100%;max-width:440px}
.auth-card .brand{margin-bottom:32px}
.auth-card h1{font-size:1.85rem;line-height:1.2;margin-bottom:6px}
.auth-card .sub{color:var(--muted);margin-bottom:32px}

.auth-aside{
  position:relative;background:var(--grad-cta);color:#fff;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;padding:50px;
}
@media (max-width:980px){.auth-aside{display:none}}
.auth-aside::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 400px at 80% 0%,rgba(255,255,255,.14),transparent),
    radial-gradient(600px 400px at 20% 100%,rgba(109,92,255,.35),transparent);
  pointer-events:none;
}
.auth-aside > *{position:relative;z-index:1}
.auth-aside .brand-mark{box-shadow:0 6px 14px -6px rgba(0,0,0,.3);background:#fff;color:var(--brand-2)}
.auth-aside h2{color:#fff;font-size:1.9rem;line-height:1.25;margin:30px 0 14px;max-width:24ch}
.auth-aside p{color:rgba(255,255,255,.85);max-width:42ch}
.auth-quote{
  background:rgba(255,255,255,.08);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.14);padding:26px;border-radius:16px;
}
.auth-quote blockquote{margin:0;font-size:1.1rem;line-height:1.5;color:#fff;font-weight:500}
.auth-quote .who{display:flex;gap:12px;align-items:center;margin-top:18px}
.auth-quote .who .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#ff8a4c,#f4b740);display:grid;place-items:center;color:#fff;font-weight:700}
.auth-quote .who strong{display:block;color:#fff}
.auth-quote .who span{color:rgba(255,255,255,.7);font-size:.85rem}
.auth-stats{display:flex;gap:32px;margin-top:30px;flex-wrap:wrap}
.auth-stats > div strong{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:1.6rem;font-weight:800;color:#fff}
.auth-stats > div span{color:rgba(255,255,255,.7);font-size:.85rem}

/* social buttons */
.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.social-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:11px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;
  font-weight:600;font-size:.92rem;color:var(--ink-2);cursor:pointer;transition:all .15s ease;
}
.social-btn:hover{background:var(--bg-mute);border-color:#cfe0d9;transform:translateY(-1px)}
.divider-or{
  display:flex;align-items:center;gap:14px;color:var(--muted);font-size:.82rem;
  text-transform:uppercase;letter-spacing:.1em;margin:18px 0;
}
.divider-or::before,.divider-or::after{content:"";flex:1;height:1px;background:var(--line)}

/* form inputs in app context */
.form-row{margin-bottom:16px}
.form-row label{display:block;font-size:.88rem;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.form-row .hint{font-size:.82rem;color:var(--muted);margin-top:6px}
.form-row a.right{float:right;font-size:.85rem;color:var(--brand-2);font-weight:600}
.input{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:.95rem;background:#fff;color:var(--ink);
  transition:all .15s ease;
}
.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(15,174,106,.15)}
.input.with-icon{padding-left:42px}
.input-wrap{position:relative}
.input-wrap > svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);width:18px;height:18px}
.input-wrap .toggle-pw{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;padding:4px}
.input-wrap .toggle-pw:hover{color:var(--ink)}

.checkbox{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--ink-2);cursor:pointer}
.checkbox input{margin-top:3px;width:16px;height:16px;accent-color:var(--brand)}

.btn-block{width:100%;justify-content:center}
.auth-foot{margin-top:22px;text-align:center;color:var(--muted);font-size:.93rem}
.auth-foot a{color:var(--brand-2);font-weight:600}

/* OTP boxes */
.otp-row{display:flex;gap:10px;justify-content:space-between;margin:24px 0}
.otp-row input{
  width:56px;height:64px;text-align:center;font-size:1.6rem;font-weight:700;
  border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);
  transition:all .15s ease;font-family:'Plus Jakarta Sans',sans-serif;
}
.otp-row input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(15,174,106,.15)}
@media (max-width:480px){.otp-row input{width:46px;height:54px;font-size:1.3rem}}

/* password strength */
.pw-meter{display:flex;gap:4px;margin-top:8px}
.pw-meter > i{flex:1;height:4px;border-radius:3px;background:#e6ede9;transition:background .2s}
.pw-meter[data-score="1"] > i:nth-child(-n+1){background:#e5484d}
.pw-meter[data-score="2"] > i:nth-child(-n+2){background:#f4b740}
.pw-meter[data-score="3"] > i:nth-child(-n+3){background:#0fae6a}
.pw-meter[data-score="4"] > i{background:#0fae6a}
.pw-hint{font-size:.8rem;color:var(--muted);margin-top:6px}

/* Onboarding wizard */
.wizard{
  min-height:100vh;background:var(--bg-soft);
  display:flex;flex-direction:column;
}
.wizard-top{
  background:#fff;border-bottom:1px solid var(--line);
  padding:18px 32px;display:flex;align-items:center;justify-content:space-between;
}
.wiz-stepper{display:flex;gap:4px;align-items:center}
.wiz-stepper .step-pill{
  display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:30px;
  background:var(--bg-mute);color:var(--muted);font-size:.85rem;font-weight:600;
  border:1px solid transparent;
}
.wiz-stepper .step-pill.done{background:#e8f7ef;color:var(--brand-2);border-color:#cdebd9}
.wiz-stepper .step-pill.active{background:#fff;color:var(--ink);border-color:var(--brand);box-shadow:0 0 0 3px rgba(15,174,106,.12)}
.wiz-stepper .step-num{
  width:22px;height:22px;border-radius:50%;background:#cfe0d9;color:#fff;
  display:grid;place-items:center;font-size:.78rem;font-weight:700;
}
.step-pill.done .step-num{background:var(--brand)}
.step-pill.active .step-num{background:var(--brand)}
.wiz-arrow{color:#cfe0d9;font-size:1.2rem}
.wizard-body{flex:1;display:flex;align-items:center;justify-content:center;padding:50px 32px}
.wizard-card{
  width:100%;max-width:680px;background:#fff;border:1px solid var(--line);
  border-radius:18px;box-shadow:var(--shadow);padding:40px;
}
.wizard-card h1{font-size:1.7rem;margin-bottom:8px}
.wizard-card .sub{color:var(--muted);margin-bottom:28px}
.wiz-cta{display:flex;justify-content:space-between;gap:12px;margin-top:30px;padding-top:24px;border-top:1px solid var(--line)}

/* connect-card (used in wizard) */
.connect-card{
  display:flex;gap:18px;align-items:center;padding:20px;
  border:1px solid var(--line);border-radius:14px;background:var(--bg-soft);
  transition:all .2s ease;cursor:pointer;
}
.connect-card:hover{border-color:#cfe5da;background:#fff;transform:translateY(-1px)}
.connect-card.selected{border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(15,174,106,.12)}
.connect-card .ico{width:48px;height:48px;border-radius:12px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--brand-2);flex-shrink:0}
.connect-card h3{font-size:1.02rem;margin-bottom:2px}
.connect-card p{font-size:.88rem;color:var(--muted);margin:0}
.connect-card .badge-rec{margin-left:auto;background:#e8f7ef;color:var(--brand-2);padding:4px 10px;border-radius:30px;font-size:.74rem;font-weight:700;border:1px solid #cdebd9}

/* ============================================================
   APP SHELL (Dashboard)
   ============================================================ */
.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:var(--bg-soft)}
@media (max-width:1080px){.app-shell{grid-template-columns:72px 1fr}.app-sidebar .nav-text,.app-sidebar .ws-text,.app-sidebar .nav-section-label,.app-sidebar .user-meta,.app-sidebar .brand-text{display:none}}
@media (max-width:780px){.app-shell{grid-template-columns:1fr}.app-sidebar{position:fixed;left:-280px;top:0;bottom:0;width:280px;z-index:100;transition:left .25s ease}.app-shell.menu-open .app-sidebar{left:0}.app-sidebar .nav-text,.app-sidebar .ws-text,.app-sidebar .nav-section-label,.app-sidebar .user-meta,.app-sidebar .brand-text{display:initial}}

.app-sidebar{
  background:#0a1612;color:#cdd9d4;
  display:flex;flex-direction:column;
  border-right:1px solid #14241f;
}
.app-sidebar .brand{padding:18px 20px;color:#fff;border-bottom:1px solid rgba(255,255,255,.06)}
.app-sidebar .brand-mark{box-shadow:0 4px 10px -2px rgba(15,174,106,.4)}
.workspace{
  margin:14px 12px;padding:10px 12px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);border-radius:10px;
  display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .15s ease;
}
.workspace:hover{background:rgba(255,255,255,.07)}
.workspace .ws-logo{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#0fae6a,#6d5cff);display:grid;place-items:center;color:#fff;font-weight:700;font-size:.85rem;flex-shrink:0}
.workspace .ws-text{flex:1;min-width:0}
.workspace strong{display:block;color:#fff;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.workspace span{color:#7e9089;font-size:.78rem}
.workspace svg{color:#7e9089;flex-shrink:0}

.nav-section{padding:10px 12px}
.nav-section-label{display:block;color:#5d736b;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:8px 12px 6px}
.nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px}
.nav-list a{
  display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:8px;
  color:#cdd9d4;font-weight:500;font-size:.92rem;transition:all .15s ease;position:relative;
}
.nav-list a:hover{background:rgba(255,255,255,.05);color:#fff}
.nav-list a.active{background:linear-gradient(90deg,rgba(15,174,106,.18),rgba(15,174,106,.04));color:#fff}
.nav-list a.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:2px;background:var(--brand)}
.nav-list a svg{width:18px;height:18px;flex-shrink:0;color:#9bb0a8}
.nav-list a.active svg{color:var(--brand)}
.nav-list a .pill{
  margin-left:auto;background:rgba(15,174,106,.18);color:#0fae6a;
  font-size:.7rem;padding:2px 8px;border-radius:30px;font-weight:700;
}
.nav-list a .pill.warm{background:rgba(255,138,76,.18);color:#ff8a4c}

.sidebar-foot{
  margin-top:auto;padding:14px 12px;border-top:1px solid rgba(255,255,255,.06);
}
.user-block{
  display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;
  cursor:pointer;transition:all .15s ease;
}
.user-block:hover{background:rgba(255,255,255,.05)}
.user-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#6d5cff,#0fae6a);display:grid;place-items:center;color:#fff;font-weight:700;font-size:.82rem;flex-shrink:0}
.user-meta{flex:1;min-width:0}
.user-meta strong{display:block;color:#fff;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-meta span{color:#7e9089;font-size:.76rem}

/* ===== App Main ===== */
.app-main{display:flex;flex-direction:column;min-width:0}

.app-topbar{
  position:sticky;top:0;z-index:30;background:rgba(255,255,255,.88);backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);padding:0 22px;height:56px;
  display:flex;align-items:center;gap:14px;
}
.menu-btn{display:none;background:none;border:none;padding:6px;color:var(--ink);cursor:pointer}
@media (max-width:780px){.menu-btn{display:block}}
.search{
  flex:1;max-width:480px;position:relative;
}
.search input{
  width:100%;padding:7px 14px 7px 36px;border:1px solid var(--line);border-radius:8px;
  background:var(--bg-soft);font-size:.9rem;height:34px;
}
.search input:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(15,174,106,.12)}
.search > svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);width:16px;height:16px}
.search kbd{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  font-family:inherit;font-size:.7rem;color:var(--muted);
  background:#fff;border:1px solid var(--line);padding:2px 6px;border-radius:5px;line-height:1;
}

.topbar-actions{display:flex;align-items:center;gap:4px;margin-left:auto}
.topbar-actions .btn{padding:7px 14px;font-size:.88rem;height:34px}
.icon-btn{
  position:relative;width:34px;height:34px;border-radius:8px;background:transparent;border:1px solid transparent;
  display:grid;place-items:center;color:var(--ink-2);cursor:pointer;transition:all .15s ease;
}
.icon-btn:hover{background:var(--bg-mute);border-color:var(--line)}
.icon-btn .dot-notif{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid #fff}

.topbar-user{display:flex;align-items:center;gap:8px;padding:3px 10px 3px 3px;border-radius:30px;cursor:pointer;transition:all .15s ease;border:1px solid transparent;height:34px}
.topbar-user:hover{background:var(--bg-mute);border-color:var(--line)}
.topbar-user .av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#6d5cff,#0fae6a);display:grid;place-items:center;color:#fff;font-weight:700;font-size:.72rem}
.topbar-user span{font-size:.88rem;font-weight:600;color:var(--ink)}
@media (max-width:540px){.topbar-user span{display:none}}

/* ===== Dropdown menus (topbar user + workspace) ===== */
.menu-wrap{position:relative}
.menu-pop{
  position:absolute;min-width:240px;background:#fff;color:var(--ink);
  border:1px solid var(--line);border-radius:12px;
  box-shadow:0 18px 40px -12px rgba(11,32,24,.22),0 4px 10px -4px rgba(11,32,24,.08);
  padding:8px;z-index:80;
  opacity:0;visibility:hidden;transform:translateY(-6px);pointer-events:none;
  transition:opacity .12s ease,transform .12s ease,visibility .12s;
}
.menu-wrap.open .menu-pop{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.menu-pop-right{right:0;top:calc(100% + 8px)}
.menu-pop-ws{left:12px;right:12px;top:calc(100% + 6px);min-width:0}
.menu-head{display:flex;align-items:center;gap:10px;padding:8px 10px 10px}
.menu-head .av,.menu-head .ws-logo{width:34px;height:34px;border-radius:8px;flex-shrink:0;display:grid;place-items:center;color:#fff;font-weight:700;font-size:.78rem;background:linear-gradient(135deg,#6d5cff,#0fae6a)}
.menu-head .av{border-radius:50%}
.menu-head-text{min-width:0;flex:1}
.menu-head-text strong{display:block;color:var(--ink);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.menu-head-text span{color:var(--muted);font-size:.76rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.menu-sep{height:1px;background:var(--line);margin:4px 0}
.menu-item{
  display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;
  color:var(--ink);font-size:.88rem;text-decoration:none;cursor:pointer;transition:background .12s ease;
}
.menu-item:hover{background:var(--bg-mute)}
.menu-item svg{color:var(--muted);flex-shrink:0}
.menu-item-danger{color:var(--danger)}
.menu-item-danger svg{color:var(--danger)}
.menu-item-danger:hover{background:rgba(224,49,49,.08)}
.menu-pill{margin-left:auto;background:linear-gradient(135deg,rgba(15,174,106,.18),rgba(109,92,255,.18));color:#0a6b42;border:1px solid rgba(15,174,106,.25);border-radius:999px;padding:1px 8px;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}

/* workspace dropdown override — its panel uses the dark sidebar palette */
.ws-menu-wrap .menu-pop{background:#12221c;border-color:rgba(255,255,255,.08);box-shadow:0 18px 40px -10px rgba(0,0,0,.6)}
.ws-menu-wrap .menu-head-text strong{color:#fff}
.ws-menu-wrap .menu-head-text span{color:#9bb0a8}
.ws-menu-wrap .menu-sep{background:rgba(255,255,255,.08)}
.ws-menu-wrap .menu-item{color:#d6e3dd}
.ws-menu-wrap .menu-item svg{color:#7e9089}
.ws-menu-wrap .menu-item:hover{background:rgba(255,255,255,.06)}
.ws-menu-wrap .menu-item-danger{color:#ff8080}
.ws-menu-wrap .menu-item-danger svg{color:#ff8080}
.ws-menu-wrap .menu-item-danger:hover{background:rgba(224,49,49,.14)}
.ws-menu-wrap .menu-pill{color:#b8ffd6;background:rgba(15,174,106,.18);border-color:rgba(15,174,106,.3)}
.workspace[aria-expanded="true"] svg:last-child,
.topbar-user[aria-expanded="true"] svg:last-child{transform:rotate(180deg);transition:transform .15s ease}

/* ===== App Content ===== */
.app-content{padding:32px 28px;max-width:1400px;width:100%}
@media (max-width:600px){.app-content{padding:22px 18px}}

.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:28px;flex-wrap:wrap}
.page-head h1{font-size:1.8rem;margin:0 0 4px}
.page-head .sub{color:var(--muted);margin:0}
.page-head .actions{display:flex;gap:10px;flex-wrap:wrap}

/* ===== KPI Cards ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}
@media (max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.kpi-grid{grid-template-columns:1fr}}
.kpi{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;
  position:relative;overflow:hidden;transition:all .2s ease;
}
.kpi:hover{box-shadow:var(--shadow-sm);border-color:#cfe5da}
.kpi-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.kpi-icon{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:#e8f7ef;color:var(--brand-2)}
.kpi-icon.violet{background:#efecff;color:#4b3ae0}
.kpi-icon.warm{background:#ffece1;color:#d8651f}
.kpi-icon.gold{background:#fef4dc;color:#a67708}
.kpi-label{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.kpi-value{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.9rem;font-weight:800;color:var(--ink);line-height:1;margin-bottom:8px}
.kpi-delta{display:inline-flex;align-items:center;gap:4px;font-size:.85rem;font-weight:600}
.kpi-delta.up{color:var(--brand-2)}
.kpi-delta.down{color:var(--danger)}
.kpi-spark{margin-top:10px;height:36px}

/* ===== Cards / Panels ===== */
.panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:18px}
.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.panel-head h3{margin:0;font-size:1.05rem}
.panel-head .actions{display:flex;gap:8px;align-items:center}
.tabs{display:flex;gap:2px;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:3px}
.tabs button{padding:7px 14px;border:none;background:transparent;border-radius:8px;font-weight:600;font-size:.86rem;color:var(--muted);cursor:pointer}
.tabs button.active{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}

.grid-2-3{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:18px}
@media (max-width:980px){.grid-2-3{grid-template-columns:1fr}}

/* Chart */
.chart-wrap{height:280px;position:relative}
.chart-legend{display:flex;gap:18px;margin-top:14px;flex-wrap:wrap;font-size:.85rem;color:var(--muted)}
.chart-legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}
svg.chart{width:100%;height:100%;overflow:visible}

/* Tables */
.tbl{width:100%;border-collapse:separate;border-spacing:0}
.tbl thead th{
  text-align:left;font-size:.78rem;color:var(--muted);font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;padding:10px 14px;
  border-bottom:1px solid var(--line);white-space:nowrap;
}
.tbl tbody td{padding:14px;border-bottom:1px solid var(--line);font-size:.94rem;color:var(--ink-2);vertical-align:middle}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:background .15s ease}
.tbl tbody tr:hover{background:var(--bg-soft)}
.tbl .nm{display:flex;align-items:center;gap:10px}
.tbl .nm-av{width:32px;height:32px;border-radius:8px;background:#e8f7ef;color:var(--brand-2);display:grid;place-items:center;font-weight:700;font-size:.78rem}
.tbl .nm-av.violet{background:#efecff;color:#4b3ae0}
.tbl .nm-av.warm{background:#ffece1;color:#d8651f}

/* status pills */
.pill-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:30px;font-size:.78rem;font-weight:700;border:1px solid transparent}
.pill-status .blip{width:6px;height:6px;border-radius:50%;background:currentColor}
.pill-status.live{background:#e8f7ef;color:#08864f;border-color:#cdebd9}
.pill-status.draft{background:#f1f5f3;color:#5a6a66;border-color:var(--line)}
.pill-status.scheduled{background:#fef4dc;color:#a67708;border-color:#f5e3a4}
.pill-status.failed{background:#fde7e8;color:#c93338;border-color:#f7c5c7}
.pill-status.completed{background:#efecff;color:#4b3ae0;border-color:#dcd6ff}
.pill-status.paused{background:#ffece1;color:#d8651f;border-color:#ffd4ba}

/* progress mini */
.mini-bar{width:120px;height:6px;background:#eef5f2;border-radius:3px;overflow:hidden;display:inline-block;vertical-align:middle;margin-right:8px}
.mini-bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:3px}

/* Activity / convo list */
.activity{display:flex;flex-direction:column;gap:2px}
.activity-item{
  display:flex;gap:12px;padding:12px;border-radius:10px;cursor:pointer;
  transition:background .15s ease;align-items:flex-start;
}
.activity-item:hover{background:var(--bg-soft)}
.activity-item .av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0fae6a,#6d5cff);display:grid;place-items:center;color:#fff;font-weight:700;font-size:.82rem;flex-shrink:0}
.activity-item .meta{flex:1;min-width:0}
.activity-item .meta-top{display:flex;justify-content:space-between;gap:8px;align-items:center}
.activity-item .name{font-weight:600;color:var(--ink);font-size:.92rem}
.activity-item .time{color:var(--muted);font-size:.78rem;flex-shrink:0}
.activity-item .msg{color:var(--muted);font-size:.88rem;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-item .unread{background:var(--brand);color:#fff;font-size:.7rem;padding:1px 7px;border-radius:30px;font-weight:700;margin-left:6px}

/* Setup checklist */
.checklist{display:flex;flex-direction:column;gap:10px}
.check-item{
  display:flex;align-items:center;gap:14px;padding:14px;border-radius:10px;
  border:1px solid var(--line);background:#fff;transition:all .15s ease;
}
.check-item:hover{border-color:#cfe5da}
.check-item.done{background:var(--bg-soft)}
.check-item .check{
  width:24px;height:24px;border-radius:50%;border:2px solid var(--line);
  display:grid;place-items:center;flex-shrink:0;color:transparent;
}
.check-item.done .check{background:var(--brand);border-color:var(--brand);color:#fff}
.check-item .ci-text{flex:1}
.check-item .ci-text strong{display:block;color:var(--ink);font-size:.94rem}
.check-item .ci-text span{color:var(--muted);font-size:.85rem}
.check-item.done .ci-text strong{text-decoration:line-through;color:var(--muted)}
.check-item .ci-cta{font-size:.85rem;color:var(--brand-2);font-weight:600}

.setup-progress{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.setup-progress .ring{
  width:54px;height:54px;border-radius:50%;
  background:conic-gradient(var(--brand) 0% 60%, #eef5f2 60% 100%);
  display:grid;place-items:center;
}
.setup-progress .ring i{
  width:42px;height:42px;border-radius:50%;background:#fff;display:grid;place-items:center;
  font-weight:700;font-size:.88rem;color:var(--ink);font-family:'Plus Jakarta Sans',sans-serif;
}

/* tag chips for filters */
.chip{
  display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:30px;
  background:var(--bg-mute);color:var(--ink-2);font-size:.78rem;font-weight:600;border:1px solid var(--line);
}
.chip-close{width:14px;height:14px;border-radius:50%;background:rgba(0,0,0,.08);display:grid;place-items:center;cursor:pointer;font-size:.65rem}

/* Empty state */
.empty{text-align:center;padding:40px 20px;color:var(--muted)}
.empty .ico{width:60px;height:60px;border-radius:14px;background:var(--bg-mute);display:grid;place-items:center;margin:0 auto 14px;color:var(--brand-2)}

/* Banner / announcement */
.banner{
  display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:12px;
  background:linear-gradient(135deg,#e8f7ef,#efecff);border:1px solid #cdebd9;margin-bottom:18px;
}
.banner .ico{width:36px;height:36px;border-radius:10px;background:#fff;display:grid;place-items:center;color:var(--brand-2);flex-shrink:0}
.banner .txt{flex:1}
.banner strong{display:block;color:var(--ink)}
.banner span{color:var(--ink-2);font-size:.88rem}
.banner .x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.2rem;padding:4px}

/* =========================================================
   Extra components for inner dashboard pages
   ========================================================= */

/* Toggle switch */
.toggle{position:relative;display:inline-block;width:38px;height:22px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle .slider{
  position:absolute;cursor:pointer;inset:0;background:#cfd8d4;border-radius:22px;transition:.2s;
}
.toggle .slider::before{
  content:"";position:absolute;height:16px;width:16px;left:3px;top:3px;
  background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.toggle input:checked + .slider{background:var(--brand)}
.toggle input:checked + .slider::before{transform:translateX(16px)}

/* Filter bar */
.filter-bar{
  display:flex;gap:10px;align-items:center;padding:14px 16px;
  background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:18px;flex-wrap:wrap;
}
.filter-bar .left{flex:1;display:flex;gap:8px;align-items:center;flex-wrap:wrap;min-width:0}
.filter-bar .search-input{flex:1;min-width:240px;position:relative}
.filter-bar .search-input input{width:100%;padding:8px 12px 8px 34px;border:1px solid var(--line);border-radius:8px;font-size:.9rem;background:var(--bg-soft)}
.filter-bar .search-input svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);width:15px;height:15px}
.filter-btn{
  display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid var(--line);
  background:#fff;border-radius:8px;font-weight:600;font-size:.85rem;color:var(--ink-2);cursor:pointer;
}
.filter-btn:hover{background:var(--bg-mute)}
.filter-btn.active{background:#e8f7ef;color:var(--brand-2);border-color:#cdebd9}

/* Tag chips */
.tag-chip{
  display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:30px;
  font-size:.74rem;font-weight:600;border:1px solid var(--line);background:var(--bg-soft);color:var(--ink-2);
}
.tag-chip.green{background:#e8f7ef;color:var(--brand-2);border-color:#cdebd9}
.tag-chip.violet{background:#efecff;color:#4b3ae0;border-color:#dcd6ff}
.tag-chip.warm{background:#ffece1;color:#d8651f;border-color:#ffd4ba}
.tag-chip.gold{background:#fef4dc;color:#a67708;border-color:#f5e3a4}

/* Pagination */
.pager{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-top:1px solid var(--line);font-size:.88rem;color:var(--muted)}
.pager .controls{display:flex;gap:4px}
.pager .pg-btn{
  width:30px;height:30px;border-radius:7px;border:1px solid var(--line);background:#fff;
  display:grid;place-items:center;cursor:pointer;color:var(--ink-2);font-weight:600;font-size:.85rem;
}
.pager .pg-btn:hover{background:var(--bg-mute)}
.pager .pg-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}
.pager .pg-btn:disabled{opacity:.4;cursor:not-allowed}

/* Conversations layout */
.inbox{display:grid;grid-template-columns:340px 1fr 320px;height:calc(100vh - 56px - 64px);min-height:500px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}
@media (max-width:1180px){.inbox{grid-template-columns:300px 1fr}.inbox > .convo-side{display:none}}
@media (max-width:780px){.inbox{grid-template-columns:1fr}.inbox > .convo-list{display:none}.inbox.show-list > .convo-list{display:block}.inbox.show-list > .convo-thread{display:none}}

.convo-list{border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0}
.convo-list-head{padding:14px;border-bottom:1px solid var(--line)}
.convo-list-head h3{margin:0 0 10px;font-size:1.05rem}
.convo-list-search{position:relative}
.convo-list-search input{width:100%;padding:7px 12px 7px 32px;border:1px solid var(--line);border-radius:8px;background:var(--bg-soft);font-size:.88rem}
.convo-list-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);width:14px;height:14px}
.convo-tabs{display:flex;gap:2px;margin-top:10px;padding:2px;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px}
.convo-tabs button{flex:1;padding:5px;border:none;background:transparent;border-radius:6px;font-weight:600;font-size:.78rem;color:var(--muted);cursor:pointer}
.convo-tabs button.active{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.convo-items{flex:1;overflow-y:auto}
.convo-item{
  display:flex;gap:12px;padding:12px 14px;border-bottom:1px solid var(--line);cursor:pointer;
  transition:background .12s ease;align-items:flex-start;
}
.convo-item:hover{background:var(--bg-soft)}
.convo-item.selected{background:linear-gradient(90deg,#e8f7ef,transparent)}
.convo-item.selected::before{content:"";position:absolute;left:0;width:3px;background:var(--brand);height:100%;margin-left:-3px}
.convo-item .avx{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#0fae6a,#6d5cff);display:grid;place-items:center;color:#fff;font-weight:700;font-size:.82rem;flex-shrink:0;position:relative}
.convo-item .avx .online-dot{position:absolute;right:-2px;bottom:-2px;width:11px;height:11px;border-radius:50%;background:#0fae6a;border:2px solid #fff}
.convo-item .body{flex:1;min-width:0}
.convo-item .body-top{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:2px}
.convo-item .nm{font-weight:600;color:var(--ink);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.convo-item .tm{color:var(--muted);font-size:.74rem;flex-shrink:0}
.convo-item .preview{color:var(--muted);font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}
.convo-item.unread .nm{font-weight:700}
.convo-item.unread .preview{color:var(--ink-2);font-weight:500}
.convo-item .dot-unread{width:8px;height:8px;border-radius:50%;background:var(--brand);flex-shrink:0;margin-left:auto}

/* Thread */
.convo-thread{display:flex;flex-direction:column;min-height:0;background:#f5f9f7}
.thread-head{display:flex;align-items:center;gap:12px;padding:12px 18px;background:#fff;border-bottom:1px solid var(--line)}
.thread-head .avx{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0fae6a,#6d5cff);display:grid;place-items:center;color:#fff;font-weight:700;font-size:.78rem}
.thread-head .who{flex:1}
.thread-head .who strong{display:block;font-size:.95rem;color:var(--ink)}
.thread-head .who span{font-size:.78rem;color:var(--muted)}
.thread-head-actions{display:flex;gap:4px}

.thread-window{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:8px}
.day-sep{text-align:center;color:var(--muted);font-size:.78rem;margin:14px 0;position:relative}
.day-sep::before,.day-sep::after{content:"";position:absolute;top:50%;width:35%;height:1px;background:var(--line)}
.day-sep::before{left:0}.day-sep::after{right:0}
.bub{padding:9px 13px;border-radius:14px;max-width:65%;font-size:.92rem;line-height:1.45;position:relative}
.bub.in{background:#fff;border-bottom-left-radius:4px;align-self:flex-start;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.bub.out{background:#dcf8c6;border-bottom-right-radius:4px;align-self:flex-end}
.bub small{display:block;margin-top:3px;color:#7a8a85;font-size:.7rem;text-align:right}

/* Reply composer */
.composer{padding:14px 18px;background:#fff;border-top:1px solid var(--line)}
.composer-template-bar{
  display:flex;gap:8px;padding:8px 10px;background:linear-gradient(135deg,#fef4dc,#ffece1);
  border:1px solid #f5e3a4;border-radius:10px;margin-bottom:10px;font-size:.84rem;color:#7a5d12;align-items:center;
}
.composer-input{
  display:flex;align-items:center;gap:10px;background:var(--bg-soft);border:1px solid var(--line);
  border-radius:24px;padding:6px 8px 6px 16px;
}
.composer-input input{flex:1;border:none;background:transparent;font-size:.95rem;outline:none;padding:6px 0;font-family:inherit}
.composer-input button.ic{width:34px;height:34px;border-radius:50%;border:none;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center}
.composer-input button.ic:hover{background:var(--bg-mute);color:var(--ink)}
.composer-input button.send{width:36px;height:36px;border-radius:50%;border:none;background:var(--brand);color:#fff;cursor:pointer;display:grid;place-items:center}
.composer-input button.send:hover{background:var(--brand-2)}

/* Side info */
.convo-side{border-left:1px solid var(--line);padding:18px;overflow-y:auto;background:#fff}
.convo-side h4{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:18px 0 8px;font-weight:700}
.convo-side h4:first-child{margin-top:0}
.side-row{display:flex;justify-content:space-between;font-size:.86rem;margin-bottom:6px;color:var(--ink-2)}
.side-row span:first-child{color:var(--muted)}

/* Compose campaign workflow */
.workflow-tabs{
  display:flex;gap:4px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px;margin-bottom:18px;
}
.workflow-tabs > button{
  flex:1;display:flex;align-items:center;gap:10px;padding:11px 16px;border:none;background:transparent;
  border-radius:8px;font-weight:600;font-size:.92rem;color:var(--muted);cursor:pointer;justify-content:center;
}
.workflow-tabs > button.active{background:var(--brand);color:#fff;box-shadow:0 4px 12px -4px rgba(15,174,106,.45)}
.workflow-tabs > button.done{color:var(--brand-2)}
.workflow-tabs .tab-num{
  width:22px;height:22px;border-radius:50%;background:var(--bg-mute);color:var(--muted);
  display:grid;place-items:center;font-size:.78rem;font-weight:700;
}
.workflow-tabs > button.active .tab-num{background:rgba(255,255,255,.2);color:#fff}
.workflow-tabs > button.done .tab-num{background:#e8f7ef;color:var(--brand-2)}

/* Filter row (audience builder) */
.filter-row{
  display:flex;gap:10px;align-items:center;padding:12px;
  background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;margin-bottom:8px;
}
.filter-row select,.filter-row input{padding:7px 10px;border:1px solid var(--line);border-radius:7px;background:#fff;font-size:.86rem;font-family:inherit}
.filter-row .rm{width:28px;height:28px;border-radius:7px;border:1px solid var(--line);background:#fff;color:var(--muted);cursor:pointer;display:grid;place-items:center;margin-left:auto}
.filter-row .rm:hover{background:#fde7e8;color:#c93338;border-color:#f7c5c7}

/* Stat strip */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:linear-gradient(135deg,#e8f7ef,#efecff);border:1px solid #cdebd9;border-radius:12px;overflow:hidden}
.stat-strip > div{padding:18px 20px;text-align:center;border-right:1px solid rgba(15,174,106,.12)}
.stat-strip > div:last-child{border-right:none}
.stat-strip strong{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:1.5rem;font-weight:800;color:var(--ink)}
.stat-strip span{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
@media (max-width:780px){.stat-strip{grid-template-columns:repeat(2,1fr)}.stat-strip > div{border-right:none;border-bottom:1px solid rgba(15,174,106,.12)}}

/* Template card */
.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.tpl-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;
  display:flex;flex-direction:column;transition:all .15s ease;
}
.tpl-card:hover{box-shadow:var(--shadow-sm);border-color:#cfe5da;transform:translateY(-2px)}
.tpl-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:10px}
.tpl-card h3{font-size:1rem;margin-bottom:4px}
.tpl-meta{font-size:.78rem;color:var(--muted);font-family:'SF Mono',Menlo,monospace}
.tpl-preview{
  background:#dcf8c6;padding:10px 12px;border-radius:10px;font-size:.86rem;line-height:1.45;
  margin:12px 0;color:#1a2e29;border-bottom-right-radius:4px;
}
.tpl-foot{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:14px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted)}

/* Funnel chart */
.funnel{display:flex;flex-direction:column;gap:6px}
.funnel-row{
  display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:10px;
  background:linear-gradient(90deg,#e8f7ef,#fff);border:1px solid var(--line);
}
.funnel-row .lbl{width:140px;flex-shrink:0;font-weight:600;color:var(--ink)}
.funnel-row .bar{flex:1;height:28px;background:#eef5f2;border-radius:6px;overflow:hidden;position:relative}
.funnel-row .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:6px}
.funnel-row .bar span{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:.82rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}
.funnel-row .pct{width:80px;text-align:right;color:var(--muted);font-weight:600;font-size:.88rem}

/* Plan / billing */
.plan-card{
  background:linear-gradient(135deg,#e8f7ef 0%,#efecff 100%);
  border:1px solid #cdebd9;border-radius:14px;padding:22px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
}
.plan-card .icp{width:54px;height:54px;border-radius:14px;background:#fff;display:grid;place-items:center;color:var(--brand-2);font-size:1.5rem;flex-shrink:0}
.plan-card .pi{flex:1;min-width:0}
.plan-card strong{display:block;color:var(--ink);font-size:1.1rem}
.plan-card span{color:var(--muted);font-size:.92rem}

.usage-row{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.usage-row .ut{display:flex;justify-content:space-between;font-size:.92rem}
.usage-row .ut strong{color:var(--ink)}
.usage-row .ut span{color:var(--muted)}
.usage-bar{height:8px;background:#eef5f2;border-radius:5px;overflow:hidden}
.usage-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:5px}
.usage-bar.warning i{background:linear-gradient(90deg,#f4b740,#ff8a4c)}
.usage-bar.danger i{background:linear-gradient(90deg,#e5484d,#ff8a4c)}

/* Settings page nav (sub) */
.settings-shell{display:grid;grid-template-columns:240px 1fr;gap:24px}
@media (max-width:880px){.settings-shell{grid-template-columns:1fr}}
.settings-nav{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:8px;height:fit-content;position:sticky;top:80px;
}
.settings-nav a{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-weight:500;
  color:var(--ink-2);font-size:.92rem;
}
.settings-nav a:hover{background:var(--bg-soft)}
.settings-nav a.active{background:var(--bg-mute);color:var(--ink);font-weight:600}
.settings-nav a svg{width:16px;height:16px;color:var(--muted)}
.settings-nav a.active svg{color:var(--brand-2)}

/* Section card (inside settings) */
.section-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;margin-bottom:18px;
}
.section-card h3{font-size:1.1rem;margin-bottom:6px}
.section-card .sub{color:var(--muted);margin-bottom:18px;font-size:.92rem}
.row-split{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-top:1px solid var(--line);gap:14px}
.row-split:first-of-type{border-top:none;padding-top:0}
.row-split .rs-text strong{display:block;color:var(--ink);font-size:.94rem}
.row-split .rs-text span{color:var(--muted);font-size:.86rem}

/* Activity feed item (audit log) */
.audit{display:flex;flex-direction:column;gap:0}
.audit-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.audit-item:last-child{border-bottom:none}
.audit-item .ico{width:32px;height:32px;border-radius:8px;background:var(--bg-soft);color:var(--muted);display:grid;place-items:center;flex-shrink:0}
.audit-item .body{flex:1}
.audit-item .body strong{color:var(--ink)}
.audit-item .body span{color:var(--muted);font-size:.82rem;display:block;margin-top:2px}
.audit-item .meta-r{color:var(--muted);font-size:.82rem;flex-shrink:0;text-align:right}
