:root{--bg: #f4f6fb;--surface: #ffffff;--surface-2: #f9fafc;--border: #e6e9f2;--text: #1a2138;--text-soft: #5b6478;--text-faint: #9aa3b7;--brand: #4f46e5;--brand-700: #4338ca;--navy: #0f1734;--navy-2: #1b264f;--shadow: 0 1px 2px rgba(16,24,40,.06), 0 8px 24px rgba(16,24,40,.06);--shadow-lg: 0 12px 40px rgba(16,24,40,.16);--radius: 16px;--a-indigo:#6366f1;--a-sky:#0ea5e9;--a-teal:#14b8a6;--a-emerald:#10b981;--a-amber:#f59e0b;--a-rose:#f43f5e;--a-green:#22c55e;--a-orange:#fb923c;--a-violet:#8b5cf6;--a-cyan:#06b6d4;--a-fuchsia:#d946ef;--a-lime:#84cc16;--a-slate:#64748b}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}a{color:var(--brand);text-decoration:none}.login-wrap{min-height:100%;display:grid;grid-template-columns:1.1fr 1fr}.login-hero{background:radial-gradient(1200px 600px at 20% 10%,#27306b 0%,var(--navy) 55%);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between}.login-hero .brandmark{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.3px}.login-hero h1{font-size:40px;line-height:1.12;margin:0 0 16px;font-weight:800}.login-hero p{color:#b9c0e0;font-size:16px;max-width:460px;line-height:1.6}.hero-stats{display:flex;gap:28px;margin-top:28px}.hero-stats div span{display:block}.hero-stats .n{font-size:26px;font-weight:800}.hero-stats .l{font-size:12px;color:#9aa6d8;text-transform:uppercase;letter-spacing:.6px}.login-panel{display:flex;align-items:center;justify-content:center;padding:40px}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:36px 32px;box-shadow:var(--shadow);text-align:center}.login-card h2{margin:4px 0 6px;font-size:22px}.login-card .sub{color:var(--text-soft);font-size:14px;margin-bottom:26px}.gbtn-host{display:flex;justify-content:center;min-height:44px}.devbtn{width:100%;margin-top:14px;padding:11px;border-radius:10px;border:1px dashed var(--border);background:var(--surface-2);color:var(--text-soft);font-size:13px}.login-note{margin-top:18px;font-size:12px;color:var(--text-faint);line-height:1.5}.pw-form{display:flex;flex-direction:column;gap:10px;text-align:left}.pw-field{display:flex;align-items:center;gap:9px;border:1px solid var(--border);background:var(--surface-2);border-radius:10px;padding:0 12px;color:var(--text-soft)}.pw-field input{flex:1;border:none;background:transparent;outline:none;padding:11px 0;font-size:14px;color:var(--text)}.pw-submit{width:100%;justify-content:center;margin-top:4px;padding:11px}.banner{border-radius:10px;padding:10px 12px;font-size:13px;margin-bottom:16px;text-align:left}.banner.warn{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa}.banner.err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.shell{min-height:100%;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:30;background:var(--navy);color:#fff;display:flex;align-items:center;gap:16px;padding:0 24px;height:64px;box-shadow:0 1px #ffffff0a}.topbar .logo{display:flex;align-items:center;gap:10px;font-weight:700}.topbar .logo .dot{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#6366f1,#22d3ee);display:grid;place-items:center}.topbar .spacer{flex:1}.sync-meta{font-size:12px;color:#a9b2d8;margin-right:4px;text-align:right;line-height:1.3}.btn{display:inline-flex;align-items:center;gap:8px;border:none;border-radius:10px;padding:9px 14px;font-size:14px;font-weight:600;transition:.15s}.btn-light{background:#ffffff1f;color:#fff}.btn-light:hover{background:#fff3}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-700)}.btn-ghost{background:transparent;color:var(--text-soft);border:1px solid var(--border)}.btn:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.user-chip{display:flex;align-items:center;gap:10px}.user-chip img,.user-chip .avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;background:linear-gradient(135deg,#6366f1,#22d3ee);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}.user-chip .meta{line-height:1.15}.user-chip .meta b{font-size:13px}.user-chip .meta span{font-size:11px;color:#a9b2d8}.content{max-width:1280px;width:100%;margin:0 auto;padding:28px 24px 60px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}.page-head h1{margin:0;font-size:24px;font-weight:800}.page-head p{margin:4px 0 0;color:var(--text-soft);font-size:14px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.kpi{position:relative;isolation:isolate;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:20px;box-shadow:0 1px 2px #1018280a;cursor:pointer;text-align:left;overflow:hidden;transition:transform .2s cubic-bezier(.2,.7,.2,1),box-shadow .2s,border-color .2s}.kpi:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;opacity:.85;background:radial-gradient(130px 130px at 100% 0%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 70%)}.kpi:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--accent) 38%,var(--border));box-shadow:0 18px 38px -14px color-mix(in srgb,var(--accent) 42%,transparent)}.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.kpi .ico{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;color:var(--accent);background:linear-gradient(145deg,color-mix(in srgb,var(--accent) 20%,#fff),color-mix(in srgb,var(--accent) 7%,#fff));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 20%,transparent)}.kpi .kpi-go{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);opacity:0;transform:translate(-4px);transition:opacity .2s,transform .2s}.kpi:hover .kpi-go{opacity:1;transform:none}.kpi .value{font-size:32px;font-weight:800;letter-spacing:-1px;line-height:1.04;color:var(--text)}.kpi .value.cur{font-size:27px}.kpi .label{font-size:13px;color:var(--text-soft);font-weight:600;margin-top:4px}.kpi .foot{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:12px;color:var(--text-faint);display:flex;align-items:center;gap:6px}.kpi .chip{font-size:11px;padding:3px 9px;border-radius:999px;background:color-mix(in srgb,var(--accent) 10%,var(--surface-2));border:1px solid color-mix(in srgb,var(--accent) 18%,var(--border));color:var(--text-soft);font-weight:600}.kpi.empty{box-shadow:none}.kpi.empty:before{opacity:.4}.kpi.empty .value{color:var(--text-faint)}.kpi.empty .ico{filter:saturate(.5);opacity:.75}.section-title{font-size:13px;text-transform:uppercase;letter-spacing:.7px;color:var(--text-faint);font-weight:700;margin:28px 4px 12px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f173473;z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade .15s}@keyframes fade{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(960px,94vw);background:var(--bg);z-index:60;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slidein .2s ease}@keyframes slidein{0%{transform:translate(40px);opacity:.6}to{transform:none;opacity:1}}.drawer-head{display:flex;align-items:center;gap:14px;padding:18px 22px;background:var(--surface);border-bottom:1px solid var(--border)}.drawer-head .ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 14%,#fff);color:var(--accent)}.drawer-head h2{margin:0;font-size:18px}.drawer-head .sub{font-size:12px;color:var(--text-soft)}.drawer-head .x{margin-left:auto}.icon-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--border);background:var(--surface);display:grid;place-items:center;color:var(--text-soft)}.icon-btn:hover{background:var(--surface-2)}.drawer-tools{display:flex;align-items:center;gap:10px;padding:12px 22px;background:var(--surface);border-bottom:1px solid var(--border)}.search{flex:1;display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:8px 12px}.search input{border:none;background:transparent;outline:none;width:100%;font-size:14px;color:var(--text)}.count-pill{font-size:12px;color:var(--text-soft);background:var(--surface-2);border:1px solid var(--border);padding:5px 10px;border-radius:999px;white-space:nowrap}.drawer-body{flex:1;overflow:auto;padding:18px 22px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:auto;box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse;font-size:13px}thead th{position:sticky;top:0;background:var(--surface-2);text-align:left;padding:11px 14px;font-weight:700;color:var(--text-soft);border-bottom:1px solid var(--border);white-space:nowrap;font-size:12px;text-transform:uppercase;letter-spacing:.4px}tbody td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:top}tbody tr:last-child td{border-bottom:none}td .code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;background:var(--surface-2);border:1px solid var(--border);padding:2px 6px;border-radius:6px}.status{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:capitalize}.status.ok{background:#dcfce7;color:#166534}.status.warn{background:#fef3c7;color:#92400e}.status.bad{background:#fee2e2;color:#991b1b}.status.neutral{background:#e5e7eb;color:#374151}.drive-link{display:inline-flex;align-items:center;gap:6px;font-weight:600}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}.doc-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}.doc-card .folder{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:#eef2ff;color:#4f46e5}.doc-card b{font-size:14px}.doc-card span{font-size:12px;color:var(--text-soft)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-soft)}.empty-state .e-ico{width:64px;height:64px;border-radius:16px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;margin:0 auto 16px;color:var(--text-faint)}.empty-state h3{margin:0 0 6px;color:var(--text)}.skeleton{background:linear-gradient(90deg,#eef1f7 25%,#f6f8fc 37%,#eef1f7 63%);background-size:400% 100%;animation:shimmer 1.3s ease infinite;border-radius:10px}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.loader-full{min-height:100%;display:grid;place-items:center}.loader-card{text-align:center;color:var(--text-soft)}.loader-ring{width:46px;height:46px;border-radius:50%;border:4px solid var(--border);border-top-color:var(--brand);margin:0 auto 16px;animation:spin .8s linear infinite}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%);background:var(--navy);color:#fff;padding:12px 18px;border-radius:12px;font-size:14px;box-shadow:var(--shadow-lg);z-index:80;display:flex;align-items:center;gap:10px}.menu-btn{width:40px;height:40px;border-radius:10px;border:none;background:#ffffff1a;color:#fff;display:grid;place-items:center;margin-right:4px}.menu-btn:hover{background:#fff3}.logo-btn{background:none;border:none;color:#fff;cursor:pointer}.navmenu{position:fixed;top:0;left:0;bottom:0;width:min(320px,86vw);background:var(--surface);z-index:60;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideleft .2s ease}@keyframes slideleft{0%{transform:translate(-30px);opacity:.5}to{transform:none;opacity:1}}.navmenu-head{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid var(--border)}.navmenu-head .logo{color:var(--text);font-weight:700}.navmenu-head .logo .dot{width:28px;height:28px}.navmenu-head .icon-btn{margin-left:auto}.navmenu-scroll{flex:1;overflow:auto;padding:8px 10px 20px}.nav-group{margin-top:10px}.nav-group-title{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--text-faint);font-weight:700;padding:8px 10px 4px}.nav-item{width:100%;display:flex;align-items:center;gap:11px;padding:10px 12px;border:none;background:none;border-radius:10px;color:var(--text-soft);font-size:14px;font-weight:600;text-align:left}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:color-mix(in srgb,var(--brand) 12%,#fff);color:var(--brand-700)}.nav-item.home{margin:10px;width:auto;background:var(--navy);color:#fff;justify-content:center}.nav-item.home:hover{background:var(--navy-2)}.nav-label{flex:1}.nav-count{font-size:12px;color:var(--text-faint);background:var(--surface-2);border:1px solid var(--border);padding:2px 8px;border-radius:999px}.entity-head{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:64px;z-index:20}.entity-head-inner{max-width:1280px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}.entity-head-inner .spacer{flex:1}.back-btn{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:9px 14px;border-radius:10px;font-weight:600;font-size:14px}.back-btn:hover{background:#eef1f7}.entity-title{display:flex;align-items:center;gap:12px}.entity-title .ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 14%,#fff);color:var(--accent)}.entity-title h1{margin:0;font-size:20px;font-weight:800}.entity-title span{font-size:13px;color:var(--text-soft)}.entity-tabs{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;gap:6px;overflow:auto}.entity-tabs .tab{background:none;border:none;padding:11px 14px;font-size:14px;font-weight:600;color:var(--text-soft);border-bottom:2px solid transparent;display:flex;align-items:center;gap:7px;white-space:nowrap}.entity-tabs .tab:hover{color:var(--text)}.entity-tabs .tab.active{color:var(--brand-700);border-bottom-color:var(--brand)}.tab-count{font-size:11px;background:var(--surface-2);border:1px solid var(--border);padding:1px 7px;border-radius:999px;color:var(--text-soft)}.filterbar{margin-bottom:14px}.filterbar-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search.grow{flex:1;min-width:220px}.clear-x{border:none;background:none;color:var(--text-faint);display:grid;place-items:center;cursor:pointer}.add-filter{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:0 6px 0 12px;color:var(--text-soft)}.add-filter select{border:none;background:none;outline:none;padding:9px 6px;font-size:14px;color:var(--text);font-weight:600;cursor:pointer}.filter-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.chip-filter{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:5px 6px 5px 10px;box-shadow:var(--shadow)}.chip-col{font-size:12px;font-weight:700;color:var(--brand-700)}.chip-filter select,.chip-filter input{border:1px solid var(--border);background:var(--surface-2);border-radius:7px;padding:5px 8px;font-size:13px;outline:none;color:var(--text);max-width:200px}.chip-x{border:none;background:none;color:var(--text-faint);cursor:pointer;display:grid;place-items:center}.chip-x:hover{color:var(--a-rose)}.col-menu{position:relative}.col-popover{position:absolute;right:0;top:46px;z-index:30;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);padding:10px;width:240px;max-height:340px;overflow:auto}.col-popover-head{display:flex;gap:8px;padding:2px 4px 10px;border-bottom:1px solid var(--border);margin-bottom:6px}.col-popover-head button{flex:1;font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--surface-2);border-radius:8px;padding:6px;color:var(--text-soft)}.col-opt{display:flex;align-items:center;gap:9px;padding:7px 6px;font-size:13px;border-radius:8px;cursor:pointer}.col-opt:hover{background:var(--surface-2)}.col-opt input{accent-color:var(--brand)}.result-meta{font-size:13px;color:var(--text-soft);margin:2px 2px 12px}.rel-btns{display:flex;flex-wrap:wrap;gap:6px}.rel-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--surface-2);color:var(--brand-700);padding:4px 9px;border-radius:8px;white-space:nowrap}.rel-btn:hover{background:color-mix(in srgb,var(--brand) 12%,#fff);border-color:#c7cdf0}.rel-btn b{font-weight:800}.rel-btn.rel-empty,.rel-btn:disabled{opacity:.45;cursor:not-allowed;color:var(--text-faint);background:var(--surface-2)}.rel-btn.rel-empty b{color:var(--text-faint)}.entity-shell{height:100vh;display:flex;flex-direction:column;overflow:hidden}.entity-content{flex:1;min-height:0;display:flex;flex-direction:column;padding-top:18px;padding-bottom:14px}.entity-scroll{flex:1;min-height:0;display:flex;flex-direction:column}.entity-scroll .table-wrap{flex:1;min-height:0}.entity-scroll table{width:max-content;min-width:100%}.entity-scroll .doc-grid{flex:1;min-height:0;overflow:auto;align-content:start;padding:2px}.entity-scroll .empty-state{margin:auto}.result-meta .hint{color:var(--text-faint)}table colgroup col.col-hover{background:color-mix(in srgb,var(--brand) 6%,transparent)}tbody tr:hover>td{background:color-mix(in srgb,var(--brand) 9%,#fff)}.num-col{-webkit-user-select:none;user-select:none;text-align:center;width:48px;color:var(--text-faint)}.table-wrap td.cell .ell{display:block;max-width:34ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-wrap td.cell .ell .code,.table-wrap td.cell .ell .status,.table-wrap td.cell .ell .drive-link{max-width:100%}thead th.col-th{padding:0}.th-inner{display:inline-flex;align-items:center;gap:6px;padding:11px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.th-inner:hover{color:var(--brand-700)}.th-sort{display:inline-flex;color:var(--brand)}.th-sort-idle{color:var(--text-faint);font-size:12px}thead th.sort-asc .th-inner,thead th.sort-desc .th-inner{color:var(--brand-700)}.th-freeze{border:none;background:transparent;color:var(--text-faint);padding:4px;margin-right:6px;border-radius:6px;display:inline-flex;vertical-align:middle;cursor:pointer;opacity:0;transition:opacity .12s}thead th.col-th:hover .th-freeze{opacity:.7}.th-freeze:hover{background:var(--surface);color:var(--brand-700);opacity:1}.th-freeze.on{opacity:1;color:var(--brand-700);background:color-mix(in srgb,var(--brand) 16%,var(--surface-2))}.table-wrap td.num-col,.table-wrap th.num-col{position:sticky;left:0;z-index:2;background:var(--surface-2)}.table-wrap thead th.num-col{z-index:6}.table-wrap td.frozen,.table-wrap th.frozen{position:sticky;left:48px;z-index:2;background:var(--surface);box-shadow:2px 0 0 var(--border)}.table-wrap thead th.frozen{z-index:6;background:var(--surface-2)}tbody tr:hover>td.num-col,tbody tr:hover>td.frozen{background:color-mix(in srgb,var(--brand) 9%,#fff)}.table-wrap td.editable .ell{cursor:text;border-bottom:1px dotted color-mix(in srgb,var(--brand) 45%,transparent)}.table-wrap td.editable:hover{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--brand) 30%,transparent)}.cell-edit{width:100%;min-width:130px;border:1px solid var(--brand);border-radius:6px;padding:5px 7px;font:inherit;font-size:13px;outline:none;background:var(--surface);color:var(--text);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 14%,transparent)}select.cell-edit{padding:5px 4px}@media (max-width: 1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 860px){.login-wrap{grid-template-columns:1fr}.login-hero{display:none}}@media (max-width: 560px){.kpi-grid{grid-template-columns:1fr}.content{padding:18px 14px 50px}.entity-head{top:64px}.topbar .logo span:last-child{display:none}.sync-meta{display:none}}
