.layout{min-height:100vh}.sidebar{display:none}.main{min-height:100vh;background:var(--app);padding-bottom:calc(var(--nav-h) + 8px);overflow-x:hidden}.hero{background:linear-gradient(135deg,#0b5ec7,#0a78da 55%,#3aa0ff);color:#fff;padding:18px 18px 24px;border-radius:0 0 28px 28px;position:relative;overflow:hidden}.hero:after{content:"";position:absolute;right:-40px;top:-50px;width:190px;height:190px;border-radius:50%;background:#ffffff1a}.hero-top{display:flex;gap:8px;position:relative;z-index:1}.hero-badge{background:#ffffff2e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 11px;border-radius:999px;font-size:12px;font-weight:600}.hero-title{font-size:24px;font-weight:800;margin-top:22px;letter-spacing:-.02em;position:relative;z-index:1}.hero-sub{font-size:13px;opacity:.92;margin-top:4px;position:relative;z-index:1}.morebar{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:14px 14px 2px}.morebtn{display:flex;flex-direction:column;align-items:center;gap:5px;border:1px solid var(--line);background:var(--app);border-radius:15px;padding:10px 4px;font-size:10.5px;font-weight:700;color:#44556b;cursor:pointer;text-align:center}.morebtn svg{width:19px;height:19px}.morebtn.active{border-color:var(--primary);color:var(--primary);background:var(--soft)}.content{min-height:40vh}.bottomnav{position:fixed;left:0;right:0;bottom:0;background:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);padding:8px 4px calc(8px + env(safe-area-inset-bottom));z-index:20}.navitem{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:700;color:var(--muted);cursor:pointer}.navitem svg{width:22px;height:22px}.navitem.active{color:var(--primary)}@media (min-width: 861px){.layout{display:flex}.sidebar{display:flex;flex-direction:column;gap:3px;width:264px;flex:none;position:sticky;top:0;height:100vh;overflow-y:auto;background:var(--app);border-right:1px solid var(--line);padding:18px 14px}.side-brand{display:flex;align-items:center;gap:11px;padding:4px 8px 16px}.side-logo{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--primary-2));display:grid;place-items:center;font-size:20px}.side-name{font-weight:800;font-size:1.05rem}.side-tag{font-size:11px;color:var(--muted)}.side-group{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:14px 10px 5px}.side-link{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:11px;color:var(--muted);font-weight:600;font-size:.92rem}.side-link svg{width:20px;height:20px;flex:none}.side-link:hover{background:var(--soft);color:var(--ink)}.side-link.active{background:var(--soft);color:var(--primary)}.main{flex:1;min-width:0;background:var(--bg);padding-bottom:28px}.morebar,.bottomnav{display:none}.hero{max-width:1120px;margin:20px auto 0;border-radius:20px;padding:22px 28px}.hero:after{top:-70px;right:-30px}}.hero-logout{margin-left:auto;background:#ffffff2e;border:none;color:#fff;width:30px;height:30px;border-radius:999px;display:grid;place-items:center;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex:none}.hero-logout:hover{background:#ffffff47}.side-spacer,.side-user{display:none}@media (min-width: 861px){.hero-logout{display:none}.side-spacer{display:block;flex:1}.side-user{display:flex;align-items:center;gap:8px;padding:10px;border-top:1px solid var(--line);margin-top:8px}.side-user-info{flex:1;min-width:0}.side-user-name{font-weight:700;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-user-role{font-size:11px;color:var(--muted)}.side-logout{background:var(--soft);border:none;color:var(--primary);width:34px;height:34px;border-radius:10px;display:grid;place-items:center;cursor:pointer;flex:none}.side-logout:hover{background:#dcebfd}}:root{--bg: #e9f1fd;--app: #ffffff;--ink: #102033;--muted: #65758a;--primary: #0b5ec7;--primary-2: #0a78da;--soft: #eef6ff;--line: #e6eefb;--radius: 22px;--radius-sm: 16px;--shadow: 0 8px 18px rgba(18, 68, 130, .06);--shadow-tile: 0 8px 22px rgba(20, 64, 120, .12);--shadow-blue: 0 12px 26px rgba(11, 94, 199, .28);--appw: 500px;--nav-h: 70px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Noto Sans", Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin:0}ul{margin:0;padding:0;list-style:none}button{font-family:inherit}.page{padding:14px;display:flex;flex-direction:column;gap:12px}.section-title{font-size:1rem;font-weight:800;margin:6px 2px 0}.stack{display:flex;flex-direction:column;gap:12px}.card{background:var(--app);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.card-head h2{font-size:1rem;font-weight:800}.blue-card{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border-radius:24px;padding:18px;box-shadow:var(--shadow-blue)}.blue-card .bc-label{font-size:12px;opacity:.9}.blue-card .bc-big{font-size:34px;font-weight:800;letter-spacing:-.02em}.row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.row:last-child{border-bottom:none}.row-main-wrap{flex:1;min-width:0}.row-main{font-weight:700}.row-sub{color:var(--muted);font-size:12.5px;margin-top:2px;line-height:1.35}.row-actions{display:flex;gap:6px;flex:none;align-items:center}.muted{color:var(--muted);font-size:12.5px;line-height:1.4}.empty{text-align:center;color:var(--muted);padding:22px 10px;font-size:.9rem}.err{color:#d83737;font-size:.85rem}.pill,.badge{display:inline-block;font-size:11px;font-weight:700;padding:5px 10px;border-radius:999px;background:#e8f3ff;color:#075bb7;white-space:nowrap}.pill.red,.badge.red{background:#fff0f0;color:#d83737}.pill.green,.badge.green{background:#e9fbf2;color:#087b4f}.pill.orange,.badge.orange,.badge.amber{background:#fff6e6;color:#af6500}.pill.gray,.badge.gray{background:#eef2f7;color:#5c6b82}.pill.blue,.badge.blue{background:#e8f3ff;color:#075bb7}.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}.quick{background:var(--app);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 6px;text-align:center;box-shadow:var(--shadow-tile);cursor:pointer}.quick.active{border-color:var(--primary);background:var(--soft)}.quick .q-num{font-size:20px;font-weight:800;color:var(--primary);line-height:1}.quick .q-name{font-size:12px;font-weight:700;margin-top:4px}.quick .q-sub{font-size:10px;color:var(--muted);margin-top:2px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.stat{background:var(--app);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow-tile)}.stat .num{font-size:1.7rem;font-weight:800;color:var(--ink);letter-spacing:-.02em}.stat .lbl{color:var(--muted);font-size:12px;margin-top:2px}.module-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.module{background:var(--app);border:1px solid var(--line);border-radius:18px;padding:13px;box-shadow:var(--shadow);cursor:pointer}.module h3{font-size:14px;margin-bottom:6px}.module p{font-size:12px;color:var(--muted);line-height:1.35}.tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.tab{flex:0 0 auto;padding:9px 13px;border-radius:999px;background:var(--app);border:1px solid var(--line);font-size:12px;font-weight:700;cursor:pointer;color:var(--ink)}.tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.rank{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--line)}.rank:last-child{border-bottom:none}.ranknum{width:30px;height:30px;border-radius:10px;background:var(--soft);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;flex:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;border-radius:14px;border:1px solid var(--line);background:var(--app);color:var(--ink);font-weight:700;font-size:.9rem;cursor:pointer;transition:background .12s,opacity .12s}.btn:hover{background:var(--soft)}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-2)}.btn-danger{background:#fff;border-color:#f2c4bb;color:#d83737}.btn-danger:hover{background:#fdeeeb}.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}.btn-ghost:hover{background:var(--soft);color:var(--ink)}.btn-sm{padding:7px 11px;font-size:.82rem;border-radius:11px}.btn-block{width:100%}.form{display:flex;flex-direction:column;gap:12px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field{display:flex;flex-direction:column;gap:6px}.field>label{font-size:12.5px;font-weight:700;color:var(--muted)}.input,.select,.textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:var(--app);color:var(--ink);font-family:inherit;font-size:.92rem}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--soft)}.textarea{resize:vertical;min-height:70px}.form-actions{display:flex;gap:10px;justify-content:flex-end}@media (max-width: 420px){.form-grid{grid-template-columns:1fr}}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;font-size:.86rem}.table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:8px;border-bottom:1px solid var(--line);white-space:nowrap}.table td{padding:10px 8px;border-bottom:1px solid var(--line)}.table tr:last-child td{border-bottom:none}.status{display:flex;align-items:center;gap:12px}.dot{width:11px;height:11px;border-radius:50%;flex:none}.dot.ok{background:#16b8a6;box-shadow:0 0 0 4px #16b8a629}.dot.off{background:#e0533d;box-shadow:0 0 0 4px #e0533d29}.dot.wait{background:#f0b429;box-shadow:0 0 0 4px #f0b42929}.status .s-main{font-weight:700}.status .s-sub{color:var(--muted);font-size:12.5px;margin-top:2px;word-break:break-all}@media (min-width: 861px){.page{max-width:1120px;margin:0 auto;padding:20px 24px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.module-grid{grid-template-columns:repeat(3,1fr)}}.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:24px;background:linear-gradient(160deg,#0b5ec7,#0a78da 55%,#3aa0ff)}.login-hero{text-align:center;color:#fff}.login-logo{font-size:46px;line-height:1}.login-hero h1{font-size:30px;font-weight:800;margin-top:8px;letter-spacing:-.02em}.login-hero p{opacity:.9;font-size:13px;margin-top:3px}.login-card{width:100%;max-width:360px;background:#fff;border-radius:20px;padding:22px;box-shadow:0 22px 55px #081e4659;display:flex;flex-direction:column;gap:14px}.login-hint{text-align:center;font-size:12px;color:var(--muted);margin-top:2px}.splash{min-height:100vh;display:grid;place-items:center;color:var(--muted);font-size:.95rem}
