:root{
  --coral:#F26257; --coral-dim:#E54B40; --navy:#23485A; --navy-deep:#152C39;
  --mango:#F0CC56; --mango-soft:#FCEFC4; --cream:#FAF6EC; --paper:#FFFCF4;
  --ink:#171A1F; --ink-soft:#4B5561; --rule:#E8DDC2; --green:#2F7D5D;
  --shadow:0 1px 0 rgba(21,44,57,.06), 0 24px 60px -28px rgba(21,44,57,.22);
  --display:"Fraunces",Georgia,serif; --body:"Inter Tight",system-ui,sans-serif; --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box} html,body{margin:0;padding:0} body{font-family:var(--body);background:var(--paper);color:var(--ink);line-height:1.45;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}
.hidden{display:none!important}.mono,.eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:1.8px;text-transform:uppercase;color:var(--ink-soft)}.eyebrow{color:var(--coral)}
.brand-row{display:flex;align-items:baseline;gap:14px}.brand-mark{font-family:var(--display);font-weight:900;font-size:34px;letter-spacing:-1.5px;position:relative}.brand-mark::after{content:"";position:absolute;top:.15em;right:-13px;width:9px;height:9px;border-radius:50%;background:var(--mango)}.brand-tag{font-family:var(--mono);font-size:10px;letter-spacing:1.8px;text-transform:uppercase;color:var(--ink-soft);padding-left:14px;border-left:1px solid var(--rule)}
.auth-screen{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{max-width:980px;width:100%;display:grid;grid-template-columns:1.05fr .95fr;gap:34px;background:var(--cream);border:1px solid var(--rule);padding:38px;box-shadow:var(--shadow)}.auth-copy{align-self:end}.auth-copy h1{font-family:var(--display);font-size:clamp(42px,6vw,74px);line-height:.95;letter-spacing:-2.5px;margin:20px 0 22px}.auth-copy p{font-size:18px;color:var(--ink-soft);max-width:560px}.auth-form{background:var(--paper);border:1px solid var(--rule);padding:26px;align-self:center}.auth-form label,.filters-card label,.form-grid label{font-family:var(--mono);font-size:10px;letter-spacing:1.3px;text-transform:uppercase;color:var(--ink-soft);display:flex;flex-direction:column;gap:8px}input,select,textarea{font:inherit;border:1px solid var(--rule);background:#fffdfa;color:var(--ink);padding:12px 13px;border-radius:2px;outline:none}textarea{min-height:105px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(242,98,87,.12)}.auth-actions{display:flex;gap:10px;margin-top:18px}.setup-note{font-size:12px;color:var(--ink-soft);line-height:1.4;margin-top:18px}
.btn{border:1px solid var(--ink);background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:1.4px;text-transform:uppercase;padding:12px 15px;border-radius:2px;cursor:pointer}.btn:hover{transform:translateY(-1px)}.btn.primary{background:var(--coral);border-color:var(--coral)}.btn.ghost{background:transparent;color:var(--ink);border-color:var(--rule)}.btn.tiny{padding:8px 10px;margin-top:12px}.btn.danger{background:#8b1e18;border-color:#8b1e18}.icon-btn{border:0;background:var(--cream);width:34px;height:34px;font-size:25px;line-height:1;cursor:pointer;color:var(--ink)}
.save-state-chip{align-self:center;border:1px solid var(--rule);background:var(--cream);color:var(--ink-soft);font-family:var(--mono);font-size:9px;letter-spacing:1.2px;text-transform:uppercase;padding:9px 11px;min-width:72px;text-align:center}.save-state-chip.saving{border-color:var(--mango);background:var(--mango-soft);color:var(--navy)}.save-state-chip.error{border-color:#ef9a92;background:#fff0ee;color:#8b1e18}.save-state-chip.saved{border-color:#aad9bf;background:#edf8f2;color:#1e6b4c}
.app-shell{min-height:100vh;display:grid;grid-template-columns:280px 1fr}.sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--rule);background:var(--cream);padding:24px;display:flex;flex-direction:column;gap:26px;z-index:10}.sidebar-brand{display:block}.sidebar-brand .brand-tag{display:block;margin-top:4px;padding-left:0;border-left:0}.side-nav{display:flex;flex-direction:column;gap:8px}.side-nav button{border:1px solid transparent;background:transparent;text-align:left;padding:13px 12px;font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-soft);cursor:pointer}.side-nav button.active,.side-nav button:hover{border-color:var(--rule);background:var(--paper);color:var(--coral)}.sidebar-card{margin-top:auto;border:1px solid var(--rule);background:var(--paper);padding:16px;word-break:break-all}.sidebar-card strong{display:block;font-size:14px;margin-top:6px}.main-panel{padding:28px 34px 60px;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;border-bottom:1px solid var(--rule);padding-bottom:22px}.topbar h1{font-family:var(--display);font-weight:500;font-size:48px;letter-spacing:-1.6px;margin:5px 0 0}.topbar-actions{display:flex;gap:10px;flex-wrap:wrap}.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:24px 0}.metric{border:1px solid var(--rule);background:var(--cream);padding:20px;position:relative}.metric::before{content:"";position:absolute;left:0;top:0;width:48px;height:3px;background:var(--coral)}.metric:nth-child(2)::before{background:var(--mango)}.metric:nth-child(3)::before{background:var(--navy)}.metric:nth-child(4)::before{background:var(--green)}.metric-value{font-family:var(--display);font-size:42px;line-height:1;font-weight:600;letter-spacing:-1.2px}.metric-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1.4px;color:var(--ink-soft);margin-top:6px}.filters-card{border:1px solid var(--rule);background:var(--paper);padding:18px;margin-bottom:20px}.filter-grid{display:grid;grid-template-columns:2fr repeat(5,1fr);gap:12px}.content-area{display:grid;gap:18px}.task-list{display:grid;gap:12px}.task-card{border:1px solid var(--rule);background:var(--paper);padding:18px;display:grid;grid-template-columns:1fr auto;gap:16px;box-shadow:0 1px 0 rgba(21,44,57,.04)}.task-card:hover{box-shadow:var(--shadow)}.task-title{font-family:var(--display);font-size:22px;font-weight:600;letter-spacing:-.4px;margin:0 0 10px}.task-meta{display:flex;gap:8px;flex-wrap:wrap}.pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--rule);background:var(--cream);padding:5px 9px;border-radius:99px;font-family:var(--mono);font-size:10px;letter-spacing:.7px;color:var(--ink-soft)}.pill.owner{background:var(--mango-soft);border-color:var(--mango);color:var(--navy)}.pill.high,.pill.urgent{background:#ffe4df;border-color:#ffb8ad;color:#9a2b21}.pill.done{background:#def3e8;border-color:#aad9bf;color:#1e6b4c}.task-actions{display:flex;align-items:start;gap:8px}.task-actions button{white-space:nowrap}.board{display:grid;grid-template-columns:repeat(4,minmax(240px,1fr));gap:14px;overflow-x:auto}.lane{border:1px solid var(--rule);background:var(--cream);padding:14px;min-height:280px}.lane h3{font-family:var(--display);font-size:22px;margin:0 0 12px}.mini-card{background:var(--paper);border:1px solid var(--rule);padding:13px;margin-bottom:10px;cursor:pointer}.mini-card b{display:block;line-height:1.2}.team-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.person-card{border:1px solid var(--rule);background:var(--paper);padding:18px}.avatar{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--navy);color:var(--paper);font-family:var(--display);font-weight:700;margin-bottom:12px}.person-card h3{font-family:var(--display);font-size:23px;margin:0}.person-card p{color:var(--ink-soft);font-size:13.5px}.progress-wrap{height:9px;background:#efe5cf;border-radius:99px;overflow:hidden;margin-top:12px}.progress-bar{height:100%;background:var(--coral);width:0}.modal{border:0;padding:0;background:transparent;width:min(920px,92vw)}.large-modal{width:min(1100px,94vw)}.modal::backdrop{background:rgba(21,44,57,.35);backdrop-filter:blur(2px)}.modal-box{background:var(--paper);border:1px solid var(--rule);padding:26px;box-shadow:var(--shadow)}.modal-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;border-bottom:1px solid var(--rule);padding-bottom:16px;margin-bottom:20px}.modal-head h2{font-family:var(--display);font-size:36px;line-height:1;margin:6px 0 0;letter-spacing:-1px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.span-2{grid-column:span 2}.modal-actions{display:grid;grid-template-columns:auto 1fr auto;gap:12px;margin-top:18px}.detail-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}.panel{border:1px solid var(--rule);background:var(--cream);padding:18px}.panel h3{font-family:var(--display);font-size:24px;margin:0 0 14px}.subtask-row,.comment-row,.attachment-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:start;border-bottom:1px dashed var(--rule);padding:10px 0}.subtask-row:last-child,.comment-row:last-child,.attachment-row:last-child{border-bottom:0}.inline-form{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:12px}.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.toast{position:fixed;right:20px;bottom:20px;z-index:100;background:var(--navy-deep);color:var(--paper);padding:13px 16px;box-shadow:var(--shadow);font-size:14px}.empty-state{border:1px dashed var(--rule);background:var(--cream);padding:34px;text-align:center;color:var(--ink-soft)}
@media(max-width:1080px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.side-nav{display:grid;grid-template-columns:repeat(3,1fr)}.metrics-grid,.team-grid{grid-template-columns:repeat(2,1fr)}.filter-grid{grid-template-columns:1fr 1fr}.detail-grid{grid-template-columns:1fr}.auth-card{grid-template-columns:1fr}.sidebar-card{margin-top:0}}
@media(max-width:640px){.main-panel{padding:20px}.topbar{align-items:flex-start;flex-direction:column}.topbar h1{font-size:38px}.metrics-grid,.team-grid,.filter-grid,.form-grid{grid-template-columns:1fr}.span-2{grid-column:auto}.task-card{grid-template-columns:1fr}.side-nav{grid-template-columns:1fr 1fr}.auth-card{padding:24px}.auth-actions,.topbar-actions{width:100%;display:grid;grid-template-columns:1fr}.btn{width:100%}}
@media print{.sidebar,.topbar-actions,.filters-card,.task-actions,.btn,.icon-btn{display:none!important}.app-shell{display:block}.main-panel{padding:0}.task-card,.panel,.metric{break-inside:avoid}body{background:#fff}body::before{display:none}}

/* ===================================================== TABLE VIEW */
.table-toolbar{border:1px solid var(--rule);background:var(--cream);padding:18px;margin-bottom:14px;display:flex;align-items:flex-end;justify-content:space-between;gap:18px}
.table-toolbar h2{font-family:var(--display);font-size:32px;line-height:1;margin:5px 0 0;letter-spacing:-.8px}
.sort-wrap{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.sort-chip{border:1px solid var(--rule);background:var(--paper);color:var(--ink-soft);font-family:var(--mono);font-size:10px;letter-spacing:1.1px;text-transform:uppercase;padding:9px 10px;cursor:pointer;border-radius:99px}
.sort-chip.active,.sort-chip:hover{border-color:var(--coral);color:var(--coral);background:#fffdfa}
.grouped-table-wrap{display:grid;gap:18px}
.status-group{border:1px solid var(--rule);background:var(--paper);box-shadow:0 1px 0 rgba(21,44,57,.04)}
.group-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--rule);background:var(--cream)}
.group-head h3{font-family:var(--display);font-size:24px;line-height:1;margin:0;letter-spacing:-.5px}.group-head b{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-soft);border:1px solid var(--rule);background:var(--paper);padding:4px 9px;border-radius:99px}
.status-dot{width:10px;height:10px;border-radius:50%;background:var(--ink-soft);display:inline-block}.status-dot.not_started{background:#9aa3ad}.status-dot.in_progress{background:var(--coral)}.status-dot.waiting{background:var(--mango)}.status-dot.blocked{background:#8b1e18}.status-dot.done{background:var(--green)}.status-dot.cancelled{background:#676767}
.table-scroll{overflow-x:auto}.task-table{width:100%;min-width:1120px;border-collapse:collapse;font-size:13.5px}.task-table th{text-align:left;font-family:var(--mono);font-size:10px;letter-spacing:1.4px;text-transform:uppercase;color:var(--ink-soft);font-weight:500;padding:12px 12px;border-bottom:1px solid var(--rule);background:#fffdfa;position:sticky;top:0}.task-table td{padding:12px;border-bottom:1px solid var(--rule);vertical-align:top}.task-table tbody tr:hover{background:var(--cream)}.task-table tbody tr:last-child td{border-bottom:0}.task-col{width:320px}.row-title{border:0;background:transparent;padding:0;text-align:left;font-family:var(--display);font-size:17px;font-weight:600;letter-spacing:-.2px;color:var(--ink);cursor:pointer}.row-title:hover{color:var(--coral)}.task-col small{display:block;color:var(--ink-soft);font-size:12px;line-height:1.35;margin-top:5px}.person-pill{display:inline-flex;border:1px solid var(--mango);background:var(--mango-soft);color:var(--navy);border-radius:99px;padding:4px 9px;font-family:var(--mono);font-size:10px;letter-spacing:.5px;white-space:nowrap}.person-pill.muted{background:var(--cream);border-color:var(--rule);color:var(--ink-soft)}.date-pill{display:inline-flex;border:1px solid var(--rule);background:var(--cream);border-radius:99px;padding:4px 9px;font-family:var(--mono);font-size:10px;white-space:nowrap}.date-pill.overdue{border-color:#ffb8ad;background:#ffe4df;color:#9a2b21}.inline-select{font-family:var(--mono);font-size:10px;letter-spacing:.5px;padding:6px 8px;min-width:112px}.inline-select.priority-select.urgent,.inline-select.priority-select.high{background:#ffe4df;border-color:#ffb8ad;color:#9a2b21}.inline-select.priority-select.medium{background:var(--mango-soft);border-color:var(--mango);color:var(--navy)}.inline-select.status-select.done{background:#def3e8;border-color:#aad9bf;color:#1e6b4c}.inline-select.status-select.blocked{background:#ffe4df;border-color:#ffb8ad;color:#9a2b21}.row-actions{display:flex;gap:6px;white-space:nowrap}.row-actions .btn{padding:8px 9px}
.member-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;border:1px solid var(--rule);background:var(--cream);padding:12px}.member-tab{border:1px solid var(--rule);background:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:1.1px;text-transform:uppercase;padding:9px 11px;border-radius:99px;cursor:pointer;color:var(--ink-soft)}.member-tab.active,.member-tab:hover{background:var(--coral);border-color:var(--coral);color:var(--paper)}
@media(max-width:760px){.table-toolbar{align-items:flex-start;flex-direction:column}.sort-wrap{justify-content:flex-start}.task-table{min-width:980px}.table-scroll{margin-left:-20px;margin-right:-20px;padding-left:20px}.member-tabs{overflow-x:auto;flex-wrap:nowrap}.member-tab{white-space:nowrap}.side-nav{grid-template-columns:1fr 1fr!important}}

/* ===================================================== SIDEBAR COLLAPSE + PROPER SPREADSHEET TABLE OVERRIDES */
.sidebar-toggle{
  position:absolute;right:16px;top:16px;width:34px;height:34px;
  border:1px solid var(--rule);background:var(--paper);color:var(--ink);
  font-family:var(--mono);font-size:14px;cursor:pointer;border-radius:2px;z-index:12;
}
.sidebar-toggle:hover{border-color:var(--coral);color:var(--coral)}
body.sidebar-collapsed .app-shell{grid-template-columns:76px 1fr}
body.sidebar-collapsed .sidebar{padding:18px 12px;align-items:center;gap:20px}
body.sidebar-collapsed .sidebar-brand .brand-mark{font-size:24px;writing-mode:vertical-rl;letter-spacing:-.8px;line-height:1}
body.sidebar-collapsed .sidebar-brand .brand-mark::after{display:none}
body.sidebar-collapsed .sidebar-brand .brand-tag,
body.sidebar-collapsed .side-nav button,
body.sidebar-collapsed .sidebar-card{font-size:0;color:transparent;letter-spacing:0;padding:0;border:0;background:transparent;overflow:hidden}
body.sidebar-collapsed .side-nav{gap:10px;width:100%;align-items:center}
body.sidebar-collapsed .side-nav button{width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--rule);background:var(--paper)}
body.sidebar-collapsed .side-nav button::before{font-size:11px;color:var(--ink-soft);font-family:var(--mono);letter-spacing:0}
body.sidebar-collapsed .side-nav button[data-view="dashboard"]::before{content:'DB'}
body.sidebar-collapsed .side-nav button[data-view="tasks"]::before{content:'AT'}
body.sidebar-collapsed .side-nav button[data-view="table"]::before{content:'TV'}
body.sidebar-collapsed .side-nav button[data-view="teamTable"]::before{content:'TT'}
body.sidebar-collapsed .side-nav button[data-view="today"]::before{content:'TD'}
body.sidebar-collapsed .side-nav button[data-view="mine"]::before{content:'MY'}
body.sidebar-collapsed .side-nav button[data-view="team"]::before{content:'TM'}
body.sidebar-collapsed .side-nav button[data-view="catalogue"]::before{content:'CT'}
body.sidebar-collapsed .side-nav button.active::before,
body.sidebar-collapsed .side-nav button:hover::before{color:var(--coral)}
body.sidebar-collapsed .sidebar-toggle{right:50%;transform:translateX(50%)}

.table-help{
  border:1px dashed var(--rule);background:var(--cream);color:var(--ink-soft);
  padding:10px 14px;margin:-4px 0 14px;font-size:13px;
}
.table-scroll{
  width:100%;overflow:auto;max-width:100%;
  border-top:0;
}
.task-table.spreadsheet-table{
  width:100%;min-width:1440px;table-layout:fixed;border-collapse:separate;border-spacing:0;
  background:var(--paper);font-size:13px;
}
.spreadsheet-table col.col-check{width:44px}
.spreadsheet-table col.col-task{width:360px}
.spreadsheet-table col.col-owner{width:118px}
.spreadsheet-table col.col-assigned{width:128px}
.spreadsheet-table col.col-due{width:100px}
.spreadsheet-table col.col-priority{width:140px}
.spreadsheet-table col.col-status{width:150px}
.spreadsheet-table col.col-category{width:150px}
.spreadsheet-table col.col-small{width:80px}
.spreadsheet-table col.col-actions{width:132px}
.task-table.spreadsheet-table th,
.task-table.spreadsheet-table td{
  padding:10px 12px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  vertical-align:middle;background:rgba(255,252,244,.92);
}
.task-table.spreadsheet-table th:last-child,
.task-table.spreadsheet-table td:last-child{border-right:0}
.task-table.spreadsheet-table th{
  position:sticky;top:0;z-index:3;background:#fff9ea;color:var(--ink-soft);
  box-shadow:0 1px 0 var(--rule);height:46px;
}
.task-table.spreadsheet-table .check-col{text-align:center;padding-left:8px;padding-right:8px}
.task-table.spreadsheet-table tbody tr{height:62px}
.task-table.spreadsheet-table tbody tr:nth-child(even) td{background:rgba(250,246,236,.54)}
.task-table.spreadsheet-table tbody tr:hover td{background:#fff3d7}
.th-sort{
  border:0;background:transparent;padding:0;margin:0;color:inherit;cursor:pointer;
  font-family:var(--mono);font-size:10px;letter-spacing:1.4px;text-transform:uppercase;text-align:left;
}
.th-sort:hover{color:var(--coral)}
.task-table.spreadsheet-table .row-title{
  display:block;width:100%;font-size:15.5px;line-height:1.15;white-space:normal;
}
.task-table.spreadsheet-table .task-col small{
  font-size:11.5px;line-height:1.25;margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.category-cell{display:block;line-height:1.25;color:var(--ink)}
.num-cell{text-align:center;font-family:var(--mono);font-size:12px;color:var(--ink)}
.task-table.spreadsheet-table .inline-select{width:100%;min-width:0;padding:8px 8px}
.task-table.spreadsheet-table .row-actions{display:flex;gap:6px;align-items:center;justify-content:flex-start}
.task-table.spreadsheet-table .row-actions .btn{width:auto;padding:8px 9px}

@media(max-width:1080px){
  body.sidebar-collapsed .app-shell{grid-template-columns:1fr}
  body.sidebar-collapsed .sidebar{align-items:stretch}
  body.sidebar-collapsed .sidebar-brand .brand-mark{writing-mode:initial;font-size:34px}
  body.sidebar-collapsed .sidebar-brand .brand-tag{display:block;font-size:10px;color:var(--ink-soft);letter-spacing:1.8px;padding-left:0;border-left:0;background:transparent;overflow:visible}
  body.sidebar-collapsed .side-nav button{width:auto;height:auto;font-size:10px;color:var(--ink-soft);letter-spacing:1.5px;padding:13px 12px;border:1px solid transparent;background:transparent;display:block}
  body.sidebar-collapsed .side-nav button::before{display:none}
  body.sidebar-collapsed .sidebar-card{font-size:initial;color:var(--ink);letter-spacing:normal;padding:16px;border:1px solid var(--rule);background:var(--paper);overflow:visible}
}

/* ===================================================== V3: VIEWPORT-FIT TABLES + INTERNAL SCROLL */
html, body { width:100%; max-width:100%; height:100%; overflow:hidden; }
.app-shell{
  height:100vh;
  max-width:100vw;
  overflow:hidden;
  grid-template-columns:minmax(76px, 280px) minmax(0,1fr);
}
.sidebar{height:100vh;overflow:hidden;min-width:0;}
.main-panel{
  height:100vh;
  min-width:0;
  max-width:100%;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  padding-bottom:22px;
}
.topbar,.metrics-grid,.filters-card{flex:0 0 auto;}
.metrics-grid{margin:16px 0;}
.filters-card{margin-bottom:12px;}
.content-area{
  flex:1 1 auto;
  min-height:0;
  max-width:100%;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.table-toolbar{
  flex:0 0 auto;
  margin-bottom:8px;
  padding:13px 16px;
  max-width:100%;
}
.table-toolbar h2{font-size:28px;}
.sort-wrap{gap:6px;}
.sort-chip{padding:7px 9px;font-size:9px;}
.table-help{flex:0 0 auto;margin:0 0 8px;padding:8px 12px;}
.grouped-table-wrap{
  flex:1 1 auto;
  min-height:0;
  max-width:100%;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.status-group{
  flex:1 1 0;
  min-height:96px;
  max-width:100%;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.status-group.collapsed{flex:0 0 auto;min-height:0;}
.status-group.collapsed .table-scroll{display:none;}
.group-head{
  width:100%;
  border:0;
  border-bottom:1px solid var(--rule);
  cursor:pointer;
  text-align:left;
  flex:0 0 auto;
}
.group-head:hover{background:#fff3d7;}
.group-head .chev{font-family:var(--mono);font-size:14px;color:var(--ink-soft);width:16px;text-align:center;}
.table-scroll{
  flex:1 1 auto;
  min-height:0;
  width:100%;
  max-width:100%;
  overflow-y:auto;
  overflow-x:hidden;
  overscroll-behavior:contain;
}
.task-table.spreadsheet-table{
  width:100%;
  min-width:0!important;
  max-width:100%;
  table-layout:fixed;
  font-size:12px;
}
.spreadsheet-table col.col-check{width:32px!important}
.spreadsheet-table col.col-task{width:25%!important}
.spreadsheet-table col.col-owner{width:7.5%!important}
.spreadsheet-table col.col-assigned{width:8%!important}
.spreadsheet-table col.col-due{width:7%!important}
.spreadsheet-table col.col-priority{width:8.5%!important}
.spreadsheet-table col.col-status{width:9%!important}
.spreadsheet-table col.col-category{width:10%!important}
.spreadsheet-table col.col-small{width:4.5%!important}
.spreadsheet-table col.col-actions{width:9%!important}
.task-table.spreadsheet-table th,
.task-table.spreadsheet-table td{
  padding:7px 8px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:normal;
}
.task-table.spreadsheet-table th{height:38px;}
.task-table.spreadsheet-table tbody tr{height:54px;}
.task-table.spreadsheet-table .row-title{font-size:13.5px;line-height:1.12;}
.task-table.spreadsheet-table .task-col small{font-size:10.5px;-webkit-line-clamp:1;}
.person-pill,.person-pill.muted,.date-pill{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:3px 6px;font-size:9px;}
.task-table.spreadsheet-table .inline-select{font-size:9px;padding:6px 4px;}
.category-cell{font-size:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.num-cell{font-size:11px;}
.task-table.spreadsheet-table .row-actions{gap:4px;}
.task-table.spreadsheet-table .row-actions .btn{padding:6px 6px;font-size:9px;}
.th-sort{font-size:9px;line-height:1.1;}

/* Non-table areas scroll inside content only */
.board,.task-list,.team-grid{max-width:100%;overflow:auto;min-height:0;}

@media(max-width:1080px){
  html,body{overflow:auto;height:auto;}
  .app-shell{height:auto;min-height:100vh;overflow:visible;display:block;}
  .sidebar{height:auto;overflow:visible;}
  .main-panel{height:auto;min-height:100vh;overflow:visible;display:block;}
  .content-area{overflow:visible;display:block;}
  .grouped-table-wrap{max-height:70vh;overflow-y:auto;display:block;}
  .status-group{margin-bottom:10px;display:block;}
  .table-scroll{max-height:48vh;overflow-y:auto;overflow-x:hidden;display:block;}
  .task-table.spreadsheet-table{font-size:11px;}
  .spreadsheet-table col.col-check{width:28px!important}
  .spreadsheet-table col.col-task{width:27%!important}
  .spreadsheet-table col.col-owner{width:8%!important}
  .spreadsheet-table col.col-assigned{width:8%!important}
  .spreadsheet-table col.col-due{width:7%!important}
  .spreadsheet-table col.col-priority{width:8%!important}
  .spreadsheet-table col.col-status{width:9%!important}
  .spreadsheet-table col.col-category{width:10%!important}
  .spreadsheet-table col.col-small{width:4%!important}
  .spreadsheet-table col.col-actions{width:7%!important}
}
@media(max-width:760px){
  .main-panel{padding:16px;}
  .table-toolbar,.sort-wrap{width:100%;}
  .sort-wrap{justify-content:flex-start;}
  .table-scroll{margin-left:0!important;margin-right:0!important;padding-left:0!important;}
  .task-table.spreadsheet-table th,.task-table.spreadsheet-table td{padding:6px 4px;font-size:10px;}
  .task-table.spreadsheet-table .row-title{font-size:11px;}
  .task-table.spreadsheet-table .task-col small{display:none;}
  .person-pill,.date-pill,.inline-select{font-size:8px!important;padding:4px 2px!important;}
  .task-table.spreadsheet-table .row-actions{flex-direction:column;align-items:stretch;}
  .task-table.spreadsheet-table .row-actions .btn{font-size:8px;padding:5px 3px;}
  .th-sort{font-size:8px;letter-spacing:.7px;}
}

/* =====================================================
   V4 TABLE FIX: page can scroll, each expanded status table shows up to 15 rows
   ===================================================== */
html, body{
  height:auto!important;
  min-height:100vh!important;
  overflow-x:hidden!important;
  overflow-y:auto!important;
}
.app-shell{
  min-height:100vh!important;
  height:auto!important;
  max-width:100vw!important;
  overflow:visible!important;
}
.sidebar{
  position:sticky!important;
  top:0!important;
  height:100vh!important;
  overflow:hidden!important;
}
.main-panel{
  height:auto!important;
  min-height:100vh!important;
  overflow:visible!important;
  max-width:100%!important;
}
.content-area{
  height:auto!important;
  min-height:0!important;
  overflow:visible!important;
  display:block!important;
}
.table-toolbar,
.table-help{
  max-width:100%!important;
}
.grouped-table-wrap{
  display:block!important;
  max-width:100%!important;
  height:auto!important;
  max-height:none!important;
  overflow:visible!important;
}
.status-group{
  display:flex!important;
  flex-direction:column!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  overflow:hidden!important;
  margin-bottom:16px!important;
}
.status-group.collapsed .table-scroll{display:none!important;}
.table-scroll{
  width:100%!important;
  max-width:100%!important;
  height:auto!important;
  /* header row + 15 task rows. The table scrolls only after 15 visible rows. */
  max-height:870px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  display:block!important;
}
.task-table.spreadsheet-table{
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  table-layout:fixed!important;
}
.task-table.spreadsheet-table th{
  position:sticky!important;
  top:0!important;
  z-index:2!important;
}
.task-table.spreadsheet-table tbody tr{
  min-height:54px!important;
}
.task-table.spreadsheet-table .row-title{
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
  overflow:hidden!important;
}

@media(max-width:1080px){
  .sidebar{position:relative!important;height:auto!important;}
  .table-scroll{max-height:720px!important;overflow-x:auto!important;}
  .task-table.spreadsheet-table{min-width:980px!important;}
}

/* ===================================================== V5 CHILD TASKS + STICKY SIDEBAR FIXES */
.app-shell{align-items:start!important;}
.sidebar{
  position:sticky!important;
  top:0!important;
  align-self:start!important;
  height:100vh!important;
  max-height:100vh!important;
  overflow:hidden!important;
}
.main-panel{min-width:0!important;}
.expand-row-btn{
  width:26px;height:26px;border:1px solid var(--rule);background:var(--paper);color:var(--ink-soft);
  display:inline-grid;place-items:center;font-family:var(--mono);font-size:15px;line-height:1;cursor:pointer;border-radius:2px;
}
.expand-row-btn:hover,.expand-row-btn.has-child{border-color:var(--coral);color:var(--coral);background:#fffdfa;}
.parent-task-row.is-expanded td{background:#fff6df!important;}
.subtask-row-table td{
  background:#fffaf0!important;
  border-bottom:1px dashed var(--rule)!important;
  font-size:12.5px!important;
}
.subtask-row-table:hover td{background:#fff0cf!important;}
.child-task-cell{position:relative;padding-left:28px!important;}
.child-connector{
  position:absolute;left:10px;top:18px;width:12px;height:18px;border-left:1px solid var(--coral);border-bottom:1px solid var(--coral);opacity:.7;
}
.child-title{font-size:14px!important;font-family:var(--body)!important;font-weight:700!important;letter-spacing:0!important;}
.empty-child td{color:var(--ink-soft);font-size:12px!important;font-style:italic;}
.mini-select,.mini-date{
  width:100%;min-width:0;border:1px solid var(--rule);background:var(--paper);padding:7px 6px;
  font-family:var(--mono);font-size:10px;letter-spacing:.3px;color:var(--ink);
}
.subtask-form-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px;border-top:1px dashed var(--rule);padding-top:14px;
}
.subtask-form-grid label{font-family:var(--mono);font-size:10px;letter-spacing:1.1px;text-transform:uppercase;color:var(--ink-soft);}
.subtask-form-grid input,.subtask-form-grid select,.subtask-form-grid textarea{margin-top:6px;}
.subtask-form-grid textarea{min-height:78px;resize:vertical;}
.subtask-detail-list{max-height:360px;overflow:auto;padding-right:4px;}
.table-scroll{
  max-height:980px!important; /* header + about 15 parent rows before table-specific scroll */
}
.task-table.spreadsheet-table{
  min-width:0!important;
  width:100%!important;
}
.spreadsheet-table col.col-check{width:42px!important}
.spreadsheet-table col.col-task{width:30%!important}
.spreadsheet-table col.col-owner{width:9%!important}
.spreadsheet-table col.col-assigned{width:9%!important}
.spreadsheet-table col.col-due{width:8%!important}
.spreadsheet-table col.col-priority{width:10%!important}
.spreadsheet-table col.col-status{width:10%!important}
.spreadsheet-table col.col-category{width:10%!important}
.spreadsheet-table col.col-small{width:5%!important}
.spreadsheet-table col.col-actions{width:10%!important}

@media(max-width:1080px){
  .sidebar{position:sticky!important;top:0!important;height:100vh!important;}
  .subtask-form-grid{grid-template-columns:1fr;}
  .subtask-form-grid .span-2{grid-column:span 1;}
  .table-scroll{overflow-x:auto!important;}
  .task-table.spreadsheet-table{min-width:1120px!important;}
}

/* ===================================================== V6 FIXES: fixed sidebar + organised task/detail modal */
@media (min-width:1081px){
  .app-shell{
    display:block!important;
    padding-left:280px!important;
    min-height:100vh!important;
    max-width:100vw!important;
    overflow:visible!important;
  }
  .sidebar{
    position:fixed!important;
    left:0!important;
    top:0!important;
    bottom:0!important;
    width:280px!important;
    height:100vh!important;
    max-height:100vh!important;
    overflow:hidden!important;
    z-index:80!important;
  }
  .main-panel{
    width:100%!important;
    min-height:100vh!important;
    height:auto!important;
    overflow:visible!important;
  }
  body.sidebar-collapsed .app-shell{
    display:block!important;
    padding-left:76px!important;
    grid-template-columns:none!important;
  }
  body.sidebar-collapsed .sidebar{
    width:76px!important;
    min-width:76px!important;
    padding:18px 12px!important;
    align-items:center!important;
  }
}

/* Detail modal: make form readable and prevent controls from overlapping */
.large-modal{width:min(1220px,94vw)!important;max-height:92vh!important;overflow:hidden!important;}
.large-modal .modal-box{max-height:92vh!important;overflow:auto!important;padding:28px!important;}
.detail-grid{
  display:grid!important;
  grid-template-columns:minmax(0,1.25fr) minmax(340px,.75fr)!important;
  gap:18px!important;
  align-items:start!important;
}
.detail-grid > div{min-width:0!important;}
.panel{overflow:hidden!important;}
.status-grid{display:grid!important;grid-template-columns:minmax(0,1fr) auto!important;gap:10px!important;align-items:stretch!important;}
.status-grid select{width:100%!important;min-width:0!important;}
.status-grid .btn{min-width:190px!important;}

.subtask-form-grid{
  display:grid!important;
  grid-template-columns:repeat(12,minmax(0,1fr))!important;
  gap:12px!important;
  margin-top:16px!important;
  border-top:1px dashed var(--rule)!important;
  padding-top:16px!important;
}
.subtask-form-grid label{
  display:flex!important;
  flex-direction:column!important;
  gap:7px!important;
  min-width:0!important;
  font-family:var(--mono)!important;
  font-size:10px!important;
  letter-spacing:1.15px!important;
  line-height:1.2!important;
  text-transform:uppercase!important;
  color:var(--ink-soft)!important;
}
.subtask-form-grid input,
.subtask-form-grid select,
.subtask-form-grid textarea{
  width:100%!important;
  min-width:0!important;
  margin-top:0!important;
  font-family:var(--body)!important;
  font-size:14px!important;
  letter-spacing:0!important;
}
.subtask-form-grid label:nth-child(1){grid-column:span 12!important;}
.subtask-form-grid label:nth-child(2),
.subtask-form-grid label:nth-child(3){grid-column:span 6!important;}
.subtask-form-grid label:nth-child(4),
.subtask-form-grid label:nth-child(5),
.subtask-form-grid label:nth-child(6),
.subtask-form-grid label:nth-child(7){grid-column:span 3!important;}
.subtask-form-grid label.span-2{grid-column:span 12!important;}
.subtask-form-grid .btn.span-2{grid-column:span 12!important;width:100%!important;}
.subtask-form-grid textarea{min-height:96px!important;resize:vertical!important;}
.subtask-detail-list{max-height:300px!important;overflow:auto!important;padding-right:4px!important;border:1px dashed var(--rule);background:var(--paper);padding:12px!important;}
.subtask-row{grid-template-columns:auto minmax(0,1fr) auto!important;gap:12px!important;align-items:flex-start!important;}
.subtask-row b{display:block;margin-bottom:6px;line-height:1.25;}

/* Right side panels should feel like stacked cards inside modal */
.detail-grid .panel + .panel{margin-top:16px!important;}
.inline-form{display:grid!important;grid-template-columns:minmax(0,1fr) auto!important;gap:8px!important;}
.inline-form input{width:100%!important;min-width:0!important;}
#attachmentInput{width:100%!important;max-width:100%!important;background:var(--paper)!important;}

@media(max-width:1080px){
  .large-modal{width:min(94vw,760px)!important;}
  .large-modal .modal-box{max-height:90vh!important;padding:20px!important;}
  .detail-grid{grid-template-columns:1fr!important;}
  .subtask-form-grid{grid-template-columns:1fr!important;}
  .subtask-form-grid label,
  .subtask-form-grid label:nth-child(1),
  .subtask-form-grid label:nth-child(2),
  .subtask-form-grid label:nth-child(3),
  .subtask-form-grid label:nth-child(4),
  .subtask-form-grid label:nth-child(5),
  .subtask-form-grid label:nth-child(6),
  .subtask-form-grid label:nth-child(7),
  .subtask-form-grid label.span-2,
  .subtask-form-grid .btn.span-2{grid-column:1/-1!important;}
  .status-grid{grid-template-columns:1fr!important;}
  .status-grid .btn{min-width:0!important;width:100%!important;}
}

/* =====================================================
   V7 THEME OVERRIDE: White workspace + dark grey sidebar
   ===================================================== */
:root{
  --main-bg:#FFFFFF;
  --sidebar-bg:#2F3237;
  --sidebar-bg-deep:#26292E;
  --sidebar-border:#444850;
  --sidebar-text:#F7F4EA;
  --sidebar-muted:#B9BEC6;
}

html, body{
  background:var(--main-bg) !important;
}

body::before{
  display:none !important;
}

.app-shell,
.main-panel,
.content-area,
.view-wrap,
#app{
  background:var(--main-bg) !important;
}

.sidebar{
  background:var(--sidebar-bg) !important;
  border-right:1px solid var(--sidebar-border) !important;
  color:var(--sidebar-text) !important;
  box-shadow:12px 0 28px -28px rgba(0,0,0,.55);
}

.sidebar .brand-mark,
.sidebar .brand-tag,
.sidebar-card,
.sidebar-card strong{
  color:var(--sidebar-text) !important;
}

.sidebar .brand-mark::after{
  background:var(--mango) !important;
}

.sidebar .brand-tag,
.sidebar-card .mini-label,
.sidebar-card small,
.sidebar-card span{
  color:var(--sidebar-muted) !important;
}

.side-nav button{
  color:var(--sidebar-muted) !important;
  border-color:transparent !important;
  background:transparent !important;
}

.side-nav button.active,
.side-nav button:hover{
  background:var(--sidebar-bg-deep) !important;
  border-color:var(--sidebar-border) !important;
  color:#FFFFFF !important;
}

.side-nav button.active{
  box-shadow:inset 3px 0 0 var(--coral);
}

.sidebar-card{
  background:var(--sidebar-bg-deep) !important;
  border-color:var(--sidebar-border) !important;
}

.sidebar .btn,
.sidebar-card .btn{
  background:#111318 !important;
  border-color:#111318 !important;
  color:#FFFFFF !important;
}

.sidebar-toggle{
  background:var(--sidebar-bg-deep) !important;
  border-color:var(--sidebar-border) !important;
  color:var(--sidebar-text) !important;
}

.sidebar-toggle:hover{
  border-color:var(--coral) !important;
  color:#FFFFFF !important;
}

body.sidebar-collapsed .side-nav button{
  background:var(--sidebar-bg-deep) !important;
  border-color:var(--sidebar-border) !important;
}

body.sidebar-collapsed .side-nav button::before{
  color:var(--sidebar-muted) !important;
}

body.sidebar-collapsed .side-nav button.active::before,
body.sidebar-collapsed .side-nav button:hover::before{
  color:#FFFFFF !important;
}

/* keep work surfaces readable on white background */
.filters-card,
.table-toolbar,
.status-group,
.metric,
.panel,
.task-card,
.person-card,
.lane,
.auth-card,
.auth-form,
.modal-box{
  box-shadow:0 1px 0 rgba(21,44,57,.04);
}

/* =====================================================
   V8 THEME/PANEL OVERRIDES: clean white workspace + slimmer sidebar
   ===================================================== */
:root{
  --paper:#FFFFFF;
  --cream:#F8F8F6;
  --rule:#E3E0D8;
  --main-bg:#FFFFFF;
  --soft-surface:#FAFAF8;
  --soft-surface-2:#F5F5F2;
}

body,
.app-shell,
.main-panel,
.content-area,
.view-wrap,
#app{
  background:#FFFFFF !important;
}

/* Replace the warm yellow/beige surfaces with neutral white shades */
.metric,
.filters-card,
.table-toolbar,
.status-group,
.group-head,
.table-help,
.task-card,
.person-card,
.panel,
.lane,
.mini-card,
.auth-card,
.auth-form,
.modal-box{
  background:#FFFFFF !important;
}

.metric,
.filters-card,
.table-toolbar,
.status-group,
.task-card,
.person-card,
.panel,
.lane,
.auth-card,
.auth-form,
.modal-box{
  border-color:var(--rule) !important;
}

.table-help,
.empty-state,
.progress-wrap,
.pill:not(.owner):not(.high):not(.urgent):not(.done),
.date-pill,
.member-tabs{
  background:var(--soft-surface) !important;
}

.group-head:hover,
.task-table.spreadsheet-table tbody tr:hover td{
  background:var(--soft-surface-2) !important;
}

.task-table.spreadsheet-table,
.task-table.spreadsheet-table td{
  background:#FFFFFF !important;
}

.task-table.spreadsheet-table th{
  background:var(--soft-surface) !important;
}

.task-table.spreadsheet-table tbody tr:nth-child(even) td{
  background:#FBFBFA !important;
}

/* Slimmer fixed sidebar */
@media (min-width:1081px){
  .app-shell{
    padding-left:220px !important;
  }
  .sidebar{
    width:220px !important;
    min-width:220px !important;
    padding:20px 16px !important;
    gap:20px !important;
  }
  .sidebar .brand-mark{
    font-size:30px !important;
    line-height:1 !important;
    letter-spacing:-1.3px !important;
  }
  .sidebar .brand-tag{
    font-size:9px !important;
    letter-spacing:1.5px !important;
  }
  .side-nav{
    gap:6px !important;
  }
  .side-nav button{
    padding:11px 10px !important;
    font-size:9.5px !important;
    letter-spacing:1.25px !important;
  }
  .sidebar-card{
    padding:12px !important;
  }

  body.sidebar-collapsed .app-shell{
    padding-left:72px !important;
  }
  body.sidebar-collapsed .sidebar{
    width:72px !important;
    min-width:72px !important;
    padding:16px 10px !important;
  }

  /* Keep Orbiz branding visible in collapsed sidebar */
  body.sidebar-collapsed .sidebar-brand{
    width:52px !important;
    min-height:34px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    overflow:visible !important;
    margin-top:36px !important;
  }
  body.sidebar-collapsed .sidebar-brand .brand-mark{
    writing-mode:initial !important;
    transform:none !important;
    font-size:21px !important;
    line-height:1 !important;
    letter-spacing:-1px !important;
    white-space:nowrap !important;
    color:#FFFFFF !important;
    display:block !important;
    max-width:none !important;
    overflow:visible !important;
  }
  body.sidebar-collapsed .sidebar-brand .brand-mark::after{
    display:block !important;
    width:6px !important;
    height:6px !important;
    right:-8px !important;
    top:0 !important;
  }
  body.sidebar-collapsed .sidebar-brand .brand-tag{
    display:none !important;
  }
  body.sidebar-collapsed .sidebar-toggle{
    top:16px !important;
  }
  body.sidebar-collapsed .side-nav button{
    width:42px !important;
    height:42px !important;
    padding:0 !important;
  }
}

/* Better mobile/tablet behavior: keep full sidebar style there */
@media (max-width:1080px){
  .sidebar{
    background:var(--sidebar-bg) !important;
  }
  body.sidebar-collapsed .sidebar-brand .brand-mark{
    writing-mode:initial !important;
    transform:none !important;
  }
}

/* =====================================================
   V9 THEME POLISH: cooler white surfaces + colored status pills
   ===================================================== */
:root{
  --paper:#FFFFFF;
  --cream:#FCFCFE;
  --rule:#E5E7EE;
  --soft-surface:#FAFBFD;
  --soft-surface-2:#F4F6FA;
  --sidebar-bg:#2C3036;
  --sidebar-bg-deep:#23272D;
  --sidebar-border:#3A3F47;
}

html,body,
.app-shell,
.main-panel,
.content-area,
.view-wrap,
#app{
  background:#FFFFFF !important;
}

/* Cooler white cards/tables instead of warm beige */
.metric,
.filters-card,
.table-toolbar,
.status-group,
.group-head,
.table-help,
.task-card,
.person-card,
.panel,
.lane,
.mini-card,
.auth-card,
.auth-form,
.modal-box,
.sidebar-toggle,
.empty-state,
.progress-wrap,
.task-table.spreadsheet-table,
.task-table.spreadsheet-table td,
.task-table.spreadsheet-table tbody tr td,
.task-table,
.task-table td,
.task-table tbody tr td{
  background:#FFFFFF !important;
}

.task-table.spreadsheet-table th,
.task-table th,
.group-head,
.table-help,
.filters-card select,
.filters-card input{
  background:var(--soft-surface) !important;
}

.task-table.spreadsheet-table tbody tr:nth-child(even) td,
.task-table tbody tr:nth-child(even) td,
.board .lane,
.progress-wrap,
.empty-state,
.date-pill,
.person-pill.muted,
.pill:not(.owner):not(.urgent):not(.high):not(.medium):not(.done):not(.not_started):not(.in_progress):not(.waiting):not(.blocked):not(.cancelled){
  background:var(--soft-surface) !important;
}

.task-table.spreadsheet-table tbody tr:hover td,
.task-table tbody tr:hover td,
.group-head:hover,
.mini-card:hover,
.task-card:hover{
  background:var(--soft-surface-2) !important;
}

.metric,
.filters-card,
.table-toolbar,
.status-group,
.table-help,
.task-card,
.person-card,
.panel,
.lane,
.mini-card,
.auth-card,
.auth-form,
.modal-box,
.task-table.spreadsheet-table,
.task-table,
.group-head{
  border-color:var(--rule) !important;
  box-shadow:none !important;
}

/* Slightly narrower desktop sidebar */
@media (min-width:1081px){
  .app-shell{padding-left:196px !important;grid-template-columns:196px 1fr !important;}
  .sidebar{width:196px !important;min-width:196px !important;padding:18px 14px !important;}
  .main-panel{padding:28px 26px 56px !important;}
  body.sidebar-collapsed .app-shell{padding-left:74px !important;grid-template-columns:74px 1fr !important;}
  body.sidebar-collapsed .sidebar{width:74px !important;min-width:74px !important;}
}

/* Stronger dark sidebar consistency */
.sidebar{background:var(--sidebar-bg) !important;border-right:1px solid var(--sidebar-border) !important;}
.sidebar-card,
.side-nav button.active,
.side-nav button:hover,
body.sidebar-collapsed .side-nav button,
.sidebar-toggle{background:var(--sidebar-bg-deep) !important;}

/* Status pills across cards/details */
.pill.not_started{background:#EEF2F7 !important;border-color:#CBD5E1 !important;color:#475569 !important;}
.pill.in_progress{background:#FFE8E1 !important;border-color:#F8B9A9 !important;color:#B54708 !important;}
.pill.waiting{background:#FFF4D6 !important;border-color:#F6D98A !important;color:#9A6700 !important;}
.pill.blocked{background:#FEE2E2 !important;border-color:#FCA5A5 !important;color:#B42318 !important;}
.pill.done{background:#DDF8E7 !important;border-color:#9DDBB1 !important;color:#166534 !important;}
.pill.cancelled{background:#F3F4F6 !important;border-color:#D1D5DB !important;color:#6B7280 !important;}
.pill.medium{background:#FFF7D6 !important;border-color:#E8D48B !important;color:#8A6D1F !important;}

/* Table status + priority controls as colored pills */
.inline-select{
  border-radius:999px !important;
  font-weight:500;
}
.inline-select.status-select.not_started{background:#EEF2F7 !important;border-color:#CBD5E1 !important;color:#475569 !important;}
.inline-select.status-select.in_progress{background:#FFE8E1 !important;border-color:#F8B9A9 !important;color:#B54708 !important;}
.inline-select.status-select.waiting{background:#FFF4D6 !important;border-color:#F6D98A !important;color:#9A6700 !important;}
.inline-select.status-select.blocked{background:#FEE2E2 !important;border-color:#FCA5A5 !important;color:#B42318 !important;}
.inline-select.status-select.done{background:#DDF8E7 !important;border-color:#9DDBB1 !important;color:#166534 !important;}
.inline-select.status-select.cancelled{background:#F3F4F6 !important;border-color:#D1D5DB !important;color:#6B7280 !important;}
.inline-select.priority-select.urgent{background:#FEE2E2 !important;border-color:#FCA5A5 !important;color:#B42318 !important;}
.inline-select.priority-select.high{background:#FFE8E1 !important;border-color:#F8B9A9 !important;color:#B54708 !important;}
.inline-select.priority-select.medium{background:#FFF4D6 !important;border-color:#F6D98A !important;color:#9A6700 !important;}
.inline-select.priority-select.low{background:#EEF2F7 !important;border-color:#CBD5E1 !important;color:#475569 !important;}

.status-dot.not_started{background:#94A3B8 !important;}
.status-dot.in_progress{background:#F26257 !important;}
.status-dot.waiting{background:#EAB308 !important;}
.status-dot.blocked{background:#B42318 !important;}
.status-dot.done{background:#16A34A !important;}
.status-dot.cancelled{background:#6B7280 !important;}

/* Header/table chips lighter and cleaner */
.sort-chip,
.person-pill,
.date-pill{
  background:#FFFFFF !important;
  border-color:var(--rule) !important;
}

/* Keep collapsed logo visible and clean */
body.sidebar-collapsed .sidebar-brand .brand-mark{
  color:#FFFFFF !important;
  font-size:22px !important;
}
body.sidebar-collapsed .sidebar-brand{
  margin-top:34px !important;
}


/* =====================================================
   V10: Catalogue gallery module + cleaner all-tasks nav
   ===================================================== */
.catalogue-page{display:grid;gap:16px;}
.catalogue-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border:1px solid var(--rule);background:#FFFFFF;padding:18px 20px;}
.catalogue-head h2{font-family:var(--display);font-size:30px;letter-spacing:-.7px;margin:2px 0 6px;}
.catalogue-head p{margin:0;color:var(--ink-soft);font-size:14px;}
.catalogue-controls{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:12px;border:1px solid var(--rule);background:#FFFFFF;padding:16px;}
.catalogue-controls label{font-family:var(--mono);font-size:10px;letter-spacing:1.4px;text-transform:uppercase;color:var(--ink-soft);display:flex;flex-direction:column;gap:8px;}
.catalogue-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:16px;}
.product-card{border:1px solid var(--rule);background:#FFFFFF;display:flex;flex-direction:column;min-width:0;transition:transform .15s ease, box-shadow .15s ease;}
.product-card:hover{transform:translateY(-2px);box-shadow:0 18px 48px -34px rgba(17,24,39,.35);}
.product-image{aspect-ratio:4/3;background:var(--soft-surface);border-bottom:1px solid var(--rule);overflow:hidden;}
.product-image img{width:100%;height:100%;object-fit:cover;display:block;}
.product-body{padding:15px;display:flex;flex-direction:column;gap:10px;flex:1;}
.product-topline,.product-footer{display:flex;justify-content:space-between;align-items:center;gap:10px;}
.product-topline span:first-child,.product-footer span{font-family:var(--mono);font-size:10px;letter-spacing:1.2px;color:var(--ink-soft);text-transform:uppercase;}
.product-card h3{font-family:var(--display);font-size:22px;line-height:1.05;letter-spacing:-.4px;margin:0;}
.product-card p{font-size:13px;line-height:1.4;color:var(--ink-soft);margin:0;min-height:54px;}
.product-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.product-meta-grid div{border:1px solid var(--rule);background:var(--soft-surface);padding:9px;}
.product-meta-grid small{display:block;font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-soft);margin-bottom:3px;}
.product-meta-grid b{font-size:13px;}
.product-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;}
.product-tags span{font-family:var(--mono);font-size:9px;letter-spacing:.7px;border:1px solid var(--rule);border-radius:999px;background:#FFFFFF;padding:4px 7px;color:var(--ink-soft);}
.catalogue-status,.catalogue-status-select{font-family:var(--mono);font-size:9px;letter-spacing:.9px;text-transform:uppercase;border-radius:999px;padding:5px 8px;border:1px solid var(--rule);}
.catalogue-status.active,.catalogue-status-select.active{background:#DDF8E7;border-color:#9DDBB1;color:#166534;}
.catalogue-status.draft,.catalogue-status-select.draft{background:#EEF2F7;border-color:#CBD5E1;color:#475569;}
.catalogue-status.seasonal,.catalogue-status-select.seasonal{background:#FFF4D6;border-color:#F6D98A;color:#9A6700;}
.catalogue-status.archived,.catalogue-status-select.archived{background:#F3F4F6;border-color:#D1D5DB;color:#6B7280;}
.catalogue-status-select{padding:7px 9px;max-width:132px;}
@media(max-width:900px){.catalogue-head{flex-direction:column}.catalogue-controls{grid-template-columns:1fr 1fr}.catalogue-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));}}
@media(max-width:640px){.catalogue-controls{grid-template-columns:1fr}.catalogue-grid{grid-template-columns:1fr}.product-card p{min-height:0;}}

/* =====================================================
   V11: Compact catalogue cards + real mock photos + tighter page header
   ===================================================== */
@media (min-width:1081px){
  .main-panel{padding:20px 28px 30px !important;}
  .topbar{padding-bottom:12px !important;gap:12px !important;}
  .topbar h1{font-size:40px !important;line-height:.98 !important;margin:2px 0 0 !important;letter-spacing:-1.25px !important;}
  .topbar .eyebrow{font-size:9px !important;letter-spacing:1.5px !important;}
  .topbar-actions .btn{padding:10px 13px !important;}
  .metrics-grid{gap:12px !important;margin:12px 0 !important;}
  .metric{padding:13px 16px !important;min-height:86px !important;}
  .metric::before{height:3px !important;width:42px !important;}
  .metric-value{font-size:34px !important;letter-spacing:-.9px !important;}
  .metric-label{font-size:9px !important;margin-top:4px !important;}
  .filters-card{padding:12px !important;margin-bottom:12px !important;}
  .filter-grid{gap:10px !important;}
  .filters-card label{gap:6px !important;font-size:9px !important;letter-spacing:1.2px !important;}
  .filters-card input,.filters-card select{padding:10px 11px !important;font-size:13px !important;}
}

.catalogue-page{gap:10px !important;}
.catalogue-head{padding:10px 14px !important;align-items:center !important;}
.catalogue-head h2{font-size:24px !important;line-height:1 !important;margin:1px 0 3px !important;letter-spacing:-.5px !important;}
.catalogue-head p{font-size:12px !important;line-height:1.25 !important;}
.catalogue-head .eyebrow{font-size:9px !important;letter-spacing:1.35px !important;}
.catalogue-head .btn{padding:9px 12px !important;}
.catalogue-controls{padding:11px 12px !important;gap:10px !important;}
.catalogue-controls label{gap:5px !important;font-size:9px !important;letter-spacing:1.2px !important;}
.catalogue-controls input,.catalogue-controls select{padding:9px 10px !important;font-size:13px !important;}
.catalogue-grid{grid-template-columns:repeat(auto-fill,minmax(235px,1fr)) !important;gap:12px !important;}
.product-card{min-height:0 !important;}
.product-card:hover{transform:translateY(-1px) !important;box-shadow:0 12px 30px -26px rgba(17,24,39,.4) !important;}
.product-image{aspect-ratio:16/9 !important;background:#F3F4F6 !important;}
.product-image img{object-fit:cover !important;filter:saturate(.98) contrast(1.02);}
.product-body{padding:11px 12px !important;gap:7px !important;}
.product-topline,.product-footer{gap:8px !important;}
.product-topline span:first-child,.product-footer span{font-size:8.5px !important;letter-spacing:1px !important;}
.product-card h3{font-size:18px !important;line-height:1.05 !important;letter-spacing:-.25px !important;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px;}
.product-card p{font-size:12px !important;line-height:1.32 !important;min-height:32px !important;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.product-meta-grid{gap:6px !important;}
.product-meta-grid div{padding:7px 8px !important;}
.product-meta-grid small{font-size:8px !important;letter-spacing:.9px !important;margin-bottom:2px !important;}
.product-meta-grid b{font-size:12px !important;line-height:1.1 !important;}
.product-tags{gap:5px !important;margin-top:2px !important;max-height:25px !important;overflow:hidden !important;}
.product-tags span{font-size:8px !important;padding:3px 6px !important;letter-spacing:.6px !important;}
.catalogue-status,.catalogue-status-select{font-size:8px !important;padding:4px 7px !important;letter-spacing:.75px !important;}
.catalogue-status-select{padding:6px 8px !important;max-width:112px !important;}

@media(max-width:900px){
  .catalogue-head{align-items:flex-start !important;}
  .catalogue-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr)) !important;}
}

/* =====================================================
   V12: Product create/edit modal + compact catalogue meta + field visit module
   ===================================================== */
.product-compact-meta{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:5px;
}
.product-compact-meta span{
  border:1px solid var(--rule);
  background:#FAFBFD;
  padding:5px 6px;
  min-width:0;
}
.product-compact-meta small{
  display:block;
  font-family:var(--mono);
  font-size:7.5px;
  letter-spacing:.75px;
  text-transform:uppercase;
  color:var(--ink-soft);
  line-height:1;
  margin-bottom:2px;
}
.product-compact-meta b{
  display:block;
  font-size:11px;
  line-height:1.05;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.product-actions{display:flex;align-items:center;gap:5px;min-width:0;}
.product-actions .btn.tiny{padding:6px 7px !important;font-size:8px !important;}
.product-footer{margin-top:1px !important;}
.product-form-grid textarea{min-height:72px;}

.field-visit-module{
  border:1px solid var(--rule);
  background:#FFFFFF;
  padding:12px;
  display:grid;
  gap:10px;
}
.module-head{display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid var(--rule);padding-bottom:10px;}
.module-head h2{font-family:var(--display);font-size:24px;line-height:1;margin:2px 0 0;letter-spacing:-.5px;}
.module-tabs{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end;}
.module-body{display:grid;gap:10px;}
.visit-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.visit-kpis div{border:1px solid var(--rule);background:#FAFBFD;padding:9px 10px;}
.visit-kpis b{display:block;font-family:var(--display);font-size:24px;line-height:1;letter-spacing:-.4px;}
.visit-kpis span{display:block;font-family:var(--mono);font-size:8px;letter-spacing:.9px;text-transform:uppercase;color:var(--ink-soft);margin-top:4px;}
.visit-form-card,.visit-table-card,.visit-insight-card,.visit-insight-grid>div{
  border:1px solid var(--rule);
  background:#FFFFFF;
  padding:12px;
}
.visit-form-card h3,.visit-table-card h3,.visit-insight-card h3{font-family:var(--display);font-size:20px;line-height:1.05;margin:0 0 10px;}
.visit-form-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;align-items:end;}
.visit-form-grid label{display:flex;flex-direction:column;gap:5px;font-family:var(--mono);font-size:8.5px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-soft);}
.visit-form-grid input,.visit-form-grid select{padding:9px;border:1px solid var(--rule);background:#fff;font:500 12px var(--sans);color:var(--ink);}
.visit-form-grid .span-2{grid-column:span 2;}
.table-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;}
.table-title-row h3{margin:0;}
.table-title-row span{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-soft);}
.table-scroll.compact{max-height:360px;overflow:auto;border:1px solid var(--rule);}
.visit-table{width:100%;border-collapse:collapse;background:#fff;font-size:12px;}
.visit-table th{position:sticky;top:0;background:#F8FAFC;z-index:1;font-family:var(--mono);font-size:8px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-soft);text-align:left;padding:9px;border-bottom:1px solid var(--rule);}
.visit-table td{padding:9px;border-bottom:1px solid var(--rule);vertical-align:top;}
.visit-table td small{display:block;color:var(--ink-soft);font-size:11px;line-height:1.25;margin-top:3px;}
.visit-status{display:inline-flex;border-radius:999px;padding:5px 8px;font:600 8px var(--mono);letter-spacing:.75px;text-transform:uppercase;border:1px solid var(--rule);white-space:nowrap;}
.visit-status.scheduled{background:#EEF2F7;border-color:#CBD5E1;color:#475569;}
.visit-status.checked_in{background:#FFE8E1;border-color:#F8B9A9;color:#B54708;}
.visit-status.checked_out{background:#DDF8E7;border-color:#9DDBB1;color:#166534;}
.visit-status.missed{background:#FEE2E2;border-color:#FCA5A5;color:#B42318;}
.calendar-layout{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;}
.calendar-day{border:1px solid var(--rule);background:#fff;padding:10px;display:grid;gap:8px;}
.calendar-date{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--rule);padding-bottom:8px;}
.calendar-date b{font-family:var(--display);font-size:20px;}
.calendar-date span{font-family:var(--mono);font-size:8px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-soft);}
.calendar-event{display:flex;justify-content:space-between;gap:8px;border:1px solid var(--rule);padding:8px;background:#FAFBFD;}
.calendar-event b{font-size:13px;line-height:1.15;}
.calendar-event small{display:block;color:var(--ink-soft);font-size:11px;line-height:1.25;margin-top:3px;}
.visit-insight-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.visit-insight-grid b{font-family:var(--display);font-size:18px;}
.visit-insight-grid p,.visit-insight-card p{margin:6px 0 0;color:var(--ink-soft);font-size:13px;line-height:1.35;}

@media(max-width:1180px){.visit-form-grid{grid-template-columns:repeat(3,1fr)}.visit-form-grid .span-2{grid-column:span 3}.visit-kpis{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.module-head{flex-direction:column;align-items:flex-start}.visit-form-grid{grid-template-columns:1fr}.visit-form-grid .span-2{grid-column:span 1}.visit-kpis,.visit-insight-grid{grid-template-columns:1fr}.product-compact-meta{grid-template-columns:repeat(2,1fr)}}

/* V14 field visit layout polish */
.field-visit-page .module-head{
  display:block;
  padding-bottom:8px;
}
.visit-tabbar{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  flex-wrap:wrap;
  border-bottom:1px solid var(--rule);
  padding:0 0 12px;
  margin-top:-2px;
}
.visit-tabbar .member-tab{
  min-width:170px;
  justify-content:center;
  background:#fff;
  border-color:#E1E6EF;
}
.visit-tabbar .member-tab.active{
  background:var(--coral);
  border-color:var(--coral);
  color:#fff;
}
.visit-action-buttons{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;
  min-width:190px;
}
.visit-action-buttons .btn{
  min-width:86px;
  text-align:center;
  justify-content:center;
}
.visit-action-buttons .btn:disabled{
  opacity:.42;
  cursor:not-allowed;
  background:#F6F8FB;
}
.live-check-table th:last-child,
.live-check-table td:last-child{
  min-width:205px;
}
.visit-calendar-panel{
  border:1px solid var(--rule);
  background:#fff;
  padding:12px;
}
.visit-calendar-toolbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding-bottom:12px;
  border-bottom:1px solid var(--rule);
}
.visit-calendar-toolbar h3{
  font-family:var(--display);
  font-size:26px;
  line-height:1;
  margin:0 0 4px;
}
.visit-calendar-toolbar p{
  margin:0;
  color:var(--ink-soft);
  font-size:13px;
  line-height:1.35;
}
.calendar-nav{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.month-calendar{
  width:100%;
  overflow:hidden;
}
.month-weekdays{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  border-left:1px solid var(--rule);
  border-right:1px solid var(--rule);
  margin-top:12px;
}
.month-weekdays div{
  background:#F8FAFC;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  border-right:1px solid var(--rule);
  padding:9px 10px;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.month-weekdays div:last-child{border-right:0;}
.month-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  border-left:1px solid var(--rule);
}
.month-cell{
  min-height:132px;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  background:#fff;
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
}
.month-cell.muted{
  background:#FAFBFD;
}
.month-cell.today{
  box-shadow:inset 0 0 0 2px rgba(242,98,87,.35);
}
.month-day-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:6px;
}
.month-day-head b{
  font-family:var(--display);
  font-size:18px;
  line-height:1;
}
.month-day-head span{
  font-family:var(--mono);
  font-size:7.5px;
  letter-spacing:.75px;
  text-transform:uppercase;
  color:var(--ink-soft);
  white-space:nowrap;
}
.month-events{
  display:grid;
  gap:5px;
  align-content:start;
  overflow:hidden;
}
.month-event{
  border:1px solid #DDE4EE;
  background:#F8FAFC;
  border-left:3px solid #94A3B8;
  padding:6px 7px;
  text-align:left;
  min-width:0;
  cursor:pointer;
}
.month-event strong{
  display:block;
  font:700 11px var(--sans);
  line-height:1.15;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.month-event small{
  display:block;
  color:var(--ink-soft);
  font-size:10px;
  line-height:1.2;
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.month-event.checked_in{border-left-color:#F26257;background:#FFF4F1;}
.month-event.checked_out{border-left-color:#16A34A;background:#F1FBF5;}
.month-event.missed{border-left-color:#B42318;background:#FEF2F2;}
.month-event.scheduled{border-left-color:#94A3B8;}

@media(max-width:1180px){
  .month-grid,.month-weekdays{min-width:980px;}
  .month-calendar{overflow-x:auto;}
}
@media(max-width:760px){
  .visit-tabbar .member-tab{min-width:100%;}
  .visit-calendar-toolbar{flex-direction:column;}
  .calendar-nav{justify-content:flex-start;}
  .visit-action-buttons{min-width:0;flex-wrap:wrap;}
  .live-check-table th:last-child,.live-check-table td:last-child{min-width:160px;}
}

/* V15 compact month calendar - fit full month in viewport */
body[data-view="fieldVisits"] .main-panel{
  padding-top:16px !important;
  padding-bottom:22px !important;
}
body[data-view="fieldVisits"] .topbar{
  padding-bottom:9px !important;
  gap:10px !important;
}
body[data-view="fieldVisits"] .topbar h1{
  font-size:34px !important;
  line-height:.92 !important;
  margin:0 !important;
}
body[data-view="fieldVisits"] .topbar .eyebrow{
  font-size:8px !important;
  letter-spacing:1.4px !important;
}
body[data-view="fieldVisits"] .topbar-actions .btn{
  padding:8px 12px !important;
  min-height:34px !important;
}
body[data-view="fieldVisits"] .metrics-grid{
  margin:8px 0 10px !important;
  gap:10px !important;
}
body[data-view="fieldVisits"] .metric{
  padding:9px 14px !important;
  min-height:60px !important;
}
body[data-view="fieldVisits"] .metric-value{
  font-size:29px !important;
  line-height:.95 !important;
}
body[data-view="fieldVisits"] .metric-label{
  font-size:8px !important;
  margin-top:3px !important;
}
body[data-view="fieldVisits"] .content-area{
  gap:10px !important;
}
body[data-view="fieldVisits"] .field-visit-module{
  padding:10px 14px !important;
}
body[data-view="fieldVisits"] .field-visit-page .module-head{
  padding-bottom:4px !important;
}
body[data-view="fieldVisits"] .field-visit-page .module-head h2{
  font-size:23px !important;
  line-height:.98 !important;
  margin:1px 0 4px !important;
}
body[data-view="fieldVisits"] .field-visit-page .module-head p{
  font-size:12px !important;
  line-height:1.25 !important;
  margin:0 !important;
}
body[data-view="fieldVisits"] .visit-tabbar{
  padding-bottom:7px !important;
  margin-top:0 !important;
  gap:6px !important;
}
body[data-view="fieldVisits"] .visit-tabbar .member-tab{
  min-width:142px !important;
  padding:8px 12px !important;
  font-size:8.5px !important;
}
body[data-view="fieldVisits"] .module-body{
  margin-top:8px !important;
}
body[data-view="fieldVisits"] .visit-kpis{
  display:none !important;
}
body[data-view="fieldVisits"] .visit-calendar-panel{
  padding:8px !important;
}
body[data-view="fieldVisits"] .visit-calendar-toolbar{
  padding-bottom:7px !important;
  gap:10px !important;
  align-items:center !important;
}
body[data-view="fieldVisits"] .visit-calendar-toolbar h3{
  font-size:22px !important;
  margin:0 !important;
}
body[data-view="fieldVisits"] .visit-calendar-toolbar p{
  display:none !important;
}
body[data-view="fieldVisits"] .calendar-nav{
  gap:6px !important;
}
body[data-view="fieldVisits"] .calendar-nav .btn{
  padding:7px 10px !important;
  min-height:30px !important;
  font-size:8.5px !important;
}
body[data-view="fieldVisits"] .month-weekdays{
  margin-top:7px !important;
}
body[data-view="fieldVisits"] .month-weekdays div{
  padding:5px 7px !important;
  font-size:7.5px !important;
  letter-spacing:.75px !important;
}
body[data-view="fieldVisits"] .month-cell{
  min-height:76px !important;
  padding:5px !important;
  gap:3px !important;
}
body[data-view="fieldVisits"] .month-day-head b{
  font-size:14px !important;
}
body[data-view="fieldVisits"] .month-day-head span{
  font-size:6.5px !important;
  letter-spacing:.55px !important;
}
body[data-view="fieldVisits"] .month-events{
  gap:3px !important;
  max-height:48px !important;
}
body[data-view="fieldVisits"] .month-event{
  padding:3px 5px !important;
  border-left-width:2px !important;
}
body[data-view="fieldVisits"] .month-event strong{
  font-size:9px !important;
  line-height:1.08 !important;
}
body[data-view="fieldVisits"] .month-event small{
  font-size:8px !important;
  line-height:1.05 !important;
  margin-top:1px !important;
}
body[data-view="fieldVisits"] .field-visit-page:has(.visit-tabbar .member-tab.active[onclick*="calendar"]) .visit-insight-card{
  display:none !important;
}
body[data-view="fieldVisits"] .field-visit-page:has(.visit-tabbar .member-tab.active[onclick*="calendar"]) .module-head p{
  display:none !important;
}

@media (min-width:1181px){
  body[data-view="fieldVisits"] .month-grid,
  body[data-view="fieldVisits"] .month-weekdays{
    min-width:0 !important;
  }
  body[data-view="fieldVisits"] .month-calendar{
    overflow:hidden !important;
  }
}

@media (max-height:820px) and (min-width:900px){
  body[data-view="fieldVisits"] .topbar h1{font-size:30px !important;}
  body[data-view="fieldVisits"] .metrics-grid{display:none !important;}
  body[data-view="fieldVisits"] .month-cell{min-height:66px !important;}
  body[data-view="fieldVisits"] .month-events{max-height:40px !important;}
  body[data-view="fieldVisits"] .field-visit-page .module-head h2{font-size:21px !important;}
}

/* V16 — visit detail modal + clean collapsed SVG sidebar */
.visit-modal{width:min(1120px,94vw)!important;}
.visit-modal-box{padding:24px!important;max-height:92vh!important;overflow:auto!important;}
.visit-modal-head{padding-bottom:14px!important;margin-bottom:14px!important;}
.visit-modal-head h2{font-size:34px!important;line-height:1.05!important;margin-top:3px!important;}
.visit-modal-sub{margin:6px 0 0;color:var(--ink-soft);font-size:13px;}
.visit-modal-summary{display:grid;grid-template-columns:1.1fr repeat(4,1fr);gap:10px;margin-bottom:16px;}
.visit-modal-summary>span{border:1px solid var(--rule);background:#F8FAFC;padding:10px 12px;min-height:54px;display:flex;flex-direction:column;justify-content:center;gap:2px;}
.visit-modal-summary>span:first-child{align-items:center;text-align:center;border-radius:0;}
.visit-modal-summary b{font-size:16px;line-height:1.05;}
.visit-modal-summary small{font-family:var(--mono);font-size:8px;text-transform:uppercase;letter-spacing:1px;color:var(--ink-soft);}
.visit-edit-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:12px!important;}
.visit-edit-grid label{min-width:0;}
.visit-edit-grid input,.visit-edit-grid select,.visit-edit-grid textarea{width:100%;}
.visit-edit-grid textarea{min-height:72px;resize:vertical;}
.visit-timeline-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px;}
.visit-timeline-strip>div{border:1px dashed var(--rule);background:#fff;padding:10px 12px;min-height:58px;}
.visit-timeline-strip b{display:block;font-family:var(--mono);font-size:8px;text-transform:uppercase;letter-spacing:1px;color:var(--ink-soft);margin-bottom:4px;}
.visit-timeline-strip span{display:block;font-size:13px;line-height:1.25;color:var(--ink);word-break:break-word;}
.visit-modal-actions{grid-template-columns:auto 1fr auto!important;align-items:center!important;}
.visit-quick-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;}
.month-event:focus{outline:2px solid #0b87ff;outline-offset:-2px;}
.month-event{border-radius:2px;}
@media(max-width:920px){
  .visit-modal-summary,.visit-timeline-strip{grid-template-columns:1fr 1fr;}
  .visit-edit-grid{grid-template-columns:1fr 1fr!important;}
}
@media(max-width:640px){
  .visit-modal-summary,.visit-timeline-strip,.visit-edit-grid{grid-template-columns:1fr!important;}
  .visit-modal-actions{grid-template-columns:1fr!important;}
}

@media (min-width:1081px){
  body.sidebar-collapsed .app-shell{grid-template-columns:74px 1fr!important;padding-left:74px!important;}
  body.sidebar-collapsed .sidebar{width:74px!important;min-width:74px!important;padding:14px 9px!important;gap:14px!important;align-items:center!important;}
  body.sidebar-collapsed .sidebar-brand{width:100%;margin:28px 0 2px!important;display:flex!important;align-items:center!important;justify-content:center!important;}
  body.sidebar-collapsed .sidebar-brand .brand-mark{writing-mode:initial!important;font-size:17px!important;line-height:1!important;letter-spacing:-.5px!important;color:#fff!important;transform:none!important;max-width:none!important;}
  body.sidebar-collapsed .sidebar-brand .brand-tag{display:none!important;}
  body.sidebar-collapsed .side-nav{width:100%!important;gap:8px!important;align-items:center!important;}
  body.sidebar-collapsed .side-nav button{width:42px!important;height:42px!important;padding:0!important;border:1px solid #3C424B!important;background:#252A31!important;color:transparent!important;font-size:0!important;border-radius:0!important;display:grid!important;place-items:center!important;overflow:hidden!important;}
  body.sidebar-collapsed .side-nav button.active{border-color:#F26257!important;background:#20252B!important;box-shadow:inset 3px 0 0 #F26257!important;}
  body.sidebar-collapsed .side-nav button:hover{border-color:#5D6572!important;background:#2F353D!important;}
  body.sidebar-collapsed .side-nav button::before{content:""!important;width:18px!important;height:18px!important;display:block!important;background-repeat:no-repeat!important;background-position:center!important;background-size:18px 18px!important;opacity:.92!important;filter:none!important;}
  body.sidebar-collapsed .side-nav button.active::before{opacity:1!important;filter:brightness(1.35)!important;}
  body.sidebar-collapsed .side-nav button[data-view="dashboard"]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7'/%3E%3Crect x='14' y='3' width='7' height='7'/%3E%3Crect x='14' y='14' width='7' height='7'/%3E%3Crect x='3' y='14' width='7' height='7'/%3E%3C/svg%3E");}
  body.sidebar-collapsed .side-nav button[data-view="tasks"]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 6h12'/%3E%3Cpath d='M9 12h12'/%3E%3Cpath d='M9 18h12'/%3E%3Cpath d='M4 6h.01'/%3E%3Cpath d='M4 12h.01'/%3E%3Cpath d='M4 18h.01'/%3E%3C/svg%3E");}
  body.sidebar-collapsed .side-nav button[data-view="teamTable"]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 6h18'/%3E%3Cpath d='M3 12h18'/%3E%3Cpath d='M3 18h18'/%3E%3Cpath d='M8 6v12'/%3E%3Cpath d='M16 6v12'/%3E%3C/svg%3E");}
  body.sidebar-collapsed .side-nav button[data-view="today"]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='17' rx='2'/%3E%3Cpath d='M8 2v4'/%3E%3Cpath d='M16 2v4'/%3E%3Cpath d='M3 10h18'/%3E%3Cpath d='M8 14h3'/%3E%3C/svg%3E");}
  body.sidebar-collapsed .side-nav button[data-view="mine"]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 21c1.6-4 14.4-4 16 0'/%3E%3C/svg%3E");}
  body.sidebar-collapsed .side-nav button[data-view="team"]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E");}
  body.sidebar-collapsed .side-nav button[data-view="fieldVisits"]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-11a7 7 0 1 0-14 0c0 5.9 7 11 7 11Z'/%3E%3Ccircle cx='12' cy='10' r='2.5'/%3E%3Cpath d='M4 22h16'/%3E%3C/svg%3E");}
  body.sidebar-collapsed .side-nav button[data-view="catalogue"]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16Z'/%3E%3Cpath d='m3.3 7 8.7 5 8.7-5'/%3E%3Cpath d='M12 22V12'/%3E%3C/svg%3E");}
  body.sidebar-collapsed .sidebar-card{width:42px!important;min-height:64px!important;padding:0!important;border:1px solid #3C424B!important;background:#252A31!important;overflow:hidden!important;display:grid!important;place-items:center!important;margin-top:auto!important;}
  body.sidebar-collapsed .sidebar-card .mono,
  body.sidebar-collapsed .sidebar-card strong{display:none!important;}
  body.sidebar-collapsed .sidebar-card .btn{width:42px!important;height:42px!important;min-height:42px!important;padding:0!important;font-size:0!important;border:0!important;background:#11151B!important;}
  body.sidebar-collapsed .sidebar-card .btn::before{content:"";display:block;width:18px;height:18px;margin:auto;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23D6DDE7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'/%3E%3Cpath d='M16 17l5-5-5-5'/%3E%3Cpath d='M21 12H9'/%3E%3C/svg%3E") center/18px 18px no-repeat;}
  body.sidebar-collapsed .sidebar-toggle{top:16px!important;right:50%!important;transform:translateX(50%)!important;background:#252A31!important;border-color:#3C424B!important;color:#fff!important;}
}

/* =====================================================
   V17 NAV + SALES OPS MODULES
   ===================================================== */
.nav-section{
  margin:14px 8px 4px;
  font-family:var(--mono);
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:1.8px;
  color:rgba(255,255,255,.42);
}
.side-nav button{
  display:flex;
  align-items:center;
  gap:10px;
}
.side-nav button::before{
  content:"";
  flex:0 0 15px;
  width:15px;
  height:15px;
  background:currentColor;
  opacity:.9;
  -webkit-mask:var(--nav-icon) center/contain no-repeat;
  mask:var(--nav-icon) center/contain no-repeat;
}
.side-nav button[data-view="dashboard"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='3' width='7' height='7'/%3E%3Crect x='14' y='3' width='7' height='7'/%3E%3Crect x='14' y='14' width='7' height='7'/%3E%3Crect x='3' y='14' width='7' height='7'/%3E%3C/svg%3E")}
.side-nav button[data-view="tasks"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M9 11l3 3L22 4'/%3E%3Cpath d='M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11'/%3E%3C/svg%3E")}
.side-nav button[data-view="leads"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M3 3v18h18'/%3E%3Cpath d='M7 15l4-4 3 3 6-7'/%3E%3C/svg%3E")}
.side-nav button[data-view="customers"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M23 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E")}
.side-nav button[data-view="followups"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 15a4 4 0 0 1-4 4H7l-4 4V5a4 4 0 0 1 4-4h10a4 4 0 0 1 4 4z'/%3E%3Cpath d='M8 9h8M8 13h5'/%3E%3C/svg%3E")}
.side-nav button[data-view="fieldVisits"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 10c0 7-9 13-9 13S3 17 3 10a9 9 0 1 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E")}
.side-nav button[data-view="catalogue"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 16V8a2 2 0 0 0-1-1.73L13 2.27a2 2 0 0 0-2 0L4 6.27A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16z'/%3E%3Cpath d='M3.27 6.96L12 12.01l8.73-5.05M12 22.08V12'/%3E%3C/svg%3E")}
.side-nav button[data-view="samples"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M20 7l-8-4-8 4 8 4 8-4z'/%3E%3Cpath d='M4 7v10l8 4 8-4V7'/%3E%3Cpath d='M12 11v10'/%3E%3C/svg%3E")}
.side-nav button[data-view="okr"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Ccircle cx='12' cy='12' r='6'/%3E%3Ccircle cx='12' cy='12' r='2'/%3E%3C/svg%3E")}
.side-nav button[data-view="dailyReport"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/%3E%3Cpath d='M14 2v6h6M8 13h8M8 17h6'/%3E%3C/svg%3E")}
.side-nav button[data-view="reports"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M3 3v18h18'/%3E%3Crect x='7' y='12' width='3' height='5'/%3E%3Crect x='12' y='8' width='3' height='9'/%3E%3Crect x='17' y='5' width='3' height='12'/%3E%3C/svg%3E")}
.side-nav button[data-view="whatsapp"]{--nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 11.5a8.38 8.38 0 0 1-1.9 5.3A8.5 8.5 0 0 1 12.5 20a8.38 8.38 0 0 1-4.5-1.3L3 20l1.3-4.7A8.38 8.38 0 0 1 3 11.5 8.5 8.5 0 1 1 21 11.5z'/%3E%3C/svg%3E")}
body.sidebar-collapsed .nav-section{display:none}
body.sidebar-collapsed .side-nav button{font-size:0!important;color:var(--sidebar-muted)!important;padding:0!important}
body.sidebar-collapsed .side-nav button::before{content:""!important;width:18px;height:18px;background:currentColor;display:block;opacity:1}
body.sidebar-collapsed .side-nav button.active,body.sidebar-collapsed .side-nav button:hover{color:var(--coral)!important}

.module-tabbar{display:flex;gap:8px;flex-wrap:wrap;border:1px solid var(--rule);background:var(--soft-surface);padding:10px;margin-bottom:14px}.module-tab{border:1px solid var(--rule);background:#fff;border-radius:999px;padding:9px 14px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--ink-soft);cursor:pointer}.module-tab.active,.module-tab:hover{background:var(--coral);border-color:var(--coral);color:#fff}.module-page{display:grid;gap:16px}.module-head{border:1px solid var(--rule);background:#fff;padding:18px;display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.module-head h2{font-family:var(--display);font-size:34px;letter-spacing:-.8px;margin:4px 0 6px}.module-head p{margin:0;color:var(--ink-soft);max-width:760px}.pipeline-board{display:grid;grid-template-columns:repeat(6,minmax(170px,1fr));gap:10px;overflow-x:auto;padding-bottom:4px}.pipeline-lane{border:1px solid var(--rule);background:var(--soft-surface);padding:10px;min-height:210px}.pipeline-lane h3{font-family:var(--display);font-size:21px;margin:0 0 10px}.pipeline-card,.sample-card,.template-card,.okr-card,.analytics-grid article{border:1px solid var(--rule);background:#fff;padding:12px;margin-bottom:8px}.pipeline-card b,.sample-card b,.template-card b{display:block}.pipeline-card span,.sample-card span,.template-card span{display:block;color:var(--ink-soft);font-size:12px;margin-top:3px}.pipeline-card small{display:block;color:var(--ink-soft);margin-top:8px}.compact-empty{padding:18px!important}.module-table td small{display:block;color:var(--ink-soft);font-size:12px;margin-top:3px}.sample-grid,.template-grid,.okr-grid,.analytics-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.template-card p{font-size:13px;line-height:1.45;color:var(--ink);min-height:76px}.okr-card h3,.analytics-grid h3{font-family:var(--display);font-size:24px;margin:0 0 8px}.okr-card p{color:var(--ink-soft);min-height:42px}.okr-card b{display:block;margin:10px 0}.bar-row{display:grid;grid-template-columns:130px 1fr;align-items:center;gap:10px;margin:12px 0;color:var(--ink-soft)}.bar-row b{display:block;height:12px;background:var(--coral);border-radius:99px}.analytics-grid{grid-template-columns:1fr 1fr}
@media(max-width:1100px){.pipeline-board{grid-template-columns:repeat(3,220px)}.sample-grid,.template-grid,.okr-grid{grid-template-columns:1fr 1fr}.analytics-grid{grid-template-columns:1fr}}
@media(max-width:680px){.module-head{flex-direction:column}.sample-grid,.template-grid,.okr-grid{grid-template-columns:1fr}.pipeline-board{grid-template-columns:repeat(2,220px)}}


/* V18 Leads CRM tabs + CRUD */
.pipeline-lane-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.pipeline-lane-head span{font-family:var(--mono);font-size:10px;color:var(--ink-soft);border:1px solid var(--rule);padding:4px 8px;border-radius:999px;background:#fff}
.pipeline-card{cursor:pointer;border-radius:14px}
.pipeline-card-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.icon-chip{border:1px solid var(--rule);background:#fff;border-radius:999px;padding:6px 10px;font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;color:var(--ink-soft)}
.icon-chip:hover{border-color:var(--coral);color:var(--coral)}
.lead-stage-select{min-width:170px;border-radius:999px!important;background:#fff!important}
.row-actions{display:flex;gap:8px;flex-wrap:wrap}
.danger-lite{color:#a63b35;border-color:#f0c4c0}
.danger-lite:hover{background:#fff2f1}
@media (max-width:1200px){.pipeline-board{grid-template-columns:repeat(3,minmax(220px,1fr));}}
@media (max-width:760px){.pipeline-board{grid-template-columns:1fr;}}

/* =====================================================
   V19 CRM drawer + module CRUD controls
   ===================================================== */
.module-filter-card{
  display:grid;
  grid-template-columns: minmax(220px,1.4fr) repeat(4,minmax(130px,1fr)) auto;
  gap:10px;
  border:1px solid var(--rule);
  background:#fff;
  padding:12px;
  align-items:end;
}
.module-filter-card label{display:grid;gap:6px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1.4px;color:var(--ink-soft)}
.module-filter-card input,.module-filter-card select{height:42px;border:1px solid var(--rule);background:var(--soft-surface);padding:0 12px;font-family:var(--body);font-size:14px;color:var(--ink)}
.drawer-backdrop{position:fixed;inset:0;background:rgba(16,22,32,.38);z-index:80;display:flex;justify-content:flex-end;backdrop-filter:blur(3px)}
.drawer-backdrop.hidden{display:none!important}
.lead-drawer{width:min(560px,96vw);height:100vh;background:#fff;border-left:1px solid var(--rule);box-shadow:-28px 0 70px rgba(15,23,42,.18);overflow-y:auto;padding:22px}
.drawer-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;border-bottom:1px solid var(--rule);padding-bottom:16px;margin-bottom:14px}
.drawer-head h2{font-family:var(--display);font-size:34px;line-height:1;margin:4px 0 6px;letter-spacing:-.8px}.drawer-head p{margin:0;color:var(--ink-soft)}
.drawer-actions{display:flex;gap:10px;margin-bottom:14px}.drawer-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px}.drawer-grid span{border:1px solid var(--rule);background:var(--soft-surface);padding:12px}.drawer-grid small{display:block;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--ink-soft);margin-bottom:4px}.drawer-grid b{font-size:16px}
.drawer-section{border:1px solid var(--rule);background:#fff;padding:14px;margin-bottom:14px}.drawer-section h3{font-family:var(--display);font-size:22px;margin:0 0 10px}.drawer-two{display:grid;grid-template-columns:1fr 1fr;gap:10px}.drawer-two label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--ink-soft);display:grid;gap:6px}.drawer-two select{height:42px;border:1px solid var(--rule);background:var(--soft-surface);padding:0 10px}.muted-line{color:var(--ink-soft);font-size:13px;margin:10px 0 0}.timeline-list{display:grid;gap:8px}.timeline-item{border:1px solid var(--rule);background:var(--soft-surface);padding:11px}.timeline-item b{font-size:14px;display:block}.timeline-item small{display:block;color:var(--ink-soft);margin-top:5px}.timeline-item.done-item{opacity:.74}.drawer-inline{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:10px}.drawer-inline textarea{min-height:74px;border:1px solid var(--rule);background:var(--soft-surface);padding:10px;font-family:var(--body)}.drawer-followup-form{display:grid;grid-template-columns:1fr 150px auto;gap:8px;margin-top:10px}.drawer-followup-form input{height:42px;border:1px solid var(--rule);background:var(--soft-surface);padding:0 10px}.pipeline-card{transition:transform .18s ease,box-shadow .18s ease}.pipeline-card:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(15,23,42,.08)}.sample-card-footer{display:flex;gap:8px;margin-top:12px}.row-actions .danger-lite,.danger-lite{color:#a63b35;border-color:#f0c4c0!important}.danger-lite:hover{background:#fff2f1!important;color:#8b1e18!important}.lead-stage-select{min-width:170px}
@media (max-width:1100px){.module-filter-card{grid-template-columns:1fr 1fr}.drawer-followup-form{grid-template-columns:1fr}.drawer-inline{grid-template-columns:1fr}.drawer-two{grid-template-columns:1fr}}
@media (max-width:720px){.module-filter-card{grid-template-columns:1fr}.lead-drawer{width:100vw}.drawer-grid{grid-template-columns:1fr}}

/* ===== V20 compact module headers / space-saving UI ===== */
.main-panel{padding:18px 22px 20px !important;}
.topbar{padding-bottom:12px !important;gap:12px !important;align-items:flex-end !important;}
.topbar h1{font-size:34px !important;line-height:0.98 !important;letter-spacing:-1px !important;margin:2px 0 0 !important;}
.topbar .eyebrow{font-size:9px !important;letter-spacing:1.5px !important;}
.topbar-actions{gap:8px !important;}
.topbar-actions .btn{padding:10px 12px !important;min-height:40px;}
.metrics-grid{gap:10px !important;margin:10px 0 12px !important;}
.metric{padding:12px 16px !important;min-height:76px;}
.metric::before{width:42px !important;height:3px !important;}
.metric-value{font-size:26px !important;line-height:1 !important;}
.metric-label{margin-top:4px !important;font-size:9px !important;letter-spacing:1.4px !important;}
.content-area{gap:10px !important;}
.module-page,.catalogue-page{display:flex;flex-direction:column;gap:10px;}
.module-intro{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--rule);background:var(--paper);padding:10px 14px;min-height:auto;}
.module-intro .eyebrow{margin:0 0 4px 0;}
.module-intro p{margin:0;color:var(--ink-soft);font-size:13px;line-height:1.35;max-width:980px;}
.module-head,.catalogue-head{display:none !important;}
.module-filter-card,.catalogue-controls{padding:12px !important;gap:10px !important;}
.module-filter-card label,.catalogue-controls label{font-size:9px !important;gap:6px !important;}
.module-filter-card input,.module-filter-card select,.catalogue-controls input,.catalogue-controls select{padding:10px 11px !important;font-size:13px !important;}
.module-tabbar{padding:10px 12px !important;}
.module-tab{padding:8px 14px !important;font-size:10px !important;}
.pipeline-board{gap:10px !important;}
.pipeline-lane{padding:10px !important;}
.pipeline-lane h3{font-size:18px !important;}
.pipeline-card{padding:12px !important;}
.pipeline-card b{font-size:15px !important;}
.visit-table th{font-size:9px !important;padding:10px 10px !important;}
.visit-table td{padding:10px 10px !important;font-size:13px !important;}
.visit-table td small{display:block;margin-top:3px;color:var(--ink-soft);}
.sample-card,.template-card,.okr-card,.analytics-grid article{padding:14px !important;}
.catalogue-grid{gap:12px !important;}
.product-body{padding:12px 14px 14px !important;}
.product-topline{margin-bottom:6px !important;}
.product-body h3{font-size:18px !important;line-height:1.1 !important;margin:0 0 6px !important;}
.product-body p{font-size:13px !important;line-height:1.35 !important;margin:0 0 10px !important;}
.product-compact-meta{gap:6px !important;grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
.product-compact-meta span{padding:6px 7px !important;}
.product-compact-meta small{font-size:8px !important;letter-spacing:1.1px !important;}
.product-compact-meta b{font-size:12px !important;line-height:1.15 !important;}
.product-tags{gap:5px !important;margin-top:8px !important;}
.product-tags span{font-size:9px !important;padding:4px 8px !important;}
.product-footer{margin-top:10px !important;padding-top:10px !important;}
.row-actions .btn,.product-actions .btn,.sample-card-footer .btn{padding:8px 9px !important;}
@media (max-width: 900px){
  .main-panel{padding:14px !important;}
  .topbar{align-items:flex-start !important;}
  .topbar h1{font-size:30px !important;}
  .metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .module-intro{padding:10px 12px !important;}
  .module-intro p{font-size:12px !important;}
}

/* V21 auth gate: keep login completely outside the app shell, even when
   collapsed-sidebar layout classes are restored from localStorage. */
#appShell.hidden,
body.auth-mode #appShell{
  display:none !important;
}

#authScreen.hidden,
body:not(.auth-mode) #authScreen{
  display:none !important;
}

body.auth-mode{
  overflow:auto !important;
  background:#fff !important;
}

body.auth-mode::before{
  display:none !important;
}

body.auth-mode .auth-screen{
  position:fixed !important;
  inset:0 !important;
  z-index:70 !important;
  display:grid !important;
  place-items:center !important;
  min-height:100vh !important;
  width:100vw !important;
  padding:32px !important;
  overflow:auto !important;
  background:#fff !important;
}

body.auth-mode .auth-card{
  width:min(980px,100%) !important;
  max-height:none !important;
}

/* V22 settings + RBAC workspace */
.settings-page{display:flex;flex-direction:column;gap:12px;min-height:0}
.settings-grid{display:grid;grid-template-columns:minmax(320px,1.4fr) minmax(260px,.8fr);gap:12px}
.settings-panel{border:1px solid var(--rule);background:#fff;padding:14px;min-width:0}
.settings-panel h3{font-family:var(--display);font-size:22px;line-height:1;margin:0 0 10px;letter-spacing:-.4px}
.settings-panel p,.settings-note{margin:0 0 8px;color:var(--ink-soft);font-size:13px;line-height:1.35}
.settings-form{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;align-items:end}
.settings-form label{display:grid;gap:6px;font-family:var(--mono);font-size:9px;letter-spacing:1.3px;text-transform:uppercase;color:var(--ink-soft)}
.settings-form input,.settings-form select,.settings-panel table select{height:40px;border:1px solid var(--rule);background:var(--soft-surface,#F8FAFC);padding:0 10px}
.rbac-scroll{overflow:auto;max-height:48vh;border:1px solid var(--rule)}
.rbac-table,.share-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1180px;background:#fff}
.rbac-table th,.rbac-table td,.share-table th,.share-table td{border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:9px;vertical-align:top}
.rbac-table th,.share-table th{position:sticky;top:0;z-index:2;background:#fff9ea;font-family:var(--mono);font-size:9px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-soft);text-align:left}
.rbac-table th:first-child,.share-table th:first-child{left:0;z-index:3}
.rbac-table td:first-child,.share-table td:first-child{position:sticky;left:0;background:#fff;z-index:1;min-width:170px}
.perm-cell{display:grid;gap:5px;min-width:118px}
.perm-cell b{font-size:11px;line-height:1.1}
.perm-cell label,.toggle-line{font-size:11px;color:var(--ink-soft);display:flex;align-items:center;gap:6px}
.share-table td{text-align:center}
.rbac-note{border:1px dashed var(--rule);background:var(--soft-surface,#F8FAFC);padding:10px;margin-top:12px;color:var(--ink-soft);font-size:13px}
button[hidden],.side-nav button[hidden]{display:none!important}
select:disabled,input:disabled{opacity:.55;cursor:not-allowed}
@media (max-width:900px){
  .settings-grid,.settings-form{grid-template-columns:1fr}
}

/* V23 compact viewport-bound login */
body.auth-mode{
  overflow:hidden !important;
}
body.auth-mode .auth-screen{
  height:100vh !important;
  min-height:100vh !important;
  padding:20px !important;
  overflow:hidden !important;
}
body.auth-mode .auth-card{
  width:min(860px,100%) !important;
  max-height:calc(100vh - 40px) !important;
  display:grid !important;
  grid-template-columns:.95fr 1.05fr !important;
  grid-template-areas:
    "brand form"
    "copy form" !important;
  gap:18px 34px !important;
  align-items:center !important;
  padding:28px !important;
  overflow:hidden !important;
}
body.auth-mode .auth-card > .brand-row{
  grid-area:brand !important;
  align-self:end !important;
}
body.auth-mode .auth-copy{
  grid-area:copy !important;
  align-self:start !important;
}
body.auth-mode .auth-copy .eyebrow{
  margin-bottom:10px !important;
}
body.auth-mode .auth-copy h1{
  font-size:clamp(42px,5.2vw,70px) !important;
  line-height:.92 !important;
  letter-spacing:-1.8px !important;
  margin:0 !important;
  max-width:420px !important;
}
body.auth-mode .auth-copy p{
  display:none !important;
}
body.auth-mode .auth-form{
  grid-area:form !important;
  align-self:center !important;
  padding:24px !important;
}
body.auth-mode .auth-form input{
  padding:11px 12px !important;
}
body.auth-mode .setup-note{
  margin-top:14px !important;
}
@media(max-width:760px){
  body.auth-mode .auth-screen{
    padding:12px !important;
  }
  body.auth-mode .auth-card{
    max-height:calc(100vh - 24px) !important;
    grid-template-columns:1fr !important;
    grid-template-areas:"brand" "copy" "form" !important;
    gap:12px !important;
    padding:18px !important;
  }
  body.auth-mode .auth-copy h1{
    font-size:clamp(34px,12vw,48px) !important;
    max-width:none !important;
  }
  body.auth-mode .auth-form{
    padding:16px !important;
  }
}

/* V24 task status KPI filters */
body[data-view="tasks"] .metrics-grid,
body[data-view="dashboard"] .metrics-grid{
  grid-template-columns:repeat(6,minmax(0,1fr)) !important;
  gap:8px !important;
}
.metric.status-metric{
  appearance:none;
  text-align:left;
  cursor:pointer;
  color:var(--ink);
}
.metric.status-metric:hover,
.metric.status-metric.active{
  border-color:var(--coral) !important;
  background:#FFF7F5 !important;
}
.metric.status-metric.active::after{
  content:"Filtered";
  position:absolute;
  right:12px;
  top:11px;
  font-family:var(--mono);
  font-size:8px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--coral);
}
@media(max-width:1180px){
  body[data-view="tasks"] .metrics-grid,
  body[data-view="dashboard"] .metrics-grid{
    overflow-x:auto;
    grid-template-columns:repeat(6,minmax(150px,1fr)) !important;
  }
}

/* V25 lead stage KPI filters */
body[data-view="leads"] .metrics-grid{
  grid-template-columns:repeat(7,minmax(0,1fr)) !important;
  gap:8px !important;
}
.metric.lead-stage-metric{
  appearance:none;
  text-align:left;
  cursor:pointer;
  color:var(--ink);
}
.metric.lead-stage-metric:hover,
.metric.lead-stage-metric.active{
  border-color:var(--coral) !important;
  background:#FFF7F5 !important;
}
.metric.lead-stage-metric .metric-label{
  white-space:normal;
}
@media(max-width:1280px){
  body[data-view="leads"] .metrics-grid{
    overflow-x:auto;
    grid-template-columns:repeat(7,minmax(132px,1fr)) !important;
  }
}

/* V26 sidebar compaction: keep Admin/Settings reachable */
.sidebar{
  gap:14px !important;
  padding:18px 14px !important;
  overflow:hidden !important;
}
.sidebar-brand{
  flex:0 0 auto !important;
  margin-bottom:4px !important;
}
.sidebar .brand-mark{
  font-size:32px !important;
}
.side-nav{
  flex:1 1 auto !important;
  min-height:0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  gap:3px !important;
  padding:0 3px 4px 0 !important;
  scrollbar-width:thin;
  scrollbar-color:#59606A transparent;
}
.side-nav::-webkit-scrollbar{width:5px}
.side-nav::-webkit-scrollbar-track{background:transparent}
.side-nav::-webkit-scrollbar-thumb{background:#59606A;border-radius:99px}
.nav-section{
  margin:9px 8px 3px !important;
  font-size:8px !important;
  letter-spacing:1.6px !important;
}
.side-nav button{
  min-height:38px !important;
  padding:9px 10px !important;
  gap:9px !important;
  line-height:1.22 !important;
}
.side-nav button::before{
  flex-basis:14px !important;
  width:14px !important;
  height:14px !important;
}
.sidebar-card{
  flex:0 0 auto !important;
  margin-top:8px !important;
  padding:10px !important;
}
.sidebar-card strong{
  font-size:12px !important;
  line-height:1.2 !important;
}
.sidebar-card .btn.tiny{
  margin-top:8px !important;
  padding:8px 10px !important;
}
.side-nav button[data-view="settings"]{
  --nav-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Cpath d='M19.4 15a1.7 1.7 0 0 0 .34 1.88l.06.06a2 2 0 1 1-2.83 2.83l-.06-.06A1.7 1.7 0 0 0 15 19.4a1.7 1.7 0 0 0-1 .6 1.7 1.7 0 0 0-.4 1.1V21a2 2 0 1 1-4 0v-.09A1.7 1.7 0 0 0 8.6 19.4a1.7 1.7 0 0 0-1.88.34l-.06.06a2 2 0 1 1-2.83-2.83l.06-.06A1.7 1.7 0 0 0 4.6 15a1.7 1.7 0 0 0-.6-1 1.7 1.7 0 0 0-1.1-.4H3a2 2 0 1 1 0-4h.09A1.7 1.7 0 0 0 4.6 8.6a1.7 1.7 0 0 0-.34-1.88l-.06-.06A2 2 0 1 1 7.03 3.83l.06.06A1.7 1.7 0 0 0 9 4.6a1.7 1.7 0 0 0 1-.6 1.7 1.7 0 0 0 .4-1.1V3a2 2 0 1 1 4 0v.09A1.7 1.7 0 0 0 15.4 4.6a1.7 1.7 0 0 0 1.88-.34l.06-.06a2 2 0 1 1 2.83 2.83l-.06.06A1.7 1.7 0 0 0 19.4 9c.2.36.3.74.3 1.15H21a2 2 0 1 1 0 4h-.09a1.7 1.7 0 0 0-1.51.85Z'/%3E%3C/svg%3E");
}
@media (min-width:1081px){
  body.sidebar-collapsed .side-nav{
    overflow-y:auto !important;
    gap:6px !important;
    padding-right:0 !important;
  }
  body.sidebar-collapsed .sidebar{
    overflow:hidden !important;
    gap:10px !important;
  }
  body.sidebar-collapsed .side-nav button{
    width:40px !important;
    height:40px !important;
    min-height:40px !important;
  }
}

/* V27 viewport-fit CRM modals */
@media (min-width:900px){
  #leadModal,
  #customerModal{
    width:min(1700px,92vw) !important;
    max-height:calc(100vh - 40px) !important;
  }
  #leadForm,
  #customerForm{
    max-height:calc(100vh - 40px) !important;
    overflow:hidden !important;
    padding:18px 22px 16px !important;
  }
  #leadForm .modal-head,
  #customerForm .modal-head{
    padding-bottom:10px !important;
    margin-bottom:12px !important;
    align-items:center !important;
  }
  #leadForm .modal-head h2,
  #customerForm .modal-head h2{
    font-size:32px !important;
    margin:3px 0 0 !important;
    line-height:1 !important;
  }
  #leadForm .eyebrow,
  #customerForm .eyebrow{
    font-size:8px !important;
    letter-spacing:1.4px !important;
  }
  #leadForm .product-form-grid,
  #customerForm .product-form-grid{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:9px 12px !important;
  }
  #leadForm .product-form-grid label,
  #leadForm .product-form-grid .field-with-toggle,
  #customerForm .product-form-grid label,
  #customerForm .product-form-grid .field-with-toggle{
    gap:5px !important;
    font-size:8.5px !important;
    letter-spacing:1.45px !important;
    min-width:0 !important;
  }
  #leadForm .product-form-grid .span-2,
  #customerForm .product-form-grid .span-2{
    grid-column:1 / -1 !important;
  }
  #leadForm input,
  #leadForm select,
  #leadForm .field-with-toggle > input,
  #customerForm input,
  #customerForm select,
  #customerForm .field-with-toggle > input{
    height:39px !important;
    padding:8px 11px !important;
    font-size:13px !important;
  }
  #leadForm .modal-actions,
  #customerForm .modal-actions{
    margin-top:12px !important;
    gap:10px !important;
    align-items:center !important;
  }
  #leadForm .modal-actions .btn,
  #customerForm .modal-actions .btn{
    min-height:42px !important;
    padding:11px 18px !important;
  }
}

.field-with-toggle{
  display:grid;
  grid-template-rows:auto auto;
  gap:5px;
  min-width:0;
}
.field-title{
  font-family:var(--mono);
  font-size:8.5px;
  letter-spacing:1.45px;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.field-label-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-family:var(--mono);
  font-size:8.5px;
  letter-spacing:1.45px;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.same-number-toggle{
  display:inline-flex !important;
  align-items:center;
  justify-content:flex-end;
  gap:6px !important;
  color:var(--ink-soft) !important;
  font-family:var(--body) !important;
  font-size:11px !important;
  letter-spacing:0 !important;
  text-transform:none !important;
  white-space:nowrap;
}
.same-number-row{
  display:grid;
  grid-template-columns:minmax(0,320px) auto;
  align-items:center;
  justify-content:start;
  gap:10px;
}
.same-number-row > input{
  min-width:0 !important;
}
.same-number-row .same-number-toggle{
  border:1px solid var(--rule);
  min-height:39px;
  padding:0 10px;
  background:#fff;
}
#leadForm .same-number-toggle input,
#customerForm .same-number-toggle input,
.same-number-toggle input{
  width:14px !important;
  height:14px !important;
  min-height:14px !important;
  padding:0 !important;
  accent-color:var(--coral);
}
.field-with-toggle > input.readonly-field{
  background:#f7f8fb;
  color:var(--ink-soft);
}
.settings-form-actions{
  display:flex;
  gap:10px;
  align-items:center;
}
.settings-form-actions .btn{
  flex:1 1 auto;
}
.user-form-active{
  align-self:end;
  min-height:39px;
  align-items:center;
}

/* V30 operational dashboard */
body[data-view="dashboard"] .metrics-grid{
  grid-template-columns:repeat(6,minmax(0,1fr)) !important;
  gap:8px !important;
}
.dashboard-page{
  display:grid;
  gap:12px;
}
.dashboard-summary{
  border:1px solid var(--rule);
  background:#fff;
  padding:16px 18px;
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
}
.dashboard-summary h2{
  font-family:var(--display);
  font-size:30px;
  line-height:1;
  margin:4px 0 6px;
}
.dashboard-summary p{
  margin:0;
  color:var(--ink-soft);
}
.summary-gauges{
  display:grid;
  grid-template-columns:repeat(3,minmax(110px,1fr));
  gap:8px;
  min-width:420px;
}
.summary-gauges span{
  border:1px solid var(--rule);
  background:var(--soft-surface);
  padding:10px 12px;
}
.summary-gauges b{
  display:block;
  font-family:var(--display);
  font-size:24px;
  line-height:1;
}
.summary-gauges small,
.panel-title span,
.rank-row small,
.attention-list small,
.day-bar-row small{
  color:var(--ink-soft);
}
.summary-gauges small{
  display:block;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:1.1px;
  text-transform:uppercase;
  margin-top:5px;
}
.dashboard-grid{
  display:grid;
  grid-template-columns:1.25fr 1fr;
  gap:12px;
}
.dashboard-panel{
  border:1px solid var(--rule);
  background:#fff;
  padding:14px;
  min-width:0;
}
.dashboard-panel.span-2{
  grid-column:1 / -1;
}
.panel-title{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  border-bottom:1px solid var(--rule);
  padding-bottom:10px;
  margin-bottom:12px;
}
.panel-title h3{
  font-family:var(--display);
  font-size:24px;
  line-height:1;
  margin:0;
}
.panel-title span{
  font-size:13px;
  text-align:right;
}
.day-chart,
.pipeline-visual,
.rank-list,
.attention-list,
.status-mix{
  display:grid;
  gap:8px;
}
.day-bar-row{
  display:grid;
  grid-template-columns:180px 1fr 42px;
  gap:10px;
  align-items:center;
}
.day-bar-row b,
.rank-row strong{
  display:block;
}
.stack-bar,
.pipeline-bar-row div,
.mix-row div{
  height:12px;
  background:var(--soft-surface);
  border:1px solid var(--rule);
  display:flex;
  overflow:hidden;
}
.stack-bar i,
.pipeline-bar-row i,
.mix-row b{
  display:block;
  height:100%;
}
.bar-task{background:#F26257}
.bar-lead{background:#F2C94C}
.bar-follow{background:#244B5A}
.bar-activity{background:#2F855A}
.pipeline-bar-row,
.attention-list button{
  appearance:none;
  border:1px solid var(--rule);
  background:var(--soft-surface);
  color:var(--ink);
  text-align:left;
  cursor:pointer;
}
.pipeline-bar-row{
  display:grid;
  grid-template-columns:148px 1fr 34px 94px;
  gap:10px;
  align-items:center;
  padding:8px;
}
.pipeline-bar-row:hover,
.attention-list button:hover{
  background:var(--soft-surface-2);
}
.pipeline-bar-row span,
.pipeline-bar-row small,
.mix-row span,
.mix-row em{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.9px;
}
.pipeline-bar-row i{
  background:var(--coral);
}
.rank-row{
  display:grid;
  grid-template-columns:28px 1fr auto;
  gap:10px;
  align-items:center;
  border:1px solid var(--rule);
  background:var(--soft-surface);
  padding:10px;
}
.rank-row > b{
  width:26px;
  height:26px;
  border-radius:50%;
  background:#fff;
  border:1px solid var(--rule);
  display:grid;
  place-items:center;
}
.rank-row em,
.mix-row em{
  font-style:normal;
  font-weight:700;
}
.attention-list button{
  padding:10px;
}
.attention-list b{
  display:block;
  line-height:1.2;
}
.attention-list small{
  display:block;
  margin-top:4px;
}
.mix-row{
  display:grid;
  grid-template-columns:130px 1fr 30px;
  gap:10px;
  align-items:center;
}
.mix-row span{
  display:flex;
  align-items:center;
  gap:6px;
}
.mix-row b{
  background:var(--coral);
}
@media(max-width:1280px){
  body[data-view="dashboard"] .metrics-grid{
    grid-template-columns:repeat(6,minmax(145px,1fr)) !important;
    overflow-x:auto;
  }
  .dashboard-grid{
    grid-template-columns:1fr;
  }
  .dashboard-panel.span-2{
    grid-column:auto;
  }
  .summary-gauges{
    min-width:0;
  }
}
@media(max-width:760px){
  .dashboard-summary{
    display:grid;
  }
  .summary-gauges{
    grid-template-columns:1fr;
  }
  .day-bar-row,
  .pipeline-bar-row,
  .rank-row,
  .mix-row{
    grid-template-columns:1fr;
  }
}

@media (max-width:899px){
  #leadModal,
  #customerModal{
    width:94vw !important;
    max-height:92vh !important;
  }
  #leadForm,
  #customerForm{
    max-height:92vh !important;
    overflow:auto !important;
    padding:18px !important;
  }
  #leadForm .modal-head h2,
  #customerForm .modal-head h2{
    font-size:30px !important;
  }
}

/* V28 lock background while CRM modals are open */
html.modal-open,
body.modal-open{
  overflow:hidden !important;
  overscroll-behavior:none !important;
}
body.modal-open .app-shell{
  overscroll-behavior:none !important;
}
#leadModal,
#customerModal{
  overscroll-behavior:contain !important;
}
#leadModal > .toast,
#customerModal > .toast{
  position:fixed !important;
  top:28px !important;
  right:28px !important;
  bottom:auto !important;
  z-index:2147483647 !important;
  max-width:min(440px,calc(100vw - 56px)) !important;
  border:1px solid rgba(255,255,255,.22) !important;
  box-shadow:0 18px 46px -18px rgba(0,0,0,.55) !important;
}

/* V29 compact lead detail drawer: keep the drawer itself inside the viewport */
@media (min-width:980px){
  .lead-drawer{
    width:min(760px,96vw) !important;
    height:100dvh !important;
    overflow:hidden !important;
    padding:14px 16px !important;
    display:flex !important;
    flex-direction:column !important;
  }
  #leadDrawerBody{
    min-height:0 !important;
    height:100% !important;
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    grid-template-rows:auto auto auto auto minmax(0,1fr) !important;
    gap:8px !important;
  }
  #leadDrawerBody > .drawer-head,
  #leadDrawerBody > .drawer-actions,
  #leadDrawerBody > .drawer-grid,
  #leadDrawerBody > .drawer-section:first-of-type{
    grid-column:1 / -1 !important;
  }
  .drawer-head{
    padding-bottom:8px !important;
    margin-bottom:0 !important;
    gap:12px !important;
  }
  .drawer-head h2{
    font-size:28px !important;
    letter-spacing:-.4px !important;
    margin:2px 0 3px !important;
  }
  .drawer-head p{
    font-size:14px !important;
    line-height:1.25 !important;
  }
  .drawer-actions{
    margin-bottom:0 !important;
    gap:8px !important;
  }
  .drawer-actions .btn{
    min-height:38px !important;
    padding:10px 14px !important;
  }
  .drawer-grid{
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
    gap:8px !important;
    margin-bottom:0 !important;
  }
  .drawer-grid span{
    padding:8px 9px !important;
    min-width:0 !important;
  }
  .drawer-grid small{
    font-size:8.5px !important;
    letter-spacing:1.2px !important;
    margin-bottom:3px !important;
  }
  .drawer-grid b{
    display:block !important;
    font-size:14px !important;
    line-height:1.15 !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    white-space:nowrap !important;
  }
  .drawer-section{
    min-height:0 !important;
    padding:10px !important;
    margin-bottom:0 !important;
  }
  .drawer-section h3{
    font-size:20px !important;
    line-height:1 !important;
    margin:0 0 8px !important;
  }
  #leadDrawerBody > .drawer-section:nth-of-type(2),
  #leadDrawerBody > .drawer-section:nth-of-type(3){
    display:flex !important;
    flex-direction:column !important;
    overflow:hidden !important;
  }
  .drawer-two{
    gap:8px !important;
  }
  .drawer-two label{
    gap:5px !important;
    font-size:8.5px !important;
  }
  .drawer-two select{
    height:36px !important;
    padding:0 9px !important;
  }
  .muted-line{
    font-size:12px !important;
    margin:7px 0 0 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  #leadDrawerBody > .drawer-section:nth-of-type(2) .timeline-list,
  #leadDrawerBody > .drawer-section:nth-of-type(3) .timeline-list{
    min-height:0 !important;
    overflow:auto !important;
    gap:6px !important;
    scrollbar-width:thin;
  }
  .timeline-item{
    padding:8px !important;
  }
  .timeline-item b{
    font-size:12.5px !important;
    line-height:1.2 !important;
  }
  .timeline-item small{
    margin-top:3px !important;
    font-size:11px !important;
  }
  .drawer-inline{
    grid-template-columns:1fr auto !important;
    gap:6px !important;
    margin-top:8px !important;
  }
  .drawer-inline textarea{
    min-height:38px !important;
    height:38px !important;
    padding:9px !important;
    resize:none !important;
  }
  .drawer-inline .btn,
  .drawer-followup-form .btn{
    min-height:38px !important;
    padding:9px 12px !important;
  }
  .drawer-followup-form{
    grid-template-columns:minmax(0,1fr) 122px !important;
    gap:6px !important;
    margin-top:8px !important;
  }
  .drawer-followup-form .btn{
    grid-column:1 / -1 !important;
    width:100% !important;
  }
  .drawer-followup-form input{
    min-width:0 !important;
    height:38px !important;
    padding:0 9px !important;
  }
  .compact-empty{
    padding:16px 10px !important;
    min-height:auto !important;
  }
}
