
:root {
  --navy:    #0f2557;
  --navy2:   #1a3a7c;
  --blue:    #2563eb;
  --blue2:   #1d4ed8;
  --slate:   #334155;
  --g50:     #f8fafc;
  --g100:    #f1f5f9;
  --g200:    #e2e8f0;
  --g300:    #cbd5e1;
  --g400:    #94a3b8;
  --g500:    #64748b;
  --g600:    #475569;
  --white:   #ffffff;
  --green:   #059669;
  --greenl:  #d1fae5;
  --yellow:  #d97706;
  --yellowl: #fef3c7;
  --red:     #dc2626;
  --redl:    #fee2e2;
  --orange:  #ea580c;
  --orangel: #ffedd5;
  --purple:  #7c3aed;
  --purplel: #ede9fe;
  --r:       8px;
  --r2:      12px;
  --shadow:  0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  --shadow2: 0 4px 16px rgba(0,0,0,.1);
  --sidebar: 232px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;background:var(--g100);color:var(--slate);font-size:14px;line-height:1.5;min-height:100vh}
button{font-family:inherit;cursor:pointer;border:none;outline:none}
input,select,textarea{font-family:inherit;font-size:14px}
a{color:var(--blue);text-decoration:none}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--g100)}
::-webkit-scrollbar-thumb{background:var(--g300);border-radius:10px}

/* ── Admin Drawer ── */
.adr-item{display:flex;align-items:center;gap:10px;padding:10px 16px;color:rgba(255,255,255,.7);font-size:.84rem;font-weight:500;cursor:pointer;transition:.15s;border-left:3px solid transparent}
.adr-item:hover{background:rgba(255,255,255,.07);color:#fff;border-left-color:#3b82f6}
.adr-item.active{background:rgba(37,99,235,.25);color:#fff;border-left-color:#3b82f6}
.adr-item span{font-size:1rem;width:20px;text-align:center}

/* ══ UI POLISH ══════════════════════════════════════════════ */

/* Ticket button in item actions */
.btn-ticket{background:#eff6ff;color:#2563eb;border:1.5px solid #bfdbfe;font-size:.75rem;padding:6px 12px;border-radius:7px;font-weight:700;cursor:pointer;transition:.15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.btn-ticket:hover{background:#dbeafe;border-color:#93c5fd}

/* Section subnav items in sidebar */
.sb-subnav{background:#f8fafc;border-left:3px solid var(--blue);margin:0 0 2px 0;overflow:hidden}
.sb-subitem{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:.78rem;font-weight:500;color:var(--g500);cursor:pointer;transition:.12s}
.sb-subitem:hover{background:var(--g100);color:var(--slate)}
.sb-subitem.active{background:#eff6ff;color:var(--blue);font-weight:600}
.sb-subitem span{font-size:.82rem;width:16px;text-align:center;flex-shrink:0}

/* Progress bar in subnav */
.sb-subitem .sb-sub-pct{margin-left:auto;font-size:.62rem;font-weight:700;color:var(--g300)}
.sb-subitem.active .sb-sub-pct{color:var(--blue)}

/* Better page title */
.page-title{font-size:1.2rem;font-weight:800;color:var(--navy);letter-spacing:-.01em}
.page-sub{font-size:.8rem;color:var(--g400);margin-top:2px}

/* Smooth checklist item animation */
.cl-item{animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:.6;transform:translateY(2px)}to{opacity:1;transform:none}}

/* Better focus rings */
select:focus,input:focus,textarea:focus{outline:none}

/* Responsive: on smaller screens collapse sidebar subnav text */
@media(max-width:1100px){
  .cl-nav-item-count{display:none}
  :root{--sidebar:210px}
}

/* Auth Screen ── */
#authScreen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f2557 0%,#1a3a7c 50%,#0f2557 100%)}
.auth-card{background:var(--white);border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.auth-logo-icon{width:48px;height:48px;background:var(--navy);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px}
.auth-logo-text{font-size:1.2rem;font-weight:700;color:var(--navy)}
.auth-logo-sub{font-size:.78rem;color:var(--g400);margin-top:2px}
.auth-tabs{display:flex;background:var(--g100);border-radius:10px;padding:4px;margin-bottom:24px}
.auth-tab{flex:1;padding:9px;text-align:center;border-radius:7px;font-weight:600;font-size:.85rem;color:var(--g500);cursor:pointer;transition:.2s}
.auth-tab.active{background:var(--white);color:var(--navy);box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-size:.75rem;font-weight:600;color:var(--g500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:10px 14px;border:1.5px solid var(--g200);border-radius:var(--r);font-size:.9rem;color:var(--slate);background:var(--white);transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.btn-primary{background:var(--blue);color:#fff;padding:12px 20px;border-radius:var(--r);font-weight:600;font-size:.9rem;width:100%;transition:.2s}
.btn-primary:hover{background:var(--blue2)}
.auth-msg{padding:10px 14px;border-radius:var(--r);font-size:.84rem;margin-top:12px;display:none}
.auth-msg.err{background:var(--redl);color:var(--red)}
.auth-msg.ok{background:var(--greenl);color:var(--green)}
.auth-msg.info{background:var(--yellowl);color:var(--yellow)}
.auth-link{text-align:center;margin-top:16px;font-size:.82rem;color:var(--g400)}
.auth-link span{color:var(--blue);cursor:pointer;font-weight:500}

/* ── App Layout ── */
#app{display:none;height:100vh;overflow:hidden;flex-direction:column}
.topbar{height:52px;background:var(--navy);display:flex;align-items:center;padding:0 16px;gap:12px;flex-shrink:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.06)}
.topbar-logo{font-size:.95rem;font-weight:700;color:var(--white);display:flex;align-items:center;gap:8px}
.topbar-logo span{color:#60a5fa}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.user-chip{display:flex;align-items:center;gap:8px;cursor:pointer;padding:5px 10px;border-radius:8px;transition:.2s}
.user-chip:hover{background:rgba(255,255,255,.1)}
.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff;flex-shrink:0}
.user-name{font-size:.82rem;color:rgba(255,255,255,.9);font-weight:500}
.topbar-btn{background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);padding:6px 14px;border-radius:7px;font-size:.8rem;font-weight:600;transition:.2s}
.topbar-btn:hover{background:rgba(255,255,255,.2)}

/* ── Announcement banner ── */
#announcements{display:none;background:linear-gradient(90deg,#7c3aed,#5b21b6);padding:0}
.ann-item{display:flex;align-items:center;gap:10px;padding:9px 20px;border-bottom:1px solid rgba(255,255,255,.1)}
.ann-item:last-child{border-bottom:none}
.ann-badge{background:rgba(255,255,255,.2);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap}
.ann-title{color:#fff;font-weight:600;font-size:.82rem}
.ann-body{color:rgba(255,255,255,.8);font-size:.78rem;margin-left:6px}

/* ── Pending banner ── */
#pendingBanner{display:none;background:#d97706;padding:8px 20px;color:#fff;font-size:.82rem;font-weight:600;align-items:center;gap:10px;cursor:pointer}
#pendingBanner:hover{background:#b45309}

/* ── Main layout ── */
.layout{display:flex;flex:1;overflow:hidden}
.sidebar{width:var(--sidebar);background:var(--white);border-right:1px solid var(--g200);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;overflow-x:hidden}
.sb-section{padding:12px 10px 6px}
.sb-label{font-size:.67rem;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.6px;padding:0 8px;margin-bottom:4px}
.sb-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r);cursor:pointer;color:var(--g500);font-size:.84rem;font-weight:500;transition:.15s;user-select:none}
.sb-item:hover{background:var(--g100);color:var(--slate)}
.sb-item.active{background:var(--navy);color:var(--white)}
.sb-item .icon{font-size:1rem;width:18px;text-align:center;flex-shrink:0}
.sb-badge{background:var(--red);color:#fff;font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:20px;margin-left:auto}
.sb-badge.yellow{background:var(--yellow)}
.sb-divider{height:1px;background:var(--g200);margin:8px 10px}
/* ── Sidebar module nav items ── */
.sb-mod-item{padding:6px 10px;cursor:default;border-radius:7px;transition:.12s;margin-bottom:1px;border:1px solid transparent}
.sb-mod-item:hover{background:var(--g50)}
.sb-mod-item.active{background:#eff6ff;border-color:#bfdbfe}
.sb-mod-item.active span{color:var(--blue)!important}
.sb-mod-item.pdf-sel{background:#f0fdf4}
.sb-mod-item.pdf-sel input[type=checkbox]{accent-color:var(--green)}

/* ── Project cards ── */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.proj-card{background:var(--white);border:1.5px solid var(--g200);border-radius:10px;padding:16px;cursor:pointer;transition:.15s;display:flex;flex-direction:column;gap:12px}
.proj-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(37,99,235,.1);transform:translateY(-1px)}
.proj-card-header{display:flex;align-items:flex-start;gap:12px}
.proj-card-name{font-weight:700;font-size:.95rem;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.proj-card-client{font-size:.78rem;color:var(--g400);margin-top:2px}
.proj-card-status{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}
.proj-card-tickets{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap}
.proj-card-progress{}
.proj-card-actions{display:flex;align-items:center;justify-content:space-between;padding-top:4px;border-top:1px solid var(--g100)}
/* ── Sidebar subnav ── */
.sb-proj-item{transition:.15s}
.sb-proj-item.active-proj{background:var(--navy)!important;color:#fff!important}
.sb-proj-item.active-proj span{color:rgba(255,255,255,.9)!important}
.sb-subnav{background:var(--g50);border-left:3px solid var(--blue);margin:0 0 2px 0;overflow:hidden}
.sb-subitem{display:flex;align-items:center;gap:8px;padding:7px 12px;font-size:.82rem;font-weight:500;color:var(--g500);cursor:pointer;transition:.15s}
.sb-subitem:hover{background:var(--g200);color:var(--slate)}
.sb-subitem.active{background:var(--navy2);color:#fff}
.sb-subitem span{font-size:.85rem;width:16px;text-align:center;flex-shrink:0}

/* ── Main content ── */
.main{flex:1;overflow-y:auto;padding:20px 24px;scroll-behavior:smooth}
.page{display:none}
.page.active{display:block}
.page-header{margin-bottom:24px}
.page-title{font-size:1.25rem;font-weight:700;color:var(--navy)}
.page-sub{font-size:.82rem;color:var(--g400);margin-top:3px}

/* ── Cards & KPI ── */
.card{background:var(--white);border-radius:var(--r2);box-shadow:var(--shadow);border:1px solid var(--g200)}
.card-pad{padding:20px}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:24px}
.kpi{background:var(--white);border-radius:var(--r2);padding:18px;box-shadow:var(--shadow);border:1px solid var(--g200);border-left:4px solid var(--blue)}
.kpi.green{border-left-color:var(--green)}
.kpi.red{border-left-color:var(--red)}
.kpi.yellow{border-left-color:var(--yellow)}
.kpi.purple{border-left-color:var(--purple)}
.kpi-val{font-size:1.8rem;font-weight:700;color:var(--navy);line-height:1}
.kpi-label{font-size:.75rem;color:var(--g400);margin-top:6px;font-weight:500}
.kpi-sub{font-size:.7rem;color:var(--g400);margin-top:2px}
.progress-bar{background:var(--g200);border-radius:20px;height:6px;overflow:hidden}
.progress-fill{height:100%;border-radius:20px;background:var(--green);transition:.4s}
.progress-fill.yellow{background:var(--yellow)}
.progress-fill.red{background:var(--red)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* ── Section titles ── */
.sec-title{font-size:.8rem;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--g200)}

/* ── Tables ── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{background:var(--g50);font-size:.72rem;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.4px;padding:10px 14px;text-align:left;border-bottom:2px solid var(--g200)}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--g100);font-size:.84rem;vertical-align:middle}
.tbl tr:hover td{background:var(--g50)}
.tbl tr:last-child td{border-bottom:none}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;white-space:nowrap}
.badge.active,.badge.complete{background:var(--greenl);color:var(--green)}
.badge.pending,.badge.progress{background:var(--yellowl);color:var(--yellow)}
.badge.suspended,.badge.closed{background:var(--g100);color:var(--g500)}
.badge.notdone{background:var(--redl);color:var(--red)}
.badge.pending{background:#fff7ed;color:#c2410c}
.badge.third_party{background:#f5f3ff;color:#6d28d9}
.badge.na{background:var(--g100);color:var(--g400)}
.badge.open{background:var(--yellowl);color:var(--yellow)}
.badge.in_progress{background:var(--purplel);color:var(--purple)}
.badge.superadmin{background:var(--navy);color:#fff}
.badge.admin{background:var(--purplel);color:var(--purple)}
.badge.member{background:var(--g100);color:var(--g500)}
.badge.critical{background:var(--redl);color:var(--red)}
.badge.high{background:var(--orangel);color:var(--orange)}
.badge.normal{background:var(--g100);color:var(--g500)}
.badge.receiver{background:#dbeafe;color:#1d4ed8}
.badge.developer{background:var(--greenl);color:var(--green)}
.badge.tester{background:var(--purplel);color:var(--purple)}
.badge.manager{background:var(--yellowl);color:var(--yellow)}

/* ── Buttons ── */
.btn{padding:7px 14px;border-radius:var(--r);font-weight:600;font-size:.82rem;transition:.15s;white-space:nowrap;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.btn-blue{background:var(--blue);color:#fff}.btn-blue:hover{background:var(--blue2)}
.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{background:var(--navy2)}
.btn-ghost{background:var(--g100);color:var(--slate);border:1px solid var(--g200)}.btn-ghost:hover{background:var(--g200)}
.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#047857}
.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:#b91c1c}
.btn-orange{background:var(--orange);color:#fff}.btn-orange:hover{background:#c2410c}
.btn-yellow{background:var(--yellow);color:#fff}.btn-yellow:hover{background:#b45309}
.btn-sm{padding:5px 10px;font-size:.75rem}
.btn-xs{padding:3px 8px;font-size:.7rem}
.btn-icon{width:30px;height:30px;padding:0;justify-content:center;background:var(--g100);color:var(--g500);border:1px solid var(--g200)}.btn-icon:hover{background:var(--g200)}

/* ══ CHECKLIST ═══════════════════════════════════════════════ */

/* Toolbar */
.cl-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap;background:var(--white);border:1.5px solid var(--g200);border-radius:10px;padding:10px 14px}
.cl-search{padding:8px 12px;border:1.5px solid var(--g200);border-radius:var(--r);font-size:.85rem;flex:1;min-width:160px;background:var(--g50)}
.cl-search:focus{outline:none;border-color:var(--blue);background:var(--white)}

/* Two-panel layout */
.cl-layout{display:flex;gap:0;border:1.5px solid var(--g200);border-radius:12px;overflow:visible;background:var(--white);align-items:flex-start;box-shadow:0 2px 12px rgba(0,0,0,.04)}

/* Nav panel hidden — modules are in sidebar now */
.cl-nav-panel{display:none!important}

/* Content panel fills full width */
.cl-content-panel{background:var(--white);min-height:500px;flex:1;min-width:0;border-radius:12px;overflow:hidden}

/* Section blocks */
.cl-section-block{margin:0;border-bottom:1px solid var(--g200)}
.cl-section-block:last-child{border-bottom:none;border-radius:0 0 12px 12px;overflow:hidden}
.cl-sec-head{display:flex;align-items:center;gap:12px;padding:13px 18px;background:var(--white);cursor:pointer;user-select:none;position:sticky;top:0;z-index:2;border-bottom:1px solid var(--g100)}
.cl-sec-head:hover{background:#f8fafc}
.cl-sec-icon{font-size:1.1rem;width:24px;text-align:center;flex-shrink:0}
.cl-sec-info{flex:1;min-width:0}
.cl-sec-name{font-weight:700;font-size:.88rem;color:var(--navy)}
.cl-sec-meta{font-size:.68rem;color:var(--g400);margin-top:1px}
.cl-sec-progress{display:flex;align-items:center;gap:8px;flex-shrink:0}
.cl-sec-pct{font-size:.75rem;font-weight:700;color:var(--slate);min-width:34px;text-align:right}
.cl-sec-bar{width:90px;height:5px;background:var(--g200);border-radius:10px;overflow:hidden;flex-shrink:0}
.cl-sec-bar-fill{height:100%;border-radius:10px;transition:.5s}
.cl-sec-toggle{color:var(--g300);font-size:.65rem;transition:.2s;flex-shrink:0;width:16px;text-align:center}
.cl-sec-note{background:#fffbeb;border-bottom:1px solid #fde68a;padding:8px 18px;font-size:.74rem;color:#92400e;display:flex;gap:6px;align-items:flex-start}
.cl-items{background:var(--white)}

/* Individual items */
.cl-item{border-bottom:2px solid #f1f5f9;padding:20px 22px 18px 16px;transition:.15s;display:flex;align-items:flex-start;gap:10px}
.cl-item:hover{background:#fafbff}
.cl-item:last-child{border-bottom:none}
.cl-item.done{background:#f0fdf4}
.cl-item.done .cl-text{text-decoration:line-through;color:var(--g400)}
.cl-item.na-item{opacity:.55}
.cl-item-status-bar{width:5px;border-radius:4px;flex-shrink:0;align-self:stretch;min-height:30px;margin-top:1px;opacity:.9}
.cl-item-body{flex:1;min-width:0}

/* Category + type tags row */
.cl-cat{font-size:.65rem;font-weight:800;color:var(--blue);text-transform:uppercase;letter-spacing:.06em}

/* Item text */
.cl-text{font-size:1rem;color:var(--navy);line-height:1.7;font-weight:500;margin:4px 0 2px}

/* Flags */
.cl-flags{display:flex;gap:5px;flex-wrap:wrap}
.cl-flag{font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:20px;letter-spacing:.02em}
.cl-flag.exc{background:#dbeafe;color:#1e40af}
.cl-flag.mand{background:#fee2e2;color:#b91c1c}

/* Controls row — labels above each field */
.cl-controls{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap;margin-top:10px;padding-top:10px;border-top:1px solid #f1f5f9}
.cl-ctrl-group{display:flex;flex-direction:column;gap:3px}
.cl-ctrl-label{font-size:.64rem;font-weight:800;color:var(--g500);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}
.cl-select{padding:8px 12px;border:1.5px solid var(--g200);border-radius:8px;font-size:.88rem;color:var(--navy);background:var(--white);cursor:pointer;transition:.12s;height:40px;font-weight:500}
.cl-select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.cl-select:hover{border-color:var(--g300)}

/* Ticket action button */
.cl-item-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0;padding-top:2px}
/* ── New project wizard ── */
.np-step{display:flex;align-items:center;gap:8px}
.np-step-num{width:28px;height:28px;border-radius:50%;border:2px solid var(--g200);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--g400);transition:.2s;flex-shrink:0}
.np-step-label{font-size:.78rem;font-weight:600;color:var(--g400);transition:.2s}
.np-step.active .np-step-num{border-color:var(--blue);background:var(--blue);color:#fff}
.np-step.active .np-step-label{color:var(--navy)}
.np-module-tile{border:2px solid var(--g200);border-radius:8px;padding:12px;cursor:pointer;transition:.15s;background:var(--white);user-select:none}
.np-module-tile:hover{border-color:var(--blue);background:#eff6ff}
.np-module-tile.selected{border-color:var(--blue);background:#eff6ff}
.np-mod-name{font-size:.82rem;font-weight:700;color:var(--navy)}
.np-mod-exc{font-size:.63rem;font-weight:700;color:#1e40af;background:#dbeafe;padding:1px 6px;border-radius:20px;display:inline-block;margin-top:2px}
.np-mod-desc{font-size:.72rem;color:var(--g400);margin-top:6px;line-height:1.4}
.np-mod-count{font-size:.7rem;font-weight:600;color:var(--g500);margin-top:6px}
.np-mod-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--g200);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:transparent;transition:.15s;flex-shrink:0}
.np-module-tile.selected .np-mod-check{border-color:var(--blue);background:var(--blue);color:#fff}
/* ── Full-screen new project modal ── */
.np-topbar{display:flex;align-items:center;gap:20px;padding:14px 28px;background:var(--navy);color:#fff;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.1)}
.np-topbar-brand{font-size:.9rem;color:rgba(255,255,255,.7);white-space:nowrap}
.np-steps-bar{display:flex;align-items:center;gap:0;flex:1;justify-content:center;max-width:400px;margin:0 auto}
.np-step-line{flex:1;height:2px;background:rgba(255,255,255,.2);transition:.3s}
.np-step-line.done{background:#3b82f6}
.np-step .np-step-num{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:rgba(255,255,255,.5);transition:.2s}
.np-step .np-step-label{font-size:.78rem;font-weight:600;color:rgba(255,255,255,.4);transition:.2s}
.np-step.active .np-step-num{border-color:#3b82f6;background:#3b82f6;color:#fff}
.np-step.active .np-step-label{color:#fff}
.np-body{display:grid;grid-template-columns:360px 1fr;flex:1;min-height:0;overflow:hidden;height:100%}
.np-left-panel{padding:40px 36px;border-right:1px solid var(--g200);overflow-y:auto;background:var(--white);height:100%}
.np-right-panel{padding:36px 40px;background:#f8fafc;overflow-y:auto;height:100%}
.np-panel-heading{margin-bottom:28px}
.np-panel-icon{font-size:2rem;margin-bottom:10px}
.np-panel-heading h2{font-size:1.4rem;font-weight:800;color:var(--navy);margin:0 0 8px}
.np-panel-heading p{font-size:.875rem;color:var(--g400);margin:0;line-height:1.5}
.np-info-card{background:var(--white);border:1.5px solid var(--g200);border-radius:12px;padding:24px;margin-bottom:20px}
.np-info-card h3{font-size:1rem;font-weight:700;color:var(--navy);margin:0 0 8px}
.np-info-card p{font-size:.84rem;color:var(--g500);margin:0 0 12px;line-height:1.5}
.np-info-card ul{margin:0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:6px}
.np-info-card ul li{font-size:.82rem;color:var(--slate)}
.np-modules-preview{display:flex;flex-wrap:wrap;gap:6px}
.np-prev-tag{font-size:.75rem;background:var(--white);border:1px solid var(--g200);border-radius:20px;padding:4px 10px;color:var(--slate)}
.np-summary-box{background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:8px;padding:14px 16px;font-size:.82rem;color:#1e40af;line-height:1.6}
.np-modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding:4px;align-content:start}
/* ── Module Manager ── */
.mm-modal-body{flex:1;overflow-y:auto;padding:0 28px}
.mm-module-card{background:var(--white);border:1.5px solid var(--g200);border-radius:10px;margin-bottom:14px;overflow:hidden;transition:.15s}
.mm-module-card:hover{border-color:var(--blue);box-shadow:0 2px 12px rgba(37,99,235,.08)}
.mm-card-head{display:flex;align-items:center;gap:12px;padding:14px 18px;cursor:pointer;user-select:none}
.mm-card-icon{font-size:1.2rem;width:28px;text-align:center}
.mm-card-info{flex:1}
.mm-card-name{font-weight:700;font-size:.9rem;color:var(--navy)}
.mm-card-meta{font-size:.72rem;color:var(--g400);margin-top:2px}
.mm-card-actions{display:flex;gap:6px}
.mm-items-list{border-top:1px solid var(--g100);background:#f8fafc}
.mm-item-chip{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:.7rem;background:var(--g100);color:var(--g500);font-weight:500}
.mm-item-row{display:flex;align-items:center;gap:10px;padding:9px 18px;border-bottom:1px solid var(--g100);font-size:.82rem}
.mm-item-row:last-child{border-bottom:none}
.mm-item-cat{font-size:.68rem;font-weight:700;color:var(--blue);text-transform:uppercase;min-width:100px;flex-shrink:0}
.mm-item-text{flex:1;color:var(--slate)}
.mm-item-flags{display:flex;gap:4px;flex-shrink:0}
/* MM item editor rows */
.mm-edit-row{display:grid;grid-template-columns:140px 1fr auto auto;gap:8px;align-items:center;padding:8px 12px;border-bottom:1px solid var(--g100)}
.mm-edit-row:last-child{border-bottom:none}
.mm-edit-row input{padding:5px 8px;border:1.5px solid var(--g200);border-radius:6px;font-size:.78rem;color:var(--slate);width:100%}
.mm-edit-row input:focus{outline:none;border-color:var(--blue)}
.comment{display:flex;gap:10px;margin-bottom:12px}
.comment-bubble{background:var(--g100);border-radius:0 var(--r2) var(--r2);padding:10px 14px;flex:1}
.comment-author{font-weight:600;font-size:.78rem;color:var(--navy)}
.comment-time{font-size:.7rem;color:var(--g400);margin-left:6px}
.comment-text{font-size:.84rem;color:var(--slate);margin-top:4px}
.comment-input-row{display:flex;gap:8px}
.comment-input{flex:1;padding:8px 12px;border:1.5px solid var(--g200);border-radius:var(--r);font-size:.84rem;resize:none}
.comment-input:focus{outline:none;border-color:var(--blue)}

/* ── Modals ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:200;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(2px)}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:14px;padding:28px 28px 24px;max-width:520px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.2),0 0 0 1px rgba(0,0,0,.06);position:relative}
.modal-overlay.fullscreen-modal.open{padding:0;align-items:stretch}
.modal-overlay.fullscreen-modal.open .modal{width:100vw;height:100vh;max-width:100vw;max-height:100vh;border-radius:0;padding:0;display:flex;flex-direction:column;overflow:hidden;box-shadow:none}
.modal-overlay.fullscreen-modal.open .np-body{flex:1;min-height:0;overflow:hidden}
.modal-lg{max-width:700px}
.modal-title{font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:4px}
.modal-sub{font-size:.8rem;color:var(--g400);margin-bottom:20px}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--g200)}

/* ── Slide panel ── */
.panel{display:none;position:fixed;top:0;right:0;width:480px;max-width:100vw;height:100vh;background:var(--white);box-shadow:-4px 0 30px rgba(0,0,0,.15);z-index:150;overflow-y:auto;flex-direction:column}
.panel.open{display:flex}
.panel-head{background:var(--navy);padding:18px 20px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.panel-title{color:#fff;font-weight:700;font-size:.95rem;flex:1}
.panel-close{background:rgba(255,255,255,.15);border:none;color:#fff;width:30px;height:30px;border-radius:50%;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.panel-body{padding:20px;flex:1;overflow-y:auto}
.panel-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:149}
.panel-overlay.open{display:block}

/* ── Info cards within panels ── */
.info-block{background:var(--g50);border:1px solid var(--g200);border-radius:var(--r);padding:14px 16px;margin-bottom:14px}
.info-block-title{font-size:.72rem;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}

/* ── Logs ── */
.log-row{display:flex;align-items:flex-start;gap:10px;padding:10px 4px;border-bottom:1px solid var(--g100);font-size:.78rem}
.log-row:last-child{border-bottom:none}
.log-time{color:var(--g400);white-space:nowrap;font-family:'JetBrains Mono',monospace;flex-shrink:0;font-size:.67rem;padding-top:3px;min-width:136px}
.log-avatar{width:27px;height:27px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.68rem;flex-shrink:0;margin-top:1px}
.log-user{color:var(--blue);font-weight:700;flex-shrink:0;white-space:nowrap;padding-top:3px}
.log-action{color:var(--navy);font-weight:600}
.log-detail{color:var(--g500);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-top:3px}
.log-ip{color:var(--g300);font-size:.64rem;font-family:'JetBrains Mono',monospace;background:var(--g50);border:1px solid var(--g100);border-radius:4px;padding:1px 5px;flex-shrink:0;margin-top:4px}

/* ── Toast ── */
#toast{position:fixed;bottom:24px;right:24px;z-index:999;pointer-events:none}
.toast-item{background:var(--navy);color:#fff;padding:12px 18px;border-radius:10px;font-size:.84rem;font-weight:500;margin-top:8px;box-shadow:var(--shadow2);animation:toastIn .25s ease;max-width:320px}
.toast-item.err{background:var(--red)}
.toast-item.ok{background:var(--green)}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── Misc ── */
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.mt8{margin-top:8px}
.mt16{margin-top:16px}
.mt20{margin-top:20px}
.empty-state{text-align:center;padding:48px 20px;color:var(--g400)}
.empty-state .icon{font-size:2.5rem;margin-bottom:12px}
.empty-state p{font-size:.9rem}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.filter-input{padding:7px 12px;border:1.5px solid var(--g200);border-radius:var(--r);font-size:.82rem}
.filter-input:focus{outline:none;border-color:var(--blue)}
.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;background:var(--g100);color:var(--g500)}
.field-input{width:100%;padding:10px 14px;border:1.5px solid var(--g200);border-radius:var(--r);font-size:.9rem;color:var(--slate);background:var(--white);transition:.2s;font-family:inherit}
.field-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
textarea.field-input{resize:vertical}

/* ─── V3: NOTIFICATION BELL ───────────────────────────────── */
.notif-bell{position:relative;cursor:pointer;font-size:1.2rem;padding:4px 8px;border-radius:8px;transition:.15s;user-select:none}
.notif-bell:hover{background:rgba(255,255,255,.15)}
.notif-badge{position:absolute;top:-2px;right:-2px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none}
.notif-panel{position:fixed;top:54px;right:16px;width:360px;max-height:480px;background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.18);z-index:2000;overflow:hidden;display:flex;flex-direction:column}
.notif-panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1.5px solid var(--g100);font-weight:700;font-size:.9rem;color:var(--navy)}
#notifList{overflow-y:auto;flex:1}
.notif-item{display:flex;gap:10px;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--g100);transition:.12s;position:relative}
.notif-item:hover{background:var(--g50)}
.notif-item.unread{background:#eff6ff}
.notif-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px}
.notif-body{flex:1;min-width:0}
.notif-title{font-size:.83rem;font-weight:600;color:var(--navy);margin-bottom:2px}
.notif-msg{font-size:.77rem;color:var(--g400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-time{font-size:.72rem;color:var(--g300);margin-top:3px}
.notif-dot{width:8px;height:8px;background:#3b82f6;border-radius:50%;flex-shrink:0;margin-top:4px}
.notif-empty{padding:30px;text-align:center;color:var(--g400);font-size:.85rem}
.notif-overlay{position:fixed;inset:0;z-index:1999;background:transparent}

/* ─── V3: PIPELINE BOARD ───────────────────────────────────── */
.pipeline-stages{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;align-items:flex-start}
.pipeline-col{flex-shrink:0;width:220px}
.pipeline-col-head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--white);border:1.5px solid var(--g200);border-radius:8px 8px 0 0;font-weight:700;font-size:.82rem;color:var(--navy)}
.pipeline-count{background:var(--g100);border-radius:10px;padding:1px 8px;font-size:.75rem;color:var(--g500)}
.pipeline-cards{min-height:120px;background:var(--g50);border:1.5px solid var(--g200);border-top:none;border-radius:0 0 8px 8px;padding:8px;display:flex;flex-direction:column;gap:8px}
.pipeline-card{background:#fff;border:1.5px solid var(--g200);border-radius:8px;padding:10px 12px;cursor:pointer;transition:.15s;user-select:none}
.pipeline-card:hover{border-color:var(--blue);box-shadow:0 2px 8px rgba(37,99,235,.1);transform:translateY(-1px)}
.pipeline-card.pipeline-overdue{border-color:#fca5a5;background:#fff5f5}
.pipeline-card-name{font-weight:700;font-size:.83rem;color:var(--navy);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pipeline-card-client{font-size:.74rem;color:var(--g400);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pipeline-progress-bar{height:4px;background:var(--g100);border-radius:2px;margin-bottom:6px;overflow:hidden}
.pipeline-progress-bar div{height:100%;border-radius:2px;transition:.3s}
.pipeline-card-foot{display:flex;align-items:center;justify-content:space-between;font-size:.72rem;color:var(--g400);flex-wrap:wrap;gap:4px}
.pipeline-ticket-badge{background:#fef3c7;color:#92400e;border-radius:4px;padding:1px 5px;font-weight:600}
.pipeline-due{color:var(--g400)}
.pipeline-due.overdue-text{color:#dc2626;font-weight:700}
.pipeline-empty{color:var(--g300);font-size:.78rem;text-align:center;padding:16px 8px;font-style:italic}

/* ─── V3: BULK SELECT ──────────────────────────────────────── */
.bulk-checkbox{font-size:1.2rem;flex-shrink:0;cursor:pointer;padding:4px;color:var(--g400);align-self:center}
.cl-item.bulk-selected{background:#eff6ff!important;border-color:#93c5fd!important;outline:2px solid #3b82f6}
.cl-item[data-iid]{cursor:pointer}
.cl-item[data-iid]:hover{border-color:var(--blue)}

/* ─── V3: REPORTS ──────────────────────────────────────────── */
.report-tabs{display:flex;gap:8px;flex-wrap:wrap;border-bottom:2px solid var(--g100);padding-bottom:12px}
.report-tab{padding:7px 14px;border:1.5px solid var(--g200);border-radius:20px;background:#fff;font-size:.82rem;cursor:pointer;transition:.15s;color:var(--g500)}
.report-tab:hover,.report-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.rep-table{width:100%;border-collapse:collapse;font-size:.83rem}
.rep-table th{text-align:left;padding:9px 12px;background:var(--g50);border-bottom:2px solid var(--g200);font-weight:600;color:var(--navy);font-size:.78rem}
.rep-table td{padding:9px 12px;border-bottom:1px solid var(--g100);color:var(--slate)}
.rep-table tr:hover td{background:var(--g50)}
.mini-progress{display:inline-block;width:80px;height:6px;background:var(--g100);border-radius:3px;overflow:hidden;vertical-align:middle;margin-right:4px}
.mini-progress div{height:100%;background:var(--blue);border-radius:3px}
.badge-red{background:#fee2e2;color:#dc2626;border-radius:4px;padding:1px 6px;font-weight:700;font-size:.78rem}
.score-badge{border-radius:12px;padding:2px 10px;font-weight:700;font-size:.8rem}
.score-green{background:#dcfce7;color:#16a34a}
.score-amber{background:#fef3c7;color:#d97706}
.score-red{background:#fee2e2;color:#dc2626}
.stage-pill{background:var(--g100);color:var(--slate);border-radius:10px;padding:2px 8px;font-size:.75rem;text-transform:capitalize}
.stat-card{background:var(--white);border:1.5px solid var(--g200);border-radius:10px;padding:14px 18px;text-align:center}
.stat-card.ok{border-color:#86efac}
.stat-val{font-size:1.8rem;font-weight:800;color:var(--navy)}
.stat-label{font-size:.75rem;color:var(--g400);margin-top:4px}
.btn-link{background:none;border:none;color:var(--blue);cursor:pointer;font-size:.82rem;padding:0;text-decoration:underline}

/* ─── V3: SHARE LINK ROW ───────────────────────────────────── */
.share-link-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--g100);gap:12px}
.share-link-row:last-child{border-bottom:none}

/* ─── V3: AVATAR SM ────────────────────────────────────────── */
.avatar.sm{width:24px;height:24px;font-size:.7rem;min-width:24px}
.loading-text{padding:24px;text-align:center;color:var(--g400);font-size:.85rem}
.err-text{padding:16px;color:var(--red);font-size:.85rem}

