*{box-sizing:border-box;margin:0;padding:0}
body{font-family:system-ui,-apple-system,sans-serif;background:#f8fafc;color:#1e293b;min-height:100vh}
.screen{display:none;width:100%}.screen.active{display:block}

/* ── Login ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8fafc;padding:16px}
.login-box{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:36px 32px;width:100%;max-width:360px;box-shadow:0 4px 24px rgba(0,0,0,0.06)}
.login-logo{font-size:24px;font-weight:700;color:#0F6E56;margin-bottom:4px}.login-logo span{color:#9FE1CB}
.login-sub{font-size:13px;color:#64748b;margin-bottom:24px}
.lf{margin-bottom:14px}
.lf label{display:block;font-size:12px;color:#64748b;margin-bottom:5px;font-weight:500}
.lf input{width:100%;padding:11px 13px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;color:#1e293b;font-size:16px}
.lf input:focus{outline:none;border-color:#0F6E56;background:#fff}
.pin-wrap{display:flex;gap:10px;justify-content:center;margin:6px 0}
.pbox{width:52px;height:56px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;text-align:center;font-size:22px;color:#0F6E56;outline:none;caret-color:transparent}
.pbox:focus{border-color:#0F6E56;background:#fff}
.lbtn{width:100%;padding:14px;background:#0F6E56;color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer;margin-top:6px}
.lbtn:active{background:#1D9E75}
.lerr{font-size:12px;color:#ef4444;margin-top:8px;min-height:16px;text-align:center}

/* ── App shell ── */
.app{display:block;min-height:100vh;width:100%}

/* ── Sidebar ── */
.sidebar{background:#0F6E56;display:flex;flex-direction:column;position:fixed;width:240px;height:100vh;overflow-y:auto;z-index:20;transition:transform .28s cubic-bezier(.4,0,.2,1)}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:19}
.sidebar-backdrop.open{display:block}
.main{margin-left:240px;display:flex;flex-direction:column;min-width:0;width:calc(100% - 240px);min-height:100vh}
.sbh{padding:20px 16px 14px;border-bottom:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:space-between}
.sbl{color:#fff;font-size:18px;font-weight:700}.sbl span{color:#9FE1CB}
.sbo{background:rgba(255,255,255,0.12);border:none;border-radius:6px;padding:4px 10px;color:rgba(255,255,255,0.8);font-size:11px;cursor:pointer}
.sbo:hover{background:rgba(255,255,255,0.22);color:#fff}
.sbp{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,0.1)}
.sbav{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;color:#fff;margin-bottom:8px}
.sbnm{color:#fff;font-size:14px;font-weight:500}
.sbph{color:rgba(255,255,255,0.5);font-size:11px;margin-top:2px}
.rb{display:inline-block;margin-top:5px;font-size:10px;padding:2px 8px;border-radius:4px}
.rb-a{background:rgba(250,199,117,0.2);color:#FAC775}
.rb-u{background:rgba(159,225,203,0.2);color:#9FE1CB}
.sbbal{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,0.1)}
.sbbl{color:rgba(255,255,255,0.5);font-size:10px;text-transform:uppercase;letter-spacing:1px;margin-bottom:3px}
.sbbv{color:#fff;font-size:24px;font-weight:700}
.nav{padding:12px 10px;flex:1}
.ni{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:8px;color:rgba(255,255,255,0.7);font-size:13px;cursor:pointer;margin-bottom:2px;border:none;background:none;width:100%;text-align:left}
.ni.active,.ni:hover{background:rgba(255,255,255,0.12);color:#fff}
.nico{width:16px;height:16px;flex-shrink:0}

/* ── Topbar ── */
.topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:5}
.tbtitle{font-size:17px;font-weight:500}
.badge-g{font-size:11px;padding:3px 10px;border-radius:5px;border:1px solid #1D9E75;background:#E1F5EE;color:#0F6E56}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:4px;color:#1e293b;line-height:1}

/* ── Content ── */
.content{padding:24px;flex:1;width:100%;min-width:0}
.panel{display:none}.panel.active{display:block}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:24px}
.sc{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:18px}
.sl{font-size:11px;color:#64748b;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;font-weight:500}
.sv{font-size:22px;font-weight:600;color:#1e293b}
.ss{font-size:12px;margin-top:3px}
.pos{color:#0F6E56}.neg{color:#ef4444}
.stitle{font-size:12px;font-weight:500;color:#64748b;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.tlist{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:visible}
.empty{padding:28px;text-align:center;color:#64748b;font-size:13px}
.form-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:24px;width:100%;max-width:480px}
.ff{margin-bottom:16px}
.ff label{display:block;font-size:12px;color:#64748b;margin-bottom:5px;font-weight:500}
.ff input,.ff select{display:block;width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;color:#1e293b;font-size:16px}
.ff input:focus,.ff select:focus{outline:none;border-color:#0F6E56;background:#fff}
.pin-row{display:flex;gap:10px}
.fpb{width:48px;height:52px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;text-align:center;font-size:20px;color:#0F6E56;outline:none;caret-color:transparent}
.fpb:focus{border-color:#0F6E56;background:#fff}
.fbtn{display:block;width:100%;padding:13px;background:#0F6E56;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;margin-top:4px}
.fbtn:active{background:#1D9E75}
.fmsg{font-size:12px;margin-top:8px;min-height:16px}
.fmsg.ok{color:#0F6E56}.fmsg.err{color:#ef4444}
.ut-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow-x:auto}
.ut{width:100%;border-collapse:collapse;font-size:13px}
.ut th{padding:10px 16px;text-align:left;font-size:11px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid #e2e8f0;background:#f8fafc}
.ut td{padding:12px 16px;border-bottom:1px solid #e2e8f0;vertical-align:middle;color:#1e293b}
.ut tr:last-child td{border-bottom:none}
.ab{padding:5px 12px;border-radius:6px;border:1px solid #e2e8f0;background:#fff;font-size:11px;cursor:pointer;margin-right:4px;color:#1e293b}
.ab:hover{background:#f8fafc}
.ab.fn{border-color:#1D9E75;color:#0F6E56;background:#E1F5EE}
.succ-box{background:#E1F5EE;border:1px solid #1D9E75;border-radius:14px;padding:18px;max-width:480px;margin-top:16px}

/* ── Modals ── */
.overlay-wrap{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:100;align-items:center;justify-content:center}
.overlay-wrap.open{display:flex}
.modal{background:#fff;border-radius:16px;width:400px;overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,0.15)}
.modal-hdr{background:#0F6E56;padding:18px 20px;display:flex;align-items:center;justify-content:space-between}
.modal-title{color:#fff;font-size:15px;font-weight:500}
.modal-close{background:rgba(255,255,255,0.15);border:none;border-radius:6px;padding:4px 9px;color:rgba(255,255,255,0.85);font-size:12px;cursor:pointer}
.modal-body{padding:22px}
.fqa-row{display:flex;gap:8px;margin-bottom:14px}
.fqa{flex:1;padding:8px 4px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;font-size:12px;cursor:pointer;text-align:center;color:#64748b}
.fqa:active{border-color:#0F6E56;color:#0F6E56;background:#E1F5EE}

/* ── Bottom nav (mobile only) ── */
.bnav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e2e8f0;z-index:8;padding-bottom:env(safe-area-inset-bottom,0px)}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px 6px;border:none;background:none;cursor:pointer;color:#94a3b8;font-size:10px;gap:2px;font-family:inherit}
.bn.active{color:#0F6E56}
.bn svg{width:22px;height:22px}

/* ── Mobile responsive ── */
@media(max-width:767px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;width:100%}
  .menu-btn{display:flex;align-items:center}
  .topbar{padding:12px 16px}
  .tbtitle{font-size:15px}
  .content{padding:14px;padding-bottom:76px}
  .g3{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
  .g2{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
  .sc{padding:14px 12px}
  .sv{font-size:18px}
  .form-wrap{max-width:100%;padding:16px}
  .overlay-wrap{align-items:flex-end;padding:0}
  .modal{width:100%;border-radius:20px 20px 0 0;max-height:88vh;overflow-y:auto}
  .bnav{display:flex}
  .stitle{margin-bottom:8px}
}
@media(max-width:380px){
  .g3{grid-template-columns:1fr}
  .pbox{width:44px;height:50px}
}
