/* ===== Sales CRM — base styles ===== */
:root{
  --bg:#f4f6f9; --card:#ffffff; --ink:#1f2733; --muted:#6b7787;
  --line:#e3e8ef; --brand:#2563eb; --brand-dark:#1d4ed8;
  --green:#16a34a; --green-bg:#dcfce7;
  --red:#dc2626;   --red-bg:#fee2e2;
  --amber:#d97706; --amber-bg:#fef3c7;
  --slate:#475569; --slate-bg:#e2e8f0;
  --radius:10px; --shadow:0 1px 3px rgba(16,24,40,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

/* Topbar */
.topbar{display:flex;align-items:center;gap:24px;background:#fff;border-bottom:1px solid var(--line);
  padding:0 24px;height:56px;position:sticky;top:0;z-index:10}
.brand a{font-weight:700;font-size:16px;color:var(--ink)}
.mainnav{display:flex;gap:4px;flex:1}
.mainnav a{padding:8px 14px;border-radius:8px;color:var(--muted);font-weight:500}
.mainnav a:hover{background:var(--bg);text-decoration:none}
.mainnav a.active{color:var(--brand);background:#eff4ff}
.userbox{display:flex;align-items:center;gap:12px}
.uname{font-weight:600;font-size:13px}
.role{display:inline-block;background:var(--slate-bg);color:var(--slate);font-size:10px;
  text-transform:uppercase;padding:1px 6px;border-radius:6px;margin-left:4px;font-weight:700}

.container{max-width:1180px;margin:24px auto;padding:0 24px}
.appfoot{text-align:center;color:var(--muted);font-size:12px;padding:24px}

/* Page head */
.pagehead{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}
.pagehead h1{font-size:22px;margin:0}
.pagehead p.sub{color:var(--muted);margin:2px 0 0}

/* Cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px;margin-bottom:20px}
.card h2{font-size:15px;margin:0 0 14px;display:flex;align-items:center;gap:8px}
.card h2 .count{background:var(--slate-bg);color:var(--slate);border-radius:20px;padding:1px 9px;font-size:12px}

/* KPI grid */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-bottom:22px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.kpi .v{font-size:28px;font-weight:700;line-height:1}
.kpi .l{color:var(--muted);font-size:12px;margin-top:6px;text-transform:uppercase;letter-spacing:.03em}
.kpi.alert .v{color:var(--red)}
.kpi.warn .v{color:var(--amber)}
.kpi.good .v{color:var(--green)}

/* Tables */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
tbody tr:hover{background:#fafbfc}
td.num,th.num{text-align:right}
.empty{color:var(--muted);text-align:center;padding:28px;font-style:italic}

/* Badges / pills */
.pill{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.pill.green{background:var(--green-bg);color:var(--green)}
.pill.red{background:var(--red-bg);color:var(--red)}
.pill.amber{background:var(--amber-bg);color:var(--amber)}
.pill.slate{background:var(--slate-bg);color:var(--slate)}
.pill.brand{background:#eff4ff;color:var(--brand)}

/* Stage chips */
.stage{display:inline-block;padding:2px 9px;border-radius:6px;font-size:11px;font-weight:600;
  background:#eef2ff;color:#4338ca;border:1px solid #e0e7ff}

/* Buttons */
.btn{display:inline-block;border:1px solid transparent;border-radius:8px;padding:9px 16px;font-size:13px;
  font-weight:600;cursor:pointer;background:var(--brand);color:#fff}
.btn:hover{background:var(--brand-dark);text-decoration:none}
.btn-sm{padding:6px 11px;font-size:12px}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{background:var(--bg)}
.btn-danger{background:var(--red)}
.btn-danger:hover{background:#b91c1c}

/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.field.full{grid-column:1/-1}
.field label{font-size:12px;font-weight:600;color:var(--slate)}
.field input,.field select,.field textarea{padding:9px 11px;border:1px solid var(--line);border-radius:8px;
  font-size:14px;font-family:inherit;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px #dbeafe}
.field textarea{resize:vertical;min-height:70px}
.field .hint{font-size:11px;color:var(--muted)}
.form-actions{display:flex;gap:10px;margin-top:6px}

/* Flash */
.flash{padding:11px 16px;border-radius:8px;margin-bottom:16px;font-weight:500;border:1px solid}
.flash-success{background:var(--green-bg);color:#166534;border-color:#bbf7d0}
.flash-error{background:var(--red-bg);color:#991b1b;border-color:#fecaca}
.flash-info{background:#eff4ff;color:#1e40af;border-color:#dbeafe}

/* Login */
.login-wrap{max-width:380px;margin:8vh auto;padding:0 20px}
.login-card{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:30px}
.login-card h1{font-size:20px;margin:0 0 4px;text-align:center}
.login-card .sub{color:var(--muted);text-align:center;margin:0 0 22px;font-size:13px}
.login-card .btn{width:100%;margin-top:6px}

/* Misc */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.toolbar input,.toolbar select{padding:8px 11px;border:1px solid var(--line);border-radius:8px;font-size:13px}
.muted{color:var(--muted)}
.small{font-size:12px}
.right{text-align:right}
.timeline{list-style:none;margin:0;padding:0}
.timeline li{border-left:2px solid var(--line);padding:0 0 16px 18px;position:relative}
.timeline li:before{content:"";position:absolute;left:-6px;top:3px;width:10px;height:10px;border-radius:50%;
  background:var(--brand);border:2px solid #fff}
.timeline .ft-head{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:3px}
.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}
@media(max-width:820px){.form-grid,.grid-2{grid-template-columns:1fr}.mainnav{gap:0}}

/* Nav groups */
.navgroup{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#9aa5b1;font-weight:700;
  align-self:center;padding:0 2px}
.navsep{width:1px;height:22px;background:var(--line);align-self:center;margin:0 6px}
.mainnav{align-items:center}

/* ===== Kanban board ===== */
/* Board page gets more room than the default container (graceful fallback if :has unsupported) */
.container:has(.board){max-width:min(1520px,96vw)}

.board{display:flex;gap:16px;align-items:flex-start}
.board .col{flex:1 1 0;min-width:0;display:flex;flex-direction:column}

/* Per-status colour accent */
.col[data-status="backlog"]    {--accent:#94a3b8;--accent-bg:#f1f5f9}
.col[data-status="todo"]       {--accent:#3b82f6;--accent-bg:#eff6ff}
.col[data-status="in_progress"]{--accent:#f59e0b;--accent-bg:#fffbeb}
.col[data-status="review"]     {--accent:#8b5cf6;--accent-bg:#f5f3ff}
.col[data-status="done"]       {--accent:#22c55e;--accent-bg:#f0fdf4}

.col{position:relative;background:#eef1f5;border:1px solid var(--line);border-radius:14px;
  padding:13px 10px 8px;min-height:140px;transition:background .15s,box-shadow .15s}
.col::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;
  border-radius:14px 14px 0 0;background:var(--accent,#cbd5e1)}
.col-head{display:flex;align-items:center;gap:8px;margin:0 4px 12px;font-size:12px;
  font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--slate)}
.col-head .dot{width:9px;height:9px;border-radius:50%;background:var(--accent,#cbd5e1);flex-shrink:0}
.col-head .cnt{margin-left:auto;background:#fff;border:1px solid var(--line);border-radius:20px;
  min-width:24px;text-align:center;padding:1px 8px;font-size:11px;color:var(--slate);font-weight:700}
.col.drop-on{background:var(--accent-bg,#e7efff)}
.col.drop-on::after{content:"";position:absolute;inset:6px;border:2px dashed var(--accent,var(--brand));
  border-radius:11px;pointer-events:none;opacity:.7}

.col-empty{display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);
  font-size:12px;font-style:italic;border:1.5px dashed #cbd5e1;border-radius:10px;padding:16px 10px;margin-bottom:2px}
.col:has(.tcard) .col-empty{display:none}

.tcard{background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 12px;margin-bottom:10px;
  box-shadow:var(--shadow);cursor:grab;border-left:4px solid var(--slate);min-width:0;
  transition:transform .12s,box-shadow .12s,border-color .12s}
.tcard:hover{border-color:#cbd5e1;box-shadow:0 4px 12px rgba(16,24,40,.10);transform:translateY(-1px)}
.tcard:active{cursor:grabbing}
.tcard.dragging{opacity:.5;transform:rotate(1.5deg) scale(.98);box-shadow:0 10px 22px rgba(16,24,40,.18)}
.tcard.p-high{border-left-color:var(--red)}
.tcard.p-medium{border-left-color:var(--amber)}
.tcard.p-low{border-left-color:#94a3b8}
.tcard .t-title{font-weight:600;font-size:13.5px;display:block;margin-bottom:9px;color:var(--ink);
  line-height:1.35;overflow-wrap:anywhere}
.tcard .t-title:hover{text-decoration:none;color:var(--brand)}
.tcard .t-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tcard .spacer{flex:1 1 auto}
.tcard .stuck{display:inline-flex;align-items:center;gap:3px;color:var(--red);font-weight:700;
  background:var(--red-bg);border-radius:20px;padding:1px 8px;font-size:11px}
.avatar{width:24px;height:24px;border-radius:50%;background:var(--brand);color:#fff;font-size:10px;
  font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 0 2px #fff}
.avatar.unassigned{background:#cbd5e1;color:#fff}
.proj-tag{font-size:10px;color:var(--slate);background:#f1f5f9;border:1px solid var(--line);
  border-radius:6px;padding:1px 7px;font-weight:600;white-space:nowrap}
a.proj-tag:hover{background:#e2e8f0;text-decoration:none}

/* Narrow screens: revert to horizontal scroll with snap */
@media(max-width:980px){
  .container:has(.board){max-width:none}
  .board{overflow-x:auto;scroll-snap-type:x proximity;padding-bottom:12px;margin-inline:-16px;padding-inline:16px}
  .board .col{flex:0 0 82%;max-width:330px;min-width:250px;scroll-snap-align:start}
}

.gh-commit{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:11px}
.gh-sha{color:var(--brand);font-weight:600}
.kbd{font-family:ui-monospace,monospace;background:#f1f5f9;border:1px solid var(--line);border-bottom-width:2px;
  border-radius:5px;padding:1px 6px;font-size:11px}
