@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --font:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --bg:#f1f5f9;--bg-card:#ffffff;--bg-soft:#f8fafc;--bg-input:#ffffff;
  --bg-side:#0f172a;--bg-side-h:#172033;--bg-side-a:#1e293b;
  --border:#e2e8f0;--border2:#f1f5f9;
  --text:#0f172a;--text2:#334155;--text3:#64748b;--text-side:#94a3b8;
  --accent:#2563eb;--accent-h:#1d4ed8;--accent-l:#eff6ff;
  --blue:#2563eb;--blue-l:#eff6ff;
  --emerald:#059669;--emerald-l:#ecfdf5;
  --amber:#d97706;--amber-l:#fffbeb;
  --rose:#dc2626;--rose-l:#fef2f2;
  --sky:#0284c7;--sky-l:#f0f9ff;
  --slate:#475569;--slate-l:#f1f5f9;
  --violet:#7c3aed;--violet-l:#f5f3ff;
  --shadow-sm:0 1px 2px rgba(15,23,42,.05);
  --shadow:0 4px 16px rgba(15,23,42,.06);
  --shadow-md:0 12px 32px rgba(15,23,42,.08);
  --r:10px;--r-lg:14px;--r-sm:8px;
  --side-w:260px;--top-h:56px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;font-feature-settings:'cv02','cv03','cv04','cv11'}
a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-h)}
.app{display:flex;min-height:100vh}

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}
*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}

/* ─── SIDEBAR ─── */
.sidebar{width:var(--side-w);background:var(--bg-side);position:fixed;top:0;left:0;bottom:0;z-index:100;display:flex;flex-direction:column;overflow-y:auto;transition:transform .25s ease}
.sidebar-brand{padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:12px}
.sidebar-brand .logo-text{color:#fff;font-weight:800;font-size:18px;letter-spacing:-.5px}
.sidebar-brand .logo-dot{color:#60a5fa}
.sidebar-brand .brand-sub{display:block;font-size:9px;color:var(--text-side);font-weight:600;letter-spacing:1.2px;text-transform:uppercase;margin-top:1px}
.sidebar-nav{padding:14px 10px;flex:1}
.nav-section{margin-bottom:20px}
.nav-label{font-size:9px;text-transform:uppercase;letter-spacing:1.4px;color:rgba(148,163,184,.4);padding:0 12px 6px;font-weight:700}
.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-sm);color:var(--text-side);font-size:13px;font-weight:500;transition:all .12s}
.nav-link:hover{background:rgba(255,255,255,.06);color:#e2e8f0}
.nav-link.active{background:rgba(37,99,235,.15);color:#fff}
.nav-link svg{width:18px;height:18px;opacity:.6;flex-shrink:0}
.nav-link.active svg{opacity:1;color:#93c5fd}
.nav-link .nav-badge{margin-left:auto;font-size:10px;font-weight:700;background:rgba(37,99,235,.14);color:var(--blue);padding:2px 7px;border-radius:999px;min-width:28px;text-align:center;line-height:1.2}
.sidebar-user{padding:14px 16px;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px}
.user-avatar{width:32px;height:32px;border-radius:8px;background:rgba(59,130,246,.2);display:flex;align-items:center;justify-content:center;color:#93c5fd;font-weight:700;font-size:11px;flex-shrink:0}
.user-name{color:#e2e8f0;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{color:var(--text-side);font-size:10px;text-transform:uppercase;letter-spacing:.5px}

/* ─── MAIN ─── */
.main{margin-left:var(--side-w);flex:1;min-height:100vh;display:flex;flex-direction:column}
.topbar{height:var(--top-h);background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;position:sticky;top:0;z-index:50}
.topbar .page-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}
.topbar .page-title small{color:var(--text3);font-weight:400;font-size:12px}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--text)}
.content{padding:24px;flex:1;width:100%;max-width:1600px}

/* ─── CARDS ─── */
.card{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.card-head{padding:14px 18px;border-bottom:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.card-head h3{font-size:13px;font-weight:700;color:var(--text)}
.card-body{padding:18px}
.section-title{margin-bottom:4px;font-size:11px;color:var(--text2);font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.section-hint{font-size:12px;color:var(--text3);margin-bottom:12px;font-weight:400;line-height:1.4}
.form-section{padding:18px 0;border-bottom:1px solid var(--border2)}
.form-section:first-of-type{padding-top:0}
.form-section:last-of-type{border-bottom:none}
.form-section-head{margin-bottom:14px}
.form-actions{display:flex;gap:8px;padding-top:18px;border-top:1px solid var(--border2);margin-top:8px}
.section-divider{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border2)}
.block-label{margin-bottom:6px}
.detail-block{padding:14px 16px;border-top:1px solid var(--border2)}
.detail-text{font-size:13px;white-space:pre-wrap;color:var(--text2)}

/* ─── STAT CARDS ─── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:20px}
.stat{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border);padding:16px 18px;box-shadow:var(--shadow-sm);transition:box-shadow .15s;position:relative;overflow:hidden;min-height:100px;display:flex;flex-direction:column}
.stat::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent)}
.stat:hover{box-shadow:var(--shadow)}
.stat-label{display:inline-flex;align-items:center;padding:3px 8px;border-radius:6px;background:var(--accent-l);color:var(--accent);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:normal;line-height:1.4;max-width:100%}
.stat-val{font-size:28px;font-weight:800;line-height:1;color:var(--text);margin-top:auto;padding-top:8px}
.stat-sub{font-size:11px;color:var(--text3);margin-top:4px;line-height:1.4}
.stat-trend{font-size:10px;font-weight:600;margin-top:3px;display:flex;align-items:center;gap:3px}
.stat-trend.up{color:var(--emerald)}.stat-trend.down{color:var(--rose)}.stat-trend.neutral{color:var(--text3)}
.stat.green::before{background:var(--emerald)} .stat.green .stat-label{background:var(--emerald-l);color:var(--emerald)}
.stat.yellow::before{background:var(--amber)} .stat.yellow .stat-label{background:var(--amber-l);color:var(--amber)}
.stat.red::before{background:var(--rose)} .stat.red .stat-label{background:var(--rose-l);color:var(--rose)}
.stat.red-accent{border-color:rgba(220,38,38,.2)}
.stat.red-accent::before{width:3px;background:var(--rose)}
.stat.red-accent .stat-label{background:var(--rose-l);color:var(--rose)}
.stat.red-accent .stat-val{color:var(--rose)}
.stat.purple::before{background:var(--violet)} .stat.purple .stat-label{background:var(--violet-l);color:var(--violet)}
.stat.teal::before{background:var(--sky)} .stat.teal .stat-label{background:var(--sky-l);color:var(--sky)}
.stat.orange::before{background:#b45309} .stat.orange .stat-label{background:#fff7ed;color:#b45309}
.stat-primary::before{background:var(--accent)} .stat-primary .stat-label{background:var(--accent-l);color:var(--accent)}

.stats-secondary{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;margin-bottom:20px}
.stat-mini{background:var(--bg-card);border-radius:var(--r);border:1px solid var(--border);padding:12px 14px;display:flex;align-items:center;gap:10px}
.stat-mini-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.stat-mini-icon.blue{background:var(--blue-l);color:var(--blue)}
.stat-mini-icon.green{background:var(--emerald-l);color:var(--emerald)}
.stat-mini-icon.amber{background:var(--amber-l);color:var(--amber)}
.stat-mini-icon.red{background:var(--rose-l);color:var(--rose)}
.stat-mini-icon.violet{background:var(--violet-l);color:var(--violet)}
.stat-mini-icon.slate{background:var(--slate-l);color:var(--slate)}
.stat-mini-body{flex:1;min-width:0}
.stat-mini-label{font-size:10px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.stat-mini-val{font-size:17px;font-weight:800;color:var(--text);line-height:1.2}

/* ─── TABLES ─── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.cases-table{min-width:1180px}
.cases-table .badge{max-width:100%}
.cases-table .cell-status-wrap,.cases-table .cell-priority-wrap{white-space:nowrap}
.cases-table col.col-nr{width:130px}
.cases-table col.col-client{width:180px}
.cases-table col.col-phone{width:150px}
.cases-table col.col-product{width:auto}
.cases-table col.col-sn{width:190px}
.cases-table col.col-status{width:190px}
.cases-table col.col-prio{width:110px}
.cases-table col.col-days{width:80px}
.cases-table col.col-assigned{width:120px}
.cases-table col.col-date{width:110px}
table{width:100%;border-collapse:collapse;table-layout:fixed}
table.table-auto{table-layout:auto}
th{text-align:left;padding:10px 14px;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:700;border-bottom:1px solid var(--border);background:var(--bg-soft);white-space:nowrap;position:sticky;top:0;z-index:1}
td{padding:11px 14px;border-bottom:1px solid var(--border2);font-size:13px;vertical-align:middle}
tbody tr{transition:background .1s}
tbody tr:hover{background:rgba(37,99,235,.02)}
tbody tr.clickable-row{cursor:pointer}
tbody tr.clickable-row:hover{background:rgba(37,99,235,.04)}
.nowrap{white-space:nowrap}
.strong-link{font-weight:600}
.tbl-actions{display:flex;gap:4px;flex-wrap:nowrap;white-space:nowrap}
.tbl-actions a,.tbl-actions button{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;border:1px solid var(--border);background:#fff;color:var(--text2);cursor:pointer;transition:all .1s;white-space:nowrap}
.tbl-actions a:hover,.tbl-actions button:hover{background:var(--bg-soft);color:var(--text);border-color:var(--accent)}

/* Cell truncation */
.cell-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:0}
.cell-product{width:22%;min-width:140px}
.cell-sn{width:13%;min-width:100px}
.cell-client{width:12%;min-width:100px}
.cell-nr{width:9%;min-width:90px}
.cell-phone{width:10%;min-width:90px}
.cell-status{width:13%;min-width:110px}
.cell-prio{width:6%;min-width:55px}
.cell-days{width:5%;min-width:40px}
.cell-assigned{width:8%;min-width:60px}
.cell-date{width:7%;min-width:75px}
.cell-actions{width:auto;min-width:110px;white-space:nowrap}

/* Tooltip for truncated cells */
td[title]{position:relative;cursor:default}

/* ─── BADGES ─── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:6px;font-size:10px;font-weight:700;white-space:nowrap;letter-spacing:.02em;border:1px solid transparent}
.badge .badge-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.badge-new{background:var(--blue-l);color:var(--blue);border-color:rgba(37,99,235,.15)}
.badge-new .badge-dot{background:var(--blue)}
.badge-accepted{background:var(--sky-l);color:var(--sky);border-color:rgba(2,132,199,.15)}
.badge-accepted .badge-dot{background:var(--sky)}
.badge-diag{background:var(--violet-l);color:var(--violet);border-color:rgba(124,58,237,.12)}
.badge-diag .badge-dot{background:var(--violet)}
.badge-wait{background:var(--amber-l);color:var(--amber);border-color:rgba(217,119,6,.12)}
.badge-wait .badge-dot{background:var(--amber)}
.badge-progress{background:#fff7ed;color:#c2410c;border-color:rgba(194,65,12,.12)}
.badge-progress .badge-dot{background:#c2410c}
.badge-supplier{background:var(--blue-l);color:var(--accent);border-color:rgba(37,99,235,.12)}
.badge-supplier .badge-dot{background:var(--accent)}
.badge-ready{background:var(--emerald-l);color:var(--emerald);border-color:rgba(5,150,105,.12)}
.badge-ready .badge-dot{background:var(--emerald)}
.badge-done{background:var(--emerald-l);color:#047857;border-color:rgba(4,120,87,.12)}
.badge-done .badge-dot{background:#047857}
.badge-reject{background:var(--rose-l);color:var(--rose);border-color:rgba(220,38,38,.12)}
.badge-reject .badge-dot{background:var(--rose)}
.badge-testing{background:#faf5ff;color:#9333ea;border-color:rgba(147,51,234,.12)}
.badge-testing .badge-dot{background:#9333ea}
.badge-client-wait{background:var(--amber-l);color:#b45309;border-color:rgba(180,83,9,.12)}
.badge-client-wait .badge-dot{background:#b45309}
.badge-normal{background:var(--slate-l);color:var(--text2);border-color:rgba(71,85,105,.1)}
.badge-low{background:var(--bg-soft);color:var(--text3);border-color:var(--border)}
.badge-high{background:#fff7ed;color:#c2410c;border-color:rgba(194,65,12,.15)}
.badge-urgent{background:var(--rose-l);color:var(--rose);border-color:rgba(220,38,38,.15)}
.badge-note-internal{background:var(--blue-l);color:var(--blue);border-color:rgba(37,99,235,.12)}
.badge-note-technical{background:var(--slate-l);color:var(--slate);border-color:rgba(71,85,105,.1)}
.badge-note-customer{background:var(--emerald-l);color:var(--emerald);border-color:rgba(5,150,105,.12)}
.badge-note-status{background:var(--amber-l);color:var(--amber);border-color:rgba(217,119,6,.12)}
.badge-note-communication{background:var(--violet-l);color:var(--violet);border-color:rgba(124,58,237,.12)}
.badge-action-auth{background:var(--blue-l);color:var(--accent);border-color:rgba(37,99,235,.12)}
.badge-action-danger{background:var(--rose-l);color:var(--rose);border-color:rgba(220,38,38,.12)}
.badge-action-case{background:#eef2ff;color:#4338ca;border-color:rgba(67,56,202,.1)}
.badge-action-status{background:var(--amber-l);color:var(--amber);border-color:rgba(217,119,6,.12)}
.badge-action-note{background:var(--blue-l);color:var(--blue);border-color:rgba(37,99,235,.12)}
.badge-action-file{background:var(--emerald-l);color:#15803d;border-color:rgba(21,128,61,.1)}
.badge-action-parts{background:#fff7ed;color:#c2410c;border-color:rgba(194,65,12,.1)}
.badge-action-admin{background:var(--slate-l);color:var(--slate);border-color:rgba(71,85,105,.1)}
.badge-action-comm{background:var(--violet-l);color:var(--violet);border-color:rgba(124,58,237,.12)}

/* ─── ACTIVITY FEED ─── */
.activity-feed{padding:6px 14px;overflow-y:auto}
.activity-item{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border2);position:relative;align-items:flex-start}
.activity-item:last-child{border-bottom:none}
.activity-item::before{content:'';position:absolute;left:12px;top:34px;bottom:-1px;width:1px;background:var(--border2)}
.activity-item:last-child::before{display:none}
.activity-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;z-index:1}
.activity-icon.auth{background:var(--blue-l);color:var(--accent)}
.activity-icon.danger{background:var(--rose-l);color:var(--rose)}
.activity-icon.case-ev{background:#eef2ff;color:#4338ca}
.activity-icon.status-ev{background:var(--amber-l);color:var(--amber)}
.activity-icon.note-ev{background:var(--blue-l);color:var(--blue)}
.activity-icon.file-ev{background:var(--emerald-l);color:#15803d}
.activity-icon.parts-ev{background:#fff7ed;color:#c2410c}
.activity-icon.admin-ev{background:var(--slate-l);color:var(--slate)}
.activity-icon.comm-ev{background:var(--violet-l);color:var(--violet)}
.activity-body{flex:1;min-width:0}
.activity-item-head{display:flex;justify-content:space-between;gap:8px;font-size:11px;line-height:1.3}
.activity-item-head strong{color:var(--text2);font-weight:700;font-size:11px}
.activity-item-body{display:flex;gap:6px;align-items:center;font-size:11px;margin-top:2px;overflow:hidden}
.activity-item-body .text-muted{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-filters{display:flex;gap:3px;padding:10px 14px 0;flex-wrap:wrap}
.activity-filter-btn{padding:4px 10px;border-radius:6px;font-size:10px;font-weight:600;border:1px solid var(--border);background:#fff;color:var(--text3);cursor:pointer;transition:all .1s}
.activity-filter-btn:hover,.activity-filter-btn.active{background:var(--accent-l);color:var(--accent);border-color:rgba(37,99,235,.2)}

/* ─── FORMS ─── */
.fg{margin-bottom:14px}
.fg label{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;margin-bottom:5px;color:var(--text2)}
.fg label .req{color:var(--rose)}
.tip{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;background:var(--border);color:var(--text3);font-size:9px;font-weight:800;cursor:help;flex-shrink:0;font-style:normal}
.tip:hover{background:var(--accent);color:#fff}
.fc{display:block;width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-input);font-family:var(--font);font-size:13px;color:var(--text);outline:none;transition:border-color .12s,box-shadow .12s}
.fc:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
textarea.fc{resize:vertical;min-height:36px}
select.fc{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' viewBox='0 0 24 24' stroke='%2364748b' stroke-width='3'%3E%3Cpath d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0 14px}
.fr4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:0 14px}
.parts-grid{display:grid;grid-template-columns:2fr 1fr 80px 1fr 1fr;gap:0 10px}
.checkbox-row{display:flex;align-items:center;padding-top:20px}
.checkbox-inline{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;font-weight:500}
.checkbox-inline input{accent-color:var(--accent);width:16px;height:16px}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--r-sm);font-size:12px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:all .12s;font-family:var(--font);text-decoration:none;white-space:nowrap}
.btn-p{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-p:hover{background:var(--accent-h);color:#fff}
.btn-s{background:#fff;color:var(--text2);border-color:var(--border)}
.btn-s:hover{background:var(--bg-soft);border-color:var(--text3)}
.btn-d{background:var(--rose-l);color:var(--rose);border-color:rgba(220,38,38,.2)}
.btn-d:hover{background:var(--rose);color:#fff}
.btn-ok{background:var(--emerald);color:#fff;border-color:var(--emerald)}
.btn-ok:hover{background:#047857;color:#fff}
.btn-print{background:var(--bg-soft);color:var(--text2);border-color:var(--border)}
.btn-print:hover{background:var(--accent-l);color:var(--accent);border-color:rgba(37,99,235,.2)}
.btn-sm{padding:5px 12px;font-size:11px}
.btn-g{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.full-width{width:100%}

/* ─── ALERT ─── */
.alert{padding:10px 16px;border-radius:var(--r-sm);font-size:12px;font-weight:500;margin-bottom:14px;border:1px solid transparent;line-height:1.5;animation:alertIn .2s ease}
@keyframes alertIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.alert-success{background:var(--emerald-l);color:var(--emerald);border-color:rgba(5,150,105,.15)}
.alert-error{background:var(--rose-l);color:var(--rose);border-color:rgba(220,38,38,.15)}
.alert-info{background:var(--blue-l);color:var(--blue);border-color:rgba(37,99,235,.15)}
.alert-warning{background:var(--amber-l);color:var(--amber);border-color:rgba(217,119,6,.15)}

/* ─── FILTERS ─── */
.filters{display:flex;flex-wrap:wrap;gap:10px;padding:14px 18px;background:var(--bg-soft);border-bottom:1px solid var(--border2);align-items:flex-end;border-radius:var(--r-lg) var(--r-lg) 0 0}
.filters .fg{margin-bottom:0;min-width:140px}
.filters .fc{font-size:12px;padding:7px 10px}
.filters label{font-size:10px;margin-bottom:3px;letter-spacing:.06em;text-transform:uppercase;color:var(--text3)}
.filters-inline{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.search-box{position:relative;flex:1;min-width:220px}
.search-box input{padding-left:12px;padding-right:36px}
.search-box svg{position:absolute;right:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--text3)}
.list-footnote{margin-top:8px;font-size:11px;color:var(--text3)}

/* ─── PIPELINE TABS ─── */
.pipeline-tabs{display:flex;gap:2px;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);padding:3px;overflow-x:auto}
.pipeline-spacer{margin-left:auto;flex:1 0 16px}
.pipe-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;font-size:12px;font-weight:600;color:var(--text3);text-decoration:none;transition:all .1s;white-space:nowrap}
.pipe-tab:hover{color:var(--text);background:var(--bg-soft)}
.pipe-tab.pipe-active{background:var(--accent);color:#fff}
.pipe-tab.pipe-active .pipe-count{background:rgba(255,255,255,.2);color:#fff}
.pipe-tab.pipe-blue.pipe-active{background:var(--blue)}
.pipe-tab.pipe-violet.pipe-active{background:var(--violet)}
.pipe-tab.pipe-amber.pipe-active{background:var(--amber)}
.pipe-tab.pipe-orange.pipe-active{background:#c2410c}
.pipe-tab.pipe-emerald.pipe-active{background:var(--emerald)}
.pipe-tab.pipe-slate.pipe-active{background:var(--slate)}
.pipe-tab.pipe-blue .pipe-count{color:var(--blue)}
.pipe-tab.pipe-violet .pipe-count{color:var(--violet)}
.pipe-tab.pipe-amber .pipe-count{color:var(--amber)}
.pipe-tab.pipe-orange .pipe-count{color:#c2410c}
.pipe-tab.pipe-emerald .pipe-count{color:var(--emerald)}
.pipe-tab.pipe-slate .pipe-count{color:var(--slate)}
.pipe-tab.pipe-active .pipe-count{color:#fff !important}
.pipe-count{font-size:10px;font-weight:700;background:var(--bg-soft);color:var(--text3);padding:1px 6px;border-radius:4px;min-width:20px;text-align:center}

/* ─── MY ORDERS TOGGLE ─── */
.toolbar-row{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.toolbar-row .pipeline-tabs{margin-bottom:0;flex:1;min-width:0}
.my-orders-toggle{display:flex;align-items:center;gap:8px;padding:7px 14px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;transition:all .12s;font-size:12px;font-weight:600;color:var(--text3);white-space:nowrap;flex-shrink:0;text-decoration:none}
.my-orders-toggle.pipe-inline{margin-left:auto}
.my-orders-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}
.my-orders-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.my-orders-toggle .toggle-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}
.my-orders-toggle .toggle-count{font-size:10px;font-weight:700;background:rgba(255,255,255,.2);padding:1px 5px;border-radius:4px}
.my-orders-toggle:not(.active) .toggle-count{background:var(--bg-soft);color:var(--accent)}

/* ─── SEARCH BAR ─── */
.search-bar{display:flex;flex-wrap:wrap;gap:10px;padding:12px 18px;border-bottom:1px solid var(--border2);align-items:center}
.search-bar .search-box{flex:1;min-width:200px}
.search-bar .search-box .fc{font-size:13px;padding:8px 12px}
.search-filters{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.sf-inline{display:flex;gap:6px;align-items:center}
.fc-mini{width:auto;min-width:140px;font-size:11px;padding:7px 10px}
.search-scope{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;font-size:10px;font-weight:600;background:var(--blue-l);color:var(--blue);margin-left:4px;white-space:nowrap}

/* ─── SLA ─── */
.sla-inline{display:inline-block;padding:2px 7px;border-radius:6px;font-size:11px;font-weight:600}
.sla-inline.sla-ok{background:var(--emerald-l);color:var(--emerald)}
.sla-inline.sla-warn{background:var(--amber-l);color:var(--amber)}
.sla-inline.sla-danger{background:var(--rose-l);color:var(--rose)}
.row-overdue{background:rgba(220,38,38,.015) !important}
.row-overdue:hover{background:rgba(220,38,38,.04) !important}

.closed-section{margin-top:28px}
.closed-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 4px}
.closed-header h3{font-size:13px;font-weight:700;color:var(--text3)}
.closed-count{font-size:10px;font-weight:600;color:var(--text3);background:var(--slate-l);padding:3px 8px;border-radius:6px}
.table-muted tbody tr{opacity:.65;transition:opacity .12s}
.table-muted tbody tr:hover{opacity:1}

/* ─── REPORTS ─── */
.report-kpis{display:flex;gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 8px;margin-bottom:16px;flex-wrap:wrap;align-items:center;justify-content:center}
.rkpi{text-align:center;padding:4px 18px;flex:0 0 auto}
.rkpi-val{font-size:22px;font-weight:800;color:var(--text);line-height:1.2}
.rkpi-label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.rkpi-div{width:1px;height:36px;background:var(--border);margin:0 4px;flex-shrink:0}
.rkpi-danger .rkpi-val{color:var(--rose)}
.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.bar-bg{background:var(--bg-soft);border-radius:4px;height:16px;overflow:hidden}
.bar-fill{background:var(--accent);height:100%;border-radius:4px;min-width:2px;transition:width .3s}
.bar-fill.bar-emerald{background:var(--emerald)}
.bar-fill.bar-violet{background:var(--violet)}
.bar-fill.bar-amber{background:var(--amber)}

/* ─── ROLES MATRIX ─── */
.roles-matrix th.role-col{text-align:center;min-width:100px;font-size:10px}
.roles-matrix .sticky-col{position:sticky;left:0;background:#fff;z-index:2;min-width:180px}
.roles-matrix thead .sticky-col{background:var(--bg-soft)}
.roles-matrix .perm-cell{padding:8px 14px}
.perm-name{font-size:12px;font-weight:600;display:block;color:var(--text2)}
.perm-slug{font-size:10px;font-family:var(--mono);color:var(--text3);display:block;margin-top:1px}
.roles-matrix .check-cell{text-align:center;padding:6px}
.roles-matrix .group-row td{padding:8px 14px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);background:var(--bg-soft);border-bottom:1px solid var(--border)}
.group-label{border-bottom:1px solid var(--border) !important}
.perm-form{display:inline}
.perm-toggle{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;transition:all .1s;display:inline-flex;align-items:center;justify-content:center}
.perm-toggle:hover{background:var(--bg-soft)}
.perm-on{color:var(--emerald)}.perm-off{color:var(--border)}.perm-off:hover{color:var(--text3)}

/* ─── CASE VIEW ─── */
.case-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:14px;margin-bottom:18px}
.case-head h2{font-size:18px;font-weight:700;margin-bottom:4px;letter-spacing:-.02em}
.case-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.case-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px}
.case-side{display:flex;flex-direction:column;gap:12px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.detail-item{padding:10px 14px;border-bottom:1px solid var(--border2)}
.detail-item:nth-child(odd){border-right:1px solid var(--border2)}
.d-label{font-size:10px;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.d-value{font-size:13px;font-weight:500;color:var(--text2)}

.sla-widget{padding:12px 14px;border-radius:var(--r-sm)}
.sla-widget.sla-ok{background:var(--emerald-l);border:1px solid rgba(5,150,105,.15)}
.sla-widget.sla-warn{background:var(--amber-l);border:1px solid rgba(217,119,6,.15)}
.sla-widget.sla-danger{background:var(--rose-l);border:1px solid rgba(220,38,38,.15)}
.sla-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.sla-value{font-size:18px;font-weight:800;line-height:1}
.sla-sub{font-size:10px;color:var(--text3);margin-top:2px}

.quick-panel{display:flex;flex-direction:column;gap:8px;padding:14px;background:var(--bg-soft);border-radius:var(--r-sm);border:1px solid var(--border2)}
.quick-panel .qp-row{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:12px}
.quick-panel .qp-label{color:var(--text3);font-weight:500}
.quick-panel .qp-value{font-weight:600;color:var(--text2);text-align:right}
.quick-tracker{gap:12px;padding:0;background:transparent;border:none}
.qt-item{position:relative;display:flex;gap:12px;padding-bottom:12px}
.qt-item:not(:last-child){border-bottom:1px solid var(--border2)}
.qt-item:not(:last-child)::after{content:'';position:absolute;left:7px;top:18px;bottom:-6px;width:1px;background:var(--border)}
.qt-dot{width:14px;height:14px;border-radius:999px;background:var(--accent-l);border:3px solid var(--accent);flex:0 0 14px;margin-top:4px;box-sizing:border-box}
.qt-current .qt-dot{background:var(--accent);box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.qt-body{min-width:0;flex:1;display:flex;flex-direction:column;gap:6px}
.qt-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.qt-title{font-size:12px;font-weight:700;color:var(--text2)}
.qt-time{font-size:11px;color:var(--text3);white-space:nowrap}
.qt-main{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.qt-meta{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--text3)}
.qt-comment{color:var(--text2);white-space:normal}

.case-tabs{display:flex;gap:1px;margin-bottom:16px;border-bottom:2px solid var(--border2);overflow-x:auto}
.case-tab{padding:9px 16px;font-size:12px;font-weight:600;color:var(--text3);margin-bottom:-2px;cursor:pointer;transition:all .1s;white-space:nowrap;background:none;border:none;border-bottom:2px solid transparent;font-family:var(--font)}
.case-tab:hover{color:var(--text)}
.case-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-content{display:none}
.tab-content.active{display:block}

/* ─── TIMELINE ─── */
.timeline{list-style:none;padding:0}
.tl-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border2)}
.tl-item:last-child{border-bottom:none}
.tl-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}
.tl-dot.internal{background:var(--blue)}
.tl-dot.technical{background:var(--slate)}
.tl-dot.customer{background:var(--emerald)}
.tl-dot.status_change{background:var(--amber)}
.tl-dot.communication{background:var(--violet)}
.tl-content{flex:1}
.tl-meta{display:flex;gap:8px;font-size:10px;color:var(--text3);margin-bottom:3px;flex-wrap:wrap;align-items:center}
.tl-meta strong{color:var(--text2);font-weight:700}
.tl-text{font-size:13px;line-height:1.6;white-space:pre-wrap;color:var(--text2)}

.comm-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border2)}
.comm-item:last-child{border-bottom:none}
.comm-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;background:var(--bg-soft)}
.comm-body{flex:1;font-size:12px}
.comm-time{color:var(--text3);font-size:11px}

.att-list{display:flex;flex-direction:column;gap:6px}
.att-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-soft);border:1px solid var(--border2);border-radius:var(--r-sm);font-size:12px}
.file-icon{width:28px;height:28px;border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;border:1px solid var(--border2);font-size:13px}
.att-title{font-weight:600;color:var(--text2)}
.signature-preview{max-width:100%;border:1px solid var(--border);border-radius:var(--r-sm);background:#fff}
.info-list{font-size:12px}
.info-row{display:flex;justify-content:space-between;gap:12px;margin-bottom:8px}
.info-row:last-child{margin-bottom:0}
.price-value{font-weight:700;color:var(--text)}

/* ─── LOGIN ─── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-side);padding:20px}
.login-card{width:100%;max-width:400px;background:var(--bg-card);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden}
.login-head{padding:28px 28px 20px;text-align:center;border-bottom:1px solid var(--border2)}
.login-head h1{font-size:17px;font-weight:700;margin-bottom:2px}
.login-head p{font-size:12px;color:var(--text3)}
.login-body{padding:24px 28px 28px}
.login-body .btn-p{width:100%;justify-content:center;padding:10px;font-size:13px}

.sig-canvas{border:2px dashed var(--border);border-radius:var(--r-sm);background:#fafcff;cursor:crosshair;touch-action:none;width:100%;height:130px;display:block}
.sig-canvas.active{border-color:var(--accent);border-style:solid}
.pagination{display:flex;justify-content:center;gap:4px;margin-top:14px}
.page-link{padding:6px 11px;border:1px solid var(--border);border-radius:6px;font-size:12px;color:var(--text2);font-weight:600;transition:all .1s;background:#fff}
.page-link:hover{background:var(--accent-l);color:var(--accent);border-color:rgba(37,99,235,.2)}
.page-link.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ─── UTILITIES ─── */
.text-muted{color:var(--text3)}
.text-sm{font-size:11px}
.text-r{text-align:right}
.mt-1{margin-top:8px}.mt-2{margin-top:14px}.mb-2{margin-bottom:14px}.mb-3{margin-bottom:18px}
.d-flex{display:flex}.gap-1{gap:8px}.gap-2{gap:14px}.ai-c{align-items:center}.jc-b{justify-content:space-between}
.mono{font-family:var(--mono);font-size:12px}
.empty{text-align:center;padding:36px 20px;color:var(--text3)}
.compact-empty{padding:18px}
.empty p{font-size:13px}
hr.sep{border:none;border-top:1px solid var(--border2);margin:20px 0}

.grid-2{display:grid;grid-template-columns:5fr 2fr;gap:16px}
.grid-2>.card:last-child{display:flex;flex-direction:column;overflow:hidden}
.grid-2>.card:last-child>.card-head{flex-shrink:0}
.grid-2>.card:last-child>.activity-filters{flex-shrink:0}
.grid-2>.card:last-child>.activity-feed{flex:1;overflow-y:auto;max-height:960px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ─── RESPONSIVE ─── */
@media(max-width:1100px){.case-grid,.grid-2,.report-grid{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr 1fr}.parts-grid{grid-template-columns:1fr 1fr}.fr,.fr3,.fr4{grid-template-columns:1fr}.stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.stats-secondary{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.grid-2>.card:last-child{max-height:450px}.toolbar-row{flex-direction:column;align-items:stretch}.toolbar-row .pipeline-tabs{width:100%}.pipeline-spacer{display:none}.my-orders-toggle{align-self:flex-start}}
@media(max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main{margin-left:0}.mobile-toggle{display:block}.content{padding:14px}.topbar{padding:0 14px}.detail-grid{grid-template-columns:1fr}.detail-item:nth-child(odd){border-right:none}.filters{padding:12px}.filters-inline{width:100%}.case-head{flex-direction:column}.btn-g{width:100%}.btn-g .btn{flex:1}.activity-item-head{flex-direction:column;align-items:flex-start}table{font-size:12px}th,td{padding:8px 10px}.case-tabs{gap:0}.case-tab{padding:7px 12px;font-size:11px}.pipeline-tabs{gap:1px}.pipe-tab{padding:6px 10px;font-size:11px}.my-orders-toggle.pipe-inline{padding:6px 10px;font-size:11px}.search-bar{flex-direction:column}.search-filters{width:100%}.sf-inline{width:100%;flex-wrap:wrap}.fc-mini{flex:1;min-width:100px}.qt-top{flex-direction:column;align-items:flex-start}.hide-mobile{display:none!important}}
@media(max-width:480px){.stats{grid-template-columns:1fr 1fr}.stat-val{font-size:22px}.login-card{border-radius:var(--r-lg)}.login-head,.login-body{padding-left:18px;padding-right:18px}.parts-grid{grid-template-columns:1fr}}

/* ─── PRINT ─── */
@media print{.sidebar,.topbar,.btn,.btn-g,.filters,.pagination,.no-print,.mobile-toggle,form,.tbl-actions,.topbar-actions,.toolbar-row .my-orders-toggle{display:none!important}.main{margin-left:0!important}.content{padding:0!important}.card{box-shadow:none;border:1px solid #ccc;break-inside:avoid}body{background:#fff;color:#000;font-size:11px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.badge{border:1px solid currentColor}a{color:#000!important}}
.print-page{font-family:'Inter',sans-serif;color:#000;line-height:1.5;background:#fff;padding:20mm 15mm}
.print-page .p-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #000;padding-bottom:10px;margin-bottom:14px}
.print-page .p-company{font-size:10px;line-height:1.4}
.print-page .p-company strong{font-size:15px;display:block;margin-bottom:2px}
.print-page .p-case-num{font-family:'JetBrains Mono',monospace;font-size:20px;font-weight:800;text-align:right}
.print-page .p-case-date{font-size:10px;color:#555;text-align:right}
.print-page .p-title{text-align:center;font-size:14px;font-weight:700;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}
.print-page .p-table{width:100%;border-collapse:collapse;margin-bottom:12px}
.print-page .p-table th,.print-page .p-table td{border:1px solid #333;padding:5px 8px;font-size:11px;text-align:left}
.print-page .p-table th{background:#e8e8e8;font-weight:700;text-transform:uppercase;font-size:9px;letter-spacing:.5px}
.print-page .p-table td.lbl{background:#f4f4f4;font-weight:600;width:28%}
.print-page .p-sigs{display:flex;justify-content:space-between;gap:30px;margin-top:20px;page-break-inside:avoid}
.print-page .p-sig{flex:1;text-align:center}
.print-page .p-sig-line{border-bottom:1px solid #000;height:50px;margin-bottom:4px;position:relative}
.print-page .p-sig-line img{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);max-height:46px;max-width:90%}
.print-page .p-sig-label{font-size:9px;color:#555}
.print-page .p-terms{font-size:8.5px;color:#444;line-height:1.5;margin-top:14px;padding-top:8px;border-top:1px solid #999}
.print-page .p-terms strong{display:block;margin-bottom:3px;font-size:9px;color:#000}
.print-page .p-footer{text-align:center;font-size:8px;color:#888;margin-top:16px;padding-top:6px;border-top:1px solid #ccc}
