*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f5f7;--w:#fff;--bg3:#f5f5f7;--bg4:#e8e8ed;--bg5:#d1d1d6;
  --sep:rgba(0,0,0,.08);--sep2:rgba(0,0,0,.05);
  --t:#1d1d1f;--t2:#6e6e73;--t3:#aeaeb2;
  --blue:#007aff;--bl:#e8f1ff;
  --green:#34c759;--gl:#eafaf0;--gd:#1a6b3c;
  --yellow:#ff9f0a;--yl:#fff5e6;--yd:#7a4d00;
  --red:#ff3b30;--rl:#fff0ef;--rd:#c0392b;
  --purple:#af52de;--pl:#f5eeff;--pd:#6b2f8f;
  --teal:#32ade6;--tl:#e5f6fd;--td:#1a6e96;
  --f:'Plus Jakarta Sans',-apple-system,sans-serif;
  --m:'JetBrains Mono',monospace;
  --r:14px;--rs:10px;--rxs:8px;
  --sh:0 2px 12px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04);
  --sh2:0 4px 20px rgba(0,0,0,.09);
}
body{font-family:var(--f);background:var(--bg);color:var(--t);-webkit-font-smoothing:antialiased}

/* ── LOADING SCREEN */
.loading-screen{position:fixed;inset:0;background:var(--w);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:999;transition:opacity .3s}
.loading-screen.hide{opacity:0;pointer-events:none}
.loading-mark{width:52px;height:52px;background:var(--blue);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#fff;margin-bottom:16px;animation:pulse 1.5s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.loading-text{font-size:14px;font-weight:600;color:var(--t2)}
.loading-sub{font-size:12px;color:var(--t3);margin-top:4px}

/* ── ERROR SCREEN */
.error-screen{position:fixed;inset:0;background:var(--w);display:none;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center}
.error-screen.show{display:flex}
.error-icon{font-size:40px;margin-bottom:12px}
.error-title{font-size:18px;font-weight:700;color:var(--rd);margin-bottom:8px}
.error-msg{font-size:13px;color:var(--t2);line-height:1.6;max-width:400px;background:var(--bg3);padding:14px;border-radius:var(--rs);font-family:var(--m)}

/* ── CONFIG SCREEN (jika Supabase belum dikonfigurasi) */
.config-screen{position:fixed;inset:0;background:var(--bg);display:none;flex-direction:column;align-items:center;justify-content:center;padding:24px}
.config-screen.show{display:flex}
.config-box{background:var(--w);border-radius:var(--r);box-shadow:var(--sh2);padding:28px;max-width:480px;width:100%}
.config-title{font-size:18px;font-weight:800;margin-bottom:6px}
.config-sub{font-size:13px;color:var(--t2);margin-bottom:20px;line-height:1.5}
.config-step{font-size:11px;font-weight:700;color:var(--blue);letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;padding:8px 12px;background:var(--bl);border-radius:var(--rxs)}
.config-fg{margin-bottom:12px}
.config-label{display:block;font-size:11px;font-weight:600;color:var(--t2);margin-bottom:5px}
.config-input{width:100%;background:var(--bg3);border:1.5px solid transparent;border-radius:var(--rxs);color:var(--t);font-family:var(--m);font-size:12px;padding:10px 11px;outline:none}
.config-input:focus{border-color:var(--blue);background:var(--w);box-shadow:0 0 0 3px rgba(0,122,255,.1)}
.config-btn{width:100%;height:46px;background:var(--blue);color:#fff;border:none;border-radius:11px;font-size:14px;font-weight:700;cursor:pointer;font-family:var(--f);margin-top:4px}

/* ── ROLE SCREEN */
.rscr{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px}
.rlogo{display:flex;align-items:center;gap:10px;margin-bottom:32px}
.rmark{width:42px;height:42px;background:var(--blue);border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:#fff}
.rname{font-size:22px;font-weight:800;letter-spacing:-.5px}
.rsub{font-size:12px;color:var(--t3);margin-top:2px}
.rlbl{font-size:14px;font-weight:600;color:var(--t2);margin-bottom:16px}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:660px;width:100%}
.rcard{background:var(--w);border-radius:var(--r);padding:18px 14px;box-shadow:var(--sh);cursor:pointer;border:2px solid transparent;transition:all .2s;text-align:center}
.rcard:hover{transform:translateY(-2px);box-shadow:var(--sh2);border-color:var(--blue)}
.rcard-ico{font-size:26px;margin-bottom:7px}
.rcard-name{font-size:13px;font-weight:700;color:var(--t)}
.rcard-sub{font-size:11px;color:var(--t3);margin-top:2px}
.rdate{font-family:var(--m);font-size:11px;color:var(--t3);margin-top:24px}

/* ── APP */
.app{display:none;flex-direction:column;min-height:100vh}
header{background:rgba(255,255,255,.88);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--sep);position:sticky;top:0;z-index:100;height:52px;display:flex;align-items:center;padding:0 16px;gap:10px}
.hl{display:flex;align-items:center;gap:8px;cursor:pointer}
.hm{width:26px;height:26px;background:var(--blue);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff}
.hn{font-size:14px;font-weight:700}
.hsep{width:1px;height:14px;background:var(--sep)}
.hrole{font-size:12px;font-weight:600;color:var(--t2)}
.hsp{flex:1}
.hd{font-family:var(--m);font-size:10px;color:var(--t3)}
.hbtn{font-size:12px;font-weight:600;color:var(--blue);cursor:pointer;padding:4px 10px;border-radius:16px;background:var(--bl);border:none;font-family:var(--f)}
.draft-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:10px;background:var(--yl);color:var(--yd)}

.navtabs{background:var(--w);border-bottom:1px solid var(--sep);display:flex;flex-wrap:wrap;padding:0 16px;gap:2px;flex-shrink:0}
.navtabs::-webkit-scrollbar{display:none}
.main{max-width:900px;margin:0 auto;padding:20px 18px 80px;width:100%}
.ntab{padding:9px 14px;font-size:12px;font-weight:600;color:var(--t2);cursor:pointer;border:none;background:none;font-family:var(--f);white-space:nowrap;border-bottom:2.5px solid transparent;transition:all .15s;flex-shrink:0;text-decoration:none}
.ntab.on{color:var(--blue);border-bottom-color:var(--blue)}
.ntab .badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--red);color:#fff;font-size:9px;margin-left:4px;font-weight:700}
.tpanel{display:none}.tpanel.on{display:block}

/* ── CARDS */
.card{background:var(--w);border-radius:var(--r);box-shadow:var(--sh);margin-bottom:10px;overflow:hidden}
.ch{padding:13px 16px 0;display:flex;align-items:center;justify-content:space-between}
.ct{font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.07em;text-transform:uppercase}
.cb{padding:13px 16px 16px}

/* ── HERO */
.hero{border-radius:var(--r);padding:18px;margin-bottom:10px;transition:all .3s}
.hero.e{background:var(--w);box-shadow:var(--sh)}.hero.g{background:var(--gl);box-shadow:0 2px 20px rgba(52,199,89,.1)}.hero.y{background:var(--yl);box-shadow:0 2px 20px rgba(255,159,10,.1)}.hero.r{background:var(--rl);box-shadow:0 2px 20px rgba(255,59,48,.1)}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.hero-lbl{font-size:11px;font-weight:600;letter-spacing:.03em}
.hero.e .hero-lbl{color:var(--t3)}.hero.g .hero-lbl{color:var(--gd)}.hero.y .hero-lbl{color:var(--yd)}.hero.r .hero-lbl{color:var(--rd)}
.hero-badge{padding:3px 9px;border-radius:16px;font-size:10px;font-weight:700}
.hero.e .hero-badge{background:var(--bg4);color:var(--t3)}.hero.g .hero-badge{background:rgba(52,199,89,.15);color:var(--gd)}.hero.y .hero-badge{background:rgba(255,159,10,.15);color:var(--yd)}.hero.r .hero-badge{background:rgba(255,59,48,.15);color:var(--rd)}
.hero-amt{font-size:32px;font-weight:800;font-family:var(--m);letter-spacing:-1px;line-height:1}
.hero.e .hero-amt{color:var(--t3)}.hero.g .hero-amt{color:var(--gd)}.hero.y .hero-amt{color:var(--yd)}.hero.r .hero-amt{color:var(--rd)}
.hero-sub{font-size:11px;opacity:.7;margin-top:4px}
.hero-bg{height:4px;background:rgba(0,0,0,.06);border-radius:2px;margin-top:12px}
.hero-bar{height:4px;border-radius:2px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.hero.g .hero-bar{background:var(--green)}.hero.y .hero-bar{background:var(--yellow)}.hero.r .hero-bar{background:var(--red)}.hero.e .hero-bar{background:var(--t3)}

/* ── FORM */
.fg{margin-bottom:12px}.fg:last-child{margin-bottom:0}
.fl{display:block;font-size:11px;font-weight:600;color:var(--t2);margin-bottom:5px;letter-spacing:.02em}
.fl span{font-weight:400;color:var(--t3)}
.fw{position:relative}
.fp{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:12px;font-weight:600;color:var(--t3);font-family:var(--m);pointer-events:none}
input[type=number],input[type=text],input[type=date],input[type=password],input[type=email],textarea,select{width:100%;background:var(--bg3);border:1.5px solid transparent;border-radius:var(--rxs);color:var(--t);font-family:var(--f);font-size:13px;font-weight:500;padding:10px 11px;outline:none;transition:all .15s;-webkit-appearance:none}
input[type=number]{font-family:var(--m)}
input[type=number]{padding-left:34px}
input:focus,textarea:focus,select:focus{background:var(--w);border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,122,255,.1)}
textarea{resize:none;height:76px;font-size:13px;line-height:1.55;font-family:var(--f);font-weight:400}
select{cursor:pointer}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}

/* ── COUNTERS */
.ci{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--sep2)}
.ci:last-child{border-bottom:none;padding-bottom:0}
.ci-info{flex:1}.ci-name{font-size:13px;font-weight:600;color:var(--t)}.ci-desc{font-size:11px;color:var(--t3);margin-top:1px}
.ci-tgt{display:inline-block;margin-top:3px;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;background:var(--bl);color:var(--blue)}
.ci-ctrl{display:flex;align-items:center;gap:9px;flex-shrink:0}
.cbtn{width:27px;height:27px;border-radius:50%;border:none;background:var(--bg4);color:var(--t);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:var(--f)}
.cbtn:hover{background:var(--blue);color:#fff}
.cval{font-size:17px;font-weight:700;font-family:var(--m);width:24px;text-align:center;transition:color .2s}
.cval.hit{color:var(--green)}

/* ── CHECKBOX */
.chk-row{display:flex;align-items:center;gap:8px;padding:9px 0;border-bottom:1px solid var(--sep2);cursor:pointer}
.chk-row:last-child{border-bottom:none;padding-bottom:0}
.chk-box{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--bg5);background:var(--bg3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.chk-box.on{background:var(--blue);border-color:var(--blue)}.chk-box.on::after{content:'✓';font-size:11px;color:#fff;font-weight:700}
.chk-lbl{font-size:13px;color:var(--t2);flex:1}.chk-lbl.on{color:var(--t)}
.chk-status{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px}
.chk-ok{background:var(--gl);color:var(--gd)}.chk-bad{background:var(--rl);color:var(--rd)}

/* ── RATINGS */
.stars{display:flex;gap:3px}.star{font-size:19px;cursor:pointer;color:var(--bg4);transition:color .1s;line-height:1}.star.on{color:var(--yellow)}
.rrow{display:flex;align-items:center;gap:8px;margin-bottom:6px}.rlabel{font-size:11px;color:var(--t2);width:80px;flex-shrink:0}

/* ── DYNAMIC ITEMS */
.dyn-item{background:var(--bg3);border-radius:var(--rs);padding:12px;margin-bottom:8px;border-left:3px solid var(--blue);position:relative}
.dyn-item.danger{border-color:var(--red)}.dyn-item.warn{border-color:var(--yellow)}
.dyn-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dyn-title{font-size:11px;font-weight:700;color:var(--t2);letter-spacing:.04em;text-transform:uppercase}
.dyn-rm{width:22px;height:22px;border-radius:50%;background:var(--rl);color:var(--rd);border:none;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:var(--f);flex-shrink:0}
.add-btn{display:flex;align-items:center;gap:6px;background:none;border:1.5px dashed var(--bg5);border-radius:var(--rxs);padding:10px 14px;font-size:13px;font-weight:600;color:var(--t3);cursor:pointer;width:100%;font-family:var(--f);transition:all .15s;margin-top:4px}
.add-btn:hover{border-color:var(--blue);color:var(--blue)}

/* ── ALARM */
.alarm-box{background:var(--rl);border:1.5px solid rgba(255,59,48,.2);border-radius:var(--rs);padding:13px;margin-bottom:10px;display:none;animation:sdn .22s ease}
@keyframes sdn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.alarm-hdr{display:flex;align-items:center;gap:7px;margin-bottom:10px}
.alarm-dot{width:22px;height:22px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;flex-shrink:0}
.alarm-t{font-size:13px;font-weight:700;color:var(--rd)}.alarm-s{font-size:11px;color:var(--rd);opacity:.7}

/* ── BANNERS */
.saved{background:var(--gl);border:1.5px solid rgba(52,199,89,.22);border-radius:var(--rs);padding:10px 13px;display:none;align-items:center;gap:8px;margin-bottom:10px}
.saved .ck{width:19px;height:19px;background:var(--green);border-radius:50%;color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.saved .sm{font-size:12px;font-weight:600;color:var(--gd)}
.draft-banner{background:var(--yl);border:1.5px solid rgba(255,159,10,.22);border-radius:var(--rs);padding:10px 13px;display:none;align-items:center;gap:8px;margin-bottom:10px}
.draft-banner .di{font-size:12px;font-weight:600;color:var(--yd)}

/* ── BUTTONS */
.btn-row{display:flex;gap:8px;margin-top:8px}
.btn{height:46px;border:none;border-radius:11px;font-size:14px;font-weight:700;cursor:pointer;font-family:var(--f);transition:all .2s;flex:1}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 4px 14px rgba(0,122,255,.25)}
.btn-blue:hover{transform:translateY(-1px)}
.btn-blue:disabled{background:var(--bg4);color:var(--t3);box-shadow:none;transform:none;cursor:not-allowed}
.btn-outline{background:var(--bg3);color:var(--t2);border:1.5px solid var(--sep)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}

/* ── TASKS */
.task-item{background:var(--w);border-radius:var(--rs);padding:13px;margin-bottom:8px;box-shadow:var(--sh);border-left:3px solid var(--blue)}
.task-item.done{border-color:var(--green);opacity:.75}.task-item.overdue{border-color:var(--red)}.task-item.pending{border-color:var(--yellow)}
.task-top{display:flex;align-items:flex-start;gap:8px;margin-bottom:6px}
.task-title{font-size:13px;font-weight:700;color:var(--t);flex:1}
.task-pri{font-size:9px;font-weight:700;padding:2px 7px;border-radius:10px;flex-shrink:0}
.task-desc{font-size:12px;color:var(--t2);margin-bottom:6px;line-height:1.5}
.task-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.task-chip{font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;background:var(--bg4);color:var(--t2)}
.task-chip.blue{background:var(--bl);color:var(--blue)}.task-chip.green{background:var(--gl);color:var(--gd)}.task-chip.red{background:var(--rl);color:var(--rd)}.task-chip.yellow{background:var(--yl);color:var(--yd)}.task-chip.purple{background:var(--pl);color:var(--pd)}
.task-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.task-btn{padding:5px 12px;border-radius:8px;font-size:11px;font-weight:700;cursor:pointer;border:none;font-family:var(--f)}
.tbtn-done{background:var(--gl);color:var(--gd)}.tbtn-approve{background:var(--bl);color:var(--blue)}.tbtn-reject{background:var(--rl);color:var(--rd)}
.ms-wrap{position:relative}.ms-chips{display:flex;flex-wrap:wrap;gap:4px;padding:8px 10px;background:var(--bg3);border-radius:var(--rxs);min-height:38px;cursor:pointer;border:1px solid var(--sep)}
.ms-chip{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:3px 8px;background:var(--pl,rgba(0,122,255,.1));color:var(--pd,#007aff);border-radius:12px}
.ms-chip .ms-x{cursor:pointer;font-weight:800;margin-left:2px;font-size:13px;line-height:1}
.ms-dd{position:absolute;top:100%;left:0;right:0;background:var(--w);border-radius:var(--rxs);box-shadow:0 8px 30px rgba(0,0,0,.14);max-height:200px;overflow-y:auto;display:none;z-index:200;border:1px solid var(--sep);margin-top:2px}
.ms-dd.open{display:block}
.ms-opt{padding:9px 12px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .1s}
.ms-opt:hover{background:var(--bg3)}.ms-opt.sel{background:var(--bl);color:var(--blue)}

/* ── PROGRESS BARS */
.prog-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--sep2)}
.prog-row:last-child{border-bottom:none}
.prog-name{font-size:11px;font-weight:500;color:var(--t2);width:110px;flex-shrink:0}
.prog-track{flex:1;height:5px;background:var(--bg4);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width .4s cubic-bezier(.4,0,.2,1)}
.prog-n{font-family:var(--m);font-size:11px;font-weight:600;width:30px;text-align:right}

/* ── STATS */
.ceo-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:10px}
.ceo-col-left,.ceo-col-right{min-width:0}
.stats4{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;margin-bottom:10px}
.stats6{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;margin-bottom:10px}
.stile{background:var(--w);border-radius:var(--rs);padding:12px;box-shadow:var(--sh);display:flex;flex-direction:column}
.sl{font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.sv{font-size:22px;font-weight:800;font-family:var(--m);letter-spacing:-1px;line-height:1}
.ss{font-size:10px;color:var(--t3);margin-top:2px}

/* ── TABLE */
.ht{width:100%;border-collapse:collapse}
.ht th{font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.05em;text-transform:uppercase;text-align:left;padding:7px 10px;border-bottom:1px solid var(--sep)}
.ht td{padding:9px 10px;border-bottom:1px solid var(--sep2);font-size:12px;color:var(--t)}
.ht tr:last-child td{border-bottom:none}.ht tr:hover td{background:var(--bg3)}
.pill{display:inline-flex;align-items:center;padding:2px 7px;border-radius:10px;font-size:10px;font-weight:700}
.pg{background:rgba(52,199,89,.1);color:var(--gd)}.py{background:rgba(255,159,10,.1);color:var(--yd)}.pr{background:rgba(255,59,48,.1);color:var(--rd)}.pp{background:var(--pl);color:var(--pd)}

/* ── SECTION HEADER */
.shdr{font-size:14px;font-weight:800;color:var(--t);letter-spacing:-.2px;margin:16px 0 8px}

/* ── CHART */
.chart-w{height:150px;position:relative}

/* ── DASHBOARD FILTERS */
.filter-bar{background:var(--w);border-radius:var(--r);box-shadow:var(--sh);padding:14px 16px;margin-bottom:10px}
.filter-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.filter-row:last-child{margin-bottom:0}
.filter-label{font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.06em;text-transform:uppercase;width:70px;flex-shrink:0}
.fchips{display:flex;gap:5px;flex-wrap:wrap;flex:1}
.fchip{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--sep);background:var(--bg3);color:var(--t2);transition:all .15s;white-space:nowrap;font-family:var(--f)}
.fchip:hover{border-color:var(--blue);color:var(--blue)}
.fchip.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.fdate{background:var(--bg3);border:1.5px solid transparent;border-radius:var(--rxs);color:var(--t);font-family:var(--m);font-size:12px;padding:6px 10px;outline:none;transition:all .15s;width:auto}
.fdate:focus{border-color:var(--blue);background:var(--w);box-shadow:0 0 0 3px rgba(0,122,255,.1)}
.filter-actions{display:flex;gap:6px;margin-left:auto}
.btn-filter-apply{padding:6px 14px;background:var(--blue);color:#fff;border:none;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--f)}
.btn-filter-reset{padding:6px 12px;background:none;color:var(--t3);border:1.5px solid var(--sep);border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--f)}
.btn-filter-reset:hover{color:var(--red);border-color:var(--red)}
.filter-active-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:var(--bl);color:var(--blue);border-radius:20px;font-size:11px;font-weight:600;font-family:var(--m)}
.acc-period-btn{padding:4px 12px;border-radius:16px;font-size:11px;font-weight:600;cursor:pointer;border:1.5px solid var(--sep);background:var(--bg3);color:var(--t2);transition:all .15s;font-family:var(--f)}
.acc-period-btn.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.chart-tabs{display:flex;gap:5px;margin-bottom:8px}
.chart-tab{padding:4px 12px;border-radius:16px;font-size:11px;font-weight:600;cursor:pointer;border:none;background:var(--bg3);color:var(--t2);transition:all .15s;font-family:var(--f)}
.chart-tab.on{background:var(--blue);color:#fff}

/* ── KPI */
.kpigrid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.kpitile{background:var(--bg3);border-radius:var(--rxs);padding:9px 7px;text-align:center}
.kpipos{font-size:9px;font-weight:700;color:var(--t2);letter-spacing:.02em;margin-bottom:6px;line-height:1.3}
.kpiscore{font-size:20px;font-weight:800;font-family:var(--m);color:var(--t3)}
.kpisub{font-size:8px;color:var(--t3);margin-top:1px}

/* ── ROLE SECTION */
.rs{background:var(--w);border-radius:var(--r);box-shadow:var(--sh);margin-bottom:10px;overflow:hidden}
.rshdr{padding:11px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--sep2)}
.rstitle{font-size:13px;font-weight:700;color:var(--t);flex:1}
.rsbadge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px}
.rsbody{padding:12px 14px}

/* ── EVAL */
.emp-block{padding:12px 0;border-bottom:1px solid var(--sep2)}.emp-block:last-child{border-bottom:none;padding-bottom:0}
.emp-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.emp-name-lbl{font-size:12px;font-weight:700;color:var(--t);flex:1}
.emp-note-input{width:100%;background:var(--bg3);border:1.5px solid transparent;border-radius:var(--rxs);font-size:12px;font-family:var(--f);padding:7px 10px;outline:none;color:var(--t2);margin-top:4px;transition:all .15s}
.emp-note-input:focus{border-color:var(--blue);background:var(--w)}

/* ── MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.show{display:flex}
.modal{background:var(--w);border-radius:20px;padding:24px 22px 28px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:mup .25s cubic-bezier(.4,0,.2,1)}
@keyframes mup{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.modal-title{font-size:16px;font-weight:800;margin-bottom:16px;letter-spacing:-.2px}
.btn-sm{height:34px;padding:0 14px;font-size:12px;flex:none}

/* ── TOAST */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(60px);background:rgba(29,29,31,.92);backdrop-filter:blur(20px);color:#fff;border-radius:18px;padding:9px 16px;font-size:13px;font-weight:600;z-index:999;transition:transform .28s cubic-bezier(.4,0,.2,1);white-space:nowrap;box-shadow:0 8px 30px rgba(0,0,0,.15)}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ── EMPTY */
.empty{text-align:center;padding:26px 16px;color:var(--t3)}.empty-i{font-size:24px;margin-bottom:6px}.empty-t{font-size:13px}

/* ══════════════════════════════════════════
   RESPONSIVE SYSTEM
   ══════════════════════════════════════════ */

/* ── MOBILE FIRST — default styles are for mobile ──────── */
/* Base is already mobile-sized, add enhancements per breakpoint */

/* ── MOBILE (max 599px) */
@media(max-width:599px){
  body{font-size:14px}
  header{height:50px;padding:0 12px;gap:6px}
  .hm{width:24px;height:24px;border-radius:6px;font-size:10px}
  .hn{font-size:13px}
  .hsep{display:none}
  .hrole{font-size:10px;padding:2px 7px}
  .hd{display:none} /* hide date on mobile - too cramped */
  .draft-badge{font-size:9px;padding:2px 6px}
  .navtabs{padding:0 8px;gap:0}
  .ntab{padding:9px 11px;font-size:11px}
  .main{padding:12px 12px 80px}
  .rgrid{grid-template-columns:repeat(2,1fr);gap:8px}
  .grid2,.grid3{grid-template-columns:1fr}
  .kpigrid{grid-template-columns:repeat(3,1fr);gap:5px}
  .stats4{grid-template-columns:1fr 1fr;gap:8px}
  .stats6{grid-template-columns:repeat(2,1fr);gap:8px}
  .stile{padding:10px}
  .sv{font-size:20px}
  .hero-amt{font-size:26px;letter-spacing:-.5px}
  .hero{padding:14px 16px}
  .hero-lbl{font-size:11px}
  .filter-bar{padding:10px 12px}
  .filter-row{flex-wrap:wrap;gap:5px}
  .fchip{font-size:11px;padding:4px 10px}
  .filter-label{font-size:9px;width:55px}
  .btn{height:44px;font-size:13px}
  .btn-sm{height:32px;font-size:11px}
  .ht th,.ht td{padding:7px 8px;font-size:11px}
  .task-title{font-size:13px}
  .chart-w{height:140px}
  .shdr{font-size:13px;margin:12px 0 8px}
  .ci-name{font-size:13px}
  .ci-desc{font-size:11px}
  .dyn-item{padding:10px}
  .modal{padding:18px 14px 28px;border-radius:16px}
  .modal-title{font-size:15px}
  .user-actions{flex-direction:column;align-items:flex-end;gap:4px}
  .user-actions select{font-size:11px;padding:4px 6px}
  .kpitile{padding:8px 5px}
  .kpipos{font-size:8px}
  .kpiscore{font-size:18px}
  .card{border-radius:12px}
  .cb{padding:12px 14px 14px}
  .ch{padding:12px 14px 0}
  input[type=number],input[type=text],input[type=date],input[type=password],input[type=email],textarea,select{font-size:14px;padding:11px 12px}
  .rrow{margin-bottom:8px}
  .rlabel{font-size:12px;width:80px}
  .star{font-size:20px}
  .fl{font-size:12px}
}

/* ── TABLET (600px - 899px) */
@media(min-width:600px) and (max-width:899px){
  .main{padding:16px 18px 80px}
  .stats4{grid-template-columns:repeat(2,1fr)}
  .stats6{grid-template-columns:repeat(3,1fr)}
  .kpigrid{grid-template-columns:repeat(5,1fr)}
  .rgrid{grid-template-columns:repeat(3,1fr)}
  .grid2{grid-template-columns:1fr 1fr}
  .hero-amt{font-size:30px}
  .ntab{padding:10px 14px;font-size:12px}
}

/* ── DESKTOP MEDIUM (900px - 1199px) */
@media(min-width:900px) and (max-width:1199px){
  .main{max-width:860px;margin:0 auto;padding:20px 24px 80px}
  .stats4{grid-template-columns:repeat(4,1fr)}
  .stats6{grid-template-columns:repeat(3,1fr)}
  .kpigrid{grid-template-columns:repeat(5,1fr)}
  .rgrid{grid-template-columns:repeat(4,1fr)}
  .hero-amt{font-size:34px}
  .chart-w{height:180px}
  header{height:56px;padding:0 20px}
}

/* ── DESKTOP LARGE (1200px+) — sidebar nav */
@media(min-width:1200px){
  body{font-size:15px}
  .app{display:flex;flex-direction:column;min-height:100vh}

  /* Sidebar nav layout */
  .navtabs{
    position:fixed;
    top:62px;
    left:0;
    width:220px;
    height:calc(100vh - 62px);
    flex-direction:column;
    border-right:1px solid var(--sep);
    border-bottom:none;
    padding:14px 8px;
    overflow-y:auto;
    overflow-x:visible;
    gap:3px;
    scrollbar-width:none;
    background:var(--w);
    z-index:50;
  }
  .navtabs::-webkit-scrollbar{display:none}
  .ntab{
    border-bottom:none;
    border-left:3px solid transparent;
    border-radius:10px;
    padding:12px 14px;
    font-size:13px;
    text-align:left;
    width:100%;
  }
  .ntab.on{
    background:var(--bl);
    color:var(--blue);
    border-left-color:var(--blue);
    border-bottom:none;
  }

  /* Push content right of sidebar */
  .main{
    margin-left:220px;
    max-width:none;
    width:calc(100% - 220px);
    max-width:1400px;
    padding:24px 32px 80px;
  }
  .ceo-grid{grid-template-columns:3fr 2fr;gap:20px}

  header{height:62px;padding:0 24px}
  .hm{width:30px;height:30px;font-size:12px}
  .hn{font-size:16px}
  .hrole{font-size:12px;padding:3px 10px}

  /* Bigger elements */
  .hero-amt{font-size:40px}
  .hero{padding:22px 26px}
  .hero-lbl{font-size:13px}
  .hero-sub{font-size:13px}
  .card{border-radius:16px}
  .cb{padding:18px 22px 22px}
  .ch{padding:18px 22px 0}
  .ct{font-size:11px}
  .fl{font-size:13px}
  input[type=number],input[type=text],input[type=date],input[type=password],input[type=email],textarea,select{font-size:15px;padding:12px 14px}
  .ci-name{font-size:15px}
  .ci-desc{font-size:13px}
  .task-title{font-size:15px}
  .task-desc{font-size:13px}
  .task-chip{font-size:12px}
  .task-btn{font-size:13px;padding:6px 14px}
  .fchip{font-size:13px;padding:6px 14px}
  .chart-w{height:200px}
  .ht th{font-size:13px;padding:10px 14px}
  .ht td{font-size:14px;padding:12px 14px}
  .shdr{font-size:17px;margin:20px 0 12px}
  .btn{height:50px;font-size:15px;border-radius:13px}
  .btn-sm{height:38px;font-size:12px}
  .stats4{grid-template-columns:repeat(4,1fr)}
  .stats6{grid-template-columns:repeat(4,1fr)}
  .stile{padding:16px}
  .sl{font-size:11px}
  .sv{font-size:26px}
  .ss{font-size:12px}
  .kpigrid{grid-template-columns:repeat(5,1fr)}
  .kpipos{font-size:11px}
  .kpiscore{font-size:24px}
  .rgrid{grid-template-columns:repeat(4,1fr);max-width:860px}
  .rcard-name{font-size:15px}
  .rcard-sub{font-size:13px}
  .rname{font-size:26px}
  .ci{padding:14px 0}
  .cbtn{width:32px;height:32px;font-size:18px}
  .cval{font-size:20px}
  .rlabel{font-size:13px;width:100px}
  .star{font-size:22px}
  .modal{max-width:560px;padding:28px 26px 32px}
  .modal-title{font-size:18px}
  .prog-name{font-size:13px;width:130px}
  .prog-n{font-size:13px}
  .ntab .badge{width:18px;height:18px;font-size:10px}
}

/* ── LOGIN PAGE */
#loginPage{position:fixed;inset:0;background:linear-gradient(135deg,#f0f4ff 0%,#e8f1ff 100%);display:flex;align-items:center;justify-content:center;padding:20px;z-index:500}
.login-card{background:#fff;border-radius:24px;box-shadow:0 20px 60px rgba(0,0,0,.12),0 4px 16px rgba(0,0,0,.06);padding:40px 36px;max-width:420px;width:100%;animation:fadeUp .3s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}
.login-mark{width:46px;height:46px;background:#007aff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff}
.login-brand{font-size:20px;font-weight:800;color:#1d1d1f;letter-spacing:-.4px}
.login-brand-sub{font-size:12px;color:#aeaeb2;margin-top:1px}
.login-title{font-size:26px;font-weight:800;color:#1d1d1f;letter-spacing:-.5px;margin-bottom:6px}
.login-sub{font-size:13px;color:#6e6e73;margin-bottom:28px;line-height:1.5}
.login-fg{margin-bottom:16px}
.login-label{display:block;font-size:12px;font-weight:600;color:#6e6e73;margin-bottom:6px;letter-spacing:.02em}
.login-input{width:100%;background:#f5f5f7;border:1.5px solid transparent;border-radius:10px;color:#1d1d1f;font-family:var(--m,'JetBrains Mono',monospace);font-size:14px;padding:13px 14px;outline:none;transition:all .15s;-webkit-appearance:none}
.login-input:focus{background:#fff;border-color:#007aff;box-shadow:0 0 0 3px rgba(0,122,255,.1)}
.login-btn{width:100%;height:52px;background:#007aff;color:#fff;border:none;border-radius:13px;font-size:16px;font-weight:700;cursor:pointer;font-family:var(--f,'Plus Jakarta Sans',sans-serif);transition:all .2s;box-shadow:0 4px 14px rgba(0,122,255,.3);margin-top:4px}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,122,255,.35)}
.login-btn:disabled{background:#e8e8ed;color:#aeaeb2;box-shadow:none;transform:none;cursor:not-allowed}
.login-err{background:#fff0ef;border:1px solid rgba(255,59,48,.2);border-radius:10px;padding:11px 14px;font-size:13px;color:#c0392b;margin-bottom:14px;display:none;line-height:1.5}
.login-footer{text-align:center;margin-top:20px;font-size:12px;color:#aeaeb2}
.login-footer a{color:#007aff;cursor:pointer;text-decoration:none}
.forgot-form{display:none}
