/* 99 App Audit — Styles */

/* ── DESIGN TOKENS ── */
:root{
  --bg:#000A11;--s1:#04111C;--s2:#071928;--s3:#0A2135;
  --bd:rgba(201,171,90,0.12);--bd2:rgba(255,255,255,0.06);
  --gold:#C9AB5A;--gold2:#DFC07A;--gold-dim:rgba(201,171,90,0.07);
  --green:#22C55E;--amber:#F59E0B;--red:#EF4444;--blue:#3B82F6;--purple:#A855F7;
  --text:#E2D5B8;--muted:rgba(226,213,184,0.42);
  --f:'Outfit',-apple-system,sans-serif;--ff:'Fira Code','SF Mono',monospace;
  --r:12px;--r-sm:8px;--r-lg:16px;
  --shadow:0 4px 24px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.04);
  --shadow-glow:0 0 0 1px rgba(201,171,90,0.2),0 8px 32px rgba(0,0,0,0.6);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --ease-inout:cubic-bezier(0.65,0,0.35,1);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{background:linear-gradient(170deg,#000A11 0%,#000D16 40%,#010F1A 100%);color:var(--text);font-family:var(--f);font-size:13px;line-height:1.55;min-height:100vh;overflow-x:hidden}

/* Atmospheric depth — app gradient palette: #000A11 → #012E39 → #034D36 */
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 160% 80% at 50% -15%,rgba(3,77,54,0.22) 0%,rgba(1,46,57,0.14) 30%,transparent 62%),
    radial-gradient(ellipse 80% 70% at 0% 100%,rgba(1,46,57,0.28) 0%,transparent 55%),
    radial-gradient(ellipse 60% 55% at 100% 90%,rgba(1,46,57,0.2) 0%,transparent 55%),
    radial-gradient(ellipse 120% 30% at 50% -3%,rgba(201,171,90,0.05) 0%,transparent 52%)}

/* Scrollbars */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(201,171,90,0.2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(201,171,90,0.4)}

/* ── TYPOGRAPHY ── */
h1{font-size:21px;font-weight:800;letter-spacing:-0.03em;
  background:linear-gradient(135deg,var(--gold2) 0%,var(--gold) 60%,rgba(201,171,90,0.65) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── HEADER ── */
.hdr{position:relative;padding:18px 32px 16px;display:flex;align-items:center;justify-content:space-between;gap:16px;z-index:10;
  background:linear-gradient(180deg,rgba(201,171,90,0.04) 0%,transparent 100%)}
.hdr::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(201,171,90,0.25) 30%,rgba(201,171,90,0.25) 70%,transparent 100%)}
.hdr-sub{color:var(--muted);font-size:11.5px;margin-top:3px;font-weight:400;letter-spacing:0.01em}
.hdr-meta{color:var(--muted);font-size:10.5px;text-align:right;line-height:2;font-family:var(--ff)}
.hdr-meta strong{color:var(--gold)}

/* ── TAB BAR ── */
.tabs{display:flex;gap:0;padding:0 32px;overflow-x:auto;position:sticky;top:0;z-index:50;
  background:rgba(0,10,17,0.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.05)}
.tabs::-webkit-scrollbar{height:0}
.tab{padding:12px 16px;cursor:pointer;font-weight:600;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--muted);border-bottom:2px solid transparent;
  transition:color 0.2s var(--ease-out),border-color 0.2s var(--ease-out);
  white-space:nowrap;flex-shrink:0;position:relative;background:transparent;
  display:flex;align-items:center;gap:6px}
.tab:hover{color:rgba(226,213,184,0.8)}
.tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab.active::after{content:'';position:absolute;bottom:-1px;left:20%;right:20%;height:2px;
  background:var(--gold);box-shadow:0 0 10px rgba(201,171,90,0.5);border-radius:1px 1px 0 0}
.tab svg{width:13px;height:13px;flex-shrink:0;opacity:0.6;transition:opacity 0.2s}
.tab.active svg,.tab:hover svg{opacity:1}

/* ── PANELS ── */
.panel{display:none;padding:28px 32px;position:relative;z-index:1}

@keyframes panel-enter{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.panel.active{display:block;animation:panel-enter 0.35s var(--ease-out) both}

/* ── STAT CARDS ── */
.stat-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:28px}

@keyframes stat-in{from{opacity:0;transform:translateY(14px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}

.stat{background:linear-gradient(145deg,var(--s1) 0%,rgba(4,14,22,0.92) 100%);
  border:1px solid var(--bd);border-radius:var(--r);padding:16px 18px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
  transition:transform 0.25s var(--ease-spring),box-shadow 0.25s var(--ease-out);
  animation:stat-in 0.4s var(--ease-out) both}
.stat::before{content:'';position:absolute;top:0;left:16px;right:16px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,171,90,0.25),transparent)}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-glow)}
.stat-n{font-size:28px;font-weight:800;line-height:1;letter-spacing:-0.04em}
.stat-l{font-size:10px;color:var(--muted);margin-top:6px;font-weight:700;letter-spacing:0.09em;text-transform:uppercase}

/* ── FILTERS ── */
.filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.fbtn{padding:4px 13px;border-radius:20px;border:1px solid var(--bd2);background:transparent;color:var(--muted);
  font-size:10px;font-weight:700;cursor:pointer;transition:all 0.15s var(--ease-out);letter-spacing:0.06em;text-transform:uppercase}
.fbtn.active,.fbtn:hover{background:rgba(201,171,90,0.1);color:var(--gold);border-color:rgba(201,171,90,0.3)}
.sbox{padding:7px 14px;background:var(--s1);border:1px solid var(--bd2);border-radius:var(--r-sm);
  color:var(--text);font-size:12px;width:220px;outline:none;font-family:var(--f);transition:border-color 0.15s}
.sbox:focus{border-color:rgba(201,171,90,0.4)}
.sbox::placeholder{color:var(--muted)}

/* ── TABLES ── */
table{width:100%;border-collapse:collapse;font-size:12px}
thead th{padding:9px 12px;text-align:left;font-weight:700;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--muted);border-bottom:1px solid var(--bd);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;
  position:sticky;top:44px;background:var(--bg);z-index:5;transition:color 0.15s}
thead th:hover{color:var(--text)}
tbody tr{border-bottom:1px solid rgba(255,255,255,0.03);transition:background 0.15s}
tbody tr:hover{background:rgba(201,171,90,0.03)}
tbody td{padding:8px 12px;vertical-align:middle}
.sname{font-weight:700;color:var(--text)}
.spath{font-size:10px;color:var(--muted);margin-top:1px;font-family:var(--ff)}
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:0.04em;white-space:nowrap}
.bc{background:rgba(34,197,94,0.1);color:#4ADE80;border:1px solid rgba(34,197,94,0.2)}
.bp{background:rgba(245,158,11,0.1);color:#FCD34D;border:1px solid rgba(245,158,11,0.2)}
.bx{background:rgba(239,68,68,0.1);color:#FCA5A5;border:1px solid rgba(239,68,68,0.2)}
.bs{background:rgba(59,130,246,0.1);color:#93C5FD;border:1px solid rgba(59,130,246,0.2)}
.m-p{color:var(--green)}.m-w{color:var(--amber)}.m-f{color:var(--red)}.m-n{color:var(--muted);font-size:10px}
.sec-row td{background:rgba(201,171,90,0.04);font-weight:800;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);padding:5px 12px}
.sbar{height:4px;border-radius:2px;background:rgba(255,255,255,0.07);margin-top:3px}
.sfill{height:100%;border-radius:2px}
.notes{max-width:220px;color:var(--muted);font-size:11px}

/* ── MERMAID DIAGRAMS ── */
.mwrap{background:linear-gradient(135deg,var(--s1) 0%,rgba(4,14,22,0.95) 100%);
  border:1px solid var(--bd);border-radius:var(--r-lg);padding:24px;overflow-x:auto;margin-bottom:32px;
  box-shadow:var(--shadow);position:relative}
.mwrap::before{content:'';position:absolute;top:0;left:24px;right:24px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,171,90,0.2),transparent)}
.mwrap svg{max-width:100%}
.ftitle{font-size:10.5px;font-weight:800;color:var(--gold);letter-spacing:0.12em;text-transform:uppercase;
  margin-bottom:14px;display:flex;align-items:center;gap:10px}
.ftitle::before{content:'';display:inline-block;width:3px;height:14px;
  background:linear-gradient(180deg,var(--gold2),rgba(201,171,90,0.3));border-radius:2px}

/* ── FEATURE MAP ── */
@keyframes fm-pop{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}
@keyframes fm-flash{0%{background:rgba(34,197,94,0.15)}100%{background:transparent}}
@keyframes fm-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.75)}}

.fm-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px;align-items:flex-start}
.fm-filter-group{display:flex;gap:4px;flex-wrap:wrap;align-items:center}
.fm-filter-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;white-space:nowrap}
.fm-list{border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;background:var(--s1);box-shadow:var(--shadow)}
.fm-row{display:flex;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,0.035);
  transition:background 0.15s;animation:fm-pop 0.2s var(--ease-out) both;position:relative}
.fm-row:last-child{border-bottom:none}
.fm-row:hover{background:rgba(201,171,90,0.025)}
.fm-row:hover .fm-actions{opacity:1}
.fm-actions{opacity:0;transition:opacity 0.15s;display:flex;gap:4px;align-items:flex-start;padding:8px 10px 0 0;flex-shrink:0}
.fm-bar{width:3px;flex-shrink:0;align-self:stretch}
.fm-d0{background:var(--gold)}.fm-d1{background:rgba(201,171,90,0.3)}
.fm-d2{background:rgba(201,171,90,0.15)}.fm-d3{background:rgba(201,171,90,0.07)}
[data-s="onboarding"] .fm-d0{background:#A855F7}[data-s="home"] .fm-d0{background:var(--gold)}
[data-s="ham"] .fm-d0{background:#3B82F6}[data-s="transactions"] .fm-d0{background:#F59E0B}
[data-s="profile"] .fm-d0{background:#F43F5E}[data-s="cards"] .fm-d0{background:#06B6D4}
[data-s="chat"] .fm-d0{background:#22C55E}[data-s="charity"] .fm-d0{background:#14B8A6}
[data-s="cashback"] .fm-d0{background:#FBBF24}[data-s="invest"] .fm-d0{background:#6366F1}
.fm-chev{width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;
  color:var(--muted);font-size:11px;transition:transform 0.2s var(--ease-out),color 0.15s;flex-shrink:0;margin-top:9px}
.fm-chev:hover{color:var(--text)}.fm-chev.open{transform:rotate(90deg)}.fm-chev.leaf{pointer-events:none;opacity:0}
.fm-cell{flex:1;padding:8px 10px 8px 0;min-width:0}
.fm-title-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-bottom:2px}
.fm-title{font-weight:600;font-size:12px;color:var(--text);background:transparent;border:none;outline:none;
  cursor:text;min-width:30px;padding:0;transition:color 0.15s;font-family:var(--f)}
.fm-title:focus{color:var(--gold);background:rgba(201,171,90,0.06);border-radius:3px;padding:0 3px;margin:0 -3px}
[data-d="0"] .fm-title{font-weight:800;font-size:13px;color:var(--gold)}
.fm-type{font-size:9px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:1px 5px;border-radius:3px;flex-shrink:0}
.ft-page{background:rgba(201,171,90,0.12);color:var(--gold);border:1px solid rgba(201,171,90,0.22)}
.ft-screen{background:rgba(59,130,246,0.1);color:#93C5FD;border:1px solid rgba(59,130,246,0.18)}
.ft-modal{background:rgba(245,158,11,0.08);color:#FCD34D;border:1px solid rgba(245,158,11,0.16)}
.ft-subscreen{background:rgba(168,85,247,0.08);color:#C084FC;border:1px solid rgba(168,85,247,0.15)}
.ft-action{background:rgba(34,197,94,0.08);color:#4ADE80;border:1px solid rgba(34,197,94,0.14)}
.ft-button{background:rgba(255,255,255,0.05);color:var(--muted);border:1px solid rgba(255,255,255,0.09)}

/* ── STATUS DOTS ── */
.fm-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;cursor:pointer;
  transition:transform 0.15s var(--ease-spring),box-shadow 0.15s;margin-top:1px}
.fm-dot:hover{transform:scale(1.5)}
.fd-complete{background:#22C55E;box-shadow:0 0 6px rgba(34,197,94,0.4)}
.fd-partial{background:#F59E0B;animation:fm-pulse 2.2s infinite}
.fd-placeholder{background:rgba(255,255,255,0.2)}
.fd-cs{background:#3B82F6}
.fd-todo{background:rgba(239,68,68,0.4);animation:fm-pulse 3s infinite}

/* ── FM META ── */
.fm-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:2px}
.fm-comp{font-family:var(--ff);font-size:10px;color:rgba(201,171,90,0.4);background:transparent;border:none;outline:none;cursor:text;transition:color 0.15s}
.fm-comp:focus{color:var(--gold)}
.fm-to{font-size:10px;color:#93C5FD;background:transparent;border:none;outline:none;cursor:text;min-width:20px;transition:color 0.15s;font-family:var(--f)}
.fm-to:focus{color:var(--gold)}
.fm-to-wrap{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--muted)}
.fm-desc-txt{font-size:11px;color:rgba(226,213,184,0.4);line-height:1.5;margin-top:3px}
.fm-tier{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:0.05em;flex-shrink:0}
.ftier-all{background:rgba(34,197,94,0.08);color:#4ADE80;border:1px solid rgba(34,197,94,0.14)}
.ftier-gold{background:rgba(201,171,90,0.08);color:var(--gold);border:1px solid rgba(201,171,90,0.16)}
.ftier-prepaid{background:rgba(168,85,247,0.08);color:#C084FC;border:1px solid rgba(168,85,247,0.14)}
.fm-ssel{font-size:10px;font-weight:700;background:transparent;border:none;color:var(--muted);cursor:pointer;padding:0;outline:none;max-width:100px;font-family:var(--f)}
.fm-ssel:focus{color:var(--gold)}
.fm-notes-wrap{margin-top:6px;display:none}
.fm-notes-wrap.open{display:block}
.fm-ntxt{width:100%;background:rgba(255,255,255,0.03);border:1px solid var(--bd2);border-radius:6px;
  color:var(--text);font-size:11px;padding:7px 10px;resize:vertical;min-height:34px;outline:none;font-family:var(--f);line-height:1.5;transition:border-color 0.15s}
.fm-ntxt:focus{border-color:rgba(201,171,90,0.3)}
.fm-kids{overflow:hidden;transition:max-height 0.25s var(--ease-inout),opacity 0.2s}
.fm-kids.closed{max-height:0!important;opacity:0;pointer-events:none}
.fm-flash{animation:fm-flash 0.4s var(--ease-out)}
.fm-sep{height:1px;background:linear-gradient(90deg,rgba(201,171,90,0.2),transparent);margin:0}

/* ── LEGACY DOTS ── */
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-c{background:var(--green)}.dot-p{background:var(--amber)}.dot-x{background:var(--red)}.dot-s{background:var(--blue)}
.tier{font-size:9px;font-weight:800;letter-spacing:0.05em;padding:1px 6px;border-radius:10px}
.tier-all{background:rgba(34,197,94,0.08);color:#4ADE80;border:1px solid rgba(34,197,94,0.18)}
.tier-gold{background:rgba(201,171,90,0.08);color:var(--gold);border:1px solid rgba(201,171,90,0.18)}
.tier-prepaid{background:rgba(168,85,247,0.08);color:#C084FC;border:1px solid rgba(168,85,247,0.18)}

/* ── TEST SUITE ── */
.test-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.test-progress{height:6px;border-radius:3px;background:var(--bd2);margin:8px 0;overflow:hidden;display:flex}
.test-grp{margin-bottom:28px}
.test-grp-hdr{font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);
  padding:7px 0;margin-bottom:10px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:8px}
.test-grp-hdr::before{content:'';width:3px;height:13px;background:linear-gradient(180deg,var(--gold2),rgba(201,171,90,0.3));border-radius:2px;flex-shrink:0}
.tc{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;border-radius:var(--r-sm);
  border:1px solid var(--bd2);background:linear-gradient(135deg,var(--s1) 0%,rgba(4,14,22,0.8) 100%);
  margin-bottom:6px;transition:border-color 0.2s,transform 0.2s var(--ease-spring),box-shadow 0.2s}
.tc:hover{border-color:rgba(201,171,90,0.2);transform:translateX(2px)}
.tc-id{font-size:10px;font-family:var(--ff);color:var(--muted);flex-shrink:0;width:62px;padding-top:1px}
.tc-type{font-size:9px;font-weight:800;padding:2px 8px;border-radius:10px;flex-shrink:0;letter-spacing:0.04em}
.tc-happy{background:rgba(34,197,94,0.1);color:#4ADE80;border:1px solid rgba(34,197,94,0.2)}
.tc-edge{background:rgba(245,158,11,0.1);color:#FCD34D;border:1px solid rgba(245,158,11,0.2)}
.tc-error{background:rgba(239,68,68,0.1);color:#FCA5A5;border:1px solid rgba(239,68,68,0.2)}
.tc-a11y{background:rgba(59,130,246,0.1);color:#93C5FD;border:1px solid rgba(59,130,246,0.2)}
.tc-perf{background:rgba(168,85,247,0.1);color:#C084FC;border:1px solid rgba(168,85,247,0.2)}
.tc-body{flex:1}
.tc-name{font-weight:600;font-size:12px}
.tc-desc{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.5}
.tc-sel{padding:4px 10px;background:var(--s2);border:1px solid var(--bd2);border-radius:6px;color:var(--text);
  font-size:11px;font-weight:700;cursor:pointer;outline:none;flex-shrink:0;font-family:var(--f);transition:border-color 0.15s}
.tc-pass{border-color:var(--green)!important;background:rgba(34,197,94,0.07)!important}
.tc-fail{border-color:var(--red)!important;background:rgba(239,68,68,0.07)!important}
.tc-skip{border-color:var(--amber)!important;background:rgba(245,158,11,0.06)!important}

/* ── ROADMAP ── */
.rm-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.rm-col-hdr{font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;padding:10px 14px;
  border-radius:var(--r-sm);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.rm-p0 .rm-col-hdr{background:rgba(239,68,68,0.1);color:#FCA5A5;border:1px solid rgba(239,68,68,0.18)}
.rm-p1 .rm-col-hdr{background:rgba(245,158,11,0.1);color:#FCD34D;border:1px solid rgba(245,158,11,0.18)}
.rm-p2 .rm-col-hdr{background:rgba(59,130,246,0.1);color:#93C5FD;border:1px solid rgba(59,130,246,0.18)}
.rm-p3 .rm-col-hdr{background:rgba(34,197,94,0.1);color:#4ADE80;border:1px solid rgba(34,197,94,0.18)}
.rm-card{background:linear-gradient(145deg,var(--s1) 0%,rgba(4,12,20,0.95) 100%);
  border:1px solid var(--bd2);border-radius:var(--r);padding:14px 16px;margin-bottom:10px;cursor:default;
  transition:transform 0.25s var(--ease-spring),box-shadow 0.2s,border-color 0.2s;position:relative;overflow:hidden}
.rm-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.rm-p0 .rm-card::before{background:linear-gradient(90deg,rgba(239,68,68,0.8),transparent)}
.rm-p1 .rm-card::before{background:linear-gradient(90deg,rgba(245,158,11,0.8),transparent)}
.rm-p2 .rm-card::before{background:linear-gradient(90deg,rgba(59,130,246,0.8),transparent)}
.rm-p3 .rm-card::before{background:linear-gradient(90deg,rgba(34,197,94,0.8),transparent)}
.rm-card:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 8px 28px rgba(0,0,0,0.5),0 0 0 1px rgba(201,171,90,0.1);border-color:rgba(201,171,90,0.2)}
.rm-card-title{font-weight:700;font-size:12px;margin-bottom:6px;line-height:1.4}
.rm-card-meta{font-size:10px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;font-family:var(--ff)}
.rm-tag{padding:1px 7px;border-radius:10px;font-weight:700;letter-spacing:0.04em}
.rm-xs{background:rgba(34,197,94,0.08);color:#4ADE80;border:1px solid rgba(34,197,94,0.18)}
.rm-sm{background:rgba(59,130,246,0.08);color:#93C5FD;border:1px solid rgba(59,130,246,0.18)}
.rm-md{background:rgba(245,158,11,0.08);color:#FCD34D;border:1px solid rgba(245,158,11,0.18)}
.rm-lg{background:rgba(239,68,68,0.08);color:#FCA5A5;border:1px solid rgba(239,68,68,0.18)}
.rm-status{width:8px;height:8px;border-radius:50%;margin-left:auto;flex-shrink:0}
.rm-done{background:var(--green);box-shadow:0 0 4px rgba(34,197,94,0.4)}
.rm-wip{background:var(--amber);box-shadow:0 0 4px rgba(245,158,11,0.4)}
.rm-todo{background:rgba(255,255,255,0.15)}
.rm-card-desc{font-size:11px;color:var(--muted);line-height:1.55}
.rm-file{font-family:var(--ff);font-size:10px;color:var(--muted);margin-top:5px}

/* ── LEGEND ── */
.leg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.leg-card{background:linear-gradient(145deg,var(--s1) 0%,rgba(4,14,22,0.9) 100%);border:1px solid var(--bd);border-radius:var(--r);padding:18px;box-shadow:var(--shadow)}
.leg-card h3{font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--bd)}
.leg-item{display:flex;align-items:center;gap:10px;padding:5px 0;font-size:12px}
code{font-family:var(--ff);font-size:10px;background:rgba(201,171,90,0.08);padding:2px 6px;border-radius:4px;color:var(--gold);border:1px solid rgba(201,171,90,0.15)}

/* ── TASKS ── */
.task-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.tk{background:linear-gradient(145deg,var(--s1) 0%,rgba(4,14,22,0.9) 100%);border:1px solid var(--bd2);
  border-radius:var(--r);padding:16px 18px;margin-bottom:10px;
  transition:border-color 0.2s,transform 0.2s var(--ease-spring),box-shadow 0.2s}
.tk:hover{border-color:rgba(201,171,90,0.2);transform:translateX(3px);box-shadow:-3px 0 0 rgba(201,171,90,0.18)}
.tk-hdr{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}
.tk-id{font-size:10px;font-family:var(--ff);color:var(--muted);flex-shrink:0;padding-top:3px;width:62px}
.tk-title{font-weight:700;font-size:13px;flex:1;line-height:1.4}
.tk-desc{font-size:11px;color:var(--muted);margin:4px 0 12px;line-height:1.6}
.tk-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tk-file{font-family:var(--ff);font-size:10px;color:var(--muted);margin-top:5px}
.tk-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase}
.src-gap{background:rgba(59,130,246,0.1);color:#93C5FD;border:1px solid rgba(59,130,246,0.18)}
.src-bb{background:rgba(168,85,247,0.1);color:#C084FC;border:1px solid rgba(168,85,247,0.18)}
.src-kb{background:rgba(239,68,68,0.1);color:#FCA5A5;border:1px solid rgba(239,68,68,0.18)}
.src-ceo{background:rgba(201,171,90,0.1);color:var(--gold);border:1px solid rgba(201,171,90,0.18)}
.src-ns{background:rgba(34,197,94,0.1);color:#4ADE80;border:1px solid rgba(34,197,94,0.18)}
.pri-critical{background:rgba(239,68,68,0.12);color:#FCA5A5;border:1px solid rgba(239,68,68,0.28)}
.pri-high{background:rgba(245,158,11,0.1);color:#FCD34D;border:1px solid rgba(245,158,11,0.18)}
.pri-medium{background:rgba(59,130,246,0.08);color:#93C5FD;border:1px solid rgba(59,130,246,0.14)}
.pri-low{background:rgba(255,255,255,0.05);color:var(--muted);border:1px solid var(--bd2)}
.assign-sel,.status-sel{padding:4px 9px;background:var(--s2);border:1px solid var(--bd2);border-radius:6px;
  color:var(--text);font-size:11px;font-weight:700;cursor:pointer;outline:none;font-family:var(--f);transition:border-color 0.15s}
.assign-sel:focus,.status-sel:focus{border-color:rgba(201,171,90,0.4)}
.tk-notes{width:100%;background:var(--s2);border:1px solid var(--bd2);border-radius:var(--r-sm);color:var(--text);
  font-size:11px;padding:8px 12px;resize:none;outline:none;min-height:40px;margin-top:10px;font-family:var(--f);line-height:1.5;transition:border-color 0.15s}
.tk-notes:focus{border-color:rgba(201,171,90,0.35)}
.tk-notes::placeholder{color:var(--muted)}
.tc-name.tk-done{text-decoration:line-through;color:var(--muted);opacity:0.6}
.task-grp-hdr{font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);
  padding:7px 0;margin:22px 0 12px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}

/* ── ROADMAP NOTES ── */
.rm-notes{width:100%;background:var(--s2);border:1px solid var(--bd2);border-radius:6px;color:var(--text);font-size:10px;
  padding:6px 9px;resize:none;outline:none;min-height:32px;margin-top:7px;font-family:var(--f);line-height:1.5;transition:border-color 0.15s}
.rm-notes:focus{border-color:rgba(201,171,90,0.4)}
.rm-status-sel{background:transparent;border:none;cursor:pointer;width:14px;height:14px;border-radius:50%;padding:0;outline:none;margin-left:auto;flex-shrink:0}

/* ── FLOWCHART INTERACTIVE NODES ── */
.flow-clickable{cursor:pointer!important}
.flow-clickable rect,.flow-clickable polygon,.flow-clickable .label-container{transition:filter 0.2s var(--ease-out)}
.flow-clickable:hover rect,.flow-clickable:hover polygon,.flow-clickable:hover .label-container{filter:brightness(1.5) drop-shadow(0 0 10px rgba(201,171,90,0.5))!important}

/* ── FLOW OVERLAY ── */
#flow-overlay{
  display:none;position:fixed;inset:0;z-index:199;
  background:rgba(0,0,0,0);
  transition:background 0.35s var(--ease-out);
}
#flow-overlay.fp-vis{background:rgba(0,0,0,0.4);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}

/* ── FLOW DETAIL PANEL ── */
#flow-panel{
  position:fixed;right:0;top:0;width:390px;height:100vh;
  display:flex;flex-direction:column;
  background:#040F18;
  border-left:1px solid rgba(255,255,255,0.06);
  transform:translateX(100%);
  transition:transform 0.38s var(--ease-out);
  overflow:hidden;z-index:200;
  box-shadow:-24px 0 72px rgba(0,0,0,0.8),-1px 0 0 rgba(201,171,90,0.05);
}
#flow-panel.open{transform:translateX(0)}

/* Colored top accent */
#fp-accent{height:3px;width:100%;flex-shrink:0;transition:background 0.3s var(--ease-out)}

/* Panel header */
.fp-header{
  flex-shrink:0;padding:16px 18px 14px;
  border-bottom:1px solid rgba(255,255,255,0.06);
  background:#040F18;
}
.fp-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.fp-header-left{min-width:0;flex:1}

/* Section tag chip */
.fp-section-tag{
  display:inline-flex;align-items:center;
  font-size:9px;font-weight:800;letter-spacing:0.09em;text-transform:uppercase;
  padding:2px 9px;border-radius:20px;margin-bottom:7px;
  transition:all 0.25s var(--ease-out);
}

/* Title */
.fp-title{font-size:17px;font-weight:800;color:var(--text);letter-spacing:-0.025em;line-height:1.3;margin-bottom:8px;word-break:break-word}

/* Pills row */
.fp-pills{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.fp-pill{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:800;padding:3px 9px;border-radius:20px;letter-spacing:0.04em}
.fp-status-pill{cursor:pointer;transition:transform 0.15s var(--ease-spring),box-shadow 0.15s}
.fp-status-pill:hover{transform:scale(1.07)}

/* Back button */
.fp-back{
  display:none;width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  align-items:center;justify-content:center;
  cursor:pointer;transition:all 0.2s var(--ease-spring);color:var(--muted);
  margin-right:6px;
}
.fp-back:hover{background:rgba(201,171,90,0.12);border-color:rgba(201,171,90,0.3);color:var(--gold);transform:scale(1.1) translateX(-1px)}
.fp-back svg{width:12px;height:12px}

/* Close button */
.fp-close{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all 0.2s var(--ease-spring);color:var(--muted);
}
.fp-close:hover{background:rgba(239,68,68,0.14);border-color:rgba(239,68,68,0.3);color:var(--red);transform:scale(1.12) rotate(90deg)}
.fp-close svg{width:11px;height:11px}

/* Panel body scroll */
.fp-body{flex:1;overflow-y:auto;overflow-x:hidden}

/* Animated body inner */
@keyframes fp-body-in{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
.fp-body-inner{animation:fp-body-in 0.3s var(--ease-out) both;padding:16px 18px 28px}

/* Section dividers */
.fp-sec{
  font-size:9.5px;font-weight:800;color:var(--muted);text-transform:uppercase;
  letter-spacing:0.1em;margin:20px 0 9px;display:flex;align-items:center;gap:8px;
}
.fp-sec::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.05)}
.fp-sec:first-child{margin-top:0}

/* Overview card */
.fp-overview{
  border-radius:10px;padding:12px 14px;
  transition:all 0.25s var(--ease-out);
}
.fp-overview-desc{font-size:11.5px;color:rgba(226,213,184,0.72);line-height:1.65}
.fp-leads{display:flex;align-items:center;gap:7px;margin-top:9px;padding-top:8px;border-top:1px solid rgba(255,255,255,0.05)}
.fp-leads-target{font-size:10.5px;color:#93C5FD;font-weight:600}
.fp-leads-label{font-size:10.5px;color:var(--muted)}

/* Progress bar */
.fp-progress-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.fp-progress-pct{font-size:14px;font-weight:800;letter-spacing:-0.02em}
.fp-progress-sub{font-size:10px;color:var(--muted)}
.fp-progress-track{height:6px;background:rgba(255,255,255,0.07);border-radius:3px;overflow:hidden}
.fp-progress-fill{height:100%;border-radius:3px;transition:width 0.7s var(--ease-out)}

/* Children list */
.fp-children{border:1px solid rgba(255,255,255,0.06);border-radius:10px;overflow:hidden;background:rgba(4,11,18,0.7)}
@keyframes fp-child-in{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}
.fp-child-row{
  display:flex;align-items:center;gap:10px;padding:9px 12px;
  border-bottom:1px solid rgba(255,255,255,0.04);
  cursor:pointer;position:relative;overflow:hidden;
  transition:background 0.15s;
  animation:fp-child-in 0.22s var(--ease-out) both;
}
.fp-child-row:last-child{border-bottom:none}
.fp-child-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--row-color,var(--gold));
  transition:width 0.18s var(--ease-out);
}
.fp-child-row:hover{background:rgba(201,171,90,0.04)}
.fp-child-row:hover::before{width:2px}
.fp-child-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.fp-child-title{font-size:11.5px;font-weight:500;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.fp-child-arrow{flex-shrink:0;color:rgba(226,213,184,0.2);transition:transform 0.15s var(--ease-spring),color 0.15s}
.fp-child-row:hover .fp-child-arrow{transform:translateX(3px);color:var(--gold)}

/* Color swatches */
.fp-swatches{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}
.fp-swatch-item{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer}
.fp-swatch-circle{
  width:28px;height:28px;border-radius:50%;border:2.5px solid transparent;
  transition:transform 0.2s var(--ease-spring),border-color 0.15s,box-shadow 0.2s;
}
.fp-swatch-circle:hover{transform:scale(1.25)}
.fp-swatch-circle.fc-active{border-color:rgba(255,255,255,0.75)!important}
.fp-swatch-label{font-size:9px;color:var(--muted);letter-spacing:0.02em;white-space:nowrap}
.fp-swatch-auto{font-size:10px;color:var(--muted);background:transparent;border:1px solid rgba(255,255,255,0.1);border-radius:6px;padding:4px 10px;cursor:pointer;transition:all 0.15s var(--ease-out);font-family:var(--f);align-self:flex-end;margin-bottom:2px}
.fp-swatch-auto:hover{border-color:rgba(255,255,255,0.2);color:var(--text)}

/* Notes textarea */
.fp-notes{
  width:100%;box-sizing:border-box;
  background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);
  border-radius:9px;color:var(--text);font-size:11.5px;padding:10px 12px;
  resize:none;min-height:66px;outline:none;font-family:var(--f);line-height:1.65;
  transition:border-color 0.2s,background 0.2s;
}
.fp-notes:focus{border-color:rgba(201,171,90,0.35);background:rgba(201,171,90,0.025)}
.fp-notes::placeholder{color:rgba(226,213,184,0.25)}

/* Screenshot zone */
.fp-img-zone{
  min-height:96px;border:1.5px dashed rgba(201,171,90,0.2);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(201,171,90,0.02);overflow:hidden;margin-bottom:8px;
  cursor:pointer;transition:border-color 0.2s,background 0.2s;
}
.fp-img-zone:hover{border-color:rgba(201,171,90,0.4);background:rgba(201,171,90,0.05)}
.fp-img-zone img{width:100%;display:block}
.fp-img-placeholder{text-align:center;padding:18px;pointer-events:none}
.fp-img-placeholder-icon{margin:0 auto 8px;width:34px;height:34px;background:rgba(201,171,90,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center}
.fp-img-placeholder-text{font-size:11px;color:var(--muted);font-weight:500}
.fp-img-placeholder-hint{font-size:10px;color:rgba(226,213,184,0.28);margin-top:3px}
.fp-img-btns{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px}

/* Small icon buttons (Upload / Paste / Remove) */
.fp-icon-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:7px;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  color:var(--muted);font-size:11px;cursor:pointer;
  transition:all 0.15s var(--ease-out);font-family:var(--f);
}
.fp-icon-btn:hover{background:rgba(255,255,255,0.09);color:var(--text);border-color:rgba(201,171,90,0.2)}
.fp-icon-btn.danger{color:var(--red);border-color:rgba(239,68,68,0.2);background:rgba(239,68,68,0.04)}
.fp-icon-btn.danger:hover{background:rgba(239,68,68,0.12);border-color:rgba(239,68,68,0.35)}
.fp-icon-btn svg{width:12px;height:12px;flex-shrink:0}

/* Primary action (Jump to Feature Map) */
.fp-action-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:11px;border-radius:10px;
  background:rgba(201,171,90,0.08);border:1px solid rgba(201,171,90,0.22);
  color:var(--gold);font-size:12px;font-weight:700;
  cursor:pointer;transition:all 0.22s var(--ease-out);font-family:var(--f);letter-spacing:0.04em;
  margin-top:4px;
}
.fp-action-btn:hover{background:rgba(201,171,90,0.14);transform:translateY(-1px);box-shadow:0 6px 20px rgba(201,171,90,0.15)}
.fp-action-btn svg{width:13px;height:13px;flex-shrink:0}

/* ── Keep fp-btn class for other uses (rm edit btn etc) ── */
.fp-btn{padding:5px 12px;border-radius:6px;background:rgba(255,255,255,0.05);border:1px solid var(--bd2);
  color:var(--muted);font-size:11px;cursor:pointer;transition:all 0.15s var(--ease-out);font-family:var(--f)}
.fp-btn:hover{background:rgba(255,255,255,0.09);color:var(--text);border-color:rgba(201,171,90,0.2)}

/* ── EDITABLE METRIC CELLS ── */
td[data-mkey]{transition:background 0.15s}
td[data-mkey]:not([data-mkey$="_score"]):hover{background:rgba(201,171,90,0.06)!important;cursor:pointer}
.notes-edit{font-size:11px;max-width:220px;color:var(--muted);outline:none;background:transparent;
  width:100%;resize:none;border:none;font-family:var(--f);line-height:1.5;padding:0;min-height:16px}
.notes-edit:focus{color:var(--text)}

/* ── ROLE BADGE ── */
.role-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;
  font-size:10px;font-weight:800;cursor:pointer;border:1px solid;
  transition:all 0.2s var(--ease-out);letter-spacing:0.06em;-webkit-user-select:none;user-select:none;text-transform:uppercase}
.role-badge:hover{transform:scale(1.05)}
.role-admin{background:rgba(201,171,90,0.1);color:var(--gold);border-color:rgba(201,171,90,0.28)}
.role-editor{background:rgba(59,130,246,0.08);color:#93C5FD;border-color:rgba(59,130,246,0.28)}
.role-viewer{background:rgba(255,255,255,0.04);color:var(--muted);border-color:rgba(255,255,255,0.1)}

/* ── CRUD MODAL ── */
#crud-modal{display:none;position:fixed;inset:0;z-index:300;background:rgba(0,0,0,0.7);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);align-items:center;justify-content:center}
#crud-modal.open{display:flex}

@keyframes modal-in{from{opacity:0;transform:scale(0.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}

#crud-box{background:linear-gradient(145deg,#071928 0%,#04111C 100%);border:1px solid rgba(201,171,90,0.2);
  border-radius:18px;padding:26px;width:460px;max-width:calc(100vw - 32px);max-height:82vh;overflow-y:auto;
  box-shadow:0 32px 80px rgba(0,0,0,0.7),inset 0 0 0 1px rgba(201,171,90,0.04);
  animation:modal-in 0.3s var(--ease-spring) both}
.crud-title{font-weight:800;font-size:16px;color:var(--text);margin-bottom:20px;letter-spacing:-0.02em}
.crud-row{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.crud-label{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:0.07em}
.crud-input,.crud-select,.crud-ta{background:rgba(255,255,255,0.04);border:1px solid var(--bd2);border-radius:var(--r-sm);
  color:var(--text);font-size:12px;padding:8px 12px;outline:none;width:100%;font-family:var(--f);transition:border-color 0.15s,background 0.15s}
.crud-ta{resize:vertical;min-height:64px}
.crud-input:focus,.crud-select:focus,.crud-ta:focus{border-color:rgba(201,171,90,0.4);background:rgba(201,171,90,0.02)}
.crud-select{background:rgba(4,25,40,0.8);cursor:pointer}
.crud-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:18px;padding-top:16px;border-top:1px solid var(--bd2)}
.crud-btn{padding:8px 18px;border-radius:var(--r-sm);font-size:12px;font-weight:700;cursor:pointer;transition:all 0.2s var(--ease-out);font-family:var(--f);letter-spacing:0.04em}
.crud-primary{background:var(--gold);color:#000A11;border:none}
.crud-primary:hover{background:var(--gold2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(201,171,90,0.3)}
.crud-cancel{background:transparent;color:var(--muted);border:1px solid var(--bd2)}
.crud-cancel:hover{background:rgba(255,255,255,0.05);color:var(--text);border-color:rgba(255,255,255,0.1)}

/* ── DELETE BUTTONS ── */
.del-btn{padding:2px 7px;border-radius:4px;background:transparent;border:1px solid transparent;
  color:transparent;font-size:10px;cursor:pointer;transition:all 0.15s var(--ease-out);flex-shrink:0;line-height:1.4;font-family:var(--f)}
.fm-row:hover .del-btn,.tc:hover .del-btn,.rm-card:hover .del-btn{color:var(--red);border-color:rgba(239,68,68,0.3);background:rgba(239,68,68,0.07)}
.del-btn:hover{color:#fff!important;background:rgba(239,68,68,0.35)!important;transform:scale(1.1)}

/* ── ADD ITEM BUTTONS ── */
.add-row-btn{display:flex;align-items:center;gap:7px;width:100%;padding:8px 14px;background:transparent;
  border:1px dashed rgba(201,171,90,0.15);border-radius:var(--r-sm);color:var(--muted);font-size:11px;
  cursor:pointer;transition:all 0.2s var(--ease-out);margin-top:8px;font-family:var(--f)}
.add-row-btn:hover{border-color:rgba(201,171,90,0.35);color:var(--gold);background:rgba(201,171,90,0.04);transform:translateX(2px)}

/* ── FLOWCHART COLOR SWATCHES ── */
.fc-swatch{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform 0.2s var(--ease-spring),border-color 0.15s;flex-shrink:0}
.fc-swatch:hover{transform:scale(1.3)}
.fc-swatch.fc-active{border-color:rgba(255,255,255,0.8)!important}

/* ── ROLE-BASED ACCESS ── */
[data-role="viewer"] [contenteditable]{pointer-events:none!important;opacity:0.7}
[data-role="viewer"] .del-btn,[data-role="viewer"] .add-row-btn,[data-role="viewer"] .fm-actions button{display:none!important}
[data-role="viewer"] td[data-mkey]:not([data-mkey$="_score"]){pointer-events:none!important}
[data-role="editor"] .del-btn{display:none!important}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .rm-cols{grid-template-columns:1fr 1fr}
  .leg-grid{grid-template-columns:1fr 1fr}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .hdr{padding:14px 18px}
  .tabs{padding:0 18px}
  .panel{padding:20px 18px}
}

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.001s!important;transition-duration:0.001s!important}
}
