:root{--bg: #f4f5fb;--bg-grad: radial-gradient(1200px 600px at 100% -10%, #eef0ff 0%, transparent 55%), radial-gradient(900px 500px at -10% 110%, #f0fbff 0%, transparent 50%);--surface: #ffffff;--surface-2: #f8f9fc;--border: #e9ebf2;--border-strong: #dfe2ec;--text: #0e1525;--text-2: #475069;--muted: #8a93a8;--primary: #6366f1;--primary-600: #5457e6;--primary-700: #4338ca;--primary-soft: #eef0ff;--grad-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--grad-sky: linear-gradient(135deg, #0ea5e9 0%, #22d3ee 100%);--grad-emerald: linear-gradient(135deg, #10b981 0%, #34d399 100%);--grad-amber: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);--grad-rose: linear-gradient(135deg, #f43f5e 0%, #fb7185 100%);--ok: #15915b;--ok-bg: #e7f7ef;--warn: #9a6700;--warn-bg: #fdf4e3;--err: #c11839;--err-bg: #fdecef;--info: #1f6fdb;--info-bg: #e9f1ff;--radius: 16px;--radius-sm: 11px;--radius-lg: 22px;--shadow-xs: 0 1px 2px rgba(16, 24, 40, .05);--shadow-sm: 0 2px 8px rgba(16, 24, 40, .06);--shadow-md: 0 10px 28px -8px rgba(28, 32, 80, .14);--shadow-lg: 0 24px 60px -18px rgba(28, 32, 80, .28);--sidebar-w: 260px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);background-image:var(--bg-grad);background-attachment:fixed;color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:var(--primary-600);text-decoration:none}h1,h2,h3,h4{margin:0;letter-spacing:-.02em}code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85em}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#d4d8e3;border-radius:99px;border:3px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:#c0c5d4;background-clip:content-box}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;background:linear-gradient(185deg,#1a1740,#15132f 45%,#0e0c22);color:#c9cce0;padding:22px 16px;gap:6px;border-right:1px solid rgba(255,255,255,.06)}.brand{display:flex;align-items:center;gap:12px;padding:4px 8px 18px}.brand .logo{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:var(--grad-primary);color:#fff;box-shadow:0 8px 20px -6px #6366f1b3}.brand .title{font-size:15px;font-weight:700;color:#fff;line-height:1.15}.brand .subtitle{font-size:11px;color:#8b90b5;font-weight:500}.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:#6f7499;padding:14px 12px 6px;font-weight:600}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;color:#b6bad6;font-size:13.5px;font-weight:500;cursor:pointer;position:relative;transition:background .15s,color .15s,transform .15s}.nav-item:hover{background:#ffffff0d;color:#fff}.nav-item svg{opacity:.75;flex-shrink:0}.nav-item.active{background:#6366f129;color:#fff}.nav-item.active svg{opacity:1}.nav-item.active:before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:0 4px 4px 0;background:var(--grad-primary)}.sidebar-footer{margin-top:auto;padding-top:12px;border-top:1px solid rgba(255,255,255,.07)}.user-card{display:flex;align-items:center;gap:11px;padding:8px;border-radius:12px}.avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:var(--grad-sky);color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.user-card .meta{overflow:hidden}.user-card .name{font-size:13px;color:#fff;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card .role{font-size:11px;color:#8b90b5}.btn-logout{width:100%;margin-top:8px;background:#ffffff0d;color:#c9cce0;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;gap:8px}.btn-logout:hover{background:#f43f5e29;color:#fff;border-color:transparent}.main{display:flex;flex-direction:column;min-width:0}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 30px;background:#ffffffb8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.topbar .crumb{font-size:12px;color:var(--muted);font-weight:500}.topbar h1{font-size:20px;font-weight:700}.topbar-actions{display:flex;align-items:center;gap:10px}.env-pill{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:99px;font-size:12px;font-weight:600;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-xs)}.dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px var(--ok-bg)}.page{padding:28px 30px;max-width:1240px;width:100%;animation:fadeUp .35s ease both}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px;margin-bottom:22px}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.card-head h3{font-size:15px;font-weight:700}.card-head .sub{font-size:12.5px;color:var(--muted);margin-top:2px}.card.flush{padding:0;overflow:hidden}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:24px}.stat{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .18s,box-shadow .18s}.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.stat:after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:var(--tile, var(--grad-primary));opacity:.07}.stat .tile{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;background:var(--tile, var(--grad-primary));box-shadow:var(--shadow-sm);margin-bottom:16px}.stat .num{font-size:30px;font-weight:800;letter-spacing:-.03em}.stat .label{color:var(--muted);font-size:12.5px;margin-top:3px;font-weight:500}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}thead th{text-align:left;padding:13px 18px;color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em;background:var(--surface-2);border-bottom:1px solid var(--border);position:sticky;top:0}tbody td{padding:14px 18px;border-bottom:1px solid var(--border);color:var(--text-2);vertical-align:middle}tbody tr{transition:background .12s}tbody tr:hover{background:var(--surface-2)}tbody tr:last-child td{border-bottom:none}td .mono{font-family:ui-monospace,Menlo,monospace;font-size:12.5px;color:var(--text)}.cell-strong{color:var(--text);font-weight:600}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:99px;font-size:12px;font-weight:600;line-height:1.4;white-space:nowrap}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge.ok{background:var(--ok-bg);color:var(--ok)}.badge.warn{background:var(--warn-bg);color:var(--warn)}.badge.err{background:var(--err-bg);color:var(--err)}.badge.info{background:var(--info-bg);color:var(--info)}.badge.plain{background:var(--surface-2);color:var(--text-2)}.badge.plain:before{display:none}button,.btn{font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;border:none;padding:10px 18px;border-radius:11px;display:inline-flex;align-items:center;gap:8px;background:var(--grad-primary);color:#fff;box-shadow:0 6px 16px -6px #6366f199;transition:transform .14s,box-shadow .14s,opacity .14s,background .14s}button:hover,.btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px -8px #6366f1a6}button:active,.btn:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}button.ghost,.btn.ghost{background:var(--surface);color:var(--text-2);border:1px solid var(--border-strong);box-shadow:var(--shadow-xs)}button.ghost:hover{background:var(--surface-2);color:var(--text);box-shadow:var(--shadow-sm)}button.danger{background:var(--grad-rose);box-shadow:0 6px 16px -6px #f43f5e99}button.sm,.btn.sm{padding:7px 13px;font-size:12.5px;border-radius:9px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field>span{font-size:12.5px;color:var(--text-2);font-weight:600}.field .hint{font-size:11.5px;color:var(--muted);font-weight:400}input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--border-strong);border-radius:11px;font-size:13.5px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color .15s,box-shadow .15s}input::placeholder{color:#a9b0c2}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;align-items:end}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 600px at 15% 20%,rgba(99,102,241,.35),transparent 55%),radial-gradient(800px 600px at 85% 80%,rgba(34,211,238,.3),transparent 55%),linear-gradient(160deg,#14122e,#0c0a1f)}.login-card{width:400px;max-width:100%;background:#fffffff7;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:36px 34px;animation:fadeUp .45s ease both;border:1px solid rgba(255,255,255,.5)}.login-card .brand-lg{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:26px;text-align:center}.login-card .logo-lg{width:58px;height:58px;border-radius:17px;display:grid;place-items:center;background:var(--grad-primary);color:#fff;box-shadow:0 14px 30px -10px #6366f1cc}.login-card h1{font-size:21px}.login-card .muted{color:var(--muted);font-size:13px}.login-card button{width:100%;justify-content:center;padding:12px;margin-top:6px}.login-hint{margin-top:20px;padding:12px 14px;background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:11px;font-size:12px;color:var(--muted);text-align:center}.input-group{position:relative}.input-group svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted)}.input-group input{padding-left:40px}.alert{padding:11px 14px;border-radius:11px;font-size:13px;font-weight:500;margin-bottom:14px;display:flex;gap:8px}.alert.error{background:var(--err-bg);color:var(--err)}.alert.success{background:var(--ok-bg);color:var(--ok)}.empty{text-align:center;padding:56px 20px;color:var(--muted)}.empty .ic{width:56px;height:56px;border-radius:16px;background:var(--surface-2);display:grid;place-items:center;margin:0 auto 14px;color:var(--muted)}.empty h4{font-size:15px;color:var(--text-2);margin-bottom:4px}.empty p{font-size:13px;margin:0}.skeleton{background:linear-gradient(90deg,#eef0f6 25%,#f6f7fb,#eef0f6 75%);background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skel-row{height:16px;margin:14px 18px}.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.spinner.dark{border-color:var(--border-strong);border-top-color:var(--primary)}@keyframes spin{to{transform:rotate(360deg)}}.toast-stack{position:fixed;top:20px;right:20px;z-index:100;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;gap:11px;min-width:260px;max-width:380px;padding:13px 15px;border-radius:13px;background:var(--surface);box-shadow:var(--shadow-lg);border:1px solid var(--border);font-size:13.5px;font-weight:500;color:var(--text);animation:toastIn .3s cubic-bezier(.2,.8,.2,1) both}@keyframes toastIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:none}}.toast .tic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:#fff;flex-shrink:0}.toast.success .tic{background:var(--grad-emerald)}.toast.error .tic{background:var(--grad-rose)}.toast.info .tic{background:var(--grad-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#0a0c1e8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:24px;animation:fadeUp .2s ease both}.modal{width:560px;max-width:100%;max-height:88vh;display:flex;flex-direction:column;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);animation:toastIn .25s cubic-bezier(.2,.8,.2,1) both}.modal.wide{width:760px}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 22px;border-bottom:1px solid var(--border)}.modal-head h3{font-size:16px;font-weight:700}.modal-head .sub{font-size:12.5px;color:var(--muted);margin-top:3px}.modal-body{padding:20px 22px;overflow-y:auto}.codeblock{position:relative;margin:12px 0 18px}.codeblock-label{font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:7px}.codeblock pre{margin:0;padding:14px 16px;background:#0e1020;color:#e6e8f2;border-radius:12px;overflow-x:auto;font-size:12.5px;line-height:1.6}.codeblock code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.copy-btn{position:absolute;top:8px;right:8px;padding:5px 10px;font-size:11.5px;background:#ffffff1a;color:#e6e8f2;border:1px solid rgba(255,255,255,.15);box-shadow:none;border-radius:8px}.copy-btn:hover{background:#fff3;transform:none;box-shadow:none}.kv{display:grid;grid-template-columns:130px 1fr;gap:6px 12px;font-size:13px;margin-bottom:6px}.kv dt{color:var(--muted);font-weight:600}.kv dd{margin:0;color:var(--text);word-break:break-all}.doc-step{font-size:13px;font-weight:700;color:var(--text);margin:18px 0 2px;display:flex;align-items:center;gap:8px}.doc-step .n{width:22px;height:22px;border-radius:7px;background:var(--grad-primary);color:#fff;display:grid;place-items:center;font-size:12px}.row{display:flex;gap:12px;align-items:center}.between{justify-content:space-between}.wrap{flex-wrap:wrap}.muted{color:var(--muted)}.truncate{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mt0{margin-top:0}.mb0{margin-bottom:0}@media (max-width: 860px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;z-index:50;width:250px;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:none}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#08081480;z-index:40}.menu-btn{display:inline-grid!important}}.menu-btn{display:none;place-items:center;width:38px;height:38px;padding:0;background:var(--surface);color:var(--text-2);border:1px solid var(--border);box-shadow:var(--shadow-xs)}
