/* HockeyStick Activate — shared styles
   Brand palette aligned with hockeystick-jo-sprint:
   emerald #1DAE9B, forest #0E7663, darkGreen #012D27, cream #FFF5ED
   No orange/amber per Bryan's instruction. */

:root{
  --emerald:#1DAE9B;
  --forest:#0E7663;
  --darkGreen:#012D27;
  --darkGreenDeep:#03403C;
  --cream:#FFF5ED;
  --white:#FFFFFF;
  --offWhite:#F8FAFB;
  --bg:#F3F4F6;
  --border:#E5E7EB;
  --borderLight:#F3F4F6;
  --text:#111827;
  --textSec:#6B7280;
  --textMuted:#9CA3AF;
  --tealLight:#E6F7F4;
  --tealBg:#F0FDFA;
  --red:#EF4444;
  --green:#10B981;
  --blue:#5268FF;

  --radius:12px;
  --shadow-sm:0 1px 2px rgba(1,45,39,.04);
  --shadow:0 4px 18px -8px rgba(1,45,39,.18);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Work Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased}
body{min-height:100dvh}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
.serif{font-family:'DM Serif Display',Georgia,serif;letter-spacing:-0.01em}

/* ---------- App shell ---------- */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100dvh}

aside.sidebar{
  background:var(--darkGreen);
  color:var(--cream);
  padding:22px 16px;
  display:flex;flex-direction:column;gap:18px;
  position:sticky;top:0;height:100dvh;
}
.sidebar .brand{display:flex;align-items:center;gap:10px;padding:0 6px 16px;border-bottom:1px solid rgba(255,245,237,.08)}
.sidebar .brand img{height:24px;width:auto}
.sidebar .brand .label{font-weight:600;font-size:14px;letter-spacing:.2px}
.sidebar .brand .label small{display:block;font-size:10.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--emerald);font-weight:500;margin-top:2px}

.sidebar nav{display:flex;flex-direction:column;gap:2px}
.sidebar nav a{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:8px;
  font-size:13.5px;color:rgba(255,245,237,.72);
  transition:background .12s,color .12s;
}
.sidebar nav a:hover{background:rgba(255,245,237,.04);color:var(--cream)}
.sidebar nav a.on{background:rgba(29,174,155,.16);color:var(--cream)}
.sidebar nav a.on .ico{color:var(--emerald)}
.sidebar nav a .ico{width:16px;height:16px;display:inline-grid;place-items:center;color:rgba(255,245,237,.5);font-size:14px}
.sidebar nav .group{font-size:10.5px;letter-spacing:.6px;text-transform:uppercase;color:rgba(255,245,237,.42);padding:10px 12px 4px;font-weight:500}

.sidebar .acct{margin-top:auto;padding-top:12px;border-top:1px solid rgba(255,245,237,.08);font-size:12px;color:rgba(255,245,237,.62);display:flex;align-items:center;gap:10px}
.sidebar .acct .av{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--emerald),var(--forest));display:grid;place-items:center;font-weight:700;color:var(--darkGreen);font-size:12px}

/* ---------- Main ---------- */
main.main{padding:0;min-width:0}
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;background:var(--white);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:5;
}
.topbar .crumbs{display:flex;align-items:center;gap:8px;color:var(--textSec);font-size:13px}
.topbar .crumbs strong{color:var(--text);font-weight:600}
.topbar .crumbs .sep{color:var(--textMuted)}
.topbar .right{display:flex;align-items:center;gap:14px}
.topbar .right .checkpoint{font-size:12px;color:var(--textSec);background:var(--tealBg);border:1px solid rgba(29,174,155,.25);color:var(--forest);padding:5px 10px;border-radius:99px;font-weight:500}
.topbar .right .live{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--textSec)}
.topbar .right .live .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(16,185,129,.18);animation:pulse 1.6s infinite}
@keyframes pulse{50%{opacity:.4}}

.content{padding:24px 28px 60px;max-width:1280px;margin:0 auto}
.page-head{margin:4px 0 22px}
.page-head h1{margin:0;font-family:'DM Serif Display',Georgia,serif;font-size:34px;letter-spacing:-0.015em;color:var(--darkGreen);font-weight:400}
.page-head p{margin:8px 0 0;color:var(--textSec);font-size:14.5px;max-width:720px;line-height:1.55}

/* ---------- Cards & layout primitives ---------- */
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:1fr 1fr}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-2-1{grid-template-columns:2fr 1fr}
.cols-3-2{grid-template-columns:3fr 2fr}
@media (max-width:1100px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}.cols-2-1,.cols-3-2{grid-template-columns:1fr}}
@media (max-width:760px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card .pad{padding:18px}
.card .pad-lg{padding:22px}
.card-h{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-h h3{margin:0;font-size:13px;letter-spacing:.4px;text-transform:uppercase;color:var(--textSec);font-weight:600}
.card-h .actions{display:flex;gap:8px}

.section-h{display:flex;align-items:flex-end;justify-content:space-between;margin:28px 0 12px}
.section-h h2{margin:0;font-size:13px;letter-spacing:.5px;text-transform:uppercase;color:var(--textSec);font-weight:600}
.section-h .meta{color:var(--textMuted);font-size:12px}

/* ---------- KPI cards ---------- */
.kpi{padding:18px}
.kpi .label{font-size:11.5px;color:var(--textSec);letter-spacing:.4px;text-transform:uppercase;font-weight:500}
.kpi .v{font-family:'DM Serif Display',Georgia,serif;font-size:34px;line-height:1.05;color:var(--darkGreen);margin:6px 0 4px;letter-spacing:-0.01em}
.kpi .d{font-size:12px;color:var(--textMuted)}
.kpi .d.up{color:var(--green)}
.kpi .d.dn{color:var(--red)}
.kpi .d strong{font-weight:600}

/* ---------- Buttons / chips / tags ---------- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;border:1px solid var(--border);background:var(--white);color:var(--text);transition:.12s}
.btn:hover{background:var(--offWhite)}
.btn.primary{background:var(--emerald);color:var(--white);border-color:var(--emerald)}
.btn.primary:hover{background:var(--forest);border-color:var(--forest)}
.btn.dark{background:var(--darkGreen);color:var(--cream);border-color:var(--darkGreen)}
.btn.dark:hover{background:#022820}
.btn.ghost{background:transparent;border-color:transparent;color:var(--textSec)}
.btn.ghost:hover{color:var(--text);background:var(--offWhite)}
.btn.sm{padding:5px 10px;font-size:12px}
.btn.danger{color:var(--red);border-color:#fecaca;background:#fff5f5}
.btn.danger:hover{background:#fee2e2}

.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;padding:3px 9px;border-radius:99px;background:var(--bg);color:var(--textSec);border:1px solid var(--border);font-weight:500}
.chip.ok{background:var(--tealBg);color:var(--forest);border-color:rgba(29,174,155,.25)}
.chip.warn{background:#fff7e6;color:#92580a;border-color:#fde6c0}
.chip.bad{background:#fef2f2;color:#b91c1c;border-color:#fecaca}
.chip.muted{background:var(--bg);color:var(--textMuted)}

.tag{display:inline-flex;align-items:center;font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;padding:3px 8px;border-radius:6px}
.tag.boost{background:#dcfaf3;color:var(--forest)}
.tag.fix{background:#fff4e2;color:#9a4a08}
.tag.drop{background:#fee2e2;color:#991b1b}
.tag.hold{background:#e0e7ff;color:#3730a3}
.tag.pause{background:#e5e7eb;color:#374151}
.tag.risk{background:#fef3c7;color:#854d0e}

/* ---------- Tables ---------- */
table.t{width:100%;border-collapse:collapse;font-size:13px}
table.t th{text-align:left;padding:12px 18px;font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:var(--textSec);font-weight:600;background:var(--offWhite);border-bottom:1px solid var(--border)}
table.t td{padding:14px 18px;border-bottom:1px solid var(--borderLight);vertical-align:middle}
table.t tr:last-child td{border-bottom:0}
table.t tr:hover td{background:var(--offWhite)}
table.t .num{font-variant-numeric:tabular-nums}
table.t .partner-name{font-weight:600;color:var(--darkGreen)}
table.t .partner-meta{font-size:12px;color:var(--textMuted);margin-top:2px}

/* ---------- Bars ---------- */
.bar{display:inline-block;width:100px;height:6px;background:#eef0f3;border-radius:99px;overflow:hidden;vertical-align:middle;margin-right:8px}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--emerald),var(--forest))}
.bar.warn i{background:linear-gradient(90deg,#f7c04a,#dd9706)}
.bar.bad i{background:linear-gradient(90deg,#f87171,var(--red))}

/* ---------- Agent cards ---------- */
.agents{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:1100px){.agents{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.agents{grid-template-columns:1fr}}
.agent{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:10px;min-height:200px;transition:.15s;cursor:pointer}
.agent:hover{transform:translateY(-1px);box-shadow:var(--shadow);border-color:rgba(29,174,155,.3)}
.agent .head{display:flex;align-items:center;gap:12px}
.agent .face{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-weight:700;font-size:16px;color:var(--white);font-family:'DM Serif Display',Georgia,serif}
.agent .face.drew{background:linear-gradient(135deg,#1DAE9B,#0E7663)}
.agent .face.casey{background:linear-gradient(135deg,#5268FF,#3b48b3)}
.agent .face.morgan{background:linear-gradient(135deg,#0E7663,#012D27)}
.agent .face.taylor{background:linear-gradient(135deg,#7c5fff,#5b41cf)}
.agent .face.jordan{background:linear-gradient(135deg,#e85d8a,#c23867)}
.agent .face.quinn{background:linear-gradient(135deg,#0ea5e9,#0369a1)}
.agent .face.remi{background:linear-gradient(135deg,#10b981,#047857)}
.agent .face.mia{background:linear-gradient(135deg,#012D27,#03403C)}
.agent .name{font-weight:600;color:var(--darkGreen);font-size:15px}
.agent .role{font-size:12px;color:var(--textMuted)}
.agent .doing{font-size:13px;line-height:1.5;color:var(--text);background:var(--offWhite);border:1px solid var(--borderLight);border-radius:8px;padding:10px 12px}
.agent .doing b{color:var(--forest);font-weight:600}
.agent .meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}

/* ---------- Hero / banner ---------- */
.banner{background:linear-gradient(135deg,var(--darkGreen),var(--forest) 130%);color:var(--cream);border-radius:var(--radius);padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:22px;border:1px solid rgba(29,174,155,.2)}
.banner .lead h2{margin:0;font-family:'DM Serif Display',Georgia,serif;font-size:26px;font-weight:400;letter-spacing:-0.01em}
.banner .lead p{margin:6px 0 0;color:rgba(255,245,237,.78);font-size:13.5px;max-width:560px;line-height:1.55}
.banner .actions{display:flex;gap:8px}
.banner .btn{background:var(--emerald);border-color:var(--emerald);color:var(--white)}
.banner .btn:hover{background:var(--forest);border-color:var(--forest)}
.banner .btn.alt{background:transparent;color:var(--cream);border-color:rgba(255,245,237,.2)}
.banner .btn.alt:hover{background:rgba(255,245,237,.08)}

/* ---------- Signals strip ---------- */
.signals{display:flex;flex-direction:column;gap:8px}
.signal{padding:12px 14px;border-radius:10px;border:1px solid;display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:13.5px}
.signal .kind{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-right:6px}
.signal.new{background:#ebfaf5;border-color:#9ddcc8;color:#0a3a30}
.signal.new .kind{color:var(--forest)}
.signal.warn{background:#fff7e6;border-color:#fbe4b8;color:#7a4d04}
.signal.warn .kind{color:#9a4a08}
.signal.shift{background:#e8efff;border-color:#bcc7f3;color:#21306b}
.signal.shift .kind{color:#3730a3}
.signal.bad{background:#fef2f2;border-color:#fecaca;color:#7f1d1d}
.signal.bad .kind{color:#b91c1c}

/* ---------- Variance notes ---------- */
.note{padding:14px 16px;border-radius:10px;border:1px solid;line-height:1.55;font-size:13.5px}
.note .h{font-weight:600;display:block;margin-bottom:4px}
.note.good{background:#f0fbf7;border-color:#bee5d2;color:#0a3a30}
.note.good .h{color:var(--forest)}
.note.bad{background:#fff7f7;border-color:#fbcfcf;color:#7f1d1d}
.note.bad .h{color:#b91c1c}

/* ---------- Approval queue ---------- */
.queue{display:flex;flex-direction:column}
.q-item{
  display:grid;grid-template-columns:1fr 150px 130px 110px;gap:14px;align-items:center;
  padding:14px 18px;border-bottom:1px solid var(--borderLight);font-size:13.5px;
}
.q-item:last-child{border-bottom:0}
.q-item:hover{background:var(--offWhite)}
.q-item .title{font-weight:500;color:var(--darkGreen)}
.q-item .sub{font-size:12px;color:var(--textMuted);margin-top:3px}
.q-item .due{font-size:12.5px;color:var(--textSec)}
.q-item .due.late{color:var(--red);font-weight:600}
.stage{font-size:11px;font-weight:600;padding:4px 9px;border-radius:6px;display:inline-block}
.stage.client{background:#fff4e2;color:#9a4a08}
.stage.partner{background:#e0e7ff;color:#3730a3}
.stage.revisions{background:#fee2e2;color:#991b1b}
.stage.ready{background:#dcfaf3;color:var(--forest)}
.stage.stalled{background:#fef2f2;color:#b91c1c;border:1px dashed #fca5a5}

/* ---------- Element review ---------- */
.elements{display:flex;flex-direction:column;gap:8px;padding:18px}
.el{display:flex;align-items:center;gap:14px;padding:14px;background:var(--offWhite);border:1px solid var(--borderLight);border-radius:10px;transition:.1s}
.el:hover{border-color:var(--border);background:var(--white)}
.el .label{flex:0 0 130px;font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--textMuted);font-weight:600}
.el .text{flex:1 1 auto;min-width:0;color:var(--text);font-size:14px;line-height:1.45}
.el .right{flex:0 0 160px;display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.el-status{display:inline-block;font-size:11px;padding:3px 9px;border-radius:99px;font-weight:600;line-height:1.4;height:auto;min-height:0;max-height:none;flex:none}
.el-status.app{background:#dcfaf3;color:var(--forest)}
.el-status.pen{background:#fff4e2;color:#9a4a08}
.el-status.edt{background:#e0e7ff;color:#3730a3}
.el-status.rev{background:#fee2e2;color:#991b1b}

/* ---------- Connector status ---------- */
.connector{display:flex;align-items:center;gap:14px;padding:16px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius)}
.connector .icon{width:42px;height:42px;border-radius:10px;background:var(--offWhite);border:1px solid var(--border);display:grid;place-items:center;font-weight:700;color:var(--darkGreen);font-size:14px}
.connector .info{flex:1;min-width:0}
.connector .info .name{font-weight:600;color:var(--darkGreen);display:flex;align-items:center;gap:8px}
.connector .info .meta{font-size:12.5px;color:var(--textMuted);margin-top:3px}
.connector .info .meta b{color:var(--text);font-weight:500}
.dotc{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(16,185,129,.18);flex:none}
.dotc.warn{background:#f5b836;box-shadow:0 0 0 4px rgba(245,184,54,.18)}
.dotc.bad{background:var(--red);box-shadow:0 0 0 4px rgba(239,68,68,.18)}

/* ---------- Forms ---------- */
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-row label{font-size:12px;font-weight:600;color:var(--textSec);text-transform:uppercase;letter-spacing:.4px}
.form-row input,.form-row select,.form-row textarea{
  border:1px solid var(--border);border-radius:8px;padding:10px 12px;
  font:inherit;font-size:14px;color:var(--text);background:var(--white);
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px rgba(29,174,155,.15)}
.form-row textarea{min-height:90px;resize:vertical;font-family:inherit}

/* ---------- Drew response card ---------- */
.drew-resp{
  border-left:3px solid var(--emerald);
  background:linear-gradient(135deg,#f0fbf7,#fdfffe);
  border-radius:8px;padding:16px 18px;margin-top:14px;
}
.drew-resp .who{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.drew-resp .who .face{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--emerald),var(--forest));display:grid;place-items:center;font-weight:700;color:var(--white);font-family:'DM Serif Display',Georgia,serif;font-size:14px}
.drew-resp .who .name{font-weight:600;color:var(--darkGreen)}
.drew-resp .who .name small{display:block;font-size:11px;color:var(--textMuted);font-weight:400;margin-top:1px}
.drew-resp .body{font-size:14px;line-height:1.55;color:var(--text)}
.drew-resp .body strong{color:var(--forest)}

/* ---------- Avatars / partner badges ---------- */
.pavatar{width:32px;height:32px;border-radius:8px;display:inline-grid;place-items:center;font-weight:700;color:var(--white);font-size:13px;margin-right:8px;vertical-align:middle;font-family:'DM Serif Display',Georgia,serif}
.p-snowflake{background:#29b5e8}
.p-datadog{background:#632ca6}
.p-mulesoft{background:#00a0df}
.p-auth0{background:#eb5424}
.p-workato{background:#3c2e7d}
.p-calendly{background:#006bff}
.p-talkdesk{background:#04a3c0}
.p-brightpearl{background:#f97316}
.p-stripe{background:#635bff}

/* ---------- Detail layouts ---------- */
.detail-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:14px}
.detail-h .left h1{margin:0;font-family:'DM Serif Display',Georgia,serif;font-size:32px;color:var(--darkGreen);font-weight:400;letter-spacing:-0.015em;display:flex;align-items:center;gap:14px}
.detail-h .left .sub{margin:6px 0 0;color:var(--textMuted);font-size:13.5px}
.detail-h .pavatar{width:42px;height:42px;border-radius:10px;font-size:18px;margin:0}

.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:760px){.stat-row{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:14px}
.stat .l{font-size:11px;color:var(--textMuted);text-transform:uppercase;letter-spacing:.4px;font-weight:600}
.stat .v{font-family:'DM Serif Display',Georgia,serif;font-size:24px;color:var(--darkGreen);margin:4px 0 2px;line-height:1.05}
.stat .d{font-size:12px;color:var(--textSec)}

/* ---------- Timeline ---------- */
.timeline{position:relative;padding-left:24px}
.timeline:before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--border)}
.tl-item{position:relative;padding:6px 0 16px}
.tl-item:before{content:"";position:absolute;left:-24px;top:10px;width:14px;height:14px;border-radius:50%;background:var(--white);border:3px solid var(--emerald)}
.tl-item.muted:before{border-color:var(--border)}
.tl-item .when{font-size:11.5px;color:var(--textMuted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.tl-item .what{font-size:13.5px;color:var(--text);margin-top:3px;line-height:1.5}
.tl-item .what b{color:var(--darkGreen);font-weight:600}

/* ---------- Tabs ---------- */
.tabs-nav{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:18px}
.tabs-nav a{padding:10px 18px;font-size:13.5px;color:var(--textSec);border-bottom:2px solid transparent;font-weight:500}
.tabs-nav a.on{color:var(--darkGreen);border-bottom-color:var(--emerald)}
.tabs-nav a:hover:not(.on){color:var(--text)}

/* ---------- Empty state ---------- */
.empty{text-align:center;padding:40px 20px;color:var(--textMuted)}

/* ---------- Utilities ---------- */
.muted{color:var(--textMuted)}
.sec{color:var(--textSec)}
.right{text-align:right}
.center{text-align:center}
.flex{display:flex;align-items:center;gap:10px}
.flex-between{display:flex;align-items:center;justify-content:space-between;gap:14px}
.gap-sm{gap:6px}
.gap-md{gap:12px}
.mt-0{margin-top:0!important}
.mt-2{margin-top:18px}
.mt-3{margin-top:28px}
.mb-0{margin-bottom:0!important}
.tabular{font-variant-numeric:tabular-nums}
.wrap-hide{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;background:var(--offWhite);padding:1px 6px;border-radius:4px;color:var(--forest);border:1px solid var(--borderLight)}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(1,45,39,.55);display:none;align-items:center;justify-content:center;z-index:50;padding:24px;backdrop-filter:blur(2px)}
.modal-overlay.on{display:flex}
.modal{background:var(--white);border-radius:14px;max-width:560px;width:100%;box-shadow:0 30px 60px -20px rgba(1,45,39,.4);overflow:hidden;animation:modalIn .18s ease-out}
@keyframes modalIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.modal h3{margin:0;font-family:'DM Serif Display',Georgia,serif;font-size:22px;color:var(--darkGreen);font-weight:400}
.modal .modal-h{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal .modal-b{padding:18px 22px;font-size:14px;line-height:1.55;color:var(--text)}
.modal .modal-f{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--offWhite)}
.x-close{background:transparent;border:0;color:var(--textMuted);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px}
.x-close:hover{background:var(--bg);color:var(--text)}

/* ---------- Toasts ---------- */
.toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:60}
.toast{background:var(--darkGreen);color:var(--cream);padding:12px 18px;border-radius:10px;box-shadow:var(--shadow);font-size:13.5px;animation:slideIn .2s ease-out;display:flex;align-items:center;gap:10px}
.toast.ok::before{content:"✓";color:var(--emerald);font-weight:700}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ---------- Sparkline / charts placeholder ---------- */
.spark{display:flex;align-items:flex-end;gap:3px;height:38px;margin-top:6px}
.spark .b{flex:1;background:linear-gradient(180deg,var(--emerald),var(--forest));border-radius:2px;min-width:3px;opacity:.85}

/* ---------- Mobile ---------- */
@media (max-width:900px){
  .app{grid-template-columns:1fr}
  aside.sidebar{position:relative;height:auto;flex-direction:row;flex-wrap:wrap;gap:8px;padding:12px}
  .sidebar nav{flex-direction:row;flex-wrap:wrap;flex:1}
  .sidebar nav .group{display:none}
  .sidebar .acct{margin:0;padding:0;border:0;font-size:0}
  .sidebar .acct .av{margin:0}
  .topbar{padding:14px 18px;flex-wrap:wrap;gap:8px}
  .content{padding:18px}
}
