:root{
  --bg:#f0f2f7;--sf:#ffffff;--bd:#e2e6f0;--bds:#c8cfe0;
  --tx:#0f1117;--tm:#5a6070;--th:#9aa0b0;
  --ac:#3b6ef8;--acb:#ebf0fe;--ac2:#2952d4;
  --gn:#0d7a48;--gnb:#e6f7ef;
  --or:#c45e00;--orb:#fef4e6;
  --rd:#c0302a;--rdb:#fdecea;
  --pu:#6d28d9;--pub:#f2effe;
  --mn:'IBM Plex Mono',monospace;--sn:'Geist',sans-serif;
  --sh:0 1px 3px rgba(15,17,23,.06),0 4px 16px rgba(15,17,23,.05);
  --sh-md:0 4px 12px rgba(15,17,23,.08),0 12px 32px rgba(15,17,23,.07);
  --sh-lg:0 8px 24px rgba(15,17,23,.1),0 24px 56px rgba(15,17,23,.1);
  --r:12px;--r-sm:8px;--r-lg:16px;--r-xl:20px;
  --tr:all .2s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sn);background:var(--bg);color:var(--tx);font-size:15px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bds);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--tm)}

/* ── LOGIN ── */
#login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#0a0d14}
#login-screen::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -5%,rgba(59,110,248,.38) 0%,transparent 62%),radial-gradient(ellipse 50% 45% at 85% 105%,rgba(13,122,72,.2) 0%,transparent 55%),radial-gradient(ellipse 35% 35% at 8% 92%,rgba(109,40,217,.18) 0%,transparent 55%);pointer-events:none}
#login-screen::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.035) 1px,transparent 1px);background-size:36px 36px;pointer-events:none}
.lbox{position:relative;z-index:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:44px 40px;width:100%;max-width:400px;box-shadow:0 8px 40px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.05);backdrop-filter:blur(20px);animation:pageIn .5s cubic-bezier(.4,0,.2,1) forwards}
.llogo{display:flex;align-items:center;gap:13px;margin-bottom:32px}
.llogo-ico{width:46px;height:46px;background:linear-gradient(135deg,var(--ac),var(--ac2));border-radius:13px;display:flex;align-items:center;justify-content:center;font-family:var(--mn);font-size:19px;font-weight:500;color:#fff;box-shadow:0 0 0 1px rgba(255,255,255,.12),0 8px 28px rgba(59,110,248,.55);flex-shrink:0}
.llogo h1{font-size:17px;font-weight:700;letter-spacing:-.03em;color:#fff}
.llogo p{font-size:12px;color:rgba(255,255,255,.4);margin-top:1px;font-family:var(--mn)}
.lbox .f label{color:rgba(255,255,255,.55);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.lbox .f input{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);color:#fff;border-radius:10px;font-size:14px;padding:10px 14px}
.lbox .f input::placeholder{color:rgba(255,255,255,.25)}
.lbox .f input:focus{outline:none;border-color:rgba(59,110,248,.65);background:rgba(255,255,255,.1);box-shadow:0 0 0 3px rgba(59,110,248,.2)}
.lbox .btn.p{background:linear-gradient(135deg,var(--ac),var(--ac2));border:none;color:#fff;font-weight:600;letter-spacing:.01em;box-shadow:0 4px 18px rgba(59,110,248,.45);transition:var(--tr)}
.lbox .btn.p:hover{box-shadow:0 6px 24px rgba(59,110,248,.6);transform:translateY(-1px)}
.lerr{background:rgba(192,48,42,.2);color:#f87171;border:1px solid rgba(192,48,42,.4);border-radius:10px;padding:10px 14px;font-size:13px;margin-bottom:14px;display:none}
.llink{font-size:13px;color:rgba(123,167,251,.85);cursor:pointer;text-decoration:none;margin-top:14px;display:block;text-align:center;transition:color .15s}
.llink:hover{color:#fff;text-decoration:underline}

/* ── WELCOME ── */
#welcome-screen{display:none;min-height:100vh;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;position:relative;overflow:hidden;background:#0a0d14}
#welcome-screen.vis{display:flex}
#welcome-screen::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 90% 70% at 50% -10%,rgba(59,110,248,.4) 0%,transparent 65%),radial-gradient(ellipse 60% 50% at 85% 110%,rgba(13,122,72,.25) 0%,transparent 55%),radial-gradient(ellipse 40% 40% at 10% 90%,rgba(109,40,217,.2) 0%,transparent 55%);pointer-events:none}
#welcome-screen::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:36px 36px;pointer-events:none}
.wc-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;max-width:860px;width:100%}
.wc-logo{display:flex;align-items:center;gap:13px;margin-bottom:52px;opacity:0;animation:wcFade .6s .1s forwards}
.wc-logo-ico{width:46px;height:46px;background:linear-gradient(135deg,var(--ac),var(--ac2));border-radius:13px;display:flex;align-items:center;justify-content:center;font-family:var(--mn);font-size:20px;font-weight:500;color:#fff;box-shadow:0 0 0 1px rgba(255,255,255,.12),0 8px 32px rgba(59,110,248,.55)}
.wc-logo span{font-size:13px;font-weight:600;color:rgba(255,255,255,.45);letter-spacing:.1em;text-transform:uppercase;font-family:var(--mn)}
.wc-greeting{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:rgba(255,255,255,.35);margin-bottom:12px;font-family:var(--mn);opacity:0;animation:wcFade .6s .25s forwards}
.wc-title{font-size:clamp(26px,4vw,42px);font-weight:700;color:#fff;text-align:center;line-height:1.15;letter-spacing:-.03em;margin-bottom:14px;opacity:0;animation:wcFade .7s .35s forwards}
.wc-title strong{background:linear-gradient(135deg,#7ba7fb,#a5c4fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.wc-sub{font-size:15px;color:rgba(255,255,255,.4);text-align:center;margin-bottom:64px;font-weight:400;opacity:0;animation:wcFade .7s .45s forwards}
.wc-modules{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;width:100%;margin-bottom:40px}
.wc-mod{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:20px;padding:30px 18px 24px;cursor:pointer;text-align:center;transition:var(--tr);display:flex;flex-direction:column;align-items:center;gap:13px;opacity:0;animation:wcSlide .6s forwards;backdrop-filter:blur(12px)}
.wc-mod:nth-child(1){animation-delay:.55s}.wc-mod:nth-child(2){animation-delay:.65s}.wc-mod:nth-child(3){animation-delay:.75s}.wc-mod:nth-child(4){animation-delay:.85s}
.wc-mod:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);transform:translateY(-6px);box-shadow:0 20px 56px rgba(0,0,0,.35)}
.wc-mod:active{transform:translateY(-2px)}
.wc-mod-ico{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:2px}
.wc-mod-ico.est{background:rgba(59,110,248,.22);box-shadow:0 0 0 1px rgba(59,110,248,.4)}
.wc-mod-ico.cli{background:rgba(13,122,72,.18);box-shadow:0 0 0 1px rgba(13,122,72,.35)}
.wc-mod-ico.adm{background:rgba(109,40,217,.18);box-shadow:0 0 0 1px rgba(109,40,217,.35)}
.wc-mod-ico.fro{background:rgba(196,94,0,.18);box-shadow:0 0 0 1px rgba(196,94,0,.35)}
.wc-mod-name{font-size:14px;font-weight:600;color:#fff;letter-spacing:-.01em}
.wc-mod-desc{font-size:11.5px;color:rgba(255,255,255,.38);line-height:1.45}
.wc-mod-arrow{font-size:11px;color:rgba(255,255,255,.18);margin-top:4px;transition:color .2s,transform .2s;font-family:var(--mn)}
.wc-mod:hover .wc-mod-arrow{color:rgba(255,255,255,.55);transform:translateX(4px)}
.wc-footer{position:absolute;bottom:20px;left:0;right:0;text-align:center;font-size:11px;color:rgba(255,255,255,.15);font-family:var(--mn);letter-spacing:.06em;opacity:0;animation:wcFade .8s 1.1s forwards}
@keyframes wcFade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes wcSlide{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:600px){.wc-modules{grid-template-columns:repeat(2,1fr)}.wc-title{font-size:22px}}
@media(max-width:900px){.mets{grid-template-columns:repeat(2,1fr)}.fg.c4{grid-template-columns:1fr 1fr}.fg.c3{grid-template-columns:1fr 1fr}.main{padding:20px 18px}}
@media(min-width:1400px){.main{padding:32px 52px}}

/* ── APP ── */
#app{display:none;min-height:100vh}
#app.vis{display:flex}
.sidebar{width:224px;min-height:100vh;background:linear-gradient(180deg,#111520 0%,#0d1018 100%);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid rgba(255,255,255,.06)}
.slogo{padding:18px 16px 13px;border-bottom:1px solid rgba(255,255,255,.07)}
.slogo-ico{width:30px;height:30px;background:linear-gradient(135deg,var(--ac),var(--ac2));border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--mn);font-size:13px;font-weight:500;color:#fff;margin-bottom:7px;box-shadow:0 3px 10px rgba(59,110,248,.4)}
.slogo h1{font-size:13px;font-weight:700;color:#fff;letter-spacing:-.01em}
.slogo p{font-size:10.5px;color:rgba(255,255,255,.35);font-family:var(--mn)}
.ubadge{display:flex;align-items:center;gap:9px;padding:9px 13px;border-bottom:1px solid rgba(255,255,255,.07)}
.uav{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--ac),var(--ac2));display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 8px rgba(59,110,248,.4)}
.uinfo p{font-size:12px;color:#fff;font-weight:600;line-height:1.2;letter-spacing:-.01em}
.uinfo span{font-size:10.5px;color:rgba(255,255,255,.35)}
.blogout{margin-left:auto;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.3);font-size:15px;padding:3px;transition:color .15s}
.blogout:hover{color:#fff}
.slogout-bar{padding:10px 12px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}
.blogout-bar{width:100%;background:none;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:rgba(255,255,255,.45);font-size:12.5px;padding:7px 11px;cursor:pointer;text-align:left;transition:var(--tr);font-family:var(--sn)}
.blogout-bar:hover{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.25)}
.modsw{display:flex;gap:3px;padding:8px 8px 0}
.mbtn{flex:1;padding:6px 2px;border-radius:7px;border:none;font-size:10px;font-weight:600;cursor:pointer;font-family:var(--sn);color:rgba(255,255,255,.4);background:transparent;text-align:center;transition:var(--tr);letter-spacing:.01em}
.mbtn:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.75)}
.mbtn.on{background:rgba(59,110,248,.2);color:#7ba7fb;border:1px solid rgba(59,110,248,.3)}
.mbtn .mi{display:block;font-size:14px;margin-bottom:2px}
nav{padding:7px 9px;flex:1}
.ni{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:9px;cursor:pointer;color:rgba(255,255,255,.5);font-size:12.5px;transition:var(--tr);margin-bottom:2px;border:none;background:none;width:100%;text-align:left;font-family:var(--sn);font-weight:400}
.ni:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85)}
.ni.on{background:rgba(59,110,248,.18);color:#7ba7fb;font-weight:600;border:1px solid rgba(59,110,248,.25)}
.ni.on .nico{opacity:1;color:#7ba7fb}
.nico{width:15px;height:15px;opacity:.6;flex-shrink:0;transition:color .2s}
.sft{padding:10px 15px;border-top:1px solid rgba(255,255,255,.07)}
.sft p{font-size:10px;color:rgba(255,255,255,.25);font-family:var(--mn)}
.sipbadge{display:inline-block;margin-top:3px;padding:2px 7px;background:rgba(255,255,255,.06);border-radius:5px;font-size:9px;font-family:var(--mn);color:rgba(255,255,255,.35)}

.main{flex:1;padding:28px 40px;max-width:1600px;width:100%;animation:fadeIn .3s ease}
.page{display:none}.page.on{display:block;animation:fadeIn .25s ease}
.ph{margin-bottom:24px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px}
.ph h2{font-size:24px;font-weight:700;letter-spacing:-.04em;color:var(--tx)}
.ph p{font-size:13.5px;color:var(--tm);margin-top:3px;font-weight:400}

/* ── COMPONENTS ── */
.card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r-lg);padding:22px 24px;margin-bottom:16px;box-shadow:var(--sh)}
.ct{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--th);margin-bottom:15px}
.mets{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.met{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r-lg);padding:20px 24px;box-shadow:var(--sh);transition:var(--tr);position:relative;overflow:hidden}
.met::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px;background:var(--bd)}
.met.ok::before{background:var(--gn)}
.met.lw::before{background:var(--or)}
.met.ot::before{background:var(--rd)}
.met:hover{box-shadow:var(--sh-md);transform:translateY(-1px)}
.mv{font-size:32px;font-weight:700;font-family:var(--mn);letter-spacing:-.04em}
.ml{font-size:10.5px;color:var(--tm);margin-top:5px;text-transform:uppercase;letter-spacing:.09em;font-weight:600}
.met.ok .mv{color:var(--gn)}.met.lw .mv{color:var(--or)}.met.ot .mv{color:var(--rd)}
.fg{display:grid;gap:14px;margin-bottom:14px}
.fg.c2{grid-template-columns:1fr 1fr}
.fg.c3{grid-template-columns:1fr 1fr 1fr}
.fg.c4{grid-template-columns:1fr 1fr 1fr 1fr}
.fg.c5{grid-template-columns:repeat(5,1fr)}
.fg.c6{grid-template-columns:repeat(6,1fr)}
.f label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--tm);margin-bottom:5px}
.f input,.f select,.f textarea{width:100%;padding:9px 12px;border:1px solid var(--bd);border-radius:var(--r-sm);font-size:13.5px;font-family:var(--sn);color:var(--tx);background:#fff;transition:var(--tr);box-shadow:0 1px 2px rgba(15,17,23,.04)}
.f input:focus,.f select:focus,.f textarea:focus{outline:none;border-color:var(--ac);box-shadow:0 0 0 3px rgba(59,110,248,.12)}
.f input:hover,.f select:hover{border-color:var(--bds)}
.f textarea{resize:vertical;min-height:68px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r-sm);font-size:13.5px;font-family:var(--sn);font-weight:500;cursor:pointer;border:1px solid var(--bd);background:var(--sf);color:var(--tx);transition:var(--tr);box-shadow:0 1px 2px rgba(15,17,23,.05)}
.btn:hover{background:var(--bg);border-color:var(--bds);box-shadow:var(--sh)}
.btn:active{transform:scale(.98)}
.btn.p{background:linear-gradient(135deg,var(--ac),var(--ac2));color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(59,110,248,.3)}
.btn.p:hover{box-shadow:0 4px 16px rgba(59,110,248,.45);transform:translateY(-1px)}
.btn.p:active{transform:translateY(0) scale(.98)}
.btn.d{color:var(--rd);border-color:#f5c6c3;background:#fff}.btn.d:hover{background:var(--rdb);border-color:#f0b0ab}
.btn.e{color:var(--ac);border-color:#c5d4f7;background:#fff}.btn.e:hover{background:var(--acb)}
.btn.s{color:var(--gn);border-color:#a7d7bb;background:#fff}.btn.s:hover{background:var(--gnb)}
.btn.sm{padding:5px 11px;font-size:12px;border-radius:7px}
.tw{overflow-x:auto;border-radius:var(--r-sm);border:1px solid var(--bd)}
table{width:100%;border-collapse:collapse}
thead th{padding:10px 12px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--th);border-bottom:1px solid var(--bd);white-space:nowrap;background:#fafbfd}
thead th:first-child{border-radius:var(--r-sm) 0 0 0}
thead th:last-child{border-radius:0 var(--r-sm) 0 0}
tbody td{padding:10px 12px;border-bottom:1px solid var(--bd);font-size:13.5px;transition:background .12s}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#f6f8ff}
tbody tr:hover td:first-child{border-left:2px solid var(--ac)}
.mn{font-family:var(--mn)}
.bdg{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.01em}
.bdg::before{content:'';display:inline-block;width:5px;height:5px;border-radius:50%}
.bdg.ok{background:var(--gnb);color:var(--gn)}.bdg.ok::before{background:var(--gn)}
.bdg.lw{background:var(--orb);color:var(--or)}.bdg.lw::before{background:var(--or)}
.bdg.ot{background:var(--rdb);color:var(--rd)}.bdg.ot::before{background:var(--rd)}
.bdg.en{background:var(--gnb);color:var(--gn)}.bdg.en::before{background:var(--gn)}
.bdg.sa{background:var(--rdb);color:var(--rd)}.bdg.sa::before{background:var(--rd)}
.bdg.sd{background:var(--orb);color:var(--or)}.bdg.sd::before{background:var(--or)}
.bdg.co{background:var(--rdb);color:var(--rd)}.bdg.co::before{background:var(--rd)}
.bdg.pv{background:var(--gnb);color:var(--gn)}.bdg.pv::before{background:var(--gn)}
.bdg.pm{background:#ebf0fe;color:var(--ac);border:1px solid #c5d4f7}.bdg.pm::before{background:var(--ac)}
.bdg.ab{background:var(--orb);color:var(--or)}.bdg.ab::before{background:var(--or)}
.bdg.cn{background:var(--gnb);color:var(--gn)}.bdg.cn::before{background:var(--gn)}
.bdg.et{background:var(--gnb);color:var(--gn)}.bdg.et::before{background:var(--gn)}
.bdg.al{background:var(--rdb);color:var(--rd)}.bdg.al::before{background:var(--rd)}
.bdg.av{background:var(--orb);color:var(--or)}.bdg.av::before{background:var(--or)}
.bdg.adm{background:var(--pub);color:var(--pu)}.bdg.adm::before{background:var(--pu)}
.ab2{display:flex;align-items:center;gap:11px;padding:11px 15px;border-radius:var(--r-sm);margin-bottom:13px;font-size:13.5px;border-left:3px solid}
.ab2.or{background:var(--orb);border-color:var(--or);color:#7a3d00}
.ab2.rd{background:var(--rdb);border-color:var(--rd);color:#8b1c1c}
.empty{text-align:center;padding:40px;color:var(--th);font-size:13.5px}
.mo{display:none;position:fixed;inset:0;background:rgba(10,13,20,.6);z-index:100;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.mo.op{display:flex;animation:fadeIn .2s ease}
.mbox{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r-xl);padding:24px;width:100%;max-width:520px;margin:14px;max-height:90vh;overflow-y:auto;box-shadow:var(--sh-lg)}
.mbox.lg{max-width:680px}
.mtit{font-size:16px;font-weight:700;margin-bottom:16px;letter-spacing:-.02em}
.mft{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}
.anot{border-left:3px solid var(--ac);padding:8px 12px;margin-bottom:8px;background:var(--acb);border-radius:0 var(--r-sm) var(--r-sm) 0}
.anot-d{font-size:11px;color:var(--tm);font-family:var(--mn);margin-bottom:2px;font-weight:600}
.anot-t{font-size:13.5px}
.ro{background:#f3f4f6!important;color:var(--tm)!important}
.fl{display:flex;align-items:center;gap:8px}
.mla{margin-left:auto}
