:root{--c-primary:#0f3a6b;--c-primary-700:#0b2c52;--c-primary-600:#134781;--c-primary-50:#eaf1fb;--c-accent:#d97a2c;--c-accent-600:#c06820;--c-accent-50:#fdf1e6;--c-accent-100:#f9d9b4;--c-primary-100:#b8d0ed;--c-bg:#f4f6fa;--c-surface:#fff;--c-surface-2:#f9fafc;--c-border:#e3e8ef;--c-border-strong:#cbd2dd;--c-text:#1a2433;--c-text-soft:#4b5666;--c-text-muted:#7a8597;--c-success:#16a34a;--c-success-bg:#e7f7ee;--c-warn:#ca8a04;--c-warn-bg:#fdf4d3;--c-danger:#dc2626;--c-danger-bg:#fde7e7;--c-info:#0284c7;--c-info-bg:#e0f2fe;--c-purple:#7c3aed;--c-purple-bg:#f1e9fe;--sidebar-w:256px;--sidebar-w-collapsed:72px;--header-h:64px;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 2px #0f3a6b0f;--shadow:0 4px 14px #0f3a6b14;--shadow-lg:0 12px 32px #0f3a6b24;--transition:.18s cubic-bezier(.4,0,.2,1)}[data-theme=dark]{--c-bg:#0c1422;--c-surface:#131e2f;--c-surface-2:#182539;--c-border:#243349;--c-border-strong:#34465f;--c-text:#e8edf5;--c-text-soft:#b8c2d2;--c-text-muted:#8593aa;--c-primary-50:#1a2942;--c-accent-50:#3a2415;--c-success-bg:#0f2e1d;--c-warn-bg:#2e2510;--c-danger-bg:#2e1414;--c-info-bg:#102836;--c-purple-bg:#221538;--shadow-sm:0 1px 2px #0006;--shadow:0 4px 14px #0006;--shadow-lg:0 12px 32px #0000008c}*{box-sizing:border-box}html,body,#root{height:100%}body{color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,select,textarea{color:var(--c-text);font-family:inherit;font-size:14px}.app-shell{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;transition:grid-template-columns var(--transition);display:grid}.app-shell.collapsed{grid-template-columns:var(--sidebar-w-collapsed) 1fr}.sidebar{background:var(--c-surface);border-right:1px solid var(--c-border);flex-direction:column;height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-brand{height:var(--header-h);border-bottom:1px solid var(--c-border);align-items:center;gap:10px;padding:0 18px;display:flex}.sidebar-brand .logo{background:linear-gradient(135deg, var(--c-primary), var(--c-primary-600));color:#fff;width:36px;height:36px;box-shadow:var(--shadow-sm);border-radius:9px;flex-shrink:0;place-items:center;font-weight:700;display:grid}.sidebar-brand .brand-text{flex-direction:column;line-height:1.1;display:flex}.sidebar-brand .brand-text strong{color:var(--c-primary);letter-spacing:.2px;font-size:15px}.sidebar-brand .brand-text span{color:var(--c-text-muted);font-size:11px}.sidebar-nav{scrollbar-width:thin;flex:1;padding:10px 8px 16px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--c-border-strong);border-radius:3px}.nav-group-label{text-transform:uppercase;letter-spacing:.8px;color:var(--c-text-muted);padding:14px 14px 6px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--c-text-soft);transition:var(--transition);white-space:nowrap;align-items:center;gap:12px;margin:2px 4px;padding:9px 12px;font-size:13.5px;font-weight:500;display:flex;position:relative}.nav-item:hover{background:var(--c-primary-50);color:var(--c-primary)}.nav-item.active{background:linear-gradient(90deg, var(--c-primary-50), transparent);color:var(--c-primary);font-weight:600}.nav-item.active:before{content:"";background:var(--c-accent);border-radius:0 3px 3px 0;width:3px;position:absolute;top:8px;bottom:8px;left:-4px}.nav-item .nav-icon{flex-shrink:0;width:18px;height:18px}.nav-item .nav-badge{background:var(--c-accent);color:#fff;border-radius:10px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.collapsed .sidebar-nav .nav-item span:not(.nav-badge),.collapsed .sidebar-brand .brand-text,.collapsed .nav-group-label{display:none}.collapsed .nav-item{justify-content:center}.header{height:var(--header-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);z-index:50;align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.header-toggle{width:36px;height:36px;color:var(--c-text-soft);transition:var(--transition);border-radius:8px;place-items:center;display:grid}.header-toggle:hover{background:var(--c-primary-50);color:var(--c-primary)}.header-search{flex:1;max-width:480px;position:relative}.header-search input{border:1px solid var(--c-border);background:var(--c-surface-2);width:100%;height:38px;transition:var(--transition);border-radius:10px;outline:none;padding:0 14px 0 38px}.header-search input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-50)}.header-search .search-icon{color:var(--c-text-muted);width:16px;height:16px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.header-search kbd{background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text-muted);border-radius:4px;padding:2px 6px;font-family:inherit;font-size:10px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.icon-btn{width:38px;height:38px;color:var(--c-text-soft);transition:var(--transition);border-radius:10px;place-items:center;display:grid;position:relative}.icon-btn:hover{background:var(--c-primary-50);color:var(--c-primary)}.icon-btn .dot{background:var(--c-accent);border:2px solid var(--c-surface);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.quick-action-btn{background:var(--c-accent);color:#fff;transition:var(--transition);border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex;box-shadow:0 4px 10px #d97a2c4d}.quick-action-btn:hover{background:var(--c-accent-600);transform:translateY(-1px)}.profile-chip{border:1px solid var(--c-border);cursor:pointer;transition:var(--transition);border-radius:30px;align-items:center;gap:10px;padding:4px 10px 4px 4px;display:flex}.profile-chip:hover{background:var(--c-surface-2);border-color:var(--c-border-strong)}.avatar{background:linear-gradient(135deg, var(--c-primary), var(--c-accent));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:grid}.avatar.lg{width:64px;height:64px;font-size:22px}.avatar.xl{width:96px;height:96px;font-size:30px}.profile-chip .meta{line-height:1.1}.profile-chip .meta strong{font-size:12.5px}.profile-chip .meta span{color:var(--c-text-muted);font-size:10.5px}.dropdown{position:relative}.dropdown-menu{background:var(--c-surface);border:1px solid var(--c-border);min-width:240px;box-shadow:var(--shadow-lg);z-index:60;border-radius:12px;padding:6px;animation:.16s dropIn;position:absolute;top:calc(100% + 8px);right:0}@keyframes dropIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.dropdown-item{color:var(--c-text-soft);cursor:pointer;text-align:left;border-radius:8px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13px;display:flex}.dropdown-item:hover{background:var(--c-primary-50);color:var(--c-primary)}.dropdown-item.danger:hover{background:var(--c-danger-bg);color:var(--c-danger)}.dropdown-divider{background:var(--c-border);height:1px;margin:4px 0}.notif-panel{width:360px;padding:0}.notif-panel .notif-head{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.notif-panel .notif-head h4{margin:0;font-size:14px}.notif-list{max-height:360px;overflow-y:auto}.notif-item{border-bottom:1px solid var(--c-border);cursor:pointer;gap:10px;padding:12px 14px;display:flex}.notif-item:hover{background:var(--c-surface-2)}.notif-item .ni-icon{border-radius:10px;flex-shrink:0;place-items:center;width:36px;height:36px;display:grid}.notif-item .ni-body{flex:1}.notif-item .ni-body p{margin:0 0 2px;font-size:13px;font-weight:500}.notif-item .ni-body span{color:var(--c-text-muted);font-size:11px}.main{flex-direction:column;min-width:0;display:flex}.page{flex:1;padding:24px 28px 48px}.breadcrumb{color:var(--c-text-muted);align-items:center;gap:6px;margin-bottom:8px;font-size:12px;display:flex}.breadcrumb a:hover{color:var(--c-primary)}.breadcrumb .sep{opacity:.5}.breadcrumb .current{color:var(--c-text-soft);font-weight:500}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.page-head h1{color:var(--c-text);margin:0 0 4px;font-size:22px;font-weight:700}.page-head .subtitle{color:var(--c-text-muted);margin:0;font-size:13px}.page-actions{flex-wrap:wrap;gap:8px;display:flex}.btn{transition:var(--transition);white-space:nowrap;border:1px solid #0000;border-radius:9px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover{background:var(--c-primary-700)}.btn-accent{background:var(--c-accent);color:#fff;box-shadow:0 4px 10px #d97a2c40}.btn-accent:hover{background:var(--c-accent-600)}.btn-outline{border-color:var(--c-border-strong);color:var(--c-text-soft);background:var(--c-surface)}.btn-outline:hover{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-50)}.btn-ghost{color:var(--c-text-soft)}.btn-ghost:hover{background:var(--c-primary-50);color:var(--c-primary)}.btn-danger{background:var(--c-danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-success{background:var(--c-success);color:#fff}.btn-sm{border-radius:7px;padding:5px 10px;font-size:12px}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:var(--transition)}.card:hover{box-shadow:var(--shadow)}.card-pad{padding:18px 20px}.card-head{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-head h3{margin:0;font-size:15px;font-weight:600}.card-body{padding:18px 20px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:22px;display:grid}.stat-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);transition:var(--transition);align-items:flex-start;gap:14px;padding:16px 18px;display:flex;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow);border-color:var(--c-primary-50);transform:translateY(-2px)}.stat-icon{border-radius:11px;flex-shrink:0;place-items:center;width:44px;height:44px;display:grid}.stat-card .stat-body{flex:1;min-width:0}.stat-card .label{color:var(--c-text-muted);margin:0 0 4px;font-size:12px;font-weight:500}.stat-card .value{color:var(--c-text);margin:0;font-size:22px;font-weight:700;line-height:1.2}.stat-card .delta{align-items:center;gap:3px;margin-top:4px;font-size:11.5px;font-weight:600;display:inline-flex}.delta.up{color:var(--c-success)}.delta.down{color:var(--c-danger)}.toolbar{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;padding:12px 14px;display:flex}.toolbar .search{flex:1;min-width:240px;position:relative}.toolbar .search input{border:1px solid var(--c-border);background:var(--c-surface-2);border-radius:9px;outline:none;width:100%;height:38px;padding:0 14px 0 36px}.toolbar .search input:focus{border-color:var(--c-primary)}.toolbar .search svg{color:var(--c-text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.select{border:1px solid var(--c-border);background:var(--c-surface-2);height:38px;color:var(--c-text-soft);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;charset=US-ASCII,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%237a8597' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:8px;border-radius:9px;padding:0 30px 0 12px;font-size:13px}.input{border:1px solid var(--c-border);background:var(--c-surface-2);border-radius:9px;outline:none;width:100%;height:38px;padding:0 12px}.input:focus,.select:focus,textarea.input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-50)}textarea.input{resize:vertical;height:auto;min-height:92px;padding:10px 12px}.label{color:var(--c-text-soft);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.field{margin-bottom:14px}.table-wrap{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);overflow:hidden}.table-scroll{overflow-x:auto}table.data{border-collapse:collapse;width:100%;font-size:13px}table.data th{text-align:left;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.4px;background:var(--c-surface-2);border-bottom:1px solid var(--c-border);white-space:nowrap;padding:12px 14px;font-size:11.5px;font-weight:600}table.data td{border-bottom:1px solid var(--c-border);color:var(--c-text);vertical-align:middle;padding:13px 14px}table.data tbody tr{transition:background .12s}table.data tbody tr:hover{background:var(--c-surface-2)}table.data tbody tr:last-child td{border-bottom:none}.table-id{color:var(--c-primary);font-family:JetBrains Mono,Consolas,monospace;font-size:12px;font-weight:600}.cell-user{align-items:center;gap:10px;display:flex}.cell-user .meta strong{font-size:13px;display:block}.cell-user .meta span{color:var(--c-text-muted);font-size:11px}.badge{white-space:nowrap;border-radius:14px;align-items:center;gap:4px;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge.success{background:var(--c-success-bg);color:var(--c-success)}.badge.warn{background:var(--c-warn-bg);color:var(--c-warn)}.badge.danger{background:var(--c-danger-bg);color:var(--c-danger)}.badge.info{background:var(--c-info-bg);color:var(--c-info)}.badge.purple{background:var(--c-purple-bg);color:var(--c-purple)}.badge.muted{background:var(--c-bg);color:var(--c-text-muted)}.badge.accent{background:var(--c-accent-50);color:var(--c-accent)}.badge.dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.actions{gap:4px;display:flex}.act-btn{width:30px;height:30px;color:var(--c-text-muted);transition:var(--transition);border-radius:7px;place-items:center;display:grid}.act-btn:hover{background:var(--c-primary-50);color:var(--c-primary)}.act-btn.danger:hover{background:var(--c-danger-bg);color:var(--c-danger)}.act-btn.success:hover{background:var(--c-success-bg);color:var(--c-success)}.pagination{border-top:1px solid var(--c-border);color:var(--c-text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:14px 18px;font-size:12px;display:flex}.page-nums{gap:4px;display:flex}.page-num{border:1px solid var(--c-border);background:var(--c-surface);min-width:32px;height:32px;color:var(--c-text-soft);border-radius:7px;place-items:center;padding:0 8px;font-size:12.5px;display:grid}.page-num:hover{background:var(--c-primary-50);color:var(--c-primary)}.page-num.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.page-num:disabled{opacity:.4;cursor:not-allowed}.empty{text-align:center;color:var(--c-text-muted);padding:60px 20px}.empty .empty-icon{background:var(--c-primary-50);width:72px;height:72px;color:var(--c-primary);border-radius:50%;place-items:center;margin:0 auto 14px;display:grid}.empty h3{color:var(--c-text);margin:0 0 6px;font-size:16px}.empty p{margin:0;font-size:13px}.skeleton{background:linear-gradient(90deg, var(--c-bg) 0%, var(--c-surface-2) 50%, var(--c-bg) 100%);background-size:200% 100%;border-radius:6px;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0f172a8c;place-items:center;padding:20px;animation:.16s fadeIn;display:grid;position:fixed;inset:0}[data-theme=dark] .modal-overlay{background:#000000b3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--c-surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;animation:.2s cubic-bezier(.4,0,.2,1) modalIn;overflow-y:auto}.modal.lg{max-width:760px}.modal.xl{max-width:980px}@keyframes modalIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:none}}.modal-head{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-head h3{margin:0;font-size:16px}.modal-body{padding:20px 22px}.modal-foot{border-top:1px solid var(--c-border);justify-content:flex-end;gap:8px;padding:14px 22px;display:flex}.form-grid{grid-template-columns:repeat(2,1fr);gap:14px 18px;display:grid}@media (width<=640px){.form-grid{grid-template-columns:1fr}}.form-row{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--c-text-muted);font-size:12px;font-weight:600}.form-input{border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:8px 12px;font-size:13px;transition:border-color .15s}.form-input:focus{border-color:var(--c-accent)}.form-input.input-error{border-color:var(--c-danger)}.form-error{color:var(--c-danger);font-size:11px}textarea.form-input{resize:vertical}.confirm-icon{border-radius:50%;place-items:center;width:56px;height:56px;margin:0 auto 14px;display:grid}.tabs{border-bottom:1px solid var(--c-border);scrollbar-width:none;gap:4px;margin-bottom:18px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{color:var(--c-text-muted);white-space:nowrap;transition:var(--transition);border-bottom:2px solid #0000;padding:10px 16px;font-size:13px;font-weight:600}.tab:hover{color:var(--c-primary)}.tab.active{color:var(--c-primary);border-bottom-color:var(--c-accent)}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=1100px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=700px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.row{flex-wrap:wrap;gap:16px;display:flex}.col{flex:1;min-width:0}.gap-2{gap:8px}.gap-3{gap:12px}.chart-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius)}.chart-svg{width:100%;height:auto;display:block}.switch{flex-shrink:0;width:38px;height:22px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.switch .slider{cursor:pointer;background:var(--c-border-strong);transition:var(--transition);border-radius:30px;position:absolute;inset:0}.switch .slider:before{content:"";width:16px;height:16px;transition:var(--transition);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.switch input:checked+.slider{background:var(--c-primary)}.switch input:checked+.slider:before{transform:translate(16px)}.quick-actions{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.quick-action{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);transition:var(--transition);cursor:pointer;text-align:left;align-items:center;gap:12px;padding:16px;display:flex}.quick-action:hover{border-color:var(--c-accent);box-shadow:var(--shadow);transform:translateY(-2px)}.quick-action .qa-icon{background:var(--c-accent-50);width:40px;height:40px;color:var(--c-accent);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.quick-action strong{font-size:13.5px;display:block}.quick-action span{color:var(--c-text-muted);font-size:11.5px}.timeline{padding-left:24px;position:relative}.timeline:before{content:"";background:var(--c-border);width:2px;position:absolute;top:6px;bottom:6px;left:8px}.tl-item{padding-bottom:16px;position:relative}.tl-item:before{content:"";background:var(--c-surface);border:2px solid var(--c-primary);width:12px;height:12px;box-shadow:0 0 0 3px var(--c-primary-50);border-radius:50%;position:absolute;top:4px;left:-22px}.tl-item.done:before{background:var(--c-success);border-color:var(--c-success)}.tl-item.warn:before{background:var(--c-warn);border-color:var(--c-warn)}.tl-item p{margin:0;font-size:13px}.tl-item span{color:var(--c-text-muted);font-size:11px}.doc-card{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:10px;align-items:center;gap:12px;padding:14px;display:flex}.doc-card .doc-thumb{background:var(--c-primary-50);width:50px;height:60px;color:var(--c-primary);border-radius:6px;flex-shrink:0;place-items:center;display:grid}.progress{background:var(--c-bg);border-radius:4px;height:8px;overflow:hidden}.progress>div{background:linear-gradient(90deg, var(--c-primary), var(--c-accent));border-radius:4px;height:100%;transition:width .6s}.login-page{background:var(--c-bg);grid-template-columns:1.1fr 1fr;min-height:100vh;display:grid}@media (width<=900px){.login-page{grid-template-columns:1fr}.login-art{display:none}}.login-art{color:#fff;background:linear-gradient(135deg,#0b2c52 0%,#0f3a6b 50%,#134781 100%);flex-direction:column;justify-content:space-between;padding:60px;display:flex;position:relative;overflow:hidden}.login-art:before,.login-art:after{content:"";opacity:.12;border-radius:50%;position:absolute}.login-art:before{background:var(--c-accent);width:400px;height:400px;top:-120px;right:-120px}.login-art:after{background:#fff;width:300px;height:300px;bottom:-80px;left:-80px}.login-art .art-content{z-index:1;position:relative}.login-art h2{margin:0 0 12px;font-size:28px;line-height:1.2}.login-art p{opacity:.85;max-width:420px}.login-art .features{z-index:1;flex-direction:column;gap:14px;max-width:380px;margin-top:28px;display:flex;position:relative}.login-art .feat{align-items:flex-start;gap:12px;display:flex}.login-art .feat-icon{background:#ffffff1f;border-radius:10px;flex-shrink:0;place-items:center;width:38px;height:38px;display:grid}.login-form-wrap{place-items:center;padding:40px;display:grid}.login-form{width:100%;max-width:400px}.login-form .brand{align-items:center;gap:10px;margin-bottom:28px;display:flex}.login-form h1{margin:0 0 6px;font-size:24px}.login-form .sub{color:var(--c-text-muted);margin:0 0 26px}.login-form .security-note{background:var(--c-info-bg);color:var(--c-info);border-radius:9px;align-items:center;gap:8px;margin-bottom:20px;padding:10px 12px;font-size:12px;display:flex}.checkbox-row{justify-content:space-between;align-items:center;margin:6px 0 18px;font-size:13px;display:flex}.checkbox{cursor:pointer;align-items:center;gap:7px;display:inline-flex}.checkbox input{accent-color:var(--c-primary)}.otp-input{justify-content:center;gap:8px;margin:20px 0;display:flex}.otp-input input{text-align:center;border:1.5px solid var(--c-border);background:var(--c-surface-2);width:48px;height:56px;color:var(--c-text);border-radius:10px;outline:none;font-size:22px;font-weight:700}.otp-input input:focus{border-color:var(--c-primary)}.plan-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-bottom:22px;display:grid}.plan-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);transition:var(--transition);flex-direction:column;padding:22px;display:flex}.plan-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}.plan-card.featured{border-color:var(--c-accent);position:relative}.plan-card.featured:before{content:"POPULAR";background:var(--c-accent);color:#fff;letter-spacing:.5px;border-radius:10px;padding:3px 10px;font-size:10px;font-weight:700;position:absolute;top:-10px;right:18px}.plan-card .plan-name{color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.6px;font-size:13px;font-weight:600}.plan-card .price{color:var(--c-primary);margin:8px 0 4px;font-size:32px;font-weight:700}.plan-card .price small{color:var(--c-text-muted);font-size:13px;font-weight:500}.plan-card ul{flex:1;margin:14px 0;padding:0;list-style:none}.plan-card li{color:var(--c-text-soft);align-items:center;gap:8px;padding:6px 0;font-size:13px;display:flex}.plan-card li svg{color:var(--c-success);flex-shrink:0}.perm-table{border-collapse:collapse;width:100%;font-size:13px}.perm-table th,.perm-table td{border-bottom:1px solid var(--c-border);text-align:center;padding:10px 12px}.perm-table th{background:var(--c-surface-2);color:var(--c-text-soft);font-size:12px;font-weight:600}.perm-table td:first-child,.perm-table th:first-child{text-align:left}.perm-table input[type=checkbox]{accent-color:var(--c-primary);cursor:pointer;width:16px;height:16px}.composer-grid{grid-template-columns:1fr 360px;gap:18px;display:grid}@media (width<=1100px){.composer-grid{grid-template-columns:1fr}}.preview-card{background:linear-gradient(135deg, var(--c-primary-50), var(--c-surface));border:1px solid var(--c-border);border-radius:var(--radius);top:calc(var(--header-h) + 20px);padding:20px;position:sticky}.insight{background:linear-gradient(135deg, var(--c-primary-50), var(--c-surface));border:1px solid var(--c-border);border-radius:var(--radius);padding:16px}.insight .ins-label{color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.insight .ins-value{color:var(--c-primary);margin:6px 0 2px;font-size:17px;font-weight:700}.insight .ins-meta{color:var(--c-text-muted);font-size:11.5px}.tree{font-size:13px}.tree-item{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;display:flex}.tree-item:hover{background:var(--c-surface-2)}.tree-item.active{background:var(--c-primary-50);color:var(--c-primary)}.tree-children{border-left:1px dashed var(--c-border);margin-left:12px;padding-left:22px}@media (width<=900px){.app-shell{grid-template-columns:1fr}.sidebar{width:var(--sidebar-w);z-index:80;transition:transform var(--transition);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-lg);transform:none}.header-search{max-width:none}.page{padding:16px}}.sidebar-backdrop{display:none}@media (width<=900px){.sidebar-backdrop.show{z-index:70;background:#0006;display:block;position:fixed;inset:0}}.text-right{text-align:right}.text-muted{color:var(--c-text-muted)}.text-primary{color:var(--c-primary)}.text-accent{color:var(--c-accent)}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.mt-2{margin-top:12px}.mt-3{margin-top:18px}.mt-4{margin-top:24px}.mb-2{margin-bottom:12px}.mb-3{margin-bottom:18px}.w-full{width:100%}hr.div{border:none;border-top:1px solid var(--c-border);margin:16px 0}:root{--c-glass:#ffffffb8;--c-glass-border:#ffffffe6;--c-glass-dark:#0f3a6b14;--c-negotiation:#2f5b8f;--c-negotiation-bg:#dbeafe;--c-deal-gradient:linear-gradient(135deg,#0f3a6b 0%,#1a5fa8 50%,#0b8a74 100%);--c-phase-0:#6366f1;--c-phase-1:#3b82f6;--c-phase-2:#0ea5e9;--c-phase-3:#14b8a6;--c-phase-4:#10b981;--c-phase-5:#22c55e;--c-phase-6:#84cc16;--c-phase-7:#eab308;--c-phase-8:#f97316;--c-phase-9:#16a34a;--sidebar-w:260px}[data-theme=dark]{--c-glass:#131e2fd1;--c-glass-border:#ffffff14;--c-glass-dark:#0000004d;--c-negotiation-bg:#1e3a5f}.glass{background:var(--c-glass);border:1px solid var(--c-glass-border);-webkit-backdrop-filter:blur(12px)}.glass-card{background:var(--c-glass);border:1px solid var(--c-glass-border);-webkit-backdrop-filter:blur(16px);border-radius:var(--radius);box-shadow:0 8px 32px var(--c-glass-dark)}.role-switcher{background:var(--c-primary-50);border:1px solid var(--c-border);cursor:pointer;transition:var(--transition);border-radius:10px;align-items:center;gap:10px;margin:0 12px 8px;padding:10px 12px;display:flex;position:relative}.role-switcher:hover{background:var(--c-bg);border-color:var(--c-primary)}.role-avatar{background:linear-gradient(135deg, var(--c-primary), var(--c-accent));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:grid}.role-info{flex:1;line-height:1.15}.role-info strong{color:var(--c-text);font-size:12.5px;display:block}.role-info span{color:var(--c-text-muted);font-size:10.5px}.role-dropdown{background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-lg);z-index:90;border-radius:10px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden}.role-option{text-align:left;width:100%;color:var(--c-text-soft);cursor:pointer;background:0 0;border:none;padding:10px 14px;font-family:inherit;font-size:13px;transition:background .12s;display:block}.role-option:hover{background:var(--c-primary-50);color:var(--c-primary)}.role-option.active{background:var(--c-primary-50);color:var(--c-primary);font-weight:600}.sidebar-footer{border-top:1px solid var(--c-border);margin:16px 0 0;padding-top:16px}.nav-logout{color:var(--c-danger)!important}.nav-logout:hover{background:var(--c-danger-bg)!important;color:var(--c-danger)!important}.phase-track{align-items:center;gap:3px;display:flex}.phase-pip{background:var(--c-border);border-radius:3px;flex:1;height:5px;transition:background .3s}.phase-pip.done{background:var(--c-success)}.phase-pip.active{background:var(--c-accent)}.phase-pip.warn{background:var(--c-warn)}.nego-phases{scrollbar-width:none;gap:0;padding:0 0 8px;display:flex;overflow-x:auto}.nego-phases::-webkit-scrollbar{display:none}.nego-phase{flex-direction:column;flex:1;align-items:center;min-width:80px;display:flex;position:relative}.nego-phase:not(:last-child):after{content:"";background:var(--c-border);height:2px;position:absolute;top:14px;left:calc(50% + 14px);right:calc(14px - 50%)}.nego-phase.done:not(:last-child):after{background:var(--c-success)}.nego-phase.active:not(:last-child):after{background:var(--c-accent)}.nego-phase-dot{border:2px solid var(--c-border);background:var(--c-surface);width:28px;height:28px;color:var(--c-text-muted);z-index:1;border-radius:50%;place-items:center;margin-bottom:6px;font-size:11px;font-weight:700;transition:all .25s;display:grid;position:relative}.nego-phase.done .nego-phase-dot{background:var(--c-success);border-color:var(--c-success);color:#fff}.nego-phase.active .nego-phase-dot{background:var(--c-accent);border-color:var(--c-accent);color:#fff;box-shadow:0 0 0 4px var(--c-accent-50)}.nego-phase-label{color:var(--c-text-muted);text-align:center;white-space:nowrap;font-size:10px;font-weight:600}.nego-phase.active .nego-phase-label{color:var(--c-accent)}.nego-phase.done .nego-phase-label{color:var(--c-success)}.nego-workspace{height:calc(100vh - var(--header-h) - 120px);grid-template-columns:1fr 360px;gap:18px;display:grid}@media (width<=1100px){.nego-workspace{grid-template-columns:1fr;height:auto}}.nego-main{flex-direction:column;gap:16px;min-height:0;display:flex;overflow:auto}.nego-sidebar-panel{top:calc(var(--header-h) + 24px);max-height:calc(100vh - var(--header-h) - 120px);flex-direction:column;gap:14px;display:flex;position:sticky;overflow-y:auto}.quote-versions{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.qv-chip{border:1.5px solid var(--c-border);color:var(--c-text-muted);cursor:pointer;transition:var(--transition);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600}.qv-chip.active{border-color:var(--c-primary);background:var(--c-primary-50);color:var(--c-primary)}.qv-chip.final{border-color:var(--c-success);background:var(--c-success-bg);color:var(--c-success)}.chat-layout{height:calc(100vh - var(--header-h) - 60px);border:1px solid var(--c-border);border-radius:var(--radius);background:var(--c-surface);grid-template-columns:300px 1fr;gap:0;display:grid;overflow:hidden}@media (width<=800px){.chat-layout{grid-template-columns:1fr}}.chat-list{border-right:1px solid var(--c-border);flex-direction:column;display:flex;overflow-y:auto}.chat-list-head{border-bottom:1px solid var(--c-border);background:var(--c-surface);z-index:1;justify-content:space-between;align-items:center;padding:14px 16px;font-size:15px;font-weight:700;display:flex;position:sticky;top:0}.chat-thread{border-bottom:1px solid var(--c-border);cursor:pointer;gap:10px;padding:12px 14px;transition:background .12s;display:flex}.chat-thread:hover{background:var(--c-surface-2)}.chat-thread.active{background:var(--c-primary-50)}.chat-thread .ct-avatar{background:linear-gradient(135deg, var(--c-primary), var(--c-accent));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:40px;height:40px;font-size:14px;font-weight:700;display:grid}.chat-thread .ct-meta{flex:1;min-width:0}.chat-thread .ct-name{font-size:13px;font-weight:600}.chat-thread .ct-preview{color:var(--c-text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.chat-thread .ct-time{color:var(--c-text-muted);flex-shrink:0;font-size:11px}.chat-thread .ct-badge{background:var(--c-accent);color:#fff;border-radius:50%;place-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:grid}.chat-main{flex-direction:column;display:flex}.chat-main-head{border-bottom:1px solid var(--c-border);background:var(--c-surface);flex-shrink:0;align-items:center;gap:12px;padding:14px 18px;display:flex}.chat-linked-quote{background:var(--c-primary-50);border:1px solid var(--c-border);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;margin:0 18px;padding:6px 12px;font-size:12px;display:flex}.chat-linked-quote:hover{border-color:var(--c-primary)}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px 18px;display:flex;overflow-y:auto}.chat-msg{gap:8px;max-width:80%;display:flex}.chat-msg.own{flex-direction:row-reverse;align-self:flex-end}.chat-bubble{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:14px;padding:10px 14px;font-size:13px;line-height:1.5}.chat-msg.own .chat-bubble{background:var(--c-primary);color:#fff;border:none;border-radius:14px 14px 2px}.chat-msg:not(.own) .chat-bubble{border-radius:14px 14px 14px 2px}.chat-msg-time{color:var(--c-text-muted);text-align:right;margin-top:4px;font-size:10px}.chat-input-area{border-top:1px solid var(--c-border);background:var(--c-surface);flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 18px;display:flex}.chat-input-area textarea{border:1.5px solid var(--c-border);resize:none;background:var(--c-surface-2);min-height:42px;max-height:120px;transition:var(--transition);border-radius:12px;outline:none;flex:1;padding:10px 14px;font-size:13.5px}.chat-input-area textarea:focus{border-color:var(--c-primary)}.quote-type-grid{grid-template-columns:repeat(2,1fr);gap:14px;padding:4px 0;display:grid}.quote-type-card{border:2px solid var(--c-border);cursor:pointer;transition:var(--transition);text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:20px 16px;display:flex}.quote-type-card:hover{border-color:var(--c-accent);background:var(--c-accent-50);transform:translateY(-2px)}.quote-type-card.selected{border-color:var(--c-primary);background:var(--c-primary-50)}.quote-type-icon{border-radius:14px;place-items:center;width:48px;height:48px;font-size:22px;display:grid}.quote-type-card strong{font-size:14px}.quote-type-card p{color:var(--c-text-muted);margin:0;font-size:12px}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.kpi-value{animation:.5s both countUp}.hero-card{background:var(--c-deal-gradient);border-radius:var(--radius);color:#fff;padding:24px;position:relative;overflow:hidden}.hero-card:before{content:"";background:#ffffff0f;border-radius:50%;width:220px;height:220px;position:absolute;top:-60px;right:-60px}.hero-card:after{content:"";background:#ffffff0a;border-radius:50%;width:160px;height:160px;position:absolute;bottom:-40px;left:-40px}.hero-card>*{z-index:1;position:relative}.hero-card h2{margin:0 0 4px;font-size:20px}.hero-card p{opacity:.8;margin:0 0 18px;font-size:13px}.sticky-action-bar{z-index:20;background:var(--c-glass);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--c-glass-border);border-radius:0 0 var(--radius) var(--radius);justify-content:flex-end;align-items:center;gap:10px;padding:12px 20px;display:flex;position:sticky;bottom:0}.deal-timeline{flex-direction:column;gap:0;display:flex}.dt-item{gap:14px;padding-bottom:20px;display:flex;position:relative}.dt-item:not(:last-child):before{content:"";background:var(--c-border);width:2px;position:absolute;top:36px;bottom:0;left:19px}.dt-icon{border:2px solid var(--c-border);background:var(--c-surface);z-index:1;border-radius:50%;flex-shrink:0;place-items:center;width:40px;height:40px;display:grid;position:relative}.dt-icon.done{background:var(--c-success-bg);border-color:var(--c-success);color:var(--c-success)}.dt-icon.active{background:var(--c-accent-50);border-color:var(--c-accent);color:var(--c-accent)}.dt-icon.pending{background:var(--c-warn-bg);border-color:var(--c-warn);color:var(--c-warn)}.dt-body{flex:1;padding-top:8px}.dt-body h4{margin:0 0 2px;font-size:14px}.dt-body p{color:var(--c-text-muted);margin:0;font-size:12px}.dt-body .dt-time{color:var(--c-text-muted);margin-top:4px;font-size:11px}.product-gallery-card{border:1px solid var(--c-border);border-radius:var(--radius);transition:var(--transition);cursor:pointer;background:var(--c-surface);overflow:hidden}.product-gallery-card:hover{box-shadow:var(--shadow);border-color:var(--c-primary);transform:translateY(-3px)}.pgc-thumb{object-fit:cover;background:var(--c-primary-50);width:100%;height:160px;color:var(--c-primary);justify-content:center;align-items:center;font-size:36px;display:flex}.pgc-body{padding:14px}.pgc-title{margin:0 0 4px;font-size:14px;font-weight:700}.pgc-meta{color:var(--c-text-muted);margin:0 0 10px;font-size:12px}.pgc-price{color:var(--c-primary);font-size:16px;font-weight:700}.pgc-moq{color:var(--c-text-muted);font-size:11px}.pgc-actions{gap:6px;margin-top:10px;display:flex}.pgc-actions .btn{flex:1;justify-content:center;padding:6px 8px;font-size:12px}.notif-center{border:1px solid var(--c-border);border-radius:var(--radius);grid-template-columns:260px 1fr;gap:0;display:grid;overflow:hidden}.notif-cats{border-right:1px solid var(--c-border);background:var(--c-surface-2);padding:12px}.notif-cat-item{cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;transition:background .12s;display:flex}.notif-cat-item:hover{background:var(--c-primary-50);color:var(--c-primary)}.notif-cat-item.active{background:var(--c-primary-50);color:var(--c-primary);font-weight:600}.view-toggle{border:1px solid var(--c-border);border-radius:8px;display:flex;overflow:hidden}.vt-btn{color:var(--c-text-muted);cursor:pointer;background:0 0;border:none;padding:6px 10px;transition:background .12s}.vt-btn.active{background:var(--c-primary);color:#fff}@keyframes pageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.page{animation:.25s pageIn}@keyframes pulse-ring{0%{box-shadow:0 0 #10b98166}70%{box-shadow:0 0 0 8px #10b98100}to{box-shadow:0 0 #10b98100}}.live-dot{background:var(--c-success);border-radius:50%;width:8px;height:8px;animation:1.5s infinite pulse-ring;display:inline-block}.price-compare-row{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px;display:grid}.pci{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:9px;padding:12px 14px}.pci.winner{border-color:var(--c-success);background:var(--c-success-bg)}.pci .pci-label{color:var(--c-text-muted);text-transform:uppercase;margin:0 0 4px;font-size:11px;font-weight:600}.pci .pci-value{color:var(--c-primary);margin:0;font-size:18px;font-weight:700}.approval-row{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:10px;align-items:center;gap:8px;padding:12px;display:flex}.approval-row .appr-info{flex:1}.approval-row .appr-info strong{font-size:13px}.approval-row .appr-info span{color:var(--c-text-muted);font-size:12px;display:block}
