.card{background:var(--card);border-radius:var(--radius);padding:18px;margin-bottom:14px;box-shadow:0 1px 3px var(--shadow);transition:box-shadow .15s}
.card:hover{box-shadow:0 4px 12px var(--shadow)}
.card h2{font-size:14px;margin-bottom:8px;color:var(--text)}

.grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.stat-card{background:var(--card);border-radius:var(--radius);padding:16px 18px;box-shadow:0 1px 3px var(--shadow);transition:transform .15s,box-shadow .15s;border-left:3px solid var(--accent)}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow)}
.stat-card .num{font-size:24px;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-card .label{font-size:11px;color:var(--muted);margin-top:2px}

.btn{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:5px;transition:all .12s}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(26,73,113,.25)}
.btn-sm{padding:5px 10px;font-size:11px;border-radius:7px}
.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{opacity:.9}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text)}.btn-outline:hover{background:var(--hover);border-color:var(--accent);color:var(--accent)}
.btn-success{background:var(--green);color:#fff}.btn-success:hover{opacity:.9}
.btn-ghost{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:4px 7px;border-radius:6px;font-size:12px}.btn-ghost:hover{background:var(--hover);color:var(--text)}

.card-tabs{display:flex;gap:0;margin-bottom:0;background:var(--card);border-radius:10px 10px 0 0;overflow:hidden;box-shadow:0 -1px 3px var(--shadow)}
.card-tab{flex:1;padding:10px;text-align:center;font-size:11px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;color:var(--muted);transition:.12s}
.card-tab:hover{color:var(--accent);background:var(--hover)}
.card-tab.active{color:var(--accent);border-bottom-color:var(--accent)}

.field-sm{margin-bottom:8px}
.field-label-sm{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:600;margin-bottom:1px}

.mini-entity{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--hover);border-radius:6px;border:1px solid var(--border);margin-bottom:4px;transition:.1s}
.mini-entity:hover{background:var(--accent-light);border-color:var(--accent)}
.mini-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}

.quick-actions{display:flex;gap:6px;flex-wrap:wrap}
.qa-btn{padding:5px 10px;border-radius:6px;border:none;font-size:10px;font-weight:600;cursor:pointer;transition:.1s;font-family:inherit}
.qa-btn.success{background:var(--green);color:#fff}
.qa-btn.success:hover{opacity:.85}
.qa-btn.primary{background:var(--accent);color:#fff}
.qa-btn.primary:hover{opacity:.85}
.qa-btn.outline{background:transparent;border:1px solid var(--border);color:var(--muted)}
.qa-btn.outline:hover{background:var(--hover);color:var(--accent);border-color:var(--accent)}
.qa-btn.danger{background:var(--red);color:#fff}
.qa-btn.danger:hover{opacity:.85}
a.qa-btn{display:inline-flex;align-items:center;justify-content:center}

input,select,textarea{width:100%;padding:9px 12px;border:2px solid var(--border);border-radius:8px;font-size:13px;margin-bottom:10px;background:var(--input-bg);color:var(--text);transition:border .15s}
input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none}
label{display:block;font-size:11px;color:var(--muted);margin-bottom:3px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
textarea{resize:vertical;min-height:40px;font-family:inherit}

table{width:100%;border-collapse:collapse}
th{text-align:left;padding:10px 10px;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);font-weight:600}
td{padding:10px;border-bottom:1px solid var(--border);font-size:13px;transition:background .1s}
tbody tr{transition:background .1s}tbody tr:hover{background:var(--hover);cursor:pointer}
tbody tr:active{background:var(--accent-light)}

.status-badge{padding:3px 9px;border-radius:20px;font-size:10px;font-weight:600;display:inline-block;letter-spacing:.2px}
.status-lead{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.status-consultation{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}
.status-offer{background:#e0e7ff;color:#3730a3;border:1px solid #c7d2fe}
.status-contract{background:#e0f2fe;color:#075985;border:1px solid #bae6fd}
.status-in_progress{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.status-done{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.status-cancelled{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}

.tag{display:inline-block;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;margin:1px;color:#fff;letter-spacing:.2px}
.doc-type-badge{padding:3px 9px;border-radius:20px;font-size:10px;font-weight:600}
.type-incoming{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}
.type-outgoing{background:#e0e7ff;color:#3730a3;border:1px solid #c7d2fe}
.type-contract{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.type-invoice{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.type-act{background:#f3e8ff;color:#6d28d9;border:1px solid #e9d5ff}

.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);justify-content:center;align-items:center;z-index:100;padding:16px}
.modal-overlay.show{display:flex;animation:fadeIn .15s}
.modal{background:var(--card);border-radius:14px;padding:24px;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;box-shadow:0 25px 60px rgba(0,0,0,.2)}
.modal h2{margin-bottom:14px;font-size:16px;color:var(--text)}
.form-section-title{font-size:13px;font-weight:600;color:var(--accent);margin:14px 0 6px;padding-top:10px;border-top:1px solid var(--border)}.form-row{display:flex;gap:10px}.form-row>*{flex:1}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}

.kanban-tabs{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap}
.kanban-tab{padding:6px 12px;border-radius:8px;border:1.5px solid var(--border);background:var(--card);font-size:11px;font-weight:600;cursor:pointer;transition:all .12s;color:var(--muted);font-family:'Inter',-apple-system,sans-serif}
.kanban-tab:hover{background:var(--hover);border-color:var(--accent);color:var(--accent)}
.kanban-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.kanban-tab .tab-count{display:inline-block;margin-left:4px;padding:0 5px;border-radius:6px;font-size:9px;background:rgba(255,255,255,.15)}
.kanban-tab.active .tab-count{background:rgba(255,255,255,.2)}
.kanban-tab .dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:4px}
.kanban{display:flex;gap:14px;overflow-x:auto;padding:0 0 12px;min-height:40vh;align-items:flex-start}.kanban-col{min-width:260px;width:260px;flex-shrink:0;display:flex;flex-direction:column;background:var(--kanban-bg);border-radius:10px;padding:10px}.kanban-col-header{font-size:12px;font-weight:600;padding:6px 8px 10px;display:flex;align-items:center;gap:6px;white-space:nowrap}.kanban-col-header .count{font-size:10px;background:var(--border);padding:1px 6px;border-radius:8px;color:var(--muted)}.kanban-col-body{flex:1;overflow-y:auto;min-height:15vh;max-height:55vh}.kanban{display:flex;gap:12px;overflow-x:auto;padding:0 0 12px;min-height:35vh;align-items:flex-start}.kanban-col{min-width:240px;width:240px;flex-shrink:0;display:flex;flex-direction:column;background:var(--kanban-bg);border-radius:9px;padding:8px}.kanban-col-header{font-size:11px;font-weight:600;padding:5px 6px 8px;display:flex;align-items:center;gap:4px;white-space:nowrap}.kanban-col-header .count{font-size:10px;background:var(--border);padding:1px 5px;border-radius:6px;color:var(--muted)}.kanban-col-body{flex:1;overflow-y:auto;min-height:15vh;max-height:55vh}.kanban-cards{min-height:30vh}
.kanban-card{background:var(--card);border-radius:9px;padding:12px 14px;margin-bottom:8px;box-shadow:0 1px 3px var(--shadow);border-left:3px solid var(--accent);transition:transform .12s,box-shadow .12s;cursor:pointer}
.kanban-card:hover{box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}
.kanban-card .k-title{font-size:13px;font-weight:600}
.kanban-card .k-meta{font-size:11px;color:var(--muted);margin-top:4px;display:flex;justify-content:space-between}

.toast{position:fixed;bottom:24px;right:24px;background:var(--text);color:var(--bg);padding:12px 20px;border-radius:10px;font-size:13px;z-index:200;opacity:0;transition:all .3s;transform:translateY(20px);box-shadow:0 10px 30px rgba(0,0,0,.15)}
.toast.show{opacity:1;transform:translateY(0)}
.toast--error{background:#dc3545;color:#fff}
.toast--success{background:#28a745;color:#fff}
.toast--info{background:var(--text);color:var(--bg)}
