:root{--brand: #4f46e5;--brand-600: #4338ca;--brand-50: #eef2ff;--action: #16a34a;--action-600: #15803d;--sidebar-1: #0f172a;--sidebar-2: #1e293b;--bg: #f6f7f9;--card: #ffffff;--text: #0f172a;--muted: #64748b;--muted-2: #94a3b8;--border: #e5e8ee;--border-2: #eef1f5;--won: #16a34a;--lost: #e11d48;--warn: #d97706;--radius: 12px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 4px 16px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .16);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-size:14px}a{color:var(--brand);text-decoration:none}button{font-family:inherit;cursor:pointer}.center{display:flex;align-items:center;justify-content:center;min-height:100vh}.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid transparent;border-radius:9px;padding:9px 14px;font-size:14px;font-weight:600;white-space:nowrap}.btn-primary{background:var(--action);color:#fff}.btn-primary:hover{background:var(--action-600)}.btn-brand{background:var(--brand);color:#fff}.btn-brand:hover{background:var(--brand-600)}.btn-light{background:#fff;color:var(--text);border-color:var(--border)}.btn-light:hover{background:#f8fafc}.btn-soft{background:var(--brand-50);color:var(--brand-600)}.btn-soft:hover{background:#e0e7ff}.btn-ghost{background:transparent;color:var(--muted)}.btn-ghost:hover{background:#eef1f5;color:var(--text)}.btn:disabled{opacity:.6;cursor:not-allowed}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:9px;background:#fff;border:1px solid var(--border);color:var(--muted)}.icon-btn:hover{background:#f8fafc;color:var(--text)}.login-wrap{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.login-aside{background:linear-gradient(160deg,var(--sidebar-1),#312e81);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:center}.login-aside .logo{font-size:30px;font-weight:800;letter-spacing:-.5px}.login-aside .logo span{color:#a5b4fc}.login-aside h2{font-size:26px;font-weight:700;margin:28px 0 12px;line-height:1.3}.login-aside p{color:#c7d2fe;max-width:420px;line-height:1.6}.login-aside ul{margin-top:28px;padding:0;list-style:none;display:grid;gap:12px}.login-aside li{display:flex;gap:10px;align-items:center;color:#e0e7ff}.login-form-wrap{display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:360px}.login-card h1{font-size:22px;margin:0 0 6px}.login-card .sub{color:var(--muted);margin-bottom:24px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{font-size:13px;font-weight:600;color:#334155}.input{padding:11px 12px;border:1px solid var(--border);border-radius:9px;font-size:14px;background:#fff;width:100%}.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-50)}.error{color:var(--lost);font-size:13px;margin-bottom:12px}.login-card .btn-brand{width:100%;justify-content:center;padding:12px}.login-hint{margin-top:16px;font-size:12px;color:var(--muted-2);text-align:center}.app{display:grid;grid-template-columns:248px 1fr;grid-template-rows:60px 1fr;grid-template-areas:"sidebar topbar" "sidebar main";height:100vh}.sidebar{grid-area:sidebar;background:linear-gradient(180deg,var(--sidebar-1),var(--sidebar-2));color:#cbd5e1;display:flex;flex-direction:column;padding:16px 12px;overflow-y:auto}.sidebar .brand{display:flex;align-items:center;gap:10px;padding:6px 10px 18px}.sidebar .brand-mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--brand),#818cf8);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px}.sidebar .brand-name{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px}.sidebar .brand-name span{color:#a5b4fc}.nav-group-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;padding:14px 12px 6px}.sidebar nav{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:9px;color:#cbd5e1;font-weight:500;font-size:14px}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:#6366f12e;color:#fff}.nav-item.active svg{color:#a5b4fc}.sidebar-footer{margin-top:auto;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}.user-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px}.user-chip:hover{background:#ffffff0f}.avatar{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.user-chip .u-name{color:#fff;font-size:13px;font-weight:600;line-height:1.2}.user-chip .u-mail{color:#94a3b8;font-size:11px}.topbar{grid-area:topbar;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 22px}.topbar .page-title{font-size:18px;font-weight:700}.searchbar{flex:1;max-width:520px;display:flex;align-items:center;gap:10px;background:#f1f5f9;border:1px solid transparent;border-radius:10px;padding:9px 14px;color:var(--muted)}.searchbar input{border:none;background:transparent;outline:none;width:100%;font-size:14px}.topbar .spacer{flex:1}.topbar-actions{display:flex;align-items:center;gap:8px}.badge-dot{position:relative}.badge-dot:after{content:"";position:absolute;top:7px;right:8px;width:8px;height:8px;background:var(--lost);border-radius:50%;border:2px solid #fff}.main{grid-area:main;overflow:auto;padding:22px 26px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.page-head h1{font-size:20px;margin:0}.page-head .sub{color:var(--muted);font-size:13px;margin-top:2px}.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.toolbar .spacer{flex:1}.seg{display:inline-flex;background:#eef1f5;border-radius:9px;padding:3px}.seg button{border:none;background:transparent;padding:7px 10px;border-radius:7px;color:var(--muted);display:inline-flex;align-items:center;gap:6px;font-weight:600}.seg button.active{background:#fff;color:var(--brand);box-shadow:var(--shadow-sm)}.select{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:9px;padding:9px 12px;color:var(--text);font-weight:500}.select svg{color:var(--muted-2)}.chip{display:inline-flex;align-items:center;gap:6px;background:#eef2ff;color:var(--brand-600);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600}.toolbar-search{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:9px;padding:8px 12px;color:var(--muted-2);min-width:280px}.toolbar-search input{border:none;outline:none;background:transparent;width:100%;font-size:14px;color:var(--text)}.toolbar-search button{border:none;background:transparent;color:var(--muted-2);display:flex;cursor:pointer;padding:0}.select-input{width:auto;padding:9px 12px;font-weight:500;cursor:pointer}.dropdown{position:relative}.menu{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;min-width:220px;z-index:50}.menu button{display:flex;align-items:center;gap:10px;width:100%;border:none;background:transparent;padding:10px 12px;border-radius:8px;font-size:14px;color:var(--text);text-align:left}.menu button:hover{background:var(--brand-50);color:var(--brand-600)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:20px}.kpi{padding:18px;display:flex;flex-direction:column;gap:6px}.kpi .k-top{display:flex;align-items:center;justify-content:space-between}.kpi .k-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center}.kpi .k-value{font-size:26px;font-weight:800;letter-spacing:-.5px}.kpi .k-label{color:var(--muted);font-size:13px}.tint-indigo{background:var(--brand-50);color:var(--brand)}.tint-green{background:#dcfce7;color:var(--won)}.tint-amber{background:#fef3c7;color:var(--warn)}.tint-rose{background:#ffe4e6;color:var(--lost)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.panel{padding:18px}.panel h3{margin:0 0 14px;font-size:15px}.board{display:flex;gap:14px;overflow-x:auto;padding-bottom:12px;align-items:flex-start}.column{background:#eef1f5;border-radius:12px;width:290px;flex-shrink:0;display:flex;flex-direction:column;max-height:calc(100vh - 220px)}.column.dragover{outline:2px dashed var(--brand);outline-offset:-2px;background:#e7ecff}.column-head{padding:12px 14px;position:sticky;top:0}.column-head .c-title{display:flex;align-items:center;justify-content:space-between}.column-head .c-name{font-weight:700;font-size:13px;display:flex;align-items:center;gap:8px}.column-head .c-count{color:var(--muted);font-weight:600}.col-menu-btn{border:none;background:transparent;color:var(--muted-2);cursor:pointer;border-radius:6px;padding:2px;display:inline-flex;margin-left:4px}.col-menu-btn:hover{background:#0000000f;color:var(--text)}.column-head .c-amount{margin-top:6px;font-size:12px;color:var(--muted);font-weight:600}.stage-dot{width:8px;height:8px;border-radius:50%}.column-body{padding:0 10px 10px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.deal-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;box-shadow:var(--shadow-sm);cursor:grab;border-left:3px solid var(--brand)}.deal-card:hover{box-shadow:var(--shadow)}.deal-card.dragging{opacity:.5}.deal-card .d-title{font-weight:600;font-size:13.5px;line-height:1.35}.deal-card .d-case{margin-top:4px;font-size:11.5px;color:var(--brand-600);font-weight:600}.deal-card .d-meta{margin-top:8px;display:flex;align-items:center;gap:6px;color:var(--muted);font-size:12px}.deal-card .d-amount{margin-top:10px;font-weight:700;color:var(--won);font-size:14px}.deal-card .d-foot{margin-top:10px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border-2);padding-top:8px}.tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px}.table-card{overflow:hidden}.table{width:100%;border-collapse:collapse;background:#fff}.table thead th{text-align:left;padding:13px 16px;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:#fafbfc;border-bottom:1px solid var(--border);font-weight:700}.table tbody td{padding:14px 16px;border-bottom:1px solid var(--border-2);font-size:14px;vertical-align:middle}.table tbody tr:hover{background:#fafbff}.table tbody tr:last-child td{border-bottom:none}.cell-strong{font-weight:600;color:var(--brand-600)}.cell-with-avatar{display:flex;align-items:center;gap:10px}.avatar-sm{width:30px;height:30px;border-radius:50%;background:var(--brand-50);color:var(--brand-600);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.muted{color:var(--muted)}.table-foot{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;color:var(--muted);font-size:13px}.status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:700}.status-late{background:#ffe4e6;color:var(--lost)}.status-ok{background:#eef1f5;color:var(--muted)}.status-done{background:#dcfce7;color:var(--won)}.status-open{background:var(--brand-50);color:var(--brand-600)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:100;display:flex;justify-content:flex-end}.drawer{width:440px;max-width:92vw;height:100%;background:#fff;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slidein .18s ease}@keyframes slidein{0%{transform:translate(30px);opacity:.6}to{transform:none;opacity:1}}.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.drawer-head h2{margin:0;font-size:18px}.drawer-body{padding:22px;overflow-y:auto;flex:1}.drawer-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border)}.tip{display:flex;gap:10px;background:#f5f3ff;border-left:3px solid #8b5cf6;color:#5b21b6;padding:12px 14px;border-radius:8px;font-size:13px;margin-bottom:18px}.form-section{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);font-weight:700;margin:18px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border-2)}.case-preview{background:var(--brand-50);color:var(--brand-600);border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:6px}.detail-grid{display:flex;flex-direction:column;gap:2px}.detail-row{display:grid;grid-template-columns:24px 110px 1fr;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--border-2)}.detail-icon{color:var(--muted-2);display:flex}.detail-label{color:var(--muted);font-size:13px}.detail-value{font-size:14px;text-align:right}.detail-value.strong{font-weight:700;color:var(--won)}.timeline{display:flex;flex-direction:column;gap:2px;position:relative}.tl-item{display:grid;grid-template-columns:30px 1fr;gap:10px;padding-bottom:14px;position:relative}.tl-item:before{content:"";position:absolute;left:14px;top:26px;bottom:0;width:2px;background:var(--border)}.tl-item:last-child:before{display:none}.tl-dot{width:28px;height:28px;border-radius:50%;background:var(--brand-50);color:var(--brand);display:flex;align-items:center;justify-content:center;z-index:1}.tl-title{font-weight:600;font-size:13.5px}.tl-sub{font-size:13px;color:var(--muted);margin-top:2px}.tl-time{font-size:12px;color:var(--muted-2);margin-top:3px}.mini-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border-2);border-radius:9px;margin-bottom:8px}.mini-title{font-weight:600;font-size:13.5px}.mini-sub{font-size:12px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:4px}.code-box{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#0f172a;color:#a5b4fc;border-radius:8px;padding:10px 12px;font-family:ui-monospace,monospace;font-size:12.5px;overflow-x:auto}.code-box code{white-space:nowrap}.code-box .icon-btn{background:#ffffff14;border-color:transparent;color:#cbd5e1;flex-shrink:0}.help-fab{position:fixed;right:22px;bottom:22px;background:#7c3aed;color:#fff;border:none;border-radius:24px;padding:11px 18px;display:flex;align-items:center;gap:8px;font-weight:700;box-shadow:var(--shadow-lg)}.empty{text-align:center;color:var(--muted);padding:60px 20px}.empty svg{color:var(--muted-2);margin-bottom:12px}.skeleton{color:var(--muted);padding:30px}.col-add{background:#fff;border:1px dashed var(--border);color:var(--muted);border-radius:10px;padding:10px;width:290px;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-weight:600;height:fit-content}.col-add:hover{color:var(--brand);border-color:var(--brand)}.column-foot{padding:4px 10px 10px}.col-addcard{width:100%;justify-content:flex-start;color:var(--muted);background:transparent;border:none;padding:8px 6px;display:flex;align-items:center;gap:6px;cursor:pointer;border-radius:8px;font-size:13px}.col-addcard:hover{background:#0000000a;color:var(--text)}.exec-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 12px;box-shadow:var(--shadow-sm);cursor:grab}.exec-card:hover{box-shadow:var(--shadow)}.exec-card.dragging{opacity:.5}.exec-card .labels{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}.exec-card .label-pill{height:8px;width:36px;border-radius:4px}.exec-card .ec-title{font-weight:600;font-size:13.5px;line-height:1.35}.exec-card .ec-foot{margin-top:10px;display:flex;align-items:center;gap:12px;color:var(--muted-2);font-size:12px}.exec-card .ec-badge{display:inline-flex;align-items:center;gap:4px}.exec-card .ec-badge.late{color:var(--lost)}.exec-card .ec-spacer{flex:1}.avatar-xs{width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;border:2px solid #fff}.overlay.center{justify-content:center;align-items:center}.card-modal{width:960px;max-width:95vw;max-height:92vh;background:#fff;border-radius:14px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg)}.card-modal-head{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border)}.card-modal-head .spacer{flex:1}.card-modal-body{display:grid;grid-template-columns:1fr 340px;min-height:0;flex:1}.card-main{padding:20px 24px;overflow-y:auto}.card-side{background:#f6f7f9;border-left:1px solid var(--border);padding:18px 18px 24px;overflow-y:auto}.cm-title{font-size:20px;font-weight:700;border:none;width:100%;background:transparent;resize:none;color:var(--text)}.cm-title:focus{outline:none}.cm-actions{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 20px}.cm-actions .btn{background:#eef1f5;border:none;color:var(--text);font-weight:600}.cm-block{margin-bottom:22px}.cm-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;gap:6px}.cm-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.label-chip{display:inline-flex;align-items:center;gap:6px;color:#fff;border-radius:6px;padding:5px 10px;font-size:12.5px;font-weight:600}.member-add,.label-add{width:30px;height:30px;border-radius:50%;border:1px dashed var(--border);background:#fff;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.cm-desc{width:100%;min-height:90px;border:1px solid var(--border);border-radius:9px;padding:10px 12px;font-size:14px;font-family:inherit;resize:vertical}.checklist{margin-bottom:16px}.checklist-head{display:flex;align-items:center;justify-content:space-between}.checklist-head .ck-title{font-weight:700;font-size:14px}.progress-bar{height:8px;background:var(--border);border-radius:6px;margin:8px 0 10px;overflow:hidden}.progress-bar>span{display:block;height:100%;background:var(--won);border-radius:6px;transition:width .2s}.ck-item{display:flex;align-items:center;gap:10px;padding:5px 0;font-size:14px}.ck-item input{width:16px;height:16px}.ck-item.done span{text-decoration:line-through;color:var(--muted-2)}.ck-add{display:flex;gap:8px;margin-top:6px}.att-item{display:flex;align-items:center;gap:8px;padding:8px 10px;font-size:13.5px;border:1px solid var(--border);border-radius:9px;margin-bottom:8px}.att-item .att-name{color:var(--text);font-weight:600;max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.att-item .icon-btn{width:30px;height:30px}.activity-input{width:100%;border:1px solid var(--border);border-radius:9px;padding:10px 12px;font-size:13.5px;font-family:inherit;resize:vertical;min-height:38px}.activity-feed{display:flex;flex-direction:column;gap:14px;margin-top:16px}.af-item{display:flex;gap:10px;font-size:13px}.af-body{flex:1}.af-body .af-meta{color:var(--muted);font-size:12px;margin-top:2px}.af-body .af-comment{background:#fff;border:1px solid var(--border);border-radius:8px;padding:8px 10px;margin-top:4px}@media (max-width: 900px){.app{grid-template-columns:1fr;grid-template-areas:"topbar" "main"}.card-modal-body{grid-template-columns:1fr}.sidebar{display:none}.login-wrap{grid-template-columns:1fr}.login-aside{display:none}.grid-2{grid-template-columns:1fr}}
