/* Alfa CRM — фирменный стиль (красный/чёрный) */
:root{
  --alfa-red:#EF3124;
  --alfa-red-dark:#C8261B;
  --alfa-red-soft:#FCE8E6;
  --ink:#1A1A1A;
  --ink-2:#2D2D2D;
  --muted:#6B7280;
  --muted-2:#9CA3AF;
  --line:#E5E7EB;
  --bg:#F6F7F9;
  --card:#FFFFFF;
  --ok:#10B981;
  --warn:#F59E0B;
  --info:#3B82F6;
  --radius:10px;
  --shadow:0 1px 2px rgba(17,17,17,.04),0 1px 3px rgba(17,17,17,.06);
  --shadow-lg:0 4px 16px rgba(17,17,17,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-size:14px;line-height:1.5}
a{color:var(--ink);text-decoration:none}
a:hover{color:var(--alfa-red)}

/* layout */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--ink);color:#fff;padding:0;display:flex;flex-direction:column}
.sidebar .brand{display:flex;align-items:center;gap:10px;padding:20px;border-bottom:1px solid #2D2D2D}
.sidebar .brand-logo{width:32px;height:32px;display:block;flex-shrink:0}
.sidebar .brand-name{font-weight:700;font-size:15px;line-height:1.2}
.sidebar .brand-sub{font-size:11px;color:#9CA3AF;text-transform:uppercase;letter-spacing:0.5px;margin-top:2px}
.sidebar nav{padding:12px 8px;flex:1}
.sidebar nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;color:#D1D5DB;border-radius:8px;font-size:13.5px;margin-bottom:2px}
.sidebar nav a:hover{background:#262626;color:#fff}
.sidebar nav a.active{background:var(--alfa-red);color:#fff}
.sidebar nav a.active i{color:#fff}
.sidebar nav .sec{padding:14px 12px 6px;color:#6B7280;text-transform:uppercase;font-size:10.5px;letter-spacing:1px}
.sidebar nav i{width:18px;height:18px}
.sidebar .user{padding:14px 16px;border-top:1px solid #2D2D2D;display:flex;align-items:center;gap:10px;font-size:12.5px}
.sidebar .user .av{width:32px;height:32px;border-radius:50%;background:var(--alfa-red);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff}
.sidebar .user .name{font-weight:600;color:#fff}
.sidebar .user .role{color:#9CA3AF;font-size:11px;margin-top:2px}
.sidebar .user a.logout{margin-left:auto;color:#9CA3AF}
.sidebar .user a.logout:hover{color:var(--alfa-red)}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{background:#fff;border-bottom:1px solid var(--line);padding:14px 28px;display:flex;align-items:center;gap:16px}
.topbar h1{margin:0;font-size:20px;font-weight:700;letter-spacing:-0.3px}
.topbar .crumbs{color:var(--muted);font-size:12.5px}
.topbar .spacer{flex:1}
.content{padding:24px 28px;flex:1}

/* card */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
.card h2{margin:0 0 14px;font-size:16px;font-weight:700}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-head h2{margin:0}

/* grid */
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* stat */
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.stat .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}
.stat .value{font-size:26px;font-weight:800;letter-spacing:-0.5px}
.stat .sub{color:var(--muted);font-size:12px;margin-top:4px}
.stat.accent{background:linear-gradient(135deg,var(--alfa-red) 0%,var(--alfa-red-dark) 100%);color:#fff;border-color:transparent}
.stat.accent .label{color:rgba(255,255,255,.85)}
.stat.accent .sub{color:rgba(255,255,255,.8)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.btn:hover{border-color:var(--ink);color:var(--ink)}
.btn i{width:15px;height:15px}
.btn-primary{background:var(--alfa-red);border-color:var(--alfa-red);color:#fff}
.btn-primary:hover{background:var(--alfa-red-dark);border-color:var(--alfa-red-dark);color:#fff}
.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn-ghost:hover{background:#F3F4F6;color:var(--ink)}
.btn-danger{background:#fff;border-color:#FCA5A5;color:var(--alfa-red)}
.btn-danger:hover{background:var(--alfa-red-soft);border-color:var(--alfa-red);color:var(--alfa-red-dark)}
.btn-sm{padding:5px 10px;font-size:12px}

/* form */
.form-row{margin-bottom:14px}
.form-row label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:6px;font-weight:500}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:8px;font-size:13.5px;font-family:inherit;background:#fff;color:var(--ink)}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--alfa-red);box-shadow:0 0 0 3px rgba(239,49,36,.1)}
.form-row textarea{resize:vertical;min-height:80px}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:680px){.form-2col{grid-template-columns:1fr}}

/* table */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}
table.t{width:100%;border-collapse:collapse;font-size:13px}
table.t th{text-align:left;padding:11px 14px;background:#F9FAFB;color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:0.4px;border-bottom:1px solid var(--line)}
table.t td{padding:13px 14px;border-bottom:1px solid var(--line)}
table.t tr:last-child td{border-bottom:none}
table.t tr:hover td{background:#FAFAFA}
table.t a{color:var(--ink);font-weight:600}
table.t a:hover{color:var(--alfa-red)}

/* badge */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11.5px;font-weight:600;background:#F3F4F6;color:var(--ink-2)}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.red{background:var(--alfa-red-soft);color:var(--alfa-red-dark)}
.badge.green{background:#D1FAE5;color:#065F46}
.badge.blue{background:#DBEAFE;color:#1E40AF}
.badge.yellow{background:#FEF3C7;color:#92400E}
.badge.gray{background:#F3F4F6;color:#374151}
.badge.purple{background:#EDE9FE;color:#5B21B6}

/* kanban */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px}
.col{min-width:280px;flex:0 0 280px;background:#F0F2F5;border-radius:var(--radius);padding:12px}
.col-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 4px}
.col-head .title{font-weight:700;font-size:12.5px;display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:0.4px}
.col-head .count{background:#fff;color:var(--muted);font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;border:1px solid var(--line)}
.col-head .dot{width:8px;height:8px;border-radius:50%}
.col-body{display:flex;flex-direction:column;gap:8px;min-height:50px}
.kanban-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:11px 12px;cursor:grab;box-shadow:var(--shadow);transition:all .15s}
.kanban-card:hover{box-shadow:var(--shadow-lg);border-color:var(--ink)}
.kanban-card.drag{opacity:.5}
.kanban-card .ttl{font-weight:600;font-size:13px;margin-bottom:6px;color:var(--ink);line-height:1.3}
.kanban-card .meta{font-size:11.5px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;margin-top:6px}
.kanban-card .meta .money{color:var(--ink);font-weight:700}
.kanban-card .client{font-size:11.5px;color:var(--muted-2);margin-bottom:4px}

/* pagination / filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;align-items:center}
.filters select,.filters input{padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:13px;font-family:inherit}
.filters .search{flex:1;min-width:200px;max-width:380px}

/* login */
.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1A1A1A 0%,#2D2D2D 100%);padding:20px}
.auth-card{background:#fff;border-radius:14px;padding:40px;width:100%;max-width:400px;box-shadow:0 10px 40px rgba(0,0,0,.3)}
.auth-card .logo{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.auth-card .logo-mark{width:40px;height:40px;display:block;flex-shrink:0}
.auth-card .logo-text{font-weight:700;font-size:18px}
.auth-card .logo-sub{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
.auth-card h1{margin:0 0 6px;font-size:22px}
.auth-card p.hint{color:var(--muted);font-size:13px;margin:0 0 22px}
.auth-card .demo-creds{margin-top:18px;padding:12px;background:#F9FAFB;border-radius:8px;font-size:11.5px;color:var(--muted);line-height:1.7}
.auth-card .demo-creds b{color:var(--ink)}

.alert{padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:13px}
.alert-error{background:#FEE2E2;color:#991B1B;border:1px solid #FCA5A5}
.alert-ok{background:#D1FAE5;color:#065F46;border:1px solid #6EE7B7}

/* deal page */
.kv{display:grid;grid-template-columns:160px 1fr;gap:10px 16px;font-size:13px}
.kv dt{color:var(--muted);font-weight:500}
.kv dd{margin:0;color:var(--ink);font-weight:500}

.timeline{display:flex;flex-direction:column;gap:14px;padding-left:6px;border-left:2px solid var(--line);margin-left:8px}
.timeline-item{position:relative;padding-left:16px}
.timeline-item::before{content:'';position:absolute;left:-7px;top:5px;width:10px;height:10px;border-radius:50%;background:var(--alfa-red);border:2px solid #fff;box-shadow:0 0 0 1px var(--line)}
.timeline-item .meta{font-size:11.5px;color:var(--muted);margin-bottom:3px}
.timeline-item .ttl{font-weight:600;font-size:13px}
.timeline-item .body{color:var(--muted);font-size:13px;margin-top:3px}

.stage-progress{display:flex;gap:4px;margin-bottom:20px;flex-wrap:wrap}
.stage-progress .pill{padding:5px 11px;border-radius:999px;background:#F3F4F6;color:var(--muted);font-size:11.5px;font-weight:600;border:1px solid transparent}
.stage-progress .pill.done{background:#D1FAE5;color:#065F46}
.stage-progress .pill.current{background:var(--alfa-red);color:#fff}
.stage-progress .pill.rejected{background:var(--alfa-red-soft);color:var(--alfa-red-dark)}

.icon-btn{width:30px;height:30px;border-radius:6px;border:1px solid var(--line);background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted)}
.icon-btn:hover{color:var(--alfa-red);border-color:var(--alfa-red)}
.icon-btn i{width:14px;height:14px}

/* utilities */
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}
.text-muted{color:var(--muted)}
.text-right{text-align:right}
.flex{display:flex;gap:10px;align-items:center}
.flex-between{display:flex;justify-content:space-between;align-items:center;gap:10px}
.nowrap{white-space:nowrap}
.empty{padding:40px 20px;text-align:center;color:var(--muted);font-size:13px}
.empty i{width:36px;height:36px;color:var(--muted-2);margin-bottom:8px}
