:root{--brand:#1e3a5f;--brand-700:#18304e;--brand-600:#234670;--brand-100:#dbe5f0;--brand-50:#eef3f9;--accent:#e8602c;--accent-600:#d4521f;--accent-50:#fdf0e9;--slate-900:#0f172a;--slate-850:#172033;--slate-800:#1e293b;--slate-700:#334155;--slate-600:#475569;--slate-500:#64748b;--slate-400:#94a3b8;--slate-300:#cbd5e1;--slate-200:#e2e8f0;--slate-100:#f1f5f9;--slate-50:#f8fafc;--white:#fff;--green-50:#ecfdf5;--green-100:#d1fae5;--green-700:#047857;--red-50:#fef2f2;--red-100:#fee2e2;--red-700:#b91c1c;--amber-50:#fffbeb;--amber-100:#fef3c7;--amber-700:#b45309;--blue-50:#eff6ff;--blue-100:#dbeafe;--blue-700:#1d4ed8;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 2px #0f172a0f;--shadow:0 1px 3px #0f172a14, 0 1px 2px #0f172a0a;--shadow-md:0 4px 12px #0f172a14;--shadow-lg:0 12px 32px #0f172a29;--shadow-card:0 1px 2px #0f172a0a, 0 2px 6px #0f172a0d;--shadow-card-hover:0 2px 4px #0f172a0a, 0 12px 24px #0f172a1a;--ring:0 0 0 3px var(--brand-100);--sidebar-w:256px;--sidebar-collapsed:72px;--topbar-h:60px;color:var(--slate-800);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--slate-50);color:var(--slate-800);margin:0;font-size:14px;line-height:1.5}h1,h2,h3,h4{letter-spacing:-.02em;color:var(--slate-900);margin:0;font-weight:600}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:14px}.btn{border-radius:var(--radius-sm);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;height:40px;padding:0 16px;font-size:14px;font-weight:600;line-height:1;transition:all .15s;display:inline-flex}.btn svg{width:18px;height:18px}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-600)}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-600)}.btn-secondary{color:var(--slate-700);border-color:var(--slate-300);background:#fff}.btn-secondary:hover{background:var(--slate-50);border-color:var(--slate-400)}.btn-ghost{color:var(--slate-600);background:0 0}.btn-ghost:hover{background:var(--slate-100)}.btn-danger{color:var(--red-700);border-color:var(--red-100);background:#fff}.btn-danger:hover{background:var(--red-50)}.btn-sm{height:32px;padding:0 12px;font-size:13px}.btn-sm svg{width:16px;height:16px}.btn-icon{width:36px;height:36px;padding:0}.btn:disabled{opacity:.55;cursor:not-allowed}.btn:not(:disabled):active{transform:translateY(.5px)}.btn-block{width:100%}.btn:focus-visible,.tab:focus-visible,.kanban-card:focus-visible{outline:2px solid var(--brand-600);outline-offset:2px}.icon-btn:focus-visible{outline:2px solid var(--brand-600);outline-offset:1px}.nav-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.card{border:1px solid var(--slate-200);border-radius:var(--radius);box-shadow:var(--shadow-card);background:#fff}.card-pad{padding:20px}.card-head{border-bottom:1px solid var(--slate-200);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.card-head h3{font-size:16px}.field{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.field label{color:var(--slate-700);font-size:13px;font-weight:500}.field .hint{color:var(--slate-500);font-size:12px}.input,.select,.textarea{border:1px solid var(--slate-300);border-radius:var(--radius-sm);width:100%;height:40px;color:var(--slate-800);background:#fff;outline:none;padding:0 12px;transition:border-color .15s,box-shadow .15s}.textarea{resize:vertical;height:auto;min-height:84px;padding:10px 12px}.input:focus,.select:focus,.textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-100)}.input::placeholder,.textarea::placeholder{color:var(--slate-400)}.grid-2{grid-template-columns:1fr 1fr;gap:0 16px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:0 16px;display:grid}@media (width<=640px){.grid-2,.grid-3{grid-template-columns:1fr}}.table-wrap{width:100%;overflow-x:auto}table.tbl{border-collapse:collapse;width:100%;font-size:14px}table.tbl th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--slate-500);border-bottom:1px solid var(--slate-200);white-space:nowrap;background:var(--slate-50);padding:10px 16px;font-size:11px;font-weight:600}table.tbl td{border-bottom:1px solid var(--slate-100);color:var(--slate-700);vertical-align:middle;padding:12px 16px}table.tbl tbody tr{transition:background .12s}table.tbl tbody tr:hover{background:var(--slate-50)}table.tbl tbody tr:last-child td{border-bottom:none}.num{text-align:right;font-variant-numeric:tabular-nums}.th-num{text-align:right}.badge{white-space:nowrap;border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;line-height:1.4;display:inline-flex}.badge-slate{background:var(--slate-100);color:var(--slate-600)}.badge-green{background:var(--green-50);color:var(--green-700)}.badge-red{background:var(--red-50);color:var(--red-700)}.badge-amber{background:var(--amber-50);color:var(--amber-700)}.badge-blue{background:var(--blue-50);color:var(--blue-700)}.badge-brand{background:var(--brand-50);color:var(--brand)}.badge-accent{background:var(--accent-50);color:var(--accent-600)}.badge .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--slate-900);color:var(--slate-300);z-index:50;flex-direction:column;flex-shrink:0;transition:width .18s,transform .22s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{height:var(--topbar-h);border-bottom:1px solid var(--slate-800);flex-shrink:0;align-items:center;gap:10px;padding:0 18px;display:flex}.sidebar-brand .logo{flex-shrink:0;width:30px;height:30px}.sidebar-brand .name{color:#fff;letter-spacing:-.02em;white-space:nowrap;font-size:15px;font-weight:700}.sidebar-brand .name small{color:var(--slate-500);letter-spacing:0;font-size:11px;font-weight:400;display:block}.sidebar.collapsed .sidebar-brand{justify-content:center;padding:0}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--slate-700);border-radius:3px}.nav-group-label{text-transform:uppercase;letter-spacing:.08em;color:var(--slate-500);padding:14px 12px 6px;font-size:10.5px;font-weight:600}.sidebar.collapsed .nav-group-label{letter-spacing:0;color:#0000;background:var(--slate-800);border-radius:1px;height:1px;margin:12px 12px 10px;padding:0;font-size:0;overflow:hidden}.nav-item{border-radius:var(--radius-sm);color:var(--slate-300);cursor:pointer;align-items:center;gap:11px;margin-bottom:2px;padding:9px 12px;font-size:14px;font-weight:500;transition:background .13s,color .13s;display:flex;position:relative}.nav-item:hover{background:var(--slate-800);color:#fff;text-decoration:none}.nav-item.active{background:var(--brand-600);color:#fff}.nav-item.active .nav-icon{color:var(--accent)}.nav-icon{width:20px;height:20px;color:var(--slate-400);flex-shrink:0}.nav-item .nav-label{white-space:nowrap;overflow:hidden}.nav-badge{background:var(--accent);color:#fff;border-radius:999px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:700}.sidebar.collapsed .nav-item{justify-content:center;padding:10px 0}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-badge{display:none}.sidebar.collapsed .nav-item:hover:after{content:attr(data-label);background:var(--slate-800);color:#fff;white-space:nowrap;z-index:60;box-shadow:var(--shadow-md);pointer-events:none;border-radius:6px;padding:6px 10px;font-size:13px;position:absolute;top:50%;left:calc(100% + 10px);transform:translateY(-50%)}.sidebar-foot{border-top:1px solid var(--slate-800);padding:12px 10px}.user-chip{border-radius:var(--radius-sm);align-items:center;gap:10px;padding:8px;display:flex}.avatar{background:var(--brand-600);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:600;display:flex}.user-chip .info{overflow:hidden}.user-chip .info .u-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-chip .info .u-role{color:var(--slate-500);text-transform:capitalize;font-size:12px}.sidebar.collapsed .user-chip .info,.sidebar.collapsed .sidebar-foot .btn-logout{display:none}.main{min-width:0;margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .18s;display:flex}.main.collapsed{margin-left:var(--sidebar-collapsed)}.topbar{height:var(--topbar-h);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--slate-200);z-index:30;background:#ffffffd9;align-items:center;gap:12px;padding:0 24px;display:flex;position:sticky;top:0}.topbar h1{font-size:18px;font-weight:600}.topbar .sub{color:var(--slate-500);font-size:12.5px;font-weight:400}.topbar-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.icon-btn{border-radius:var(--radius-sm);width:38px;height:38px;color:var(--slate-600);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;transition:background .13s;display:inline-flex}.icon-btn:hover{background:var(--slate-100)}.icon-btn:active{background:var(--slate-200)}.icon-btn svg{width:20px;height:20px}.hamburger{display:none}.content{flex:1;width:100%;max-width:1280px;padding:24px}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.page-head .ttl{font-size:22px;font-weight:700}.page-head .desc{color:var(--slate-500);margin-top:2px;font-size:14px}.overlay{z-index:45;opacity:0;pointer-events:none;background:#0f172a80;transition:opacity .2s;position:fixed;inset:0}.overlay.show{opacity:1;pointer-events:auto}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.kpi{border:1px solid var(--slate-200);border-radius:var(--radius);box-shadow:var(--shadow-card);background:#fff;flex-direction:column;gap:8px;padding:18px 20px;display:flex}.kpi-link{cursor:pointer;transition:transform .16s,box-shadow .16s,border-color .16s}.kpi-link:hover{box-shadow:var(--shadow-card-hover);border-color:var(--slate-300);transform:translateY(-2px)}.kpi-link:active{transform:translateY(0)}.kpi-link:focus-visible{outline:2px solid var(--brand-600);outline-offset:2px}.kpi .kpi-top{justify-content:space-between;align-items:center;display:flex}.kpi .kpi-label{color:var(--slate-500);text-transform:uppercase;letter-spacing:.03em;font-size:12px;font-weight:600}.kpi .kpi-ico{background:var(--brand-50);width:36px;height:36px;color:var(--brand);border-radius:9px;justify-content:center;align-items:center;display:flex}.kpi .kpi-ico svg{width:20px;height:20px}.kpi .kpi-ico.accent{background:var(--accent-50);color:var(--accent-600)}.kpi .kpi-ico.green{background:var(--green-50);color:var(--green-700)}.kpi .kpi-ico.red{background:var(--red-50);color:var(--red-700)}.kpi .kpi-ico.amber{background:var(--amber-50);color:var(--amber-700)}.kpi .kpi-value{color:var(--slate-900);letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:28px;font-weight:700;line-height:1.1}.kpi .kpi-foot{color:var(--slate-500);font-size:12.5px}.modal-backdrop{z-index:100;background:#0f172a8c;justify-content:center;align-items:flex-start;padding:24px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{border-radius:var(--radius);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:560px;margin:auto;animation:.16s modalIn}.modal.wide{max-width:760px}@keyframes modalIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-head{border-bottom:1px solid var(--slate-200);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-head h3{font-size:17px}.modal-body{padding:22px}.modal-foot{border-top:1px solid var(--slate-200);justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}.empty{text-align:center;color:var(--slate-500);flex-direction:column;align-items:center;gap:12px;padding:56px 24px;display:flex}.empty .empty-ico{background:var(--slate-100);width:52px;height:52px;color:var(--slate-400);border-radius:14px;justify-content:center;align-items:center;display:flex}.empty .empty-ico svg{width:26px;height:26px}.empty h4{color:var(--slate-700);font-size:16px}.empty p{max-width:360px;font-size:14px}.spinner{border:2.5px solid var(--slate-200);border-top-color:var(--brand);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.center-screen{justify-content:center;align-items:center;min-height:100vh;display:flex}.row{align-items:center;gap:10px;display:flex}.row-between{justify-content:space-between;align-items:center;gap:12px;display:flex}.wrap-gap{flex-wrap:wrap;gap:8px;display:flex}.muted{color:var(--slate-500)}.strong{color:var(--slate-800);font-weight:600}.mono{font-variant-numeric:tabular-nums}.tabs{border-bottom:1px solid var(--slate-200);gap:4px;margin-bottom:20px;display:flex;overflow-x:auto}.tab{color:var(--slate-500);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 14px;font-size:14px;font-weight:500}.tab:hover{color:var(--slate-800)}.tab.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}.toast-wrap{z-index:200;flex-direction:column;gap:10px;max-width:360px;display:flex;position:fixed;top:18px;right:18px}.toast{background:var(--slate-900);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);align-items:flex-start;gap:10px;padding:12px 16px;font-size:14px;animation:.18s toastIn;display:flex}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast.success{background:#064e3b}.toast.error{background:#7f1d1d}.toast svg{flex-shrink:0;width:18px;height:18px;margin-top:1px}.divider{background:var(--slate-200);border:none;height:1px;margin:16px 0}.checkbox-row{color:var(--slate-600);align-items:flex-start;gap:10px;font-size:13.5px;display:flex}.checkbox-row input{width:18px;height:18px;accent-color:var(--brand);flex-shrink:0;margin-top:1px}.bar{background:var(--slate-100);border-radius:4px;height:6px;overflow:hidden}.bar>span{background:var(--brand);border-radius:4px;height:100%;display:block}.bar.low>span{background:var(--accent)}.kanban{grid-auto-columns:minmax(240px,1fr);grid-auto-flow:column;gap:14px;padding-bottom:8px;display:grid;overflow-x:auto}.kanban-col{background:var(--slate-100);border-radius:var(--radius);min-height:140px;padding:10px}.kanban-col h4{text-transform:uppercase;letter-spacing:.03em;color:var(--slate-500);justify-content:space-between;padding:4px 6px 10px;font-size:12px;display:flex}.kanban-card{border:1px solid var(--slate-200);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);cursor:pointer;background:#fff;margin-bottom:8px;padding:12px;transition:box-shadow .13s,transform .13s}.kanban-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kanban-card .kc-title{color:var(--slate-800);font-size:13.5px;font-weight:600}.kanban-card .kc-meta{color:var(--slate-500);margin-top:4px;font-size:12px}.kanban-card .kc-val{color:var(--brand);margin-top:6px;font-size:13px;font-weight:600}.login-screen{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-aside{background:linear-gradient(160deg, var(--brand-700), var(--brand));color:#fff;flex-direction:column;justify-content:space-between;padding:56px;display:flex;position:relative;overflow:hidden}.login-aside .glow{background:radial-gradient(circle,#e8602c59,#0000 70%);border-radius:50%;width:480px;height:480px;position:absolute;top:-120px;right:-120px}.login-aside:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff0f,#0000 70%);border-radius:50%;width:420px;height:420px;position:absolute;bottom:-160px;left:-120px}.login-aside .brand-row{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.login-aside .brand-row .logo{width:40px;height:40px}.login-aside .brand-row .nm{font-size:20px;font-weight:700}.login-aside .pitch{z-index:1;position:relative}.login-aside .pitch h2{color:#fff;max-width:420px;font-size:30px;line-height:1.2}.login-aside .pitch p{color:#fffc;max-width:440px;margin-top:16px;font-size:15px}.login-features{z-index:1;flex-direction:column;gap:12px;display:flex;position:relative}.login-features .lf{color:#ffffffeb;align-items:center;gap:10px;font-size:14px;display:flex}.login-features .lf svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}.login-main{background:var(--slate-50);justify-content:center;align-items:center;padding:32px;display:flex}.login-box{width:100%;max-width:380px}.login-box .lb-logo{display:none}.login-box h1{font-size:24px}.login-box .sub{color:var(--slate-500);margin:6px 0 26px}.demo-box{background:var(--brand-50);border:1px solid var(--brand-100);border-radius:var(--radius-sm);margin-top:20px;padding:14px 16px;font-size:13px}.demo-box .db-title{color:var(--brand);align-items:center;gap:7px;font-weight:600;display:flex}.demo-box .db-creds{color:var(--slate-600);margin:8px 0 10px}.demo-box code{border:1px solid var(--brand-100);background:#fff;border-radius:5px;padding:1px 6px;font-size:12.5px}.login-foot{text-align:center;color:var(--slate-400);margin-top:28px;font-size:12.5px}.login-foot a{color:var(--slate-500)}.alert{border-radius:var(--radius-sm);margin-bottom:16px;padding:11px 14px;font-size:13.5px}.alert-error{background:var(--red-50);color:var(--red-700);border:1px solid var(--red-100)}.alert-info{background:var(--blue-50);color:var(--blue-700);border:1px solid var(--blue-100)}@media (width<=960px){.login-screen{grid-template-columns:1fr}.login-aside{display:none}.login-box .lb-logo{align-items:center;gap:10px;margin-bottom:22px;display:flex}}@media (width<=880px){.sidebar{width:var(--sidebar-w);box-shadow:var(--shadow-lg);transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{width:var(--sidebar-w)}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-badge{display:inline}.sidebar.collapsed .nav-group-label{letter-spacing:.08em;color:var(--slate-500);background:0 0;border-radius:0;height:auto;margin:0;padding:14px 12px 6px;font-size:10.5px}.sidebar.collapsed .sidebar-brand{justify-content:flex-start;padding:0 18px}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:9px 12px}.sidebar.collapsed .user-chip .info{display:block}.main,.main.collapsed{margin-left:0}.hamburger{display:inline-flex}.content{padding:16px}.collapse-btn{display:none}}.dl-cards{display:none}@media (width<=720px){.hide-mobile{display:none!important}}.detail-grid{grid-template-columns:140px 1fr;gap:8px 16px;font-size:14px;display:grid}.detail-grid dt{color:var(--slate-500)}.detail-grid dd{color:var(--slate-800);margin:0;font-weight:500}@media (width<=520px){.detail-grid{grid-template-columns:1fr;gap:2px 0}.detail-grid dt{margin-top:8px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.legal{max-width:760px;margin:0 auto;padding:48px 24px 80px}.legal h1{margin-bottom:8px;font-size:28px}.legal h2{margin:28px 0 8px;font-size:18px}.legal p,.legal li{color:var(--slate-600);font-size:14.5px;line-height:1.7}.legal .back{align-items:center;gap:6px;margin-bottom:24px;font-size:14px;display:inline-flex}.legal .updated{color:var(--slate-400);margin-top:32px;font-size:13px;font-style:italic}
