/* Kingpin CRM — design system (cloned from the "effix" reference: light, clean, white-label) */
:root{
  --primary:#0f0f0f; --primary-600:#000; --primary-soft:#f1f2f3; --primary-ring:rgba(15,15,15,.13); --accent:#0f0f0f;
  --bg:#f5f7f9; --panel:#ffffff; --line:#eef1f4; --line-2:#e6eaef;
  --ink:#1f2a37; --ink-2:#5b6776; --ink-3:#8a95a3; --ink-soft:#aab2bd;
  --green-bg:#e8f7ef; --green:#1a8f5a; --orange-bg:#fdeede; --orange:#d97a16;
  --yellow-bg:#fdf4dd; --yellow:#b8860a; --pink-bg:#fdeaf2; --pink:#d6457f;
  --blue-bg:#e9f1fe; --blue:#2f6fed; --radius:14px; --radius-sm:10px;
  --shadow:0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.06);
  --shadow-md:0 8px 24px rgba(16,24,40,.08);
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.muted{color:var(--ink-2)}.tiny{font-size:12px}

/* ── shell ── */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px}
.brand img{height:30px;width:auto;max-width:150px;object-fit:contain}
.brand .wordmark{font-weight:700;font-size:18px;letter-spacing:-.02em;color:var(--ink)}
.nav-label{font-size:11px;font-weight:600;letter-spacing:.08em;color:var(--ink-soft);text-transform:uppercase;padding:14px 10px 6px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--radius-sm);color:var(--ink-2);font-weight:500;position:relative;margin:1px 0}
.nav a svg{width:18px;height:18px;flex:none;stroke-width:1.8}
.nav a:hover{background:#f4f6f8;color:var(--ink)}
.nav a.active{background:var(--primary-soft);color:var(--primary);font-weight:600}
.nav a.active::before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}
.nav a .badge{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 5px}
.sidebar .spacer{flex:1}
.powered{display:flex;align-items:center;gap:7px;padding:12px 10px 2px;color:var(--ink-soft);font-size:11.5px;border-top:1px solid var(--line);margin-top:10px}
.powered .crown{color:var(--primary)}

/* ── main ── */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:16px;padding:16px 28px;border-bottom:1px solid var(--line);background:var(--panel);position:sticky;top:0;z-index:5}
.search{flex:1;max-width:560px;display:flex;align-items:center;gap:9px;background:#f4f6f8;border:1px solid var(--line);border-radius:10px;padding:9px 12px;color:var(--ink-3)}
.search input{border:0;background:transparent;outline:0;flex:1;font-size:13.5px;color:var(--ink)}
.search .kbd{font-size:11px;color:var(--ink-3);border:1px solid var(--line-2);border-radius:6px;padding:1px 6px;background:#fff}
.topbar .who{display:flex;align-items:center;gap:9px;margin-left:auto}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:600;font-size:12.5px;flex:none}
.content{padding:26px 28px;max-width:1240px;width:100%}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}
.page-head h1{margin:0;font-size:23px;font-weight:700;letter-spacing:-.02em}
.page-head p{margin:3px 0 0;color:var(--ink-2);font-size:13.5px}

/* ── stat cards ── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:22px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}
.stat .ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex:none}
.stat .ico svg{width:20px;height:20px}
.stat .lbl{color:var(--ink-2);font-size:12.5px;font-weight:500}
.stat .val{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-top:1px}
.ico.green,.ico.blue,.ico.orange,.ico.pink,.ico.teal{background:#f1f2f3;color:#0f0f0f}

/* ── card / table ── */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.toolbar{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--line)}
.toolbar .right{margin-left:auto;display:flex;gap:8px}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{text-align:left;font-weight:600;color:var(--ink-2);font-size:12.5px;padding:12px 16px;background:#fbfcfd;border-bottom:1px solid var(--line)}
tbody td{padding:14px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:#fafbfc}
td .strong{font-weight:600;color:var(--ink)}
.check{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}
.row-actions a{color:var(--ink-3);padding:4px}
.row-actions a:hover{color:var(--primary)}

/* ── pills / tags ── */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap}
.pill.green{background:var(--green-bg);color:var(--green)} .pill.orange{background:var(--orange-bg);color:var(--orange)}
.pill.yellow{background:var(--yellow-bg);color:var(--yellow)} .pill.pink{background:var(--pink-bg);color:var(--pink)}
.pill.blue{background:var(--blue-bg);color:var(--blue)} .pill.gray{background:#eef1f4;color:var(--ink-2)}
.dot{width:7px;height:7px;border-radius:50%;background:currentColor}

/* ── buttons ── */
.btn{display:inline-flex;align-items:center;gap:7px;font-family:inherit;font-size:13.5px;font-weight:600;padding:9px 15px;border-radius:10px;border:1px solid var(--line-2);background:#fff;color:var(--ink);cursor:pointer;transition:.12s}
.btn svg{width:16px;height:16px}
.btn:hover{background:#f6f8fa}
.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn.primary:hover{background:var(--primary-600)}
.btn.ghost{border-color:transparent;background:transparent;color:var(--ink-2)}
.btn.sm{padding:7px 11px;font-size:12.5px}
.btn.block{width:100%;justify-content:center;padding:11px}

/* ── forms ── */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--ink)}
.field label .req{color:#e0457b}
.input,select,textarea{width:100%;font-family:inherit;font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--line-2);border-radius:10px;padding:11px 13px;outline:0;transition:.12s}
.input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}
textarea{resize:vertical;min-height:92px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ── login ── */
.auth{min-height:100vh;display:grid;place-items:center;background:radial-gradient(1200px 500px at 50% -10%,#eef0f1,transparent),var(--bg);padding:24px}
.auth .box{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-md);padding:34px 30px}
.auth .logo{display:flex;justify-content:center;margin-bottom:18px}
.auth .logo img{height:40px;max-width:200px;object-fit:contain}
.auth h1{font-size:20px;font-weight:700;text-align:center;margin:0 0 4px}
.auth .sub{text-align:center;color:var(--ink-2);font-size:13.5px;margin-bottom:22px}
.auth .powered{justify-content:center;border:0;margin-top:18px;padding-top:8px}
.alert{background:#fdecef;border:1px solid #f8d3da;color:#b42339;font-size:13px;padding:10px 13px;border-radius:10px;margin-bottom:16px}
.flash{background:var(--green-bg);border:1px solid #cdebd9;color:var(--green);font-size:13px;padding:10px 13px;border-radius:10px;margin-bottom:16px}

/* ── empty state ── */
.empty{padding:54px 20px;text-align:center;color:var(--ink-3)}
.empty svg{width:38px;height:38px;margin-bottom:10px;opacity:.6}
.empty h3{margin:0 0 4px;color:var(--ink-2);font-size:15px;font-weight:600}

/* ── sortable table headers ── */
th.sortable{padding:0}
th.sortable a{display:flex;align-items:center;gap:5px;padding:12px 16px;color:var(--ink-2);font-weight:600;white-space:nowrap}
th.sortable a:hover{color:var(--primary);background:#f4f6f8}
th.sortable.active a{color:var(--primary)}
th.sortable .sort-ar{font-size:11px;line-height:1;color:var(--ink-3)}
th.sortable.active .sort-ar{color:var(--primary)}

/* ── image upload field ── */
.imagefield-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.imagefield-prev{width:66px;height:66px;object-fit:cover;border-radius:9px;border:1px solid var(--line-2);background:#f4f6f8}
.imagefield-btn{cursor:pointer;margin:0}
.imagefield-spin{display:none}
.imagefield.busy .imagefield-spin{display:inline}
.imagefield.busy .imagefield-btn{opacity:.5;pointer-events:none}
.imagefield-url{margin-top:9px}
.imagefield-url summary{cursor:pointer;display:inline-block;list-style:none;user-select:none}
.imagefield-url summary::-webkit-details-marker{display:none}
.imagefield-url summary:hover{color:var(--ink-2)}

/* ── rich text editor (Quill, snow) tuned to the mono system ── */
.ql-host{background:#fff}
.ql-toolbar.ql-snow{border:1px solid var(--line-2);border-bottom:0;border-radius:10px 10px 0 0;padding:8px 10px}
.ql-container.ql-snow{border:1px solid var(--line-2);border-radius:0 0 10px 10px;font-family:var(--sans);font-size:14px}
.ql-container.ql-snow.ql-focused{border-color:var(--primary)}
.ql-editor{min-height:200px;color:var(--ink);line-height:1.65;padding:14px 16px}
.ql-editor.ql-blank::before{color:var(--ink-soft);font-style:normal;left:16px}
.ql-editor h2{font-size:20px;font-weight:700;letter-spacing:-.01em}
.ql-editor h3{font-size:16px;font-weight:700}
.ql-editor a{color:var(--blue);text-decoration:underline}
.ql-editor img{max-width:100%;height:auto;border-radius:8px}
.ql-editor blockquote{border-left:3px solid var(--line-2);color:var(--ink-2);margin:10px 0;padding-left:14px}
.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-picker-label.ql-active .ql-stroke{stroke:var(--primary)}
.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill{fill:var(--primary)}
.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-picker-label.ql-active{color:var(--primary)}
.ql-snow .ql-tooltip{border-radius:10px;box-shadow:var(--shadow-md);border-color:var(--line-2)}

/* ── pipeline board ── */
.board{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start}
.board-col{background:#f7f9fb;border:1px solid var(--line);border-radius:12px;padding:10px;min-height:80px}
.board-col-head{display:flex;align-items:center;gap:7px;font-weight:600;font-size:13px;margin:2px 2px 10px}
.board-card{display:block;background:#fff;border:1px solid var(--line-2);border-radius:10px;padding:10px 12px;margin-bottom:8px;box-shadow:var(--shadow)}
.board-card:hover{border-color:var(--primary)}
.board-card .strong{font-size:13.5px}

/* ── bulk action bar ── */
.bulkbar{display:none;align-items:center;gap:10px;background:var(--primary);color:#fff;border-radius:10px;padding:9px 14px;margin-bottom:12px;font-size:13px}
.bulkbar.show{display:flex}
.bulkbar select{width:auto;background:#fff;color:var(--ink);padding:7px 10px;font-size:13px}
.bulkbar b{font-weight:700}

/* ── media library ── */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}
.media-item{position:relative;aspect-ratio:1;border:1px solid var(--line-2);border-radius:10px;overflow:hidden;background:#f4f6f8}
.media-item img{width:100%;height:100%;object-fit:cover;cursor:copy;display:block}
.media-item form{position:absolute;top:4px;right:4px;margin:0}
.media-del{width:22px;height:22px;border-radius:6px;border:0;background:rgba(15,15,15,.62);color:#fff;font-size:15px;line-height:1;cursor:pointer;display:grid;place-items:center}
.media-del:hover{background:#b42339}

@media(max-width:980px){.board{grid-template-columns:repeat(2,1fr)}}
@media(max-width:880px){.app{grid-template-columns:1fr}.sidebar{display:none}.content{padding:18px}}
