*{box-sizing:border-box;margin:0;padding:0}
html{background:#f0f2f5}
body{font-family:Arial,sans-serif;font-size:14px;background:#f0f2f5;color:#1a1a2e}
button,input,select,textarea{font-family:inherit;font-size:14px}
img{max-width:100%}

/* ═══ LOGIN ════════════════════════════════════════════════════════ */
/* DESKTOP: 2-column layout — dark left panel + white card on right */
#LP{display:flex;min-height:100vh;flex-wrap:wrap;background:#f0f2f5;position:relative;overflow:hidden}
.LL{width:340px;background:#0a1628;padding:40px 36px;display:flex;flex-direction:column;justify-content:center;flex-shrink:0;z-index:3}
.lBox{width:34px;height:34px;background:#1a6ef5;border-radius:8px;display:grid;grid-template-columns:1fr 1fr;gap:3px;padding:6px;margin-bottom:32px}
.lBox span{background:#fff;border-radius:2px;display:block}
.lBox span:nth-child(3){background:#00b8d9}
.lT{font-size:24px;font-weight:700;color:#fff;margin-bottom:10px;line-height:1.3}
.lT em{color:#00b8d9;font-style:normal}
.lD{font-size:12px;color:rgba(255,255,255,.45);line-height:1.7;margin-bottom:24px}
.lF{display:flex;align-items:flex-start;gap:9px;margin-bottom:12px}
.lFi{width:28px;height:28px;background:rgba(255,255,255,.1);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;margin-top:1px}
.lFt{font-size:11px;font-weight:700;color:#fff;margin-bottom:1px}
.lFd{font-size:10px;color:rgba(255,255,255,.35)}
.LR{flex:1;min-width:300px;display:flex;align-items:center;justify-content:center;padding:32px 20px;z-index:3}

/* Curves: hidden on desktop, visible on mobile */
.lp-curve{display:none;position:absolute;width:100%;height:220px;pointer-events:none;z-index:1}
.lp-curve-top{top:0;left:0;right:0}
.lp-curve-bot{bottom:0;left:0;right:0;transform:scaleX(-1)}

/* Login card — wrapped on desktop in a bordered box, plain on mobile */
.lp-card{position:relative;z-index:2;width:100%;max-width:420px;padding:30px 28px;text-align:left;background:#fff;border-radius:14px;border:1px solid #ddd;box-shadow:0 4px 20px rgba(0,0,0,.08)}

/* Input-row icon prefix */
.lp-input-icon{position:absolute;left:0;top:50%;transform:translateY(-50%);font-size:14px;color:#1a6ef5;opacity:.6;pointer-events:none;width:22px;text-align:center}
.lp-input-row input{padding-left:0}
.lp-welcome{font-size:28px;font-weight:700;color:#0a4a8f;margin-bottom:6px}
.lp-sub{font-size:14px;color:#0a4a8f;margin-bottom:36px}

.lp-logo{text-align:center;margin:32px 0 36px}
.lp-logo-icon{font-size:34px;display:inline-block;color:#0a4a8f;margin-bottom:2px}
.lp-logo-text{font-size:22px;font-weight:900;color:#0a4a8f;letter-spacing:1.5px;line-height:1}
.lp-logo-text em{color:#1a6ef5;font-style:normal}
.lp-logo-tag{font-size:10px;color:#1a6ef5;letter-spacing:3px;margin-top:4px;text-transform:uppercase;font-weight:600}

.lp-input-row{position:relative;margin-bottom:22px;padding-bottom:6px;border-bottom:1px solid #ccc}
.lp-input-row:focus-within{border-bottom-color:#1a6ef5}
.lp-input-row input{width:100%;padding:6px 32px 6px 0;border:none;outline:none;background:transparent;font-size:15px;color:#0a1628}
.lp-input-row input::placeholder{color:#999}
.lp-eye{position:absolute;right:0;top:50%;transform:translateY(-50%);color:#999;cursor:pointer;font-size:16px;padding:6px;user-select:none}
.lp-eye:hover{color:#1a6ef5}

.lp-btn{width:100%;padding:14px;border:none;border-radius:30px;font-size:15px;font-weight:700;cursor:pointer;margin-top:14px;transition:all .15s}
.lp-btn-primary{background:#0a4a8f;color:#fff;box-shadow:0 4px 12px rgba(10,74,143,.25)}
.lp-btn-primary:hover{background:#0d5aa8}
.lp-btn-outline{background:#1a6ef5;color:#fff;box-shadow:0 4px 12px rgba(26,110,245,.25)}
.lp-btn-outline:hover{background:#0d5fd0}

.lp-forgot{text-align:center;margin-top:18px}
.lp-forgot a{font-size:12px;color:#1a6ef5;text-decoration:none}
.lp-forgot a:hover{text-decoration:underline}

.lp-contact{display:flex;justify-content:center;gap:16px;margin-top:24px;padding-top:14px;border-top:1px solid #eee}
.lp-contact a{font-size:18px;color:#1a6ef5;text-decoration:none;width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(26,110,245,.08);transition:background .15s}
.lp-contact a:hover{background:rgba(26,110,245,.18)}

.loginErr{background:#ffebe6;color:#bf2600;border-radius:7px;padding:9px 12px;font-size:12px;margin-bottom:14px;border:1px solid rgba(222,53,11,.2);display:none}

@media(max-width:700px){
  /* ─── MOBILE LOGIN — polished ─── */
  #LP{background:linear-gradient(180deg,#f8fbff 0%,#fff 35%,#fff 65%,#f8fbff 100%);align-items:center;justify-content:center;display:flex}
  .LL{display:none}
  .LR{padding:20px 16px;width:100%}
  .lp-curve{display:block;height:240px}
  .lp-curve-top{filter:drop-shadow(0 4px 20px rgba(26,110,245,.18))}
  .lp-curve-bot{filter:drop-shadow(0 -4px 20px rgba(26,110,245,.18))}

  /* Card: glass effect with fade-in */
  .lp-card{
    padding:48px 24px 28px;max-width:100%;
    background:rgba(255,255,255,.85);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,.6);
    border-radius:24px;
    box-shadow:0 20px 60px rgba(10,74,143,.15),0 6px 20px rgba(26,110,245,.08);
    animation:lpFadeUp .55s cubic-bezier(.22,.61,.36,1) both;
  }
  @keyframes lpFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

  /* Welcome heading: gradient text + tighter spacing */
  .lp-welcome{
    font-size:30px;font-weight:800;line-height:1.15;margin-bottom:8px;
    background:linear-gradient(135deg,#0a4a8f,#1a6ef5);
    -webkit-background-clip:text;background-clip:text;color:transparent;
  }
  .lp-sub{font-size:13.5px;color:#5a7a99;margin-bottom:28px;line-height:1.5}

  /* Logo: circular gradient halo behind the cap */
  .lp-logo{margin:24px 0 32px;position:relative}
  .lp-logo-icon{
    font-size:42px;width:84px;height:84px;border-radius:50%;
    background:linear-gradient(135deg,#4c9aff 0%,#1a6ef5 50%,#0a4a8f 100%);
    color:#fff;display:inline-flex;align-items:center;justify-content:center;
    box-shadow:0 10px 30px rgba(26,110,245,.4),inset 0 -3px 12px rgba(0,0,0,.15);
    margin-bottom:10px;
    animation:lpLogoPop .6s cubic-bezier(.34,1.56,.64,1) .15s both;
  }
  @keyframes lpLogoPop{from{opacity:0;transform:scale(.4) rotate(-15deg)}to{opacity:1;transform:scale(1) rotate(0)}}
  .lp-logo-text{font-size:24px;font-weight:900;color:#0a4a8f;letter-spacing:2px}
  .lp-logo-text em{color:#1a6ef5;font-style:normal}
  .lp-logo-tag{font-size:9.5px;color:#5a7a99;letter-spacing:3.5px;margin-top:6px;font-weight:700}

  /* Input rows: bigger padding, smooth focus glow */
  .lp-input-row{
    position:relative;margin-bottom:16px;padding:14px 12px 14px 38px;
    background:#fff;border:1.5px solid #e6ecf3;border-radius:12px;
    transition:all .2s;
  }
  .lp-input-row:focus-within{
    border-color:#1a6ef5;
    box-shadow:0 0 0 4px rgba(26,110,245,.12),0 4px 12px rgba(26,110,245,.1);
  }
  .lp-input-icon{left:14px;font-size:16px;opacity:.7}
  .lp-input-row:focus-within .lp-input-icon{opacity:1}
  .lp-input-row input{font-size:14.5px;padding:0 30px 0 0;background:transparent}
  .lp-eye{font-size:15px;padding:4px 8px}

  /* Buttons: gradient + arrow + hover lift */
  .lp-btn{
    padding:15px;border-radius:14px;font-size:15px;font-weight:700;
    letter-spacing:.3px;margin-top:10px;position:relative;overflow:hidden;
    transition:transform .15s,box-shadow .15s;
  }
  .lp-btn:hover{transform:translateY(-2px)}
  .lp-btn:active{transform:translateY(0)}
  .lp-btn-primary{
    background:linear-gradient(135deg,#1a6ef5 0%,#0a4a8f 100%);
    box-shadow:0 8px 20px rgba(26,110,245,.35);
  }
  .lp-btn-primary:hover{box-shadow:0 12px 28px rgba(26,110,245,.5)}
  .lp-btn-primary::after{content:" →";opacity:.85}
  .lp-btn-outline{
    background:#fff;color:#1a6ef5;border:1.5px solid #1a6ef5;
    box-shadow:0 4px 12px rgba(26,110,245,.1);
  }
  .lp-btn-outline:hover{background:#eff6ff;box-shadow:0 6px 16px rgba(26,110,245,.2)}

  /* Forgot link */
  .lp-forgot{margin-top:22px}
  .lp-forgot a{font-size:12.5px;font-weight:600;padding:6px 12px;border-radius:14px;display:inline-block}
  .lp-forgot a:hover{background:rgba(26,110,245,.08);text-decoration:none}

  /* Contact icons: pill chips with subtle pop */
  .lp-contact{margin-top:28px;padding-top:18px;border-top-color:#eef1f7;gap:12px}
  .lp-contact a{
    width:42px;height:42px;font-size:17px;
    box-shadow:0 4px 10px rgba(26,110,245,.12);
    transition:transform .15s,box-shadow .15s;
  }
  .lp-contact a:hover{transform:translateY(-2px);box-shadow:0 6px 14px rgba(26,110,245,.22)}

  /* Loginerr animation */
  .loginErr{animation:lpShake .4s both}
  @keyframes lpShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
}
@media(max-width:380px){
  .lp-welcome{font-size:26px}
  .lp-logo-icon{width:72px;height:72px;font-size:36px}
}

/* ═══ APP SHELL ════════════════════════════════════════════════════ */
#AP{display:none;height:100vh;overflow:hidden;flex-direction:column}
#AP.open{display:flex}
.AW{display:flex;flex:1;overflow:hidden;position:relative}

/* sidebar */
.SB{width:220px;flex-shrink:0;background:#0a1628;display:flex;flex-direction:column;height:100%;padding-top:env(safe-area-inset-top);transition:transform .25s;z-index:100}
.sbTop{padding:13px 12px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:8px;flex-shrink:0}
.sbLB{width:26px;height:26px;background:#1a6ef5;border-radius:6px;display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:5px;flex-shrink:0}
.sbLB span{background:#fff;border-radius:1px;display:block}
.sbLB span:nth-child(3){background:#00b8d9}
.sbLN{font-size:14px;font-weight:700;color:#fff;flex:1}
.sbLN em{color:#00b8d9;font-style:normal}
.sbClose{display:none;background:none;border:none;color:rgba(255,255,255,.5);font-size:18px;cursor:pointer;padding:2px 6px}
.sbSW{padding:7px 11px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}
.sbSLbl{font-size:9px;font-weight:700;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.sbSS{width:100%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:5px 8px;font-size:11px;color:#fff;cursor:pointer;outline:none}
.sbSS option{background:#162352}
.sbNav{flex:1;padding:6px 0;overflow-y:auto}
.sbSec{font-size:9px;font-weight:700;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.08em;padding:10px 12px 3px}
.sbIt{display:flex;align-items:center;gap:9px;padding:8px 12px;cursor:pointer;font-size:12px;font-weight:500;color:rgba(255,255,255,.55);border-left:3px solid transparent;transition:all .15s}
.sbIt:hover{background:rgba(255,255,255,.07);color:#fff}
.sbIt.active{background:rgba(26,110,245,.25);color:#fff;border-left-color:#4c9aff;font-weight:700}
.sbIc{font-size:13px;width:17px;text-align:center;flex-shrink:0}
.sbBdg{margin-left:auto;background:#1a6ef5;color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px}
.sbUsr{padding:11px 12px;padding-bottom:max(11px, env(safe-area-inset-bottom));border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:8px;flex-shrink:0}
.sbAv{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
.sbNm{font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sbRl{font-size:10px;color:rgba(255,255,255,.4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sbOut{margin-left:auto;cursor:pointer;color:rgba(255,255,255,.6);background:rgba(255,255,255,.08);border:none;font-size:18px;flex-shrink:0;width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.sbOut:hover,.sbOut:active{color:#fff;background:rgba(255,80,80,.5)}
.sbOverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99}

/* topbar */
.MA{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.TB{min-height:50px;flex-shrink:0;background:#fff;border-bottom:1px solid #ddd;display:flex;align-items:center;padding:max(0px, calc(env(safe-area-inset-top) - 14px)) 16px 0;gap:8px;box-sizing:border-box}
.tbMenu{display:none;background:#1a6ef5;border:none;font-size:22px;cursor:pointer;color:#fff;flex-shrink:0;padding:6px 12px;border-radius:7px;line-height:1;box-shadow:0 2px 6px rgba(26,110,245,.35)}
.tbMenu:active{background:#0052cc}
.tbTitle{font-size:14px;font-weight:700;color:#0a1628;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tbTag{font-size:9px;font-weight:700;background:#e3fcef;color:#006644;padding:3px 8px;border-radius:4px;white-space:nowrap}
.tbLang{display:flex;background:#f0f2f5;border-radius:6px;padding:2px;gap:2px}
.tbLB{padding:3px 8px;border-radius:4px;border:none;background:transparent;font-size:10px;font-weight:700;cursor:pointer;color:#666;transition:all .15s}
.tbLB.on{background:#0a1628;color:#fff}
.tbBtn{padding:5px 10px;border-radius:6px;border:1px solid #ddd;background:transparent;font-size:11px;font-weight:700;color:#555;cursor:pointer;transition:all .15s;white-space:nowrap}
.tbBtn:hover{border-color:#1a6ef5;color:#1a6ef5;background:#eff6ff}
.PA{flex:1;overflow-y:auto;padding:16px;padding-bottom:max(16px, env(safe-area-inset-bottom))}

/* ═══ COMPONENTS ═══════════════════════════════════════════════════ */
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.phT{font-size:18px;font-weight:700;color:#0a1628;margin-bottom:2px}
.phS{font-size:11px;color:#666}
.phA{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.kG{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}
.kC{background:#fff;border-radius:9px;border:1px solid #ddd;padding:12px 14px}
.kL{font-size:10px;font-weight:700;color:#666;text-transform:uppercase;letter-spacing:.03em;margin-bottom:5px}
.kV{font-size:24px;font-weight:700;color:#0a1628;line-height:1}
.kSb{font-size:10px;color:#999;margin-top:3px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.box{background:#fff;border-radius:9px;border:1px solid #ddd;margin-bottom:10px}
.bH{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-bottom:1px solid #eee;flex-wrap:wrap;gap:6px}
.bT{font-size:12px;font-weight:700;color:#0a1628}
.bB{padding:12px 14px}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:10px;font-weight:700;color:#666;padding:7px 11px;border-bottom:1px solid #ddd;text-transform:uppercase;background:#f8f8f8;white-space:nowrap}
td{padding:8px 11px;border-bottom:1px solid #eee;font-size:12px;color:#333}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafafa}
.tW{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tN{display:flex;align-items:center;gap:7px;font-weight:700;color:#1a1a2e}
.av{width:26px;height:26px;border-radius:50%;font-size:10px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bdg{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:700}
.bg{background:#e3fcef;color:#006644}.ba{background:#ffebe6;color:#bf2600}
.bl{background:#fff7d6;color:#974f0c}.bb{background:#ebf3ff;color:#0052cc}
.bgr{background:#eee;color:#444}.bpur{background:#eae6ff;color:#403294}
.btn{padding:6px 11px;border-radius:6px;border:1.5px solid #ddd;background:transparent;font-size:11px;font-weight:700;color:#333;cursor:pointer;transition:all .15s}
.btn:hover{border-color:#1a6ef5;color:#1a6ef5;background:#eff6ff}
.btnP{background:#1a6ef5;color:#fff;border-color:#1a6ef5}.btnP:hover{background:#0052cc;color:#fff}
.btnG{background:#36b37e;color:#fff;border-color:#36b37e}.btnG:hover{background:#006644;color:#fff}
.btnR{background:#de350b;color:#fff;border-color:#de350b}.btnR:hover{background:#bf2600;color:#fff}
.btnO{background:#ff991f;color:#fff;border-color:#ff991f}
.pb{height:5px;background:#eee;border-radius:3px;overflow:hidden}
.pbF{height:100%;border-radius:3px}
.ann{padding:9px 13px;border-radius:7px;margin-bottom:7px;border-left:3px solid #1a6ef5;background:#ebf3ff}
.annT{font-size:12px;font-weight:700;color:#0a1628;margin-bottom:2px}
.annB{font-size:11px;color:#444;margin-bottom:3px}
.annM{font-size:10px;color:#888}
.msg{padding:9px 11px;border-radius:7px;border:1px solid #ddd;margin-bottom:5px;cursor:pointer;transition:all .15s}
.msg:hover{border-color:#1a6ef5;background:#eff6ff}
.msg.unread{border-left:3px solid #1a6ef5}
.msgF{font-size:12px;font-weight:700;color:#0a1628;margin-bottom:2px}
.msgS{font-size:11px;color:#666}
.msgT{font-size:10px;color:#aaa}
.rCard{background:#f8f8f8;border-radius:8px;padding:14px;border:1px solid #ddd;cursor:pointer;transition:all .15s;height:100%}
.rCard:hover{border-color:#1a6ef5;background:#eff6ff}
.fi label{display:block;font-size:11px;font-weight:700;color:#333;margin-bottom:3px}
.fi input,.fi select,.fi textarea{width:100%;padding:8px 10px;border:1.5px solid #ddd;border-radius:6px;font-size:13px;color:#1a1a2e;outline:none;transition:border-color .15s}
.fi input:focus,.fi select:focus,.fi textarea:focus{border-color:#1a6ef5}
.fsel{padding:6px 9px;border-radius:6px;border:1px solid #ddd;background:#fff;font-size:11px;color:#333;cursor:pointer;outline:none}
.sw{display:flex;align-items:center;background:#fff;border:1px solid #ddd;border-radius:7px;overflow:hidden}
.sw input{border:none;background:transparent;padding:6px 9px;font-size:12px;color:#1a1a2e;outline:none;flex:1;min-width:0}
.swIc{padding:0 9px;color:#999;font-size:12px;flex-shrink:0}
.MOv{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:600;display:none;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto}
.MOv.open{display:flex}
.MB{background:#fff;border-radius:12px;padding:22px;width:100%;max-width:500px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.2);margin:auto}
.MB.wide{max-width:600px}
.MT{font-size:16px;font-weight:700;color:#0a1628;margin-bottom:3px}
.MS{font-size:11px;color:#666;margin-bottom:16px}
.MC{position:absolute;top:12px;right:12px;background:none;border:none;font-size:18px;cursor:pointer;color:#999;line-height:1}
.MF{display:flex;justify-content:flex-end;gap:7px;margin-top:16px;flex-wrap:wrap}
.toast{position:fixed;bottom:16px;right:16px;left:16px;max-width:360px;margin:0 auto;z-index:9999;background:#0a1628;color:#fff;padding:10px 16px;border-radius:9px;font-size:13px;font-weight:600;box-shadow:0 4px 20px rgba(0,0,0,.2);transform:translateY(100px);opacity:0;transition:all .3s;pointer-events:none;text-align:center}
.toast.show{transform:translateY(0);opacity:1}
.WB{background:linear-gradient(135deg,#0a1628,#162352);border-radius:10px;padding:16px 20px;margin-bottom:14px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.WBav{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;flex-shrink:0}
.WBn{font-size:15px;font-weight:700;color:#fff}
.WBs{font-size:10px;color:rgba(255,255,255,.5);margin-top:2px}
.WBc{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap}
.WBch{font-size:9px;font-weight:700;padding:3px 8px;border-radius:4px}
.grA{color:#006644;font-weight:700}.grB{color:#0052cc;font-weight:700}
.grC{color:#974f0c;font-weight:700}.grF{color:#bf2600;font-weight:700}
.schC{background:#fff;border-radius:9px;border:1px solid #ddd;overflow:hidden}
.empty{text-align:center;padding:36px 16px;color:#999}
.emIc{font-size:32px;margin-bottom:8px}
.cred-badge{display:inline-flex;align-items:center;gap:5px;background:#f0f4ff;border:1px solid #c7d7ff;border-radius:7px;padding:5px 10px;font-size:11px;font-weight:700;color:#0052cc;margin:2px}
.cred-copy{cursor:pointer;background:#1a6ef5;color:#fff;border:none;border-radius:4px;padding:2px 7px;font-size:10px;font-weight:700}
.acc-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid #eee}
.acc-row:last-child{border-bottom:none}
.acc-info{flex:1;min-width:0}
.acc-nm{font-size:13px;font-weight:700;color:#0a1628}
.acc-meta{font-size:11px;color:#666;margin-top:1px}
.acc-creds{font-family:monospace;font-size:11px;background:#f5f5f5;padding:2px 7px;border-radius:4px;color:#333}
.pin-box{display:flex;gap:6px;justify-content:center;margin:14px 0}
.pin-digit{width:44px;height:54px;border:2px solid #ddd;border-radius:8px;text-align:center;font-size:22px;font-weight:700;outline:none;transition:border-color .15s}
.pin-digit:focus{border-color:#1a6ef5}

/* ═══ EDITABLE TIMETABLE ═══ */
.tt-cell{cursor:pointer;transition:transform .12s,box-shadow .12s;user-select:none}
.tt-cell:hover{transform:scale(1.04);box-shadow:0 2px 8px rgba(26,110,245,.25)}
.tt-empty{display:inline-block;padding:4px 12px;border:2px dashed #ccc;border-radius:5px;font-size:10px;color:#999;cursor:pointer;transition:all .15s}
.tt-empty:hover{border-color:#1a6ef5;color:#1a6ef5;background:#eff6ff}

/* ═══ EXAMS ═══ */
.exam-status-upcoming{background:#ebf3ff;color:#0052cc}
.exam-status-today{background:#fff7d6;color:#974f0c}
.exam-status-past{background:#eee;color:#555}
.exam-status-results{background:#e3fcef;color:#006644}
.mark-input{width:60px;padding:5px 7px;border:1.5px solid #ddd;border-radius:5px;font-size:12px;text-align:center;outline:none}
.mark-input:focus{border-color:#1a6ef5}
.mark-pass{background:#e3fcef!important;color:#006644;font-weight:700}
.mark-fail{background:#ffebe6!important;color:#bf2600;font-weight:700}

/* ═══ PRINT ═══ */
@media print{
  .SB,.TB,button,.MOv,.toast,.tbMenu,.phA,.sbOverlay{display:none!important}
  .PA{padding:0}
  .MA{overflow:visible}
  #AP{height:auto;overflow:visible}
  .box{break-inside:avoid;border:1px solid #aaa}
  body{background:#fff;font-size:12px}
  table{font-size:11px}
  th{background:#f0f0f0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .bdg,.pbF{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* ═══ MOBILE RESPONSIVE ════════════════════════════════════════════ */
@media(max-width:700px){
  /* login */
  /* old .LL/.LR removed in redesign — no-op kept for safety */
  /* sidebar */
  .SB{position:fixed;top:0;left:0;height:100%;transform:translateX(-100%);width:260px}
  .SB.open{transform:translateX(0)}
  .sbClose{display:block}
  .sbOverlay{display:none}
  .sbOverlay.open{display:block}
  .tbMenu{display:block}
  /* grids */
  .kG{grid-template-columns:repeat(2,1fr)}
  .g2{grid-template-columns:1fr}
  .g3{grid-template-columns:1fr}
  /* tables */
  .tW{font-size:11px}
  th,td{padding:6px 8px}
  /* modals */
  .MB,.MB.wide{max-width:100%;margin:0;border-radius:12px 12px 0 0;position:fixed;bottom:0;left:0;right:0}
  .MOv{align-items:flex-end;padding:0}
  .WB{flex-direction:column;align-items:flex-start}
  /* page */
  .PA{padding:10px}
  .phT{font-size:16px}
  .ph{gap:8px}
  .phA{gap:5px}
  .btn{padding:5px 9px;font-size:11px}
  .bH{padding:9px 12px}
  .bB{padding:10px 12px}
  /* hide non-essential table cols on mobile */
  .hide-mob{display:none}
}
@media(max-width:400px){
  .kG{grid-template-columns:1fr 1fr}
  .rG{grid-template-columns:repeat(3,1fr)}
  .dRow{grid-template-columns:repeat(3,1fr)}
  .kV{font-size:20px}
}