/* SEO.OS — Production CSS v2 (readability improvements) */
:root{
  --black:#070707;--white:#f0ede8;--green:#39ff14;
  --gd:rgba(57,255,20,0.13);--gb:rgba(57,255,20,0.28);--gt:rgba(57,255,20,0.06);
  --dark:#0f0f0f;--mid:#1a1a1a;--card:#161616;
  --muted:#b8b6ad;          /* was #8a8a86 — clearer */
  --muted-strong:#dad8d2;   /* new — for important metadata */
  --dim:#7a7873;            /* was #3a3a38 — readable */
  --border:rgba(255,255,255,0.10);
  --red:#ff4d4d;--amber:#ffb340;--blue:#9cc3ff;--purple:#c8a6ff;
  --head:"Bebas Neue",sans-serif;
  --body:"Heebo",sans-serif;
  --label:"Heebo",sans-serif; /* Hebrew labels — was mono */
  --mono:"DM Mono",monospace;  /* English/numbers only */
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--white);font-family:var(--body);font-weight:400;overflow-x:hidden;min-height:100vh;font-size:15px;line-height:1.55}
button,input,textarea,select{font-family:inherit;color:inherit}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--dark)}::-webkit-scrollbar-thumb{background:var(--dim)}::-webkit-scrollbar-thumb:hover{background:var(--muted)}
#cur{position:fixed;width:10px;height:10px;background:var(--green);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .22s,height .22s;mix-blend-mode:exclusion}
#cur.g{width:42px;height:42px}
@media(hover:none){#cur{display:none}}

.btn{font-family:var(--label);font-size:12.5px;letter-spacing:.04em;font-weight:500;padding:11px 22px;border:none;cursor:pointer;transition:opacity .2s,transform .2s,background .2s,color .2s,border-color .2s;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.btn-primary{background:var(--green);color:var(--black);font-weight:600}
.btn-primary:hover{opacity:.88;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--white);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--gb);color:var(--green);background:var(--gd)}
.btn-danger{background:transparent;color:var(--red);border:1px solid rgba(255,77,77,.35)}
.btn-danger:hover{background:rgba(255,77,77,.12);border-color:var(--red)}
.btn-sm{padding:8px 14px;font-size:11px}

.kn-tag{font-family:var(--label);font-size:11px;letter-spacing:.02em;font-weight:500;padding:4px 10px;border:1px solid;display:inline-block;border-radius:2px}
.cat-research{color:#9cc3ff;border-color:rgba(110,168,255,.4);background:rgba(110,168,255,.10)}
.cat-onpage{color:#5dff45;border-color:var(--gb);background:var(--gd)}
.cat-content{color:#ffc56b;border-color:rgba(255,179,64,.4);background:rgba(255,179,64,.10)}
.cat-tech{color:#d7b8ff;border-color:rgba(192,132,252,.4);background:rgba(192,132,252,.10)}
.cat-links{color:#fbbf45;border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.10)}
.cat-geo{color:#ff7878;border-color:rgba(255,77,77,.4);background:rgba(255,77,77,.10)}
.cat-report{color:#5cd6e8;border-color:rgba(6,182,212,.4);background:rgba(6,182,212,.10)}
.cat-strategy{color:#c189f9;border-color:rgba(168,85,247,.4);background:rgba(168,85,247,.10)}
.prio-high{color:#ff7878;border-color:rgba(255,77,77,.4);background:rgba(255,77,77,.10)}
.prio-medium{color:#ffc56b;border-color:rgba(255,179,64,.4);background:rgba(255,179,64,.10)}
.prio-low{color:var(--muted);border-color:var(--border);background:transparent}
.prio-urgent{color:var(--white);border-color:var(--red);background:var(--red);font-weight:600}

#viewLogin{display:flex;align-items:center;justify-content:center;padding:24px;min-height:100vh}
.login-bg{position:fixed;inset:0;background:radial-gradient(circle at 20% 50%,var(--gt) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(57,255,20,.04) 0%,transparent 50%);z-index:0;pointer-events:none}
.login-grid{position:fixed;inset:0;background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:60px 60px;z-index:0;pointer-events:none}
.login-card{position:relative;z-index:2;width:100%;max-width:460px;background:rgba(15,15,15,.88);backdrop-filter:blur(10px);border:1px solid var(--border);padding:48px 42px}
.login-brand{font-family:var(--head);font-size:46px;letter-spacing:.04em;line-height:1;margin-bottom:6px;direction:ltr;text-align:right}
.login-brand .accent{color:var(--green)}
.login-sub{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--muted);margin-bottom:36px;direction:ltr;text-align:right}
.login-title{font-family:var(--head);font-size:42px;letter-spacing:.02em;line-height:1;margin-bottom:24px}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--label);font-size:12.5px;font-weight:500;color:var(--muted-strong);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;background:var(--mid);border:1px solid var(--border);color:var(--white);font-family:var(--body);font-size:15px;padding:14px 16px;outline:none;transition:border-color .2s,background .2s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gb);background:var(--dark)}
.field input::placeholder{color:var(--dim)}
.code-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;direction:ltr}
.code-row input{text-align:center;font-family:var(--mono);font-size:20px;font-weight:600;padding:14px 0}
.login-row{display:flex;align-items:center;justify-content:space-between;margin:22px 0 20px;font-family:var(--label);font-size:13px;color:var(--muted)}
.login-row a{color:var(--green);font-weight:500}
.login-row label{display:flex;align-items:center;gap:8px;cursor:pointer}
.login-row input[type=checkbox]{accent-color:var(--green)}
.login-btn{width:100%;background:var(--green);color:var(--black);border:none;padding:16px;font-family:var(--label);font-size:14px;letter-spacing:.04em;cursor:pointer;transition:opacity .2s;font-weight:600}
.login-btn:hover{opacity:.9}
.login-foot{margin-top:32px;padding-top:22px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--dim)}
.login-foot .secure{display:flex;align-items:center;gap:7px;color:var(--green)}
.login-foot .secure::before{content:"";width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.login-err{background:rgba(255,77,77,.12);border:1px solid rgba(255,77,77,.4);color:#ff7878;padding:12px 16px;font-size:13.5px;margin-bottom:14px;display:none;font-weight:500}.login-err.on{display:block}

.app{display:grid;grid-template-columns:300px 1fr;min-height:100vh}
.side{background:var(--card);border-left:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden}
.side-brand{padding:22px 24px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.side-brand .lg{font-family:var(--head);font-size:26px;letter-spacing:.04em;line-height:1;direction:ltr;cursor:pointer}
.side-brand .lg .accent{color:var(--green)}
.role-pill{font-family:var(--label);font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--green);border:1px solid var(--gb);padding:5px 11px;background:var(--gd)}
.role-pill.client{color:var(--blue);border-color:rgba(110,168,255,.4);background:rgba(110,168,255,.10)}
.role-pill.employee{color:var(--amber);border-color:rgba(255,179,64,.4);background:rgba(255,179,64,.10)}
.side-search{padding:14px 20px;border-bottom:1px solid var(--border)}
.side-search input{width:100%;background:var(--mid);border:1px solid var(--border);color:var(--white);font-size:14px;padding:10px 14px;outline:none}
.side-search input:focus{border-color:var(--gb)}
.side-lab{font-family:var(--label);font-size:12px;font-weight:500;color:var(--muted);padding:18px 24px 8px;display:flex;justify-content:space-between;align-items:center}
.side-lab a{color:var(--green);cursor:pointer;font-size:12px;font-weight:500}
.side-lab a:hover{text-decoration:underline}
.cli-list{flex:1;overflow-y:auto}
.cli{padding:13px 24px;cursor:pointer;border-right:3px solid transparent;transition:background .2s,border-color .2s;display:flex;justify-content:space-between;align-items:center;gap:10px}
.cli:hover{background:rgba(57,255,20,.04)}
.cli.on{background:rgba(57,255,20,.08);border-right-color:var(--green)}
.cli-n{font-size:15px;font-weight:500;color:var(--white)}
.cli-sub{font-family:var(--label);font-size:12px;color:var(--muted);margin-top:3px;font-weight:400}
.cli-stat{font-family:var(--label);font-size:12px;font-weight:500;color:var(--green);display:flex;align-items:center;gap:6px;white-space:nowrap}
.cli-stat .dot{width:8px;height:8px;border-radius:50%;background:var(--green)}
.cli-stat.urg{color:var(--red);font-weight:600}
.cli-stat.urg .dot{background:var(--red)}
.cli-stat.warn{color:var(--amber)}
.cli-stat.warn .dot{background:var(--amber)}
.cli-stat.zero{color:var(--dim)}
.cli-stat.zero .dot{background:var(--dim)}

.side-nav{border-top:1px solid var(--border);padding:10px 0}
.snav{padding:13px 24px;display:flex;align-items:center;gap:11px;cursor:pointer;transition:background .2s,color .2s;font-size:14px;font-weight:500;color:var(--muted-strong)}
.snav:hover{background:rgba(57,255,20,.04);color:var(--white)}
.snav.on{background:rgba(57,255,20,.08);color:var(--green)}
.snav svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.7}

.side-foot{border-top:1px solid var(--border);padding:14px 20px;display:flex;align-items:center;gap:12px}
.av{width:34px;height:34px;background:var(--green);color:var(--black);font-family:var(--head);font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600}
.av.sm{width:24px;height:24px;font-size:12px}
.av.md{width:30px;height:30px;font-size:13px}
.av.blue{background:#9cc3ff;color:var(--black)}
.av.amber{background:#ffb340;color:var(--black)}
.av.purple{background:#c8a6ff;color:var(--black)}
.av.red{background:#ff4d4d;color:var(--white)}
.av.gray{background:var(--mid);color:var(--muted);border:1px solid var(--border)}
.side-foot .info{flex:1;min-width:0}
.side-foot .nm{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--white)}
.side-foot .rl{font-family:var(--label);font-size:11.5px;color:var(--muted);margin-top:2px}
.side-foot .logout{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);cursor:pointer;background:transparent;color:var(--white);transition:border-color .2s,background .2s,color .2s}
.side-foot .logout:hover{border-color:var(--red);color:var(--red);background:rgba(255,77,77,.08)}
.side-foot .logout svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.7}

.main{background:var(--black);display:flex;flex-direction:column;min-width:0}
.topbar{padding:18px 30px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:rgba(7,7,7,.94);backdrop-filter:blur(10px);position:sticky;top:0;z-index:50;gap:14px;flex-wrap:wrap}
.crumb-lab{font-family:var(--label);font-size:12px;font-weight:500;color:var(--muted)}
.crumb-name{font-family:var(--head);font-size:34px;letter-spacing:.02em;line-height:1;display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:4px}
.crumb-pkg{font-family:var(--label);font-size:12px;font-weight:600;letter-spacing:.02em;color:var(--green);border:1px solid var(--gb);background:var(--gd);padding:5px 12px}
.topbar-right{display:flex;align-items:center;gap:10px}
.icb{width:38px;height:38px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,background .2s;position:relative;background:transparent;color:var(--white)}
.icb:hover{border-color:var(--gb);background:var(--gd)}
.icb svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5}

.tabbar{display:flex;padding:0 30px;border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;gap:12px;background:var(--black);flex-wrap:wrap}
.tabs{display:flex;gap:0}
.tab{font-family:var(--label);font-size:14px;font-weight:500;letter-spacing:.01em;color:var(--muted-strong);padding:17px 22px;background:transparent;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.tab:hover{color:var(--white)}
.tab.on{color:var(--green);border-bottom-color:var(--green);font-weight:600}
.tab-count{margin-right:8px;font-size:12px;opacity:.85;font-family:var(--mono);font-weight:400}
.tabbar-act{display:flex;gap:8px;align-items:center;padding:10px 0}

.filters{padding:14px 30px;border-bottom:1px solid var(--border);display:flex;gap:10px;flex-wrap:wrap;align-items:center;background:var(--black)}
.fchip{display:inline-flex;align-items:center;gap:8px;font-family:var(--label);font-size:13px;font-weight:500;background:var(--mid);border:1px solid var(--border);padding:9px 16px;cursor:pointer;transition:border-color .2s,background .2s,color .2s}
.fchip:hover{border-color:var(--gb);background:var(--gd);color:var(--green)}
.fchip.on{border-color:var(--gb);background:var(--gd);color:var(--green)}
.fchip .lab{color:var(--muted)}
.fchip.on .lab{color:var(--green)}
.fchip select{background:transparent;border:none;color:inherit;font-family:var(--label);font-size:13px;font-weight:500;cursor:pointer;outline:none}
.fchip select option{background:var(--mid);color:var(--white)}

.content{flex:1;padding:24px 30px;overflow-x:auto}

.kanban{display:grid;grid-template-columns:repeat(4,minmax(290px,1fr));gap:16px;min-height:calc(100vh - 260px)}
.kn-col{background:var(--card);border:1px solid var(--border);padding:16px;display:flex;flex-direction:column;min-width:0}
.kn-col.drag-over{background:var(--gd);border-color:var(--gb)}
.kn-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:14px}
.kn-name{font-family:var(--head);font-size:20px;letter-spacing:.04em;display:flex;align-items:center;gap:10px}
.kn-name .dot{width:9px;height:9px;border-radius:50%}
.kn-name.todo .dot{background:var(--muted)}
.kn-name.prog .dot{background:var(--amber)}
.kn-name.review .dot{background:var(--blue)}
.kn-name.done .dot{background:var(--green)}
.kn-cnt{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--muted-strong);background:var(--mid);padding:4px 10px;border:1px solid var(--border)}
.kn-add{padding:12px;background:transparent;border:1px dashed var(--border);color:var(--muted);font-family:var(--label);font-size:12.5px;font-weight:500;cursor:pointer;text-align:center;margin-top:10px;transition:border-color .2s,color .2s,background .2s;width:100%}
.kn-add:hover{border-color:var(--gb);color:var(--green);background:var(--gd)}
.kn-card{background:var(--mid);border:1px solid var(--border);padding:15px;margin-bottom:10px;cursor:pointer;transition:border-color .2s,transform .15s,background .2s}
.kn-card:hover{border-color:var(--gb);transform:translateY(-1px);background:var(--dark)}
.kn-card.urgent{border-right:4px solid var(--red)}
.kn-card.soon{border-right:4px solid var(--amber)}
.kn-card.done-card{opacity:.65}
.kn-card .tags-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.kn-card-title{font-size:15px;font-weight:500;line-height:1.5;margin-bottom:12px;color:var(--white);word-break:break-word}
.kn-card-meta{display:flex;align-items:center;justify-content:space-between;font-family:var(--label);font-size:12px;font-weight:500;color:var(--muted-strong)}
.kn-card-meta .due{display:flex;align-items:center;gap:6px}
.kn-card-meta .due.urgent{color:var(--red);font-weight:600}
.kn-card-meta .due.soon{color:var(--amber);font-weight:600}
.kn-card-foot{display:flex;align-items:center;gap:12px;margin-top:11px;padding-top:11px;border-top:1px solid var(--border);font-family:var(--label);font-size:12px;font-weight:500;color:var(--muted-strong)}
.kn-card-foot .ic{display:flex;align-items:center;gap:5px}
.kn-card-foot .ic svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.7}

.tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--border)}
.tbl th{font-family:var(--label);font-size:12.5px;font-weight:600;letter-spacing:.01em;color:var(--muted-strong);text-align:right;padding:15px 18px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
.tbl td{padding:15px 18px;border-bottom:1px solid var(--border);font-size:14px;color:var(--white);cursor:pointer}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:rgba(57,255,20,.03)}
.tbl .tt{font-weight:500}
.st-pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--label);font-size:12px;font-weight:500;padding:5px 11px;border:1px solid}
.st-pill.todo{color:var(--muted-strong);border-color:var(--border);background:var(--mid)}
.st-pill.prog{color:var(--amber);border-color:rgba(255,179,64,.4);background:rgba(255,179,64,.08)}
.st-pill.review{color:var(--blue);border-color:rgba(110,168,255,.4);background:rgba(110,168,255,.08)}
.st-pill.done{color:var(--green);border-color:var(--gb);background:var(--gd)}
.due-c{font-family:var(--label);font-size:13px;font-weight:500}
.due-c.urgent{color:var(--red);font-weight:600}
.due-c.soon{color:var(--amber);font-weight:600}

.empty{padding:80px 24px;text-align:center;color:var(--muted)}
.empty h2{font-family:var(--head);font-size:42px;color:var(--white);margin-bottom:12px;letter-spacing:.02em}
.empty p{font-size:15px;line-height:1.7;max-width:380px;margin:0 auto 20px;color:var(--muted-strong)}

.drawer-back{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s ease}
.drawer-back.on{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;bottom:0;left:0;width:760px;max-width:100vw;background:var(--dark);border-left:1px solid var(--border);z-index:201;transform:translateX(-100%);transition:transform .4s cubic-bezier(.4,.2,.2,1);overflow-y:auto;display:flex;flex-direction:column}
.drawer.on{transform:translateX(0)}
.dr-head{padding:22px 30px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:18px;position:sticky;top:0;background:rgba(15,15,15,.97);backdrop-filter:blur(10px);z-index:2}
.dr-head-l{flex:1;min-width:0}
.dr-tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}
.dr-title{font-family:var(--head);font-size:38px;letter-spacing:.02em;line-height:1.06;margin-bottom:8px;word-break:break-word}
.dr-meta{font-family:var(--label);font-size:12.5px;color:var(--muted-strong)}
.dr-close{width:36px;height:36px;border:1px solid var(--border);background:transparent;color:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:border-color .2s,background .2s,color .2s;flex-shrink:0}
.dr-close:hover{border-color:var(--red);color:var(--red);background:rgba(255,77,77,.08)}
.dr-body{padding:28px 30px;flex:1}
.dr-section{margin-bottom:32px}
.dr-section h4{font-family:var(--label);font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--muted-strong);text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.dr-section h4::before{content:"";width:20px;height:1px;background:var(--muted-strong);opacity:.6}
.dr-section h4 .ct{margin-right:auto;color:var(--green);font-size:13px;font-weight:600}
.dr-props{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border)}
.dr-prop{background:var(--card);padding:15px 18px}
.dr-prop .lab{font-family:var(--label);font-size:11.5px;font-weight:600;letter-spacing:.02em;color:var(--muted);margin-bottom:7px;text-transform:uppercase}
.dr-prop .val{font-size:15px;font-weight:500;display:flex;align-items:center;gap:8px;color:var(--white)}
.dr-prop select{background:var(--mid);border:1px solid var(--border);color:var(--white);padding:8px 12px;font-size:14px;font-family:var(--body);font-weight:500;outline:none;cursor:pointer}
.dr-prop select:focus{border-color:var(--gb)}
.dr-desc{background:var(--card);border:1px solid var(--border);padding:20px 22px;font-size:15px;line-height:1.75;color:var(--muted-strong);min-height:80px;white-space:pre-wrap}
.dr-desc strong{color:var(--white);font-weight:500}

.fr{display:flex;align-items:center;gap:14px;padding:12px 16px;border:1px solid var(--border);background:var(--card);margin-bottom:7px;transition:border-color .2s}
.fr:hover{border-color:var(--gb)}
.fr-ic{width:36px;height:36px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--head);font-size:11px;color:var(--green);letter-spacing:.04em}
.fr-info{flex:1;min-width:0}
.fr-name{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--white)}
.fr-meta{font-family:var(--label);font-size:11.5px;color:var(--muted);margin-top:3px}
.fr-act{font-family:var(--label);font-size:12px;font-weight:600;letter-spacing:.02em;color:var(--green);cursor:pointer;padding:6px 10px;white-space:nowrap}
.fr-act:hover{text-decoration:underline}
.fr-del{color:var(--red);cursor:pointer;padding:6px 10px;font-family:var(--label);font-size:12px;font-weight:500}
.fr-del:hover{text-decoration:underline}
.upload-zone{padding:26px;border:1.5px dashed var(--border);text-align:center;cursor:pointer;transition:border-color .2s,background .2s;margin-top:7px}
.upload-zone:hover{border-color:var(--gb);background:var(--gd)}
.upload-zone .uz-icon{font-family:var(--head);font-size:34px;color:var(--muted);line-height:1;margin-bottom:10px}
.upload-zone:hover .uz-icon{color:var(--green)}
.uz-title{font-family:var(--label);font-size:13px;font-weight:500;color:var(--white);margin-bottom:6px}
.uz-sub{font-family:var(--label);font-size:11.5px;color:var(--muted)}

.cm{padding:16px 0;border-bottom:1px solid var(--border)}
.cm:last-child{border-bottom:none}
.cm-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.cm-name{font-size:14px;font-weight:500;color:var(--white)}
.cm-role{font-family:var(--label);font-size:11px;font-weight:600;color:var(--green);letter-spacing:.02em;padding:3px 8px;border:1px solid var(--gb);background:var(--gd)}
.cm-role.cl{color:var(--blue);border-color:rgba(110,168,255,.4);background:rgba(110,168,255,.10)}
.cm-role.emp{color:var(--amber);border-color:rgba(255,179,64,.4);background:rgba(255,179,64,.10)}
.cm-time{font-family:var(--label);font-size:11.5px;color:var(--muted);margin-right:auto}
.cm-body{font-size:14.5px;line-height:1.75;color:var(--muted-strong);padding-right:34px;white-space:pre-wrap}
.cm-input{display:flex;gap:10px;margin-top:16px}
.cm-input textarea{flex:1;background:var(--card);border:1px solid var(--border);color:var(--white);font-size:14px;padding:12px 15px;outline:none;resize:vertical;min-height:72px;font-family:var(--body);line-height:1.6}
.cm-input textarea:focus{border-color:var(--gb)}

.approve-bar{padding:20px 30px;border-top:1px solid var(--border);background:rgba(57,255,20,.05);display:flex;justify-content:space-between;align-items:center;gap:14px;position:sticky;bottom:0;flex-wrap:wrap}
.approve-bar .lbl{font-family:var(--label);font-size:13px;font-weight:600;color:var(--green)}
.approve-bar .acts{display:flex;gap:8px;flex-wrap:wrap}

.act{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.act:last-child{border-bottom:none}
.act-ic{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--head);font-size:12px;font-weight:600;color:var(--black);background:var(--green);line-height:1}
.act-l{font-size:13.5px;color:var(--muted-strong);line-height:1.55;flex:1}
.act-l strong{color:var(--white);font-weight:500}
.act-t{font-family:var(--label);font-size:11px;color:var(--muted);margin-top:4px}

.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(4px);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s ease;display:flex;align-items:center;justify-content:center;padding:24px}
.modal-back.on{opacity:1;pointer-events:auto}
.modal{background:var(--dark);border:1px solid var(--gb);width:100%;max-width:580px;max-height:90vh;overflow-y:auto;transform:translateY(20px);transition:transform .3s ease}
.modal-back.on .modal{transform:translateY(0)}
.modal-head{padding:24px 30px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-family:var(--head);font-size:32px;letter-spacing:.02em}
.modal-body{padding:26px 30px}
.modal-foot{padding:20px 30px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;background:var(--card)}
.fgroup{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fgroup.three{grid-template-columns:1fr 1fr 1fr}
.fgroup.full{grid-template-columns:1fr}

.adm-head{padding:24px 30px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.adm-head-l{font-family:var(--head);font-size:42px;letter-spacing:.02em;line-height:1;margin-top:4px}
.adm-content{padding:24px 30px}

.toast{position:fixed;bottom:24px;left:24px;background:var(--card);border:1px solid var(--gb);padding:16px 26px;font-family:var(--label);font-size:14px;font-weight:500;color:var(--green);z-index:400;transform:translateX(-200%);transition:transform .35s ease;display:flex;align-items:center;gap:12px}
.toast.on{transform:translateX(0)}
.toast.err{color:var(--red);border-color:rgba(255,77,77,.4)}
.toast::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 1.5s ease-in-out infinite}

/* === REFRESH BUTTON SPIN === */
.icb.spin svg{animation:spin 1s linear}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* ============================================================ */
/* === ICON SYSTEM — consistent SVG icons across platforms === */
/* ============================================================ */
.ic{display:inline-flex;align-items:center;justify-content:center;vertical-align:-2px;flex-shrink:0;line-height:0}
.ic svg{width:100%;height:100%;display:block;color:inherit}
.tl-kpi-lab .ic{margin-left:5px;color:currentColor;opacity:.85}
.tl-process-lab .ic{margin-left:6px}
.tl-activity-icon .ic{color:var(--green)}
.tl-sec-head h3 .ic{margin-left:4px}
.m-sheet-item .ic{color:var(--muted);width:18px;height:18px}

/* ============================================================ */
/* === CLIENT TIMELINE VIEW                                === */
/* ============================================================ */
.tl-page{padding:32px;max-width:1200px;margin:0 auto;animation:tlFade .35s ease}
@keyframes tlFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* HERO DASHBOARD — horizontal one-screen overview */
.tl-dash{margin-bottom:32px;display:flex;flex-direction:column;gap:18px}
.tl-hi{font-family:var(--head);font-size:38px;letter-spacing:.01em;line-height:1.05;margin-bottom:6px}
.tl-name{color:var(--green)}
.tl-sub{font-size:14.5px;color:var(--muted-strong);line-height:1.55;font-weight:400}

/* Top row: greeting + ring + KPI tiles, side by side */
.tl-dash-top{display:grid;grid-template-columns:minmax(220px,1.4fr) 150px 2.2fr;gap:24px;align-items:center;background:var(--card);border:1px solid var(--gb);padding:24px 28px}
.tl-dash-greet{min-width:0}

.tl-dash-ring{position:relative;width:140px;height:140px;justify-self:center}
.tl-ring{width:100%;height:100%;transform:rotate(-90deg)}
.tl-ring-bg{fill:none;stroke:var(--mid);stroke-width:6}
.tl-ring-fill{fill:none;stroke:var(--green);stroke-width:6;stroke-linecap:round;transition:stroke-dasharray .9s cubic-bezier(.4,.2,.2,1)}
.tl-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.tl-ring-num{font-family:var(--head);font-size:34px;color:var(--green);line-height:1}
.tl-ring-lab{font-family:var(--label);font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.05em;margin-top:2px}

.tl-dash-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}
.tl-kpi{background:var(--mid);border:1px solid var(--border);padding:14px 14px;transition:border-color .25s,transform .15s,background .2s,box-shadow .2s;text-align:center;position:relative}
.tl-kpi-clickable{cursor:pointer;user-select:none}
.tl-kpi-clickable:hover{border-color:var(--gb);background:var(--dark);transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.35)}
.tl-kpi-clickable:active{transform:translateY(0);transition-duration:.05s}
.tl-kpi.pulse{border-color:var(--gb);background:var(--gd);animation:tlPulse 2s ease-in-out infinite}
.tl-kpi.pulse:hover{box-shadow:0 6px 22px rgba(57,255,20,.18)}
.tl-kpi.warn{border-color:rgba(255,77,77,.3)}
@keyframes tlPulse{0%,100%{box-shadow:0 0 0 0 rgba(57,255,20,.3)}50%{box-shadow:0 0 0 6px rgba(57,255,20,0)}}
.tl-kpi-num{font-family:var(--head);font-size:30px;line-height:1;margin-bottom:5px}
.tl-kpi-lab{font-family:var(--label);font-size:11.5px;color:var(--muted-strong);font-weight:500;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* PROCESS FLOW — horizontal stages */
.tl-process{background:var(--card);border:1px solid var(--border);padding:18px 24px}
.tl-process-lab{font-family:var(--label);font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.tl-process-flow{display:flex;align-items:stretch;gap:6px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.tl-process-flow::-webkit-scrollbar{height:6px}
.tl-stage{display:flex;align-items:center;gap:6px;flex-shrink:0}
.tl-stage-card{background:var(--mid);border:1px solid var(--border);padding:11px 13px;min-width:160px;transition:border-color .2s,transform .15s}
.tl-stage-card:hover{border-color:var(--gb);transform:translateY(-1px)}
.tl-stage-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px}
.tl-stage-pct{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--white);letter-spacing:.04em}
.tl-stage-bar{height:5px;background:var(--dark);border:1px solid var(--border);overflow:hidden;margin-bottom:8px}
.tl-stage-bar-fill{height:100%;transition:width .8s cubic-bezier(.4,.2,.2,1)}
.tl-stage-meta{display:flex;gap:11px;font-family:var(--label);font-size:11px;font-weight:500;flex-wrap:wrap}
.tl-stage-arrow{font-size:18px;color:var(--dim);font-family:var(--mono);align-self:center;flex-shrink:0}

/* HEALTH BADGE — single status indicator in topbar */
.tl-health{display:flex;align-items:center;gap:9px;padding:8px 14px;border:1px solid;font-family:var(--label);user-select:none;transition:transform .2s}
.tl-health-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;animation:tlHealthPulse 2.4s ease-in-out infinite}
@keyframes tlHealthPulse{0%,100%{box-shadow:0 0 0 0 currentColor;opacity:1}50%{box-shadow:0 0 0 5px transparent;opacity:.85}}
.tl-health-label{font-size:12px;font-weight:600;letter-spacing:.02em}
.tl-health-good{border-color:var(--gb);background:rgba(57,255,20,.08);color:var(--green)}
.tl-health-good .tl-health-dot{background:var(--green)}
.tl-health-warn{border-color:rgba(255,179,64,.4);background:rgba(255,179,64,.08);color:var(--amber)}
.tl-health-warn .tl-health-dot{background:var(--amber)}
.tl-health-risk{border-color:rgba(255,77,77,.4);background:rgba(255,77,77,.08);color:var(--red)}
.tl-health-risk .tl-health-dot{background:var(--red)}
.tl-health-idle{border-color:var(--border);background:var(--mid);color:var(--muted-strong)}
.tl-health-idle .tl-health-dot{background:var(--muted)}

/* NARRATIVE CARDS — Wins / Issues / Next Steps */
.tl-narrative{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tl-narr-card{background:var(--card);border:1px solid var(--border);overflow:hidden;display:flex;flex-direction:column;transition:border-color .25s,transform .15s}
.tl-narr-card:hover{border-color:rgba(255,255,255,.13)}
.tl-narr-wins{border-color:var(--gb);background:linear-gradient(180deg,rgba(57,255,20,.04) 0%,var(--card) 60%)}
.tl-narr-issues{border-color:rgba(255,179,64,.35);background:linear-gradient(180deg,rgba(255,179,64,.05) 0%,var(--card) 60%)}
.tl-narr-head{display:flex;align-items:center;gap:11px;padding:14px 18px 12px;border-bottom:1px solid var(--border)}
.tl-narr-head h4{font-family:var(--head);font-size:18px;letter-spacing:.02em;color:var(--white);margin:0;flex:1}
.tl-narr-icon{font-size:19px;line-height:1}
.tl-narr-count{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--muted-strong);background:var(--mid);border:1px solid var(--border);padding:3px 9px}
.tl-narr-wins .tl-narr-count{color:var(--green);border-color:var(--gb);background:var(--gd)}
.tl-narr-issues .tl-narr-count{color:var(--amber);border-color:rgba(255,179,64,.3);background:rgba(255,179,64,.08)}
.tl-narr-body{padding:10px 16px 14px;display:flex;flex-direction:column;gap:6px;flex:1}
.tl-narr-item{display:flex;flex-direction:column;gap:5px;padding:10px 12px;border-radius:3px;background:rgba(255,255,255,.02);border:1px solid transparent;cursor:pointer;transition:background .2s,border-color .2s,transform .15s}
.tl-narr-item:hover{background:rgba(57,255,20,.04);border-color:var(--gb);transform:translateX(-2px)}
.tl-narr-item .kn-tag{align-self:flex-start}
.tl-narr-title{font-size:13.5px;font-weight:500;color:var(--white);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tl-narr-reason{font-family:var(--label);font-size:11.5px;color:var(--muted);font-weight:500}
.tl-narr-empty{font-family:var(--label);font-size:12.5px;color:var(--muted);text-align:center;padding:18px 12px;font-style:italic;line-height:1.5}

/* RECENT ACTIVITY FEED */
.tl-activity{margin-bottom:18px;background:var(--card);border:1px solid var(--border);overflow:hidden}
.tl-activity-head{display:flex;align-items:center;gap:10px;padding:14px 20px 12px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.015)}
.tl-activity-head h4{font-family:var(--head);font-size:19px;letter-spacing:.02em;color:var(--white);margin:0;flex:1}
.tl-activity-icon{font-size:17px;line-height:1}
.tl-activity-live{font-family:var(--label);font-size:10.5px;font-weight:600;color:var(--green);background:var(--gd);border:1px solid var(--gb);padding:3px 9px;letter-spacing:.04em;text-transform:uppercase}
.tl-activity-list{display:flex;flex-direction:column}
.tl-activity-row{display:grid;grid-template-columns:34px 1fr auto auto;gap:14px;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s}
.tl-activity-row:last-child{border-bottom:none}
.tl-activity-row:hover{background:rgba(57,255,20,.03)}
.tl-activity-bullet{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;border:1px solid}
.tl-activity-bullet.st-done{background:var(--gd);border-color:var(--gb);color:var(--green)}
.tl-activity-bullet.st-in_progress{background:rgba(255,179,64,.1);border-color:rgba(255,179,64,.4);color:var(--amber)}
.tl-activity-bullet.st-review{background:rgba(110,168,255,.1);border-color:rgba(110,168,255,.4);color:var(--blue)}
.tl-activity-bullet.st-todo{background:var(--mid);border-color:var(--border);color:var(--muted-strong)}
.tl-activity-content{min-width:0;display:flex;flex-direction:column;gap:2px}
.tl-activity-title{font-size:13.5px;line-height:1.4;color:var(--muted-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tl-activity-title strong{color:var(--white);font-weight:500}
.tl-activity-label{font-family:var(--label);font-weight:500;color:var(--muted);font-size:12.5px}
.tl-activity-time{font-family:var(--label);font-size:11.5px;font-weight:500;color:var(--muted);white-space:nowrap}

/* SECTIONS — collapsible */
.tl-section{margin-bottom:24px;background:var(--card);border:1px solid var(--border);overflow:hidden;transition:border-color .25s,box-shadow .25s}
.tl-section:hover{border-color:rgba(255,255,255,.13)}
.tl-section.tl-flash{animation:tlFlash 1.8s ease-out}
@keyframes tlFlash{
  0%{box-shadow:0 0 0 0 rgba(57,255,20,.6);border-color:var(--gb)}
  30%{box-shadow:0 0 0 8px rgba(57,255,20,.18);border-color:var(--green)}
  100%{box-shadow:0 0 0 0 rgba(57,255,20,0);border-color:var(--border)}
}
.tl-sec-head{display:flex;align-items:center;gap:14px;padding:20px 24px;cursor:pointer;user-select:none;background:transparent;transition:background .2s,padding .2s}
.tl-sec-head:hover{background:rgba(57,255,20,.025)}
.tl-sec-head:active{background:rgba(57,255,20,.05)}
.tl-sec-title{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.tl-sec-head h3{font-family:var(--head);font-size:26px;letter-spacing:.02em;color:var(--white);display:inline-flex;align-items:center;gap:10px;margin:0}
.tl-sec-count{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--muted-strong);background:var(--mid);border:1px solid var(--border);padding:4px 11px;flex-shrink:0}
.tl-sec-desc{font-size:14px;color:var(--muted-strong);line-height:1.65;margin-bottom:18px}
.tl-live-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--amber);animation:tlBlink 1.4s ease-in-out infinite;flex-shrink:0}
@keyframes tlBlink{0%,100%{opacity:1}50%{opacity:.4}}

/* Chevron */
.tl-chevron{flex-shrink:0;color:var(--muted);transition:transform .3s ease,color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center}
.tl-chevron svg{width:18px;height:18px}
.tl-sec-head:hover .tl-chevron{color:var(--green)}
.tl-closed .tl-chevron{transform:rotate(-90deg)}

/* Smooth expand/collapse via grid-template-rows trick */
.tl-sec-body-wrap{display:grid;grid-template-rows:1fr;transition:grid-template-rows .35s cubic-bezier(.4,.2,.2,1)}
.tl-section.tl-closed .tl-sec-body-wrap{grid-template-rows:0fr}
.tl-sec-body{overflow:hidden;padding:0 24px 24px;min-height:0}
.tl-section.tl-closed .tl-sec-body{padding-bottom:0}

/* Special highlight for action-needed */
.tl-action-needed{border-right:5px solid var(--green);background:rgba(57,255,20,.04)}
.tl-action-needed .tl-sec-head h3{color:var(--green)}

/* CARD GRID */
.tl-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.tl-card{position:relative;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .2s,transform .15s,box-shadow .2s;overflow:hidden;display:flex}
.tl-card:hover{border-color:var(--gb);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.3)}
.tl-card-stripe{width:4px;flex-shrink:0}
.tl-card-body{padding:16px 18px;flex:1;min-width:0}
.tl-card-row1{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.tl-card-due{font-family:var(--label);font-size:11.5px;color:var(--muted);font-weight:500}
.tl-card-due.soon{color:var(--amber);font-weight:600}
.tl-card-due.urgent{color:var(--red);font-weight:600}
.tl-card-title{font-size:15px;font-weight:500;line-height:1.5;margin-bottom:8px;color:var(--white);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* === ICONS === */
.ic{display:inline-flex;align-items:center;justify-content:center;vertical-align:-2px;flex-shrink:0;line-height:0}
.ic svg{width:100%;height:100%;display:block;color:inherit}
.tl-kpi-lab .ic{margin-left:5px;color:currentColor;opacity:.85}
.tl-process-lab .ic{margin-left:6px}
.tl-activity-icon .ic{color:var(--green)}
.tl-sec-head h3 .ic{margin-left:4px}
.m-sheet-item .ic{color:var(--muted);width:18px;height:18px}

/* === CARDS — desc completion === */
.tl-card-desc{font-size:13px;line-height:1.55;color:var(--muted-strong);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tl-card-cta{margin-top:14px;padding-top:12px;border-top:1px solid var(--border);font-family:var(--label);font-size:12.5px;font-weight:600;color:var(--green);letter-spacing:.02em}
.tl-card-progress{margin-top:14px;height:4px;background:var(--mid);overflow:hidden}
.tl-card-progress-fill{height:100%;background:var(--amber);width:60%;animation:tlProg 2.5s ease-in-out infinite alternate}
@keyframes tlProg{from{width:55%}to{width:75%}}
.tl-review{border-color:rgba(110,168,255,.4)}
.tl-review .tl-card-stripe{background:#9cc3ff}
.tl-progress .tl-card-stripe{background:var(--amber)}
.tl-done{opacity:.68}
.tl-done .tl-card-stripe{background:var(--green);opacity:.5}
.cat-stripe-research{background:#9cc3ff}
.cat-stripe-onpage{background:var(--green)}
.cat-stripe-content{background:#ffc56b}
.cat-stripe-tech{background:#d7b8ff}
.cat-stripe-links{background:#fbbf45}
.cat-stripe-geo{background:#ff7878}
.cat-stripe-report{background:#5cd6e8}
.cat-stripe-strategy{background:#c189f9}

/* === PROCESS FLOW === */
.tl-process{background:var(--card);border:1px solid var(--border);padding:18px 24px;border-radius:12px}
.tl-process-lab{font-family:var(--label);font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center}
.tl-process-flow{display:flex;align-items:stretch;gap:6px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.tl-process-flow::-webkit-scrollbar{height:6px}
.tl-stage{display:flex;align-items:center;gap:6px;flex-shrink:0}
.tl-stage-card{background:var(--mid);border:1px solid var(--border);padding:11px 13px;min-width:160px;transition:border-color .2s,transform .15s;border-radius:8px}
.tl-stage-card:hover{border-color:var(--gb);transform:translateY(-1px)}
.tl-stage-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px}
.tl-stage-pct{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--white);letter-spacing:.04em}
.tl-stage-bar{height:5px;background:var(--dark);border:1px solid var(--border);overflow:hidden;margin-bottom:8px;border-radius:3px}
.tl-stage-bar-fill{height:100%;transition:width .8s cubic-bezier(.4,.2,.2,1)}
.tl-stage-meta{display:flex;gap:11px;font-family:var(--label);font-size:11px;font-weight:500;flex-wrap:wrap}
.tl-stage-arrow{font-size:18px;color:var(--dim);font-family:var(--mono);align-self:center;flex-shrink:0}

/* === HEALTH BADGE === */
.tl-health{display:flex;align-items:center;gap:9px;padding:8px 14px;border:1px solid;font-family:var(--label);user-select:none;transition:transform .2s;border-radius:8px}
.tl-health-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;animation:tlHealthPulse 2.4s ease-in-out infinite}
@keyframes tlHealthPulse{0%,100%{box-shadow:0 0 0 0 currentColor;opacity:1}50%{box-shadow:0 0 0 5px transparent;opacity:.85}}
.tl-health-label{font-size:12px;font-weight:600;letter-spacing:.02em}
.tl-health-good{border-color:var(--gb);background:rgba(57,255,20,.08);color:var(--green)}
.tl-health-good .tl-health-dot{background:var(--green)}
.tl-health-warn{border-color:rgba(255,179,64,.4);background:rgba(255,179,64,.08);color:var(--amber)}
.tl-health-warn .tl-health-dot{background:var(--amber)}
.tl-health-risk{border-color:rgba(255,77,77,.4);background:rgba(255,77,77,.08);color:var(--red)}
.tl-health-risk .tl-health-dot{background:var(--red)}
.tl-health-idle{border-color:var(--border);background:var(--mid);color:var(--muted-strong)}
.tl-health-idle .tl-health-dot{background:var(--muted)}

/* === RECENT ACTIVITY FEED === */
.tl-activity{margin-bottom:18px;background:var(--card);border:1px solid var(--border);overflow:hidden;border-radius:12px}
.tl-activity-head{display:flex;align-items:center;gap:10px;padding:14px 20px 12px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.015)}
.tl-activity-head h4{font-family:var(--head);font-size:19px;letter-spacing:.02em;color:var(--white);margin:0;flex:1}
.tl-activity-icon{display:flex;align-items:center;color:var(--green)}
.tl-activity-live{font-family:var(--label);font-size:10.5px;font-weight:600;color:var(--green);background:var(--gd);border:1px solid var(--gb);padding:3px 9px;letter-spacing:.04em;text-transform:uppercase;border-radius:4px}
.tl-activity-list{display:flex;flex-direction:column}
.tl-activity-row{display:grid;grid-template-columns:34px 1fr auto auto;gap:14px;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s}
.tl-activity-row:last-child{border-bottom:none}
.tl-activity-row:hover{background:rgba(57,255,20,.03)}
.tl-activity-bullet{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;border:1px solid}
.tl-activity-bullet.st-done{background:var(--gd);border-color:var(--gb);color:var(--green)}
.tl-activity-bullet.st-in_progress{background:rgba(255,179,64,.1);border-color:rgba(255,179,64,.4);color:var(--amber)}
.tl-activity-bullet.st-review{background:rgba(110,168,255,.1);border-color:rgba(110,168,255,.4);color:var(--blue)}
.tl-activity-bullet.st-todo{background:var(--mid);border-color:var(--border);color:var(--muted-strong)}
.tl-activity-bullet .ic{width:14px;height:14px}
.tl-activity-content{min-width:0;display:flex;flex-direction:column;gap:2px}
.tl-activity-title{font-size:13.5px;line-height:1.4;color:var(--muted-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tl-activity-title strong{color:var(--white);font-weight:500}
.tl-activity-label{font-family:var(--label);font-weight:500;color:var(--muted);font-size:12.5px}
.tl-activity-time{font-family:var(--label);font-size:11.5px;font-weight:500;color:var(--muted);white-space:nowrap}

/* === SECTION FLASH === */
.tl-section.tl-flash{animation:tlFlash 1.8s ease-out}
@keyframes tlFlash{
  0%{box-shadow:0 0 0 0 rgba(57,255,20,.6);border-color:var(--gb)}
  30%{box-shadow:0 0 0 8px rgba(57,255,20,.18);border-color:var(--green)}
  100%{box-shadow:0 0 0 0 rgba(57,255,20,0);border-color:var(--border)}
}

/* === TIMELINE BUCKETS === */
.tl-timeline{position:relative;padding:8px 0}
.tl-bucket{margin-bottom:24px;position:relative}
.tl-bucket.overdue .tl-bucket-dot{background:var(--red)}
.tl-bucket-head{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.tl-bucket-dot{width:11px;height:11px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(57,255,20,.15)}
.tl-bucket-name{font-family:var(--head);font-size:21px;letter-spacing:.02em}
.tl-bucket-cnt{font-family:var(--mono);font-size:11px;color:var(--muted);background:var(--mid);border:1px solid var(--border);padding:3px 9px;border-radius:4px}
.tl-bucket-items{display:flex;flex-direction:column;gap:8px}
.tl-item{display:flex;gap:18px;padding:13px 16px;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .2s,background .2s;align-items:center;border-radius:8px}
.tl-item:hover{border-color:var(--gb);background:var(--dark)}
.tl-item-date{font-family:var(--mono);font-size:12px;color:var(--muted-strong);min-width:80px;font-weight:500}
.tl-item-content{flex:1;display:flex;align-items:center;gap:12px;min-width:0;flex-wrap:wrap}
.tl-item-title{font-size:14.5px;font-weight:500;color:var(--white);line-height:1.4}

/* === EMPTY STATE === */
.tl-empty{text-align:center;padding:80px 24px;color:var(--muted)}
.tl-empty-icon{font-size:64px;margin-bottom:20px}
.tl-empty h2{font-family:var(--head);font-size:38px;color:var(--white);margin-bottom:14px;letter-spacing:.02em}
.tl-empty p{font-size:15px;line-height:1.7;max-width:420px;margin:0 auto;color:var(--muted-strong)}
.tl-more{text-align:center;padding:14px;margin-top:14px;color:var(--muted);font-size:13px;border:1px dashed var(--border);border-radius:6px}

/* === SYNC BADGE === */
.tl-sync-badge{display:flex;align-items:center;gap:9px;padding:8px 14px;background:rgba(57,255,20,.06);border:1px solid var(--gb);user-select:none;border-radius:8px}
.tl-sync-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(57,255,20,.6);animation:tlSyncPulse 2.2s ease-in-out infinite}
@keyframes tlSyncPulse{0%{box-shadow:0 0 0 0 rgba(57,255,20,.5)}70%{box-shadow:0 0 0 8px rgba(57,255,20,0)}100%{box-shadow:0 0 0 0 rgba(57,255,20,0)}}
.tl-sync-text{display:flex;flex-direction:column;line-height:1.3;gap:3px}
.tl-sync-text strong{font-family:var(--label);font-size:11.5px;font-weight:600;color:var(--green);letter-spacing:.02em;display:block}
.tl-sync-rel{font-family:var(--label);font-size:10.5px;color:var(--muted);display:block}

/* === REFRESH BUTTON SPIN === */
.icb.spin svg{animation:spinIcon 1s linear}
@keyframes spinIcon{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* === MOBILE BOTTOM NAV (native-app style, client only) === */
.m-nav{display:none}
@media(max-width:900px){
  .m-nav{
    display:grid;grid-template-columns:repeat(5,1fr);
    position:fixed;bottom:0;left:0;right:0;
    background:rgba(7,7,7,.97);
    backdrop-filter:blur(14px) saturate(160%);
    -webkit-backdrop-filter:blur(14px) saturate(160%);
    border-top:1px solid var(--gb);
    z-index:90;padding:6px 4px;
    padding-bottom:calc(6px + env(safe-area-inset-bottom, 0px));
    box-shadow:0 -8px 24px rgba(0,0,0,.45);
  }
  .m-nav-item{
    background:transparent;border:none;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
    padding:9px 4px 6px;cursor:pointer;
    color:var(--muted-strong);
    font-family:var(--label);font-size:10.5px;font-weight:600;
    transition:color .2s,background .15s,transform .1s;
    position:relative;border-radius:10px;min-height:54px;
  }
  .m-nav-item:active{background:rgba(57,255,20,.08);transform:scale(.95)}
  .m-nav-item.active{color:var(--green)}
  .m-nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}
  .m-nav-icon svg{width:22px;height:22px;stroke:currentColor;transition:stroke .2s}
  .m-nav-label{line-height:1;letter-spacing:.01em}
  .m-nav-badge{
    position:absolute;top:4px;right:50%;margin-right:-22px;
    background:var(--red);color:#fff;
    font-size:10px;font-weight:700;min-width:18px;height:18px;padding:0 5px;border-radius:9px;
    display:flex;align-items:center;justify-content:center;
    border:2px solid var(--black);animation:tlSyncPulse 2s ease-in-out infinite;
  }
  .m-nav-count{
    position:absolute;top:4px;right:50%;margin-right:-22px;
    background:var(--mid);color:var(--white);
    font-size:9.5px;font-weight:600;min-width:16px;height:16px;padding:0 4px;border-radius:8px;
    display:flex;align-items:center;justify-content:center;border:1px solid var(--border);
  }
  body{padding-bottom:calc(70px + env(safe-area-inset-bottom, 0px))}
  .tl-page{padding-bottom:24px}
}

/* === MOBILE ACCOUNT SHEET === */
.m-sheet-back{
  position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
  z-index:300;opacity:0;transition:opacity .25s ease;
  display:flex;align-items:flex-end;justify-content:center;
}
.m-sheet-back.on{opacity:1}
.m-sheet{
  width:100%;max-width:480px;background:var(--dark);border-top:1px solid var(--gb);
  border-radius:18px 18px 0 0;padding:14px 22px 24px;
  padding-bottom:calc(24px + env(safe-area-inset-bottom, 0px));
  transform:translateY(100%);transition:transform .3s cubic-bezier(.4,.2,.2,1);
  box-shadow:0 -10px 40px rgba(0,0,0,.5);
}
.m-sheet-back.on .m-sheet{transform:translateY(0)}
.m-sheet-handle{width:40px;height:4px;background:var(--muted);border-radius:2px;margin:0 auto 18px;opacity:.5}
.m-sheet-head{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--border);margin-bottom:10px}
.m-sheet-name{font-size:16px;font-weight:600;color:var(--white)}
.m-sheet-meta{font-family:var(--label);font-size:12.5px;color:var(--muted);margin-top:3px;direction:ltr;text-align:right}
.m-sheet-items{display:flex;flex-direction:column;gap:2px;margin-bottom:14px}
.m-sheet-item{
  display:flex;align-items:center;gap:14px;padding:14px 14px;background:transparent;border:none;
  color:var(--white);font-family:var(--body);font-size:15px;font-weight:500;
  cursor:pointer;border-radius:10px;transition:background .15s;text-align:right;
}
.m-sheet-item:active{background:rgba(255,255,255,.04)}
.m-sheet-close{
  width:100%;background:var(--mid);color:var(--white);border:1px solid var(--border);
  padding:14px;font-family:var(--label);font-size:14px;font-weight:600;letter-spacing:.02em;
  cursor:pointer;border-radius:10px;
}
.m-sheet-close:active{background:var(--card)}

/* === RESPONSIVE — TABLET (≤1080px) === */
@media(max-width:1080px){
  .tl-dash-top{grid-template-columns:1fr 130px;grid-template-rows:auto auto;gap:18px;padding:22px}
  .tl-dash-greet{grid-row:1;grid-column:1}
  .tl-dash-ring{grid-row:1;grid-column:2;width:130px;height:130px}
  .tl-dash-kpis{grid-row:2;grid-column:1/-1;grid-template-columns:repeat(4,1fr)}
  .tl-ring-num{font-size:30px}
}

/* === RESPONSIVE — MOBILE (≤900px) — Native app feel === */
@media(max-width:900px){
  body{font-size:15px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}
  *{-webkit-tap-highlight-color:transparent}

  /* App container — no sidebar grid on mobile */
  .app{grid-template-columns:1fr}
  .side{position:fixed;top:0;right:0;bottom:0;width:300px;max-width:85vw;z-index:100;transform:translateX(105%);transition:transform .35s cubic-bezier(.4,.2,.2,1);border-left:1px solid var(--border);border-bottom:none;box-shadow:-12px 0 32px rgba(0,0,0,.4)}
  .side.open{transform:translateX(0)}
  .cli-list{max-height:none;flex:1}

  /* Hamburger only for admin/employee (client uses bottom nav) */
  .hamburger{display:flex;width:42px;height:42px;background:transparent;border:1px solid var(--border);align-items:center;justify-content:center;cursor:pointer;flex-direction:column;gap:5px;padding:11px 12px}
  .hamburger:hover{border-color:var(--gb);background:var(--gd)}
  .hamburger span{display:block;width:18px;height:2px;background:var(--white);transition:all .3s ease;border-radius:2px}
  .hamburger.active{border-color:var(--gb);background:var(--gd)}
  .hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--green)}
  .hamburger.active span:nth-child(2){opacity:0}
  .hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--green)}

  /* TOPBAR — compact mobile */
  .topbar{padding:12px 16px;min-height:60px;gap:10px}
  .crumb-lab{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase}
  .crumb-name{font-size:22px;line-height:1.15;margin-top:2px}
  .crumb-pkg{font-size:10.5px;padding:3px 8px;font-weight:600}
  .topbar-right{gap:6px}
  .tl-sync-badge{padding:6px 9px;gap:6px}
  .tl-sync-text strong{font-size:10.5px}
  .tl-sync-rel{font-size:9.5px}
  .tl-health{padding:7px 10px;gap:6px}
  .tl-health-label{font-size:10.5px;font-weight:700}

  /* PAGE */
  .tl-page{padding:14px 14px 16px;max-width:none}

  /* HERO — full vertical stack */
  .tl-hi{font-size:26px;line-height:1.1;margin-bottom:6px}
  .tl-sub{font-size:13.5px;line-height:1.55}
  .tl-dash{gap:12px;margin-bottom:18px}
  .tl-dash-top{grid-template-columns:1fr;grid-template-rows:auto auto auto;padding:18px 16px;gap:16px;border-radius:14px}
  .tl-dash-greet{grid-row:1;grid-column:1;text-align:right}
  .tl-dash-ring{grid-row:2;grid-column:1;justify-self:center;width:120px;height:120px}
  .tl-ring-num{font-size:28px}
  .tl-ring-lab{font-size:10.5px}

  /* KPIs — 2x2 touch-friendly */
  .tl-dash-kpis{grid-row:3;grid-column:1;grid-template-columns:repeat(2,1fr);gap:8px;width:100%}
  .tl-kpi{padding:13px 12px;border-radius:10px;min-height:80px;display:flex;flex-direction:column;justify-content:center}
  .tl-kpi-num{font-size:28px;margin-bottom:4px;font-weight:400}
  .tl-kpi-lab{font-size:11px;font-weight:600;line-height:1.35;display:flex;align-items:center;justify-content:center;gap:5px}
  .tl-kpi-lab .ic{width:13px;height:13px}

  /* PROCESS FLOW — scroll-snap */
  .tl-process{padding:14px 16px;border-radius:12px}
  .tl-process-lab{font-size:11.5px;margin-bottom:12px;gap:6px}
  .tl-process-flow{gap:8px;scroll-snap-type:x mandatory;padding:0 0 6px}
  .tl-stage{scroll-snap-align:start;gap:8px}
  .tl-stage-card{min-width:170px;padding:12px 14px;border-radius:10px}
  .tl-stage-pct{font-size:14px;font-weight:700}
  .tl-stage-head{margin-bottom:10px}
  .tl-stage-bar{height:6px;margin-bottom:9px}
  .tl-stage-meta{font-size:11px;gap:9px}

  /* RECENT ACTIVITY */
  .tl-activity{border-radius:12px;margin-bottom:14px}
  .tl-activity-head{padding:14px 16px 10px}
  .tl-activity-head h4{font-size:16px}
  .tl-activity-live{font-size:9.5px;padding:3px 8px}
  .tl-activity-row{grid-template-columns:34px 1fr auto;padding:12px 16px;gap:11px}
  .tl-activity-row .kn-tag{display:none}
  .tl-activity-bullet{width:32px;height:32px;font-size:13px}
  .tl-activity-bullet .ic{width:16px;height:16px}
  .tl-activity-title{font-size:13.5px;white-space:normal;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
  .tl-activity-label{font-size:11.5px}
  .tl-activity-time{font-size:11px}

  /* SECTIONS */
  .tl-section{margin-bottom:10px;background:var(--card);border:1px solid var(--border);overflow:hidden;border-radius:12px}
  .tl-sec-head{padding:16px 18px;min-height:58px;gap:10px;display:flex;align-items:center;cursor:pointer;user-select:none}
  .tl-sec-head:active{background:rgba(57,255,20,.06);transform:scale(.995);transition-duration:.05s}
  .tl-sec-title{display:flex;align-items:center;gap:11px;flex:1;min-width:0}
  .tl-sec-head h3{font-family:var(--head);font-size:17px;line-height:1.2;color:var(--white);margin:0;display:inline-flex;align-items:center;gap:10px}
  .tl-sec-head h3 .ic{width:18px;height:18px}
  .tl-sec-count{font-size:11.5px;padding:3px 9px;font-weight:700;font-family:var(--mono);color:var(--muted-strong);background:var(--mid);border:1px solid var(--border)}
  .tl-chevron{width:22px;height:22px;flex-shrink:0;color:var(--muted);transition:transform .3s ease,color .2s;display:flex;align-items:center;justify-content:center}
  .tl-chevron svg{width:18px;height:18px}
  .tl-closed .tl-chevron{transform:rotate(-90deg)}
  .tl-sec-body-wrap{display:grid;grid-template-rows:1fr;transition:grid-template-rows .35s cubic-bezier(.4,.2,.2,1)}
  .tl-section.tl-closed .tl-sec-body-wrap{grid-template-rows:0fr}
  .tl-sec-body{overflow:hidden;padding:0 16px 18px;min-height:0}
  .tl-section.tl-closed .tl-sec-body{padding-bottom:0}
  .tl-sec-desc{font-size:13px;margin-bottom:12px;line-height:1.55;color:var(--muted-strong)}

  /* Cards in sections */
  .tl-cards-grid{display:grid;grid-template-columns:1fr;gap:9px}
  .tl-card{position:relative;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:border-color .2s,transform .15s;overflow:hidden;display:flex;border-radius:10px}
  .tl-card-stripe{width:4px;flex-shrink:0}
  .tl-card-body{padding:14px 15px;flex:1;min-width:0}
  .tl-card-row1{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
  .tl-card-title{font-size:14.5px;line-height:1.45;color:var(--white);font-weight:500;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}
  .tl-card-due{font-family:var(--label);font-size:11.5px;color:var(--muted);font-weight:500}
  .tl-card-due.soon{color:var(--amber);font-weight:600}
  .tl-card-due.urgent{color:var(--red);font-weight:600}

  /* Timeline buckets */
  .tl-bucket{margin-bottom:18px}
  .tl-bucket-head{gap:10px;margin-bottom:10px;padding-bottom:8px}
  .tl-bucket-name{font-size:16px}
  .tl-bucket-cnt{font-size:11px;padding:3px 8px}
  .tl-item{padding:13px 15px;border-radius:9px;display:flex;flex-direction:row;align-items:flex-start;gap:12px;min-height:auto}
  .tl-item-date{min-width:64px;font-size:11.5px;padding-top:2px;color:var(--muted-strong);font-weight:600}
  .tl-item-content{gap:6px}
  .tl-item-title{font-size:13.5px;line-height:1.4}

  /* Action needed highlight */
  .tl-action-needed{border-right:4px solid var(--green);background:rgba(57,255,20,.04)}
  .tl-action-needed .tl-sec-head h3{color:var(--green)}

  /* Empty */
  .tl-empty{padding:50px 20px}
  .tl-empty-icon{font-size:52px;margin-bottom:14px}
  .tl-empty h2{font-size:24px}
  .tl-empty p{font-size:14px}
}

/* === SMALL MOBILE (≤480px) === */
@media(max-width:480px){
  .topbar{padding:10px 12px;min-height:54px}
  .crumb-lab{font-size:10px}
  .crumb-name{font-size:19px;gap:7px;flex-wrap:nowrap;overflow:hidden}
  .crumb-pkg{font-size:9.5px;padding:2px 7px}
  .tl-sync-badge{padding:5px 8px;gap:5px}
  .tl-sync-text strong{font-size:10px}
  .tl-sync-rel{display:none}
  .tl-health{padding:6px;gap:0}
  .tl-health-label{display:none}
  .tl-health-dot{width:8px;height:8px}

  .tl-page{padding:12px 12px 14px}
  .tl-hi{font-size:23px}
  .tl-sub{font-size:13px}
  .tl-dash-top{padding:16px 14px;gap:14px;border-radius:12px}
  .tl-dash-ring{width:108px;height:108px}
  .tl-ring-num{font-size:26px}
  .tl-dash-kpis{gap:7px}
  .tl-kpi{padding:11px 10px;min-height:72px;border-radius:9px}
  .tl-kpi-num{font-size:24px;margin-bottom:3px}
  .tl-kpi-lab{font-size:10.5px;gap:4px}
  .tl-kpi-lab .ic{width:12px;height:12px}

  .tl-process{padding:12px 14px;border-radius:10px}
  .tl-process-lab{font-size:11px;margin-bottom:10px}
  .tl-stage-card{min-width:155px;padding:11px 12px}

  .tl-activity{border-radius:10px}
  .tl-activity-head{padding:12px 14px 9px}
  .tl-activity-head h4{font-size:15px}
  .tl-activity-row{padding:11px 14px;gap:10px;grid-template-columns:30px 1fr auto}
  .tl-activity-bullet{width:30px;height:30px}
  .tl-activity-bullet .ic{width:15px;height:15px}
  .tl-activity-title{font-size:13px}
  .tl-activity-label{font-size:11px}

  .tl-section{margin-bottom:8px;border-radius:10px}
  .tl-sec-head{padding:14px 14px;min-height:54px;gap:9px}
  .tl-sec-head h3{font-size:15.5px}
  .tl-sec-head h3 .ic{width:16px;height:16px}
  .tl-sec-count{font-size:11px;padding:2.5px 8px}
  .tl-sec-body{padding:0 14px 16px}
  .tl-sec-desc{font-size:12.5px}

  .tl-card-body{padding:13px 14px}
  .tl-card-title{font-size:14px}
  .tl-bucket-name{font-size:15px}
  .tl-item{padding:12px 13px;gap:11px}
  .tl-item-date{min-width:60px;font-size:11px}
  .tl-item-title{font-size:13px}
}

@media(max-width:360px){
  .tl-page{padding:10px 10px 12px}
  .tl-dash-kpis{grid-template-columns:repeat(2,1fr);gap:6px}
  .tl-kpi{padding:10px 8px;min-height:68px}
  .tl-kpi-num{font-size:22px}
  .tl-kpi-lab{font-size:10px}
  .crumb-name{font-size:17px}
}

/* ============================================================ */
/* === MOBILE OVERFLOW & STICKY NAV — HARDENED FIXES === */
/* ============================================================ */
@media(max-width:900px){
  /* Block any horizontal overflow at the page level */
  html, body {
    overflow-x: hidden !important;
    max-width: 100vw;
    width: 100%;
  }
  body {
    position: relative;
  }

  /* Force every container to respect viewport width */
  .tl-page, .topbar, .main, .app, .content {
    max-width: 100vw;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }
  .tl-dash, .tl-dash-top, .tl-process, .tl-activity, .tl-section {
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  /* Grid items safety — prevents min-content blowout */
  .tl-dash-greet, .tl-dash-ring, .tl-dash-kpis,
  .tl-sec-title, .tl-card, .tl-card-body,
  .tl-activity-row, .tl-activity-content,
  .tl-stage-card, .tl-item, .tl-item-content {
    min-width: 0;
  }

  /* Text containment */
  .tl-hi, .tl-sub, .tl-card-title, .tl-card-desc,
  .tl-activity-title, .tl-item-title, .crumb-name {
    word-break: break-word;
    overflow-wrap: anywhere;
  }

  /* TOPBAR — let it shrink + wrap right side if needed */
  .topbar {
    flex-wrap: wrap;
    padding: 10px 12px;
    gap: 8px;
    position: sticky;
    top: 0;
    z-index: 50;
  }
  .topbar > div:first-child {
    flex: 1 1 100%;
    min-width: 0;
  }
  .topbar-right {
    flex: 1 1 100%;
    justify-content: flex-end;
    gap: 6px;
    flex-wrap: wrap;
  }

  /* BOTTOM NAV — hardened sticky to viewport bottom */
  .m-nav {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    z-index: 9999 !important;
  }

  /* Reserve space at bottom of body for nav */
  body {
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px)) !important;
  }

  /* PROCESS FLOW — let it scroll without overflowing page */
  .tl-process-flow {
    margin: 0;
    padding-right: 0;
    padding-left: 0;
    max-width: 100%;
    overflow-x: auto;
  }
}

/* === 380px–480px range — KPIs better stacking === */
@media(max-width:420px){
  .tl-dash-kpis {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 7px;
  }
  .tl-kpi {
    padding: 11px 9px;
    min-height: 70px;
  }
  .tl-kpi-num {
    font-size: 23px;
  }
  .tl-kpi-lab {
    font-size: 10.5px;
  }
  .tl-page {
    padding: 10px 10px 14px;
  }
  .tl-dash-top {
    padding: 16px 12px;
  }
  .tl-process {
    padding: 12px 12px;
  }
  .tl-activity-head, .tl-sec-head {
    padding-left: 12px;
    padding-right: 12px;
  }
  .tl-activity-row {
    padding: 11px 12px;
    gap: 9px;
  }
  .tl-sec-body {
    padding: 0 12px 14px;
  }
}