/* =====================================================================
   FocusFlow — Operational Workspace (product dashboard)
   Extends the landing design system: dark, neon-green, glass, Manrope.
   No frameworks. Pure CSS. Tokens mirror styles.css.
   ===================================================================== */
:root{
  --lime:#6BFF11; --emerald:#00FF89; --yellow:#FFD900; --green:#009636; --action:#078D35;
  --grad:linear-gradient(135deg,#00FF89 0%,#6BFF11 55%,#FFD900 100%);
  --blue:#314EC1; --amber:#e0913a; --violet:#8b5cf6; --rose:#ff5d8d;
  --bg:#070908; --bg-2:#0C0C0C; --green-black:#101B14;
  --s1:#1A1C1A; --s2:#242624; --s3:#343634;
  --hi:#FFFFFF; --mid:#E7E7E7; --lo:#9C9C9C; --faint:#6f726f;
  --glass:rgba(255,255,255,.045);
  --glass-bd:rgba(255,255,255,.085);
  --line:rgba(255,255,255,.07);
  --r:18px;
  --font:"Manrope","Inter",system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --side:250px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--mid);line-height:1.3;
  letter-spacing:-.011em;-webkit-font-smoothing:antialiased;overflow:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:rgba(107,255,17,.25);color:#fff}
:focus-visible{outline:2px solid var(--lime);outline-offset:2px;border-radius:6px}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:99px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.16);background-clip:padding-box}

/* atmosphere (subtle, matches landing) */
.atmos{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.glow{position:absolute;border-radius:50%;filter:blur(150px)}
.glow-a{width:560px;height:560px;top:-160px;left:160px;background:radial-gradient(circle,#0e6b39,transparent 70%);opacity:.35}
.glow-b{width:620px;height:620px;bottom:-220px;right:-160px;background:radial-gradient(circle,#0a5230,transparent 70%);opacity:.3}

.glass{background:rgba(255,255,255,.045);border:1px solid var(--glass-bd);border-radius:var(--r);
  box-shadow:0 18px 50px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.04)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- shell ---------- */
.ws{position:relative;z-index:1;display:grid;grid-template-columns:var(--side) 1fr;height:100vh}

/* ---------- sidebar ---------- */
.side{display:flex;flex-direction:column;gap:6px;padding:18px 14px;
  background:rgba(9,11,9,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-right:1px solid var(--line);height:100vh;overflow-y:auto}
.side-brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--hi);font-size:17px;
  padding:6px 10px 14px}
.side-brand svg{width:26px;height:26px;filter:drop-shadow(0 0 12px rgba(107,255,17,.45))}
.side-sec{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);
  padding:14px 12px 6px;font-weight:700}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--lo);
  font-size:14px;font-weight:500;transition:background .2s,color .2s;position:relative}
.nav-item .ic{width:18px;text-align:center;font-size:14px;opacity:.9}
.nav-item .badge{margin-left:auto;background:rgba(255,255,255,.08);color:var(--mid);
  font-size:11px;font-weight:700;padding:1px 8px;border-radius:99px;min-width:22px;text-align:center}
.nav-item:hover{background:rgba(255,255,255,.05);color:var(--mid)}
.nav-item.on{background:linear-gradient(135deg,rgba(7,141,53,.32),rgba(107,255,17,.08));color:var(--hi)}
.nav-item.on .ic{color:var(--lime)}
.nav-item.on .badge{background:rgba(107,255,17,.18);color:var(--lime)}
.side-user{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-radius:13px;
  background:rgba(255,255,255,.04);border:1px solid var(--line)}
.side-user .who{font-size:13px;color:var(--hi);font-weight:600}
.side-user .role{font-size:11px;color:var(--lo)}

/* ---------- avatars / pills ---------- */
.av{border-radius:50%;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;color:#fff;font-size:12px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.av.sm{width:26px;height:26px;font-size:10px}
.av.md{width:34px;height:34px;font-size:12px}
.av.lg{width:46px;height:46px;font-size:15px}
.av-stack{display:flex}
.av-stack .av{margin-left:-9px;box-shadow:0 0 0 2px var(--bg),inset 0 0 0 1px rgba(255,255,255,.12)}
.av-stack .av:first-child{margin-left:0}

.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;
  font-size:11px;font-weight:700;letter-spacing:.03em;white-space:nowrap}
.pill.dot::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.p-green{background:rgba(107,255,17,.14);color:var(--lime)}
.p-grad{background:var(--grad);color:#06210f}
.p-blue{background:rgba(49,78,193,.24);color:#9db0ff}
.p-amber{background:rgba(224,145,58,.18);color:#f0b56a}
.p-rose{background:rgba(255,93,141,.16);color:#ff8db1}
.p-grey{background:rgba(255,255,255,.08);color:var(--mid)}
.p-hi{background:rgba(255,93,141,.16);color:#ff8db1}     /* high priority */
.p-med{background:rgba(224,145,58,.18);color:#f0b56a}    /* medium */
.p-low{background:rgba(255,255,255,.08);color:var(--lo)} /* low */

/* ---------- main + topbar ---------- */
.main{display:flex;flex-direction:column;min-width:0;height:100vh}
.topbar{display:flex;align-items:center;gap:16px;padding:14px 26px;border-bottom:1px solid var(--line);
  background:rgba(7,9,8,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.tb-title{font-size:18px;font-weight:600;color:var(--hi)}
.tb-crumb{font-size:12px;color:var(--lo);margin-top:2px}
.tb-search{margin-left:auto;display:flex;align-items:center;gap:8px;width:min(320px,30vw);
  padding:9px 13px;border-radius:11px;background:rgba(255,255,255,.04);border:1px solid var(--glass-bd);color:var(--lo);font-size:13px}
.tb-search input{flex:1;background:none;border:none;color:var(--mid);font-size:13px;outline:none}
.tb-btn{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.04);border:1px solid var(--glass-bd);
  display:flex;align-items:center;justify-content:center;color:var(--mid);font-size:15px;transition:background .2s;position:relative}
.tb-btn:hover{background:rgba(255,255,255,.09)}
.tb-btn .ndot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 8px var(--lime)}
.tb-exit{display:flex;align-items:center;gap:7px;padding:9px 15px;border-radius:99px;font-size:13px;font-weight:600;
  background:rgba(255,255,255,.04);border:1px solid var(--glass-bd);color:var(--mid);transition:.2s}
.tb-exit:hover{background:rgba(255,255,255,.09);color:var(--hi)}

.view{flex:1;overflow-y:auto;padding:26px;scroll-behavior:smooth}
.view-in{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:22px}

/* section header inside views */
.vhead{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.vhead h2{font-size:20px;font-weight:600;color:var(--hi)}
.vhead .sub{font-size:13px;color:var(--lo)}
.vhead .spacer{margin-left:auto}

/* segmented control */
.seg{display:inline-flex;gap:3px;padding:4px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid var(--line);flex-wrap:wrap}
.seg button{padding:7px 14px;border-radius:9px;font-size:13px;font-weight:500;color:var(--lo);transition:.2s;white-space:nowrap}
.seg button:hover{color:var(--mid)}
.seg button.on{background:rgba(255,255,255,.08);color:var(--hi)}
.seg button .n{margin-left:6px;font-size:11px;color:var(--faint)}
.seg button.on .n{color:var(--lime)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;border-radius:10px;
  font-size:13px;font-weight:600;transition:.2s;border:1px solid transparent}
.btn-grad{background:var(--grad);color:#06210f;box-shadow:0 6px 18px rgba(107,255,17,.22)}
.btn-grad:hover{box-shadow:0 10px 26px rgba(107,255,17,.36)}
.btn-ghost{background:rgba(255,255,255,.04);border-color:var(--glass-bd);color:var(--mid)}
.btn-ghost:hover{background:rgba(255,255,255,.09);color:var(--hi)}
.btn-danger{background:rgba(255,93,141,.12);border-color:rgba(255,93,141,.3);color:#ff8db1}
.btn-danger:hover{background:rgba(255,93,141,.2)}
.btn-ok{background:rgba(107,255,17,.14);border-color:rgba(107,255,17,.3);color:var(--lime)}
.btn-ok:hover{background:rgba(107,255,17,.22)}
.btn.sm{padding:7px 12px;font-size:12px}

/* ---------- metric cards ---------- */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.metric{padding:20px;border-radius:16px;cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease);
  display:flex;flex-direction:column;gap:10px;position:relative}
.metric:hover{transform:translateY(-4px);box-shadow:0 26px 60px rgba(0,0,0,.45),0 0 0 1px rgba(107,255,17,.2),0 0 50px rgba(107,255,17,.1),inset 0 1px 0 rgba(255,255,255,.05)}
.metric .mlabel{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--lo)}
.metric .mlabel .ic{color:var(--lime)}
.metric .mnum{font-size:38px;font-weight:200;letter-spacing:-.03em;color:var(--hi);line-height:1}
.metric .mfoot{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--faint)}
.metric .mfoot .go{color:var(--lime);font-weight:600;opacity:0;transform:translateX(-4px);transition:.25s}
.metric:hover .mfoot .go{opacity:1;transform:none}
.metric .delta{color:var(--lime)}
.metric .delta.down{color:#ff8db1}

/* ---------- panels / grids ---------- */
.grid-2{display:grid;grid-template-columns:1.6fr 1fr;gap:22px;align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.panel{padding:0;overflow:hidden}
.panel-h{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.panel-h h3{font-size:15px;font-weight:600;color:var(--hi)}
.panel-h .spacer{margin-left:auto}
.panel-h a.more{font-size:12px;color:var(--lo);font-weight:600}
.panel-h a.more:hover{color:var(--lime)}
.panel-b{padding:8px 18px 16px}

/* ---------- activity feed ---------- */
.feed{display:flex;flex-direction:column}
.feed-item{display:flex;align-items:center;gap:12px;padding:13px 6px;border-bottom:1px solid var(--line);cursor:pointer;transition:.2s;border-radius:10px}
.feed-item:last-child{border-bottom:none}
.feed-item:hover{background:rgba(255,255,255,.03);padding-left:12px}
.feed-item .body{min-width:0;flex:1}
.feed-item .body p{font-size:13.5px;color:var(--mid)}
.feed-item .body p b{color:var(--hi);font-weight:600}
.feed-item .body .meta{font-size:11.5px;color:var(--faint);margin-top:2px}
.feed-item .verbtag{font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 7px;border-radius:6px;text-transform:uppercase}

/* ---------- task list ---------- */
.tlist{display:flex;flex-direction:column}
.trow{display:grid;grid-template-columns:1.7fr .9fr .7fr .8fr .9fr;gap:12px;align-items:center;
  padding:13px 8px;border-bottom:1px solid var(--line);cursor:pointer;transition:.2s;border-radius:10px}
.trow:hover{background:rgba(255,255,255,.03)}
.trow.head{cursor:default;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:700}
.trow.head:hover{background:none}
.trow .t-title{display:flex;align-items:center;gap:10px;min-width:0}
.trow .t-title .tt{color:var(--hi);font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trow .t-assignee{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--mid)}
.trow .col-lo{font-size:13px;color:var(--lo)}
.checkbox{width:18px;height:18px;border-radius:6px;border:1.5px solid var(--s3);flex:0 0 18px;display:flex;align-items:center;justify-content:center;font-size:11px;color:transparent;transition:.2s}
.checkbox.done{background:var(--grad);border-color:transparent;color:#06210f}

/* ---------- approval pipeline ---------- */
.pipe{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:start}
.pipe-col{display:flex;flex-direction:column;gap:12px}
.pipe-head{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--lo);padding:2px 4px}
.pipe-head .cnt{margin-left:auto;background:rgba(255,255,255,.08);color:var(--mid);font-size:11px;padding:1px 8px;border-radius:99px}
.pipe-head .stagedot{width:8px;height:8px;border-radius:50%}
.acard{padding:14px;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;gap:10px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.acard:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(0,0,0,.4),0 0 0 1px rgba(107,255,17,.18)}
.acard .at{font-size:14px;font-weight:600;color:var(--hi)}
.acard .ameta{font-size:12px;color:var(--lo);display:flex;align-items:center;gap:8px}
.acard .aact{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px}
.acard .aact .btn{flex:1;min-width:0}

/* ---------- docs ---------- */
.doc-row{display:grid;grid-template-columns:1.8fr 1fr .8fr .9fr auto;gap:12px;align-items:center;
  padding:13px 8px;border-bottom:1px solid var(--line);cursor:pointer;transition:.2s;border-radius:10px}
.doc-row:hover{background:rgba(255,255,255,.03)}
.doc-row.head{cursor:default;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:700}
.doc-row.head:hover{background:none}
.doc-row .d-name{display:flex;align-items:center;gap:11px;min-width:0}
.doc-ic{width:34px;height:34px;border-radius:10px;background:rgba(107,255,17,.1);color:var(--lime);
  display:flex;align-items:center;justify-content:center;font-size:15px;flex:0 0 34px}
.doc-row .dt{color:var(--hi);font-weight:600;font-size:14px}
.doc-row .ds{font-size:11.5px;color:var(--faint);margin-top:1px}

/* ---------- teams ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.team-card{padding:18px;border-radius:16px;cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease);display:flex;flex-direction:column;gap:14px}
.team-card:hover{transform:translateY(-4px);box-shadow:0 26px 60px rgba(0,0,0,.45),0 0 0 1px rgba(107,255,17,.2),0 0 50px rgba(107,255,17,.1)}
.team-card .tc-top{display:flex;align-items:center;gap:12px}
.team-card .tc-name{font-size:15px;font-weight:600;color:var(--hi)}
.team-card .tc-lead{font-size:12px;color:var(--lo)}
.team-card .tc-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.tc-stat{text-align:center;padding:8px 4px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid var(--line)}
.tc-stat .n{font-size:17px;font-weight:300;color:var(--hi)}
.tc-stat .l{font-size:10px;color:var(--faint);margin-top:1px}

/* ---------- charts ---------- */
.chart{padding:16px 18px}
.chart h3{font-size:14px;font-weight:600;color:var(--hi);margin-bottom:2px}
.chart .csub{font-size:12px;color:var(--lo);margin-bottom:16px}
.chart .big{font-size:30px;font-weight:200;color:var(--hi);letter-spacing:-.02em}
.bars{display:flex;align-items:flex-end;gap:12px;height:140px}
.bars .bcol{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}
.bars .bar{width:100%;border-radius:7px 7px 0 0;background:rgba(255,255,255,.1);transition:height .8s var(--ease);position:relative}
.bars .bar.hot{background:var(--grad);box-shadow:0 0 16px rgba(107,255,17,.35)}
.bars .bx{font-size:11px;color:var(--faint)}
.bars .bv{font-size:11px;color:var(--lo);font-weight:600}
.hbars{display:flex;flex-direction:column;gap:13px}
.hbar{display:flex;align-items:center;gap:12px}
.hbar .hl{width:92px;font-size:12px;color:var(--mid)}
.hbar .htrack{flex:1;height:9px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden}
.hbar .hfill{height:100%;border-radius:99px;background:var(--grad);transition:width .9s var(--ease)}
.hbar .hv{width:30px;text-align:right;font-size:12px;color:var(--lo);font-weight:600}
.linechart{width:100%;height:150px}
.linechart .ln{fill:none;stroke:var(--lime);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 6px rgba(107,255,17,.4))}
.linechart .area{fill:url(#lcfill)}
.linechart .dot{fill:var(--lime)}

/* ---------- empty state ---------- */
.empty{padding:48px 20px;text-align:center;color:var(--faint)}
.empty .eic{font-size:30px;opacity:.5;margin-bottom:10px}
.empty p{font-size:14px}

/* ---------- drawer ---------- */
.scrim{position:fixed;inset:0;background:rgba(2,4,3,.6);backdrop-filter:blur(2px);z-index:40;opacity:0;
  transition:opacity .3s ease;pointer-events:none}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(460px,94vw);z-index:50;
  background:#0c0f0d;border-left:1px solid var(--glass-bd);box-shadow:-30px 0 80px rgba(0,0,0,.55);
  transform:translateX(100%);transition:transform .36s var(--ease);display:flex;flex-direction:column}
.drawer.show{transform:none}
.dr-head{display:flex;align-items:flex-start;gap:12px;padding:20px 22px 16px;border-bottom:1px solid var(--line)}
.dr-head .dh-eyebrow{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--lime);font-weight:700}
.dr-head h2{font-size:19px;font-weight:600;color:var(--hi);margin-top:4px;line-height:1.2}
.dr-close{margin-left:auto;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.05);
  display:flex;align-items:center;justify-content:center;color:var(--mid);font-size:16px;flex:0 0 34px}
.dr-close:hover{background:rgba(255,255,255,.1)}
.dr-body{flex:1;overflow-y:auto;padding:18px 22px 26px;display:flex;flex-direction:column;gap:20px}
.dr-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;gap:10px;background:rgba(255,255,255,.015)}
.dr-foot .btn{flex:1}
.field{display:flex;flex-direction:column;gap:5px}
.field .fl{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:700}
.field .fv{font-size:14px;color:var(--mid)}
.kv{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.dr-sec-t{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:700;
  display:flex;align-items:center;gap:8px}
.dr-sec-t::after{content:"";flex:1;height:1px;background:var(--line)}
.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:12px;padding-bottom:16px;position:relative}
.tl-item:not(:last-child)::before{content:"";position:absolute;left:5px;top:16px;bottom:0;width:1px;background:var(--line)}
.tl-dot{width:11px;height:11px;border-radius:50%;background:var(--grad);flex:0 0 11px;margin-top:3px;z-index:1}
.tl-item .tlb p{font-size:13px;color:var(--mid)}
.tl-item .tlb p b{color:var(--hi);font-weight:600}
.tl-item .tlb .t{font-size:11px;color:var(--faint);margin-top:1px}
.comment{display:flex;gap:10px;padding:11px 0;border-bottom:1px solid var(--line)}
.comment .cb p{font-size:13px;color:var(--mid)}
.comment .cb .ch{font-size:12px;margin-bottom:2px}
.comment .cb .ch b{color:var(--hi);font-weight:600}
.comment .cb .ch span{color:var(--faint);margin-left:6px;font-size:11px}
.composer{display:flex;gap:10px;align-items:flex-end;margin-top:6px}
.composer textarea{flex:1;resize:none;min-height:42px;max-height:120px;padding:10px 12px;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid var(--glass-bd);color:var(--mid);font-family:inherit;font-size:13px;outline:none}
.composer textarea:focus{border-color:rgba(107,255,17,.4)}
.attach{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid var(--line)}
.attach .aic{width:30px;height:30px;border-radius:8px;background:rgba(107,255,17,.1);color:var(--lime);display:flex;align-items:center;justify-content:center;font-size:13px}
.attach .anm{font-size:13px;color:var(--mid);font-weight:500}
.attach .asz{font-size:11px;color:var(--faint)}

/* progress stepper inside approval drawer */
.stepper{display:flex;align-items:center;gap:0}
.step{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.step:not(:last-child)::after{content:"";position:absolute;top:9px;left:50%;width:100%;height:2px;background:var(--line)}
.step.done:not(:last-child)::after{background:var(--grad)}
.step .sd{width:20px;height:20px;border-radius:50%;background:var(--s2);border:2px solid var(--line);z-index:1;display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent}
.step.done .sd{background:var(--grad);border-color:transparent;color:#06210f}
.step.cur .sd{border-color:var(--lime);background:rgba(107,255,17,.15)}
.step .sl{font-size:11px;color:var(--faint)}
.step.done .sl,.step.cur .sl{color:var(--mid)}

/* settings */
.set-row{display:flex;align-items:center;gap:14px;padding:15px 0;border-bottom:1px solid var(--line)}
.set-row .si{flex:1}
.set-row .si .st{font-size:14px;color:var(--hi);font-weight:600}
.set-row .si .ss{font-size:12px;color:var(--lo);margin-top:2px}
.toggle{width:42px;height:24px;border-radius:99px;background:rgba(255,255,255,.1);position:relative;transition:.25s;flex:0 0 42px}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.25s}
.toggle.on{background:var(--grad)}
.toggle.on::after{left:21px}

/* toast */
.toasts{position:fixed;bottom:22px;right:22px;z-index:60;display:flex;flex-direction:column;gap:10px}
.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;background:#10140f;
  border:1px solid var(--glass-bd);box-shadow:0 18px 44px rgba(0,0,0,.5);color:var(--mid);font-size:13px;
  transform:translateY(10px);opacity:0;transition:.3s;max-width:340px}
.toast.show{transform:none;opacity:1}
.toast .tic{width:24px;height:24px;border-radius:7px;background:rgba(107,255,17,.14);color:var(--lime);display:flex;align-items:center;justify-content:center;font-size:13px;flex:0 0 24px}
.toast b{color:var(--hi);font-weight:600}

/* small helpers */
.muted{color:var(--lo)}
.row{display:flex;align-items:center;gap:10px}
.wrap{display:flex;flex-wrap:wrap;gap:8px}
.mt8{margin-top:8px}.mt4{margin-top:4px}
.hide{display:none!important}

/* responsive */
@media (max-width:1080px){
  .metrics{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .pipe{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  :root{--side:0px}
  .side{position:fixed;left:0;top:0;width:250px;z-index:70;transform:translateX(-100%);transition:transform .3s var(--ease)}
  .side.open{transform:none}
  .ws{grid-template-columns:1fr}
  .menu-btn{display:flex!important}
  .trow{grid-template-columns:1.4fr 1fr;gap:8px}
  .trow .hide-sm{display:none}
  .doc-row{grid-template-columns:1.6fr auto}
  .doc-row .hide-sm{display:none}
  .team-grid,.pipe{grid-template-columns:1fr}
  .tb-search{display:none}
}
.menu-btn{display:none;width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.04);border:1px solid var(--glass-bd);align-items:center;justify-content:center;color:var(--mid)}

/* ===================================================================
   Overview refinement — operational density
   =================================================================== */
.btn:active{transform:translateY(1px) scale(.99)}

/* Create dropdown (primary topbar action) */
.create-wrap{position:relative}
#createBtn{padding:10px 16px}
.create-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:30;min-width:212px;padding:6px;
  background:#0d100e;border:1px solid var(--glass-bd);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.55);
  display:flex;flex-direction:column;gap:2px;opacity:0;transform:translateY(-6px) scale(.98);
  pointer-events:none;transition:.18s var(--ease)}
.create-menu.show{opacity:1;transform:none;pointer-events:auto}
.create-menu button{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;
  font-size:13.5px;font-weight:500;color:var(--mid);text-align:left;transition:.15s}
.create-menu button .ic{width:18px;text-align:center;color:var(--lime)}
.create-menu button:hover{background:rgba(255,255,255,.06);color:var(--hi)}
.create-menu .cm-sep{height:1px;background:var(--line);margin:4px 2px}
.create-menu .cm-hint{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);
  font-weight:700;padding:8px 12px 4px}

/* metric secondary stats */
.metric .msub{display:flex;flex-direction:column;gap:3px;margin-top:2px}
.metric .msub span{font-size:12px;color:var(--lo);display:flex;align-items:center;gap:7px}
.metric .msub span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--faint);flex:0 0 5px}
.metric .msub span.hot::before{background:#ff8db1}
.metric .msub span.warn::before{background:#f0b56a}
.metric .msub span.ok::before{background:var(--lime)}
.metric .mfoot{margin-top:auto;padding-top:4px}

/* quick actions */
.qa{display:flex;gap:10px;flex-wrap:wrap}
.qa button{display:flex;align-items:center;gap:8px;padding:11px 16px;border-radius:12px;font-size:13px;font-weight:600;
  color:var(--mid);background:rgba(255,255,255,.035);border:1px solid var(--glass-bd);transition:.2s}
.qa button .ic{color:var(--lime);font-size:14px}
.qa button:hover{background:rgba(255,255,255,.08);color:var(--hi);transform:translateY(-2px)}
.qa button:active{transform:translateY(0)}

/* feed = hero (65) / approvals (35) */
.grid-feed{display:grid;grid-template-columns:1.86fr 1fr;gap:22px;align-items:start}

/* feed item — OBJECT NAME is the loudest element */
.feed-item{align-items:center;gap:13px;padding:14px 8px}
.feed-item:hover{background:rgba(255,255,255,.035);box-shadow:inset 0 0 0 1px rgba(107,255,17,.12),0 10px 30px rgba(0,0,0,.28);padding-left:14px}
.feed-item .fobj{font-size:15px;font-weight:600;color:var(--hi);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-item .fsub{font-size:12px;color:var(--lo);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-item .fsub b{color:var(--mid);font-weight:600}
.feed-item .famt{color:var(--lime);font-weight:600}
.panel.feedpanel .panel-b{padding-bottom:8px}

/* approval queue — featured card */
.appro-q{display:flex;flex-direction:column;gap:14px}
.acard.featured{padding:16px;border-radius:16px;background:linear-gradient(150deg,rgba(7,141,53,.16),rgba(255,255,255,.035));
  border:1px solid rgba(107,255,17,.18);cursor:default}
.acard.featured:hover{transform:none;box-shadow:none}
.acard.featured .af-top{display:flex;align-items:center;gap:10px}
.acard.featured .af-eyebrow{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--lime);font-weight:700}
.acard.featured .af-title{font-size:18px;font-weight:600;color:var(--hi);margin-top:8px}
.acard.featured .af-amt{font-size:24px;font-weight:200;color:var(--hi);letter-spacing:-.02em;margin-top:2px}
.acard.featured .af-by{font-size:12.5px;color:var(--lo);margin-top:8px;display:flex;align-items:center;gap:8px}
.acard.featured .af-act{display:grid;grid-template-columns:1fr 1fr 1fr;gap:7px;margin-top:14px}
.acard.featured .af-act .btn{padding:9px 6px;font-size:12px}
.aq-row{display:flex;align-items:center;gap:11px;padding:12px 8px;border-radius:11px;cursor:pointer;transition:.2s}
.aq-row:hover{background:rgba(255,255,255,.04)}
.aq-row .body{min-width:0;flex:1}
.aq-row .body .aqt{font-size:13.5px;font-weight:600;color:var(--hi);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aq-row .body .aqm{font-size:11.5px;color:var(--faint);margin-top:1px}
.aq-resolved{opacity:.55}

/* analytics = supporting strip (reduced dominance) */
.an-head{display:flex;align-items:baseline;gap:12px}
.an-head h2{font-size:14px;font-weight:600;color:var(--mid)}
.an-head .sub{font-size:12px;color:var(--faint)}
.chart.mini{padding:15px 16px}
.chart.mini h3{font-size:13px}
.chart.mini .csub{font-size:11px;margin-bottom:12px}
.chart.mini .bars{height:104px}
.chart.mini .big{font-size:26px}
.chart.mini .hbars{gap:10px}
.chart.mini .hbar .hl{width:84px;font-size:11.5px}
.delta-up{color:var(--lime);font-size:12px;font-weight:600}

@media (max-width:1080px){ .grid-feed{grid-template-columns:1fr} }

/* ===================================================================
   Live / auto-updating feel — sparklines, count ticks, live feed
   =================================================================== */
.metric .mlabel .live{margin-left:auto;color:var(--lime);font-size:8px;line-height:1;animation:livePulse 1.6s infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.25}}
.mrow{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-top:2px}
.spark{width:88px;height:34px;flex:0 0 88px}
.spark polyline{fill:none;stroke:var(--lime);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 0 4px rgba(107,255,17,.4));vector-effect:non-scaling-stroke}
.spark .sdot{fill:var(--lime);animation:livePulse 1.5s infinite}
.metric .msub2{font-size:12px;color:var(--lo);margin-top:auto;padding-top:6px}
.metric .msub2 b{font-weight:700}
.metric .msub2 b.ok{color:var(--lime)} .metric .msub2 b.warn{color:#f0b56a} .metric .msub2 b.hot{color:#ff8db1}

/* count tick animation */
.num-up{animation:numUp .55s var(--ease)}
@keyframes numUp{0%{transform:translateY(7px);opacity:0;color:var(--lime)}55%{color:var(--lime)}100%{transform:none;opacity:1}}

/* new feed item slides/fades in (live) */
.feed-item.just-in{animation:feedIn .6s var(--ease)}
@keyframes feedIn{0%{opacity:0;transform:translateY(-10px);box-shadow:inset 0 0 0 1px rgba(107,255,17,.3)}
  60%{box-shadow:inset 0 0 0 1px rgba(107,255,17,.18)}100%{opacity:1;transform:none}}

/* live badge */
.live-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--lime);font-weight:600}
.live-badge .ld{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 8px var(--lime);animation:livePulse 1.4s infinite}

/* bars / hbars animate smoothly when values change live */
.bars .bar{transition:height .7s var(--ease)}
.bars .bv{transition:color .3s}
.bars .bv.up{color:var(--lime)}
.hbar .hfill{transition:width .8s var(--ease)}
.hbar .hv.up{color:var(--lime)}
#apprTime{transition:color .3s}

/* ===================================================================
   Flow coherence + full functionality
   =================================================================== */
/* flow chip — every object shows the Flow it belongs to */
.flow-chip{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:600;
  background:rgba(107,255,17,.09);color:var(--lime);border:1px solid rgba(107,255,17,.16);white-space:nowrap;vertical-align:middle}
.flow-chip::before{content:"⤳";font-size:11px;opacity:.85}
.flow-chip.sm{font-size:10px;padding:1px 7px}
.feed-item .fobj .flow-chip{margin-left:8px;font-weight:600}
.flowprog .hl{width:130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* search results dropdown */
.search-wrap{position:relative;margin-left:auto}
.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:30;max-height:60vh;overflow-y:auto;
  background:#0d100e;border:1px solid var(--glass-bd);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.55);
  padding:6px;display:none}
.search-results.show{display:block}
.sr-group{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);font-weight:700;padding:8px 10px 4px}
.sr-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;cursor:pointer;transition:.15s}
.sr-item:hover{background:rgba(255,255,255,.06)}
.sr-item .srt{font-size:13px;color:var(--hi);font-weight:500}
.sr-item .srm{font-size:11px;color:var(--faint);margin-left:auto}
.sr-empty{padding:16px 12px;text-align:center;color:var(--faint);font-size:13px}

/* centered modal (create flow / exit / update detail) */
.modal-host{position:fixed;inset:0;z-index:55;display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;pointer-events:none;transition:opacity .25s ease}
.modal-host.show{opacity:1;pointer-events:auto}
.modal{width:min(460px,94vw);background:#0c0f0d;border:1px solid var(--glass-bd);border-radius:20px;
  box-shadow:0 40px 110px rgba(0,0,0,.6);transform:translateY(12px) scale(.985);transition:transform .28s var(--ease);overflow:hidden}
.modal-host.show .modal{transform:none}
.modal-h{padding:22px 24px 6px}
.modal-h .dh-eyebrow{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--lime);font-weight:700}
.modal-h h2{font-size:19px;font-weight:600;color:var(--hi);margin-top:5px}
.modal-h p{font-size:13px;color:var(--lo);margin-top:8px;line-height:1.5}
.modal-b{padding:16px 24px;display:flex;flex-direction:column;gap:14px}
.modal-f{padding:14px 24px 22px;display:flex;gap:10px}
.modal-f .btn{flex:1}

/* section views */
.sec-summary{display:flex;gap:10px;flex-wrap:wrap}
.sumchip{display:flex;flex-direction:column;gap:2px;padding:10px 16px;border-radius:12px;background:rgba(255,255,255,.035);border:1px solid var(--line)}
.sumchip .sn{font-size:20px;font-weight:200;color:var(--hi);line-height:1}
.sumchip .sl{font-size:11px;color:var(--faint)}
.back-link{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--lo);font-weight:600;cursor:pointer;transition:.15s}
.back-link:hover{color:var(--lime)}
.section-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.mini-list{display:flex;flex-direction:column}
.mini-row{display:flex;align-items:center;gap:10px;padding:11px 4px;border-bottom:1px solid var(--line)}
.mini-row:last-child{border-bottom:none}
.mini-row .mt{font-size:13px;color:var(--hi);font-weight:500}
.mini-row .mm{font-size:11.5px;color:var(--faint)}
.mini-row .spacer{margin-left:auto}

/* notifications / profile drawer reuse .drawer; small unread dot */
.nrow{display:flex;align-items:flex-start;gap:11px;padding:13px 6px;border-bottom:1px solid var(--line);cursor:pointer;border-radius:10px;transition:.15s}
.nrow:last-child{border-bottom:none}
.nrow:hover{background:rgba(255,255,255,.03)}
.nrow .ndotc{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 8px var(--lime);margin-top:5px;flex:0 0 8px}
.nrow.read .ndotc{background:var(--s3);box-shadow:none}
.nrow .nt{font-size:13.5px;color:var(--hi);font-weight:500}
.nrow .nm{font-size:11.5px;color:var(--faint);margin-top:2px}
.prof-stat{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.prof-stat .ps{padding:12px;border-radius:12px;background:rgba(255,255,255,.035);border:1px solid var(--line);text-align:center}
.prof-stat .ps .n{font-size:22px;font-weight:200;color:var(--hi)}
.prof-stat .ps .l{font-size:10.5px;color:var(--faint);margin-top:2px}

/* clickable profile / status pill in trow */
.side-user{cursor:pointer;transition:.2s}
.side-user:hover{background:rgba(255,255,255,.07)}
.st-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:99px;white-space:nowrap}
.tab-empty{padding:36px;text-align:center;color:var(--faint);font-size:13px}
