@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Unbounded:wght@500;600;700&display=swap");
:root{
  --font-body: "Space Grotesk", "Karla", sans-serif;
  --font-display: "Unbounded", "Space Grotesk", sans-serif;
  --bg:#f5f7f9;
  --card:#ffffff;
  --accent:#1f6f5c;
  --accent-strong:#132a24;
  --muted:#55626f;
  --line:#d9e0e6;
  --ink:#1f2933;
  --surface-2:#eef2f6;
  --topo-line: rgba(31, 111, 92, 0.08);
  --topo-line-2: rgba(31, 111, 92, 0.05);
  --topo-glow: rgba(31, 111, 92, 0.06);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.5;
  background-image:linear-gradient(180deg, rgba(255,255,255,0.85), rgba(244,245,243,0.98));
  position:relative;
  isolation:isolate;
}
body::before{
  content:"";
  position:fixed;
  inset:-20% -10%;
  background-image:
    repeating-radial-gradient(circle at 12% 16%, var(--topo-line) 0 1px, transparent 1px 26px),
    repeating-linear-gradient(120deg, rgba(255,255,255,0.35) 0 160px, rgba(242,245,241,0.6) 160px 320px);
  opacity:0.35;
  pointer-events:none;
  z-index:0;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  background:radial-gradient(circle at top right, var(--topo-glow), transparent 60%);
  pointer-events:none;
  z-index:0;
}
h1,h2,h3,.brand,.mode-btn,.tab-btn,.filter-btn{font-family:var(--font-display)}
.dark body{
  background:#0f1916;
  color:#f6fbf8;
  background-image:linear-gradient(180deg, rgba(12,22,19,0.92), rgba(8,15,13,0.97));
  --ink:#f6fbf8;
  --muted:#cbd8d2;
  --topo-line: rgba(97, 197, 171, 0.12);
  --topo-line-2: rgba(97, 197, 171, 0.08);
  --topo-glow: rgba(79, 178, 151, 0.08);
}
.app{display:flex;min-height:100vh;flex-direction:row;position:relative;z-index:1}
.main{max-width:100%;overflow-x:hidden;}
.sidebar{
  width:250px;
  background:linear-gradient(180deg,#0f2e2a 0%,#1b3c33 100%);
  color:#f6fbf8;
  padding:22px 18px;
  display:flex;
  flex-direction:column;
  gap:14px;
  border-right:1px solid rgba(31,111,92,0.3);
  box-shadow:6px 0 24px rgba(18,34,30,0.4);
}
.sidebar{position:sticky;top:0;align-self:flex-start;min-height:100vh}
.dark .sidebar{background:linear-gradient(180deg,#0a1916 0%,#10231f 100%);color:var(--ink)}
.brand{font-weight:800;font-size:1.2rem;margin-bottom:4px;letter-spacing:0.14em;text-transform:uppercase}
.sidebar .subtitle{font-size:0.8rem;color:rgba(247,239,227,0.6);margin-top:-6px;margin-bottom:12px;text-transform:uppercase;letter-spacing:0.18em}
.user-chip{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,0.08);padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,0.08);cursor:pointer;transition:transform .15s ease, box-shadow .15s ease}
.user-chip:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,0.2)}
.user-chip .avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#1f6f5c,#164d41);display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#fff;letter-spacing:0.5px}
.user-chip .avatar.has-photo{color:transparent}
.sidebar nav{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.sidebar a{position:relative;overflow:hidden;color:rgba(255,255,255,0.9);text-decoration:none;padding:10px 12px;border-radius:10px;display:flex;align-items:center;gap:10px;font-weight:600;border:1px solid transparent;transition:all .2s}
.sidebar a[data-role]{display:none}
.sidebar a.always-visible{display:block}
.sidebar a.active{background:linear-gradient(90deg,rgba(31,111,92,0.26),rgba(19,42,36,0.2));border-color:rgba(31,111,92,0.5);color:#fff}
.sidebar a.active::before{
  content:"";
  position:absolute;
  left:0;
  top:6px;
  bottom:6px;
  width:4px;
  border-radius:999px;
  background:linear-gradient(180deg,#1f6f5c,#164d41);
  box-shadow:0 0 12px rgba(31,111,92,0.5);
}
.sidebar a:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.16)}
.collapse{display:none}
.main{
  flex:1;
  padding:20px;
  background-color:var(--bg);
  background-image:none;
}
.dark .main{background:#0f1916;color:var(--ink);background-image:none}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:14px 16px;border-radius:14px;background:linear-gradient(120deg,#102922,#1f6f5c);color:#fff;box-shadow:0 12px 30px rgba(18,34,30,0.35);border:1px solid rgba(31,111,92,0.3)}
.topbar h1{margin:0;font-size:1.3rem;letter-spacing:0.16em;text-transform:uppercase}
.topbar-right{display:flex;align-items:center;gap:12px}
.topbar .muted{background:rgba(31,111,92,0.2)!important;color:#fff;border:1px solid rgba(31,111,92,0.5)!important;padding:8px 14px;border-radius:10px;font-weight:700;box-shadow:0 6px 18px rgba(0,0,0,0.18);text-transform:uppercase;letter-spacing:0.12em;font-size:0.75rem}
.widgets{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}
.card{margin-bottom:16px}
.card:last-of-type{margin-bottom:0}
.card{background:var(--card);padding:16px;border-radius:16px;box-shadow:0 12px 28px rgba(24,36,32,0.16);border:1px solid var(--line);transition:transform .15s ease, box-shadow .15s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(24,36,32,0.2)}
.dark .card{background:#16221f;box-shadow:0 8px 30px rgba(0,0,0,0.45);border:1px solid #22312d}
.card h3{margin:0;color:var(--muted);font-size:0.8rem;letter-spacing:0.16em;text-transform:uppercase}
.dark .card h3{color:var(--muted)}
.value{font-size:1.8rem;font-weight:800;margin-top:8px;color:var(--accent);letter-spacing:0.12em;text-transform:uppercase}
.dark .value{color:#7ce1c4}
.panel{display:grid;grid-template-columns:2fr 1fr;gap:12px;margin-bottom:16px}
.panel:last-of-type{margin-bottom:0}
.quick-actions .card-header{margin-bottom:10px}
.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.action-tile{display:block;padding:14px;border-radius:16px;border:1px solid var(--line);background:linear-gradient(135deg,rgba(31,111,92,0.12),rgba(19,42,36,0.08));text-decoration:none;color:inherit;box-shadow:0 10px 26px rgba(24,36,32,0.14);transition:transform .15s ease, box-shadow .15s ease}
.action-tile:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(24,36,32,0.18)}
.tile-title{font-weight:800;font-size:1rem;color:var(--accent-strong);text-transform:uppercase;letter-spacing:0.08em}
.tile-sub{color:var(--muted);font-size:0.9rem}
.dark .tile-title{color:var(--ink)}
.dark .action-tile{border-color:#22312d;background:linear-gradient(135deg,rgba(31,111,92,0.22),rgba(9,20,17,0.3));color:var(--ink)}
.table-card table{font-size:0.9rem}
.table-card td,.table-card th{padding:8px}
.chart-card,.table-card{background:var(--card);padding:14px;border-radius:10px;border:1px solid var(--line);box-shadow:0 6px 24px rgba(24,36,32,0.08)}
.dark .chart-card,.dark .table-card{background:#16221f;border-color:#22312d;color:var(--ink)}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;padding:8px;color:var(--muted);font-size:0.85rem}
tbody td{padding:10px;border-top:1px solid var(--line)}
.clock{font-size:0.9rem;color:var(--muted)}
.clock-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(31,111,92,0.14);border:1px solid rgba(31,111,92,0.35);padding:6px 10px;border-radius:10px;box-shadow:0 6px 16px rgba(0,0,0,0.12)}
.clock-label{color:#e4f4ed;font-size:11px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase}
.clock-value{color:#fff;font-weight:800;font-size:14px}
.corner-clock{position:fixed;top:16px;right:16px;z-index:200}
.dark thead th{color:var(--muted)}
.dark tbody td{color:var(--ink);border-top:1px solid #22312d}

/* Mobile-friendly nav + layout */
.mobile-nav{display:none}
.bottom-nav{position:sticky;bottom:0;left:0;right:0;background:rgba(19,32,28,0.94);backdrop-filter:blur(10px);color:#fff;z-index:60;border-top:1px solid rgba(255,255,255,0.12);box-shadow:0 -10px 30px rgba(0,0,0,0.35);display:none;padding:10px 12px;border-radius:18px 18px 0 0}
.bottom-nav .nav-toggle{width:100%;background:linear-gradient(135deg,#1f6f5c,#164d41);color:#fff;font-weight:800;padding:14px 16px;border:none;cursor:pointer;letter-spacing:0.2em;border-radius:14px;box-shadow:0 10px 24px rgba(31,111,92,0.35);text-transform:uppercase;transition:transform .15s ease, box-shadow .15s ease}
.bottom-nav .nav-toggle:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(31,111,92,0.4)}
.bottom-nav .nav-items{display:flex;gap:10px;align-items:center;overflow-x:auto;padding:10px 6px;background:transparent;max-height:0;opacity:0;transform:translateY(8px);pointer-events:none;transition:max-height .25s ease, opacity .2s ease, transform .2s ease}
.bottom-nav.expanded{position:fixed;inset:0;border-radius:0;padding:16px;display:flex;flex-direction:column;gap:14px}
.bottom-nav.expanded .nav-toggle{position:sticky;top:0;z-index:1}
.bottom-nav.expanded .nav-items{max-height:calc(100vh - 120px);opacity:1;transform:translateY(0);pointer-events:auto;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;align-items:stretch;gap:12px;padding:8px 2px}
.bottom-nav a{color:rgba(255,255,255,0.95);text-decoration:none;font-size:1.05rem;padding:16px 18px;border-radius:16px;border:1px solid rgba(255,255,255,0.14);white-space:nowrap;display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,0.07);box-shadow:0 10px 22px rgba(0,0,0,0.25)}
.bottom-nav a[data-role]{display:none}
.bottom-nav a:not([data-role]){display:inline-flex}
.bottom-nav a.active{background:linear-gradient(135deg,#1f6f5c,#132a24);border-color:rgba(255,255,255,0.2);box-shadow:0 12px 24px rgba(0,0,0,0.35)}
.bottom-nav-backdrop{position:fixed;inset:0;background:rgba(6,18,29,0.42);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:55}
.bottom-nav-backdrop.active{opacity:1;pointer-events:auto}
.sticky-actions{position:sticky;bottom:20px;background:var(--card);padding:8px 0;z-index:10}
.dark .sticky-actions{background:#16221f}

@media(max-width:900px){
  .panel{grid-template-columns:1fr}
}
@media(max-width:800px){
  .app{flex-direction:column}
  .sidebar{display:none}
  .main{padding:12px;padding-bottom:100px}
  .bottom-nav{display:block!important}
  .widgets{grid-template-columns:1fr}
  .mobile-hide{display:none}
}

/* Inventory page tweaks */
.inventory-card{margin-bottom:12px}
.inventory-form{display:flex;flex-direction:column;gap:10px}
.inventory-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:8px 0 12px 0}
.inventory-toolbar input{max-width:260px}
.inventory-toolbar .muted{white-space:nowrap;background:var(--surface-2);color:var(--ink);border:1px solid var(--line);padding:8px 12px;border-radius:10px;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:0.08em;font-size:0.75rem}
.dark .inventory-toolbar .muted{background:#16221f;color:var(--ink);border:1px solid #22312d}
.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:var(--surface-2);font-size:0.8rem;font-weight:700;color:var(--ink)}
.filter-chip input{margin:0}
.dark .filter-chip{background:#101b18;color:var(--ink);border-color:#22312d}
.scan-toggle{background:rgba(31,111,92,0.08);border-color:rgba(31,111,92,0.3)}
.sticky-bar{position:sticky;top:0;background:var(--card);padding:10px;border-radius:12px;z-index:6;box-shadow:0 10px 24px rgba(15,27,43,0.08)}
.dark .sticky-bar{background:#16221f}
.count-input-col{display:none}
body.count-mode .count-input-col{display:table-cell}
.count-input{width:100%;max-width:120px;padding:6px;border-radius:8px;border:1px solid var(--line)}
.row-detail{background:var(--surface-2)}
.row-detail td{border-top:none;padding:12px}
.row-detail .detail-grid{display:flex;flex-wrap:wrap;gap:8px}
.row-detail .detail-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#ffffff;font-size:0.8rem;font-weight:700;color:var(--ink)}
.row-detail .detail-chip strong{color:var(--muted);font-weight:700}
.dark .row-detail{background:#16221f}
.dark .row-detail .detail-chip{background:#101b18;border-color:#22312d;color:var(--ink)}
.action-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-weight:700;text-decoration:none;margin-right:6px}
.dark .action-btn{background:#16221f;color:var(--ink);border:1px solid #22312d}
.job-breakdown{display:flex;flex-direction:column;gap:6px}
.job-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;border-radius:8px;border:1px solid var(--line);background:#ffffff;font-size:0.85rem;font-weight:700;color:var(--ink)}
.job-empty{color:var(--muted);font-size:0.85rem}
.dark .job-row{background:#101b18;border-color:#22312d;color:var(--ink)}
.stale{color:#b45309;font-weight:800}
.discrepancy-badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:0.75rem;font-weight:800}
.discrepancy-badge.ok{background:rgba(31,111,92,0.12);color:#1b2522;border:1px solid rgba(31,111,92,0.3)}
.dark .discrepancy-badge.ok{color:var(--ink)}
.discrepancy-badge.warn{background:rgba(234,179,8,0.16);color:#854d0e;border:1px solid rgba(234,179,8,0.4)}
.discrepancy-badge.bad{background:rgba(239,68,68,0.16);color:#7f1d1d;border:1px solid rgba(239,68,68,0.4)}
.row-highlight{outline:2px solid rgba(31,111,92,0.55);outline-offset:-2px}
.form-row{display:flex;gap:10px;position:relative}
.line-items{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}
.line-row{align-items:flex-end}
.order-lines-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.order-line{border:1px dashed var(--line);padding:10px;border-radius:10px;background:rgba(31,111,92,0.05)}
.order-line.has-error{border-color:rgba(239,68,68,0.6);background:rgba(239,68,68,0.06)}
.line-error{min-height:16px;font-size:0.8rem;color:#b91c1c;margin-top:4px}
.toggle-inline{display:flex;align-items:center;gap:6px;font-size:0.85rem;font-weight:700;color:#1b2522}
.toggle-inline input{width:auto}
.dark .toggle-inline{color:var(--ink)}
.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin:10px 0}
.summary-item{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:4px}
.summary-item span{font-size:0.8rem;color:var(--muted);font-weight:700}
.summary-item strong{font-size:1.2rem;color:var(--ink)}
.dark .summary-item strong{color:var(--ink)}
.summary-list{margin-top:10px}
.summary-items{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;border-radius:10px;border:1px solid var(--line);background:#ffffff;font-size:0.85rem;font-weight:700;color:var(--ink)}
.filter-chips{display:flex;gap:6px;flex-wrap:wrap}
.filter-btn{padding:6px 10px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:0.12em;font-size:0.72rem}
.filter-btn.active{background:linear-gradient(135deg,#132a24,#1f6f5c);color:#fff;border-color:rgba(31,111,92,0.45)}
.modal{position:fixed;inset:0;background:rgba(3,7,18,0.55);display:flex;align-items:center;justify-content:center;z-index:100}
.modal.hidden{display:none}
.modal-content{background:var(--card);color:inherit;border-radius:14px;padding:16px;width:min(900px,94vw);max-height:80vh;overflow:auto;box-shadow:0 20px 50px rgba(0,0,0,0.4);border:1px solid var(--line)}
.dark .modal-content{background:#16221f;border-color:#22312d;color:var(--ink)}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}
.modal .muted{background:var(--surface-2);color:var(--ink);border:1px solid var(--line);padding:8px 12px;border-radius:8px;font-weight:700}
.dark .modal .muted{background:#16221f;color:var(--ink);border:1px solid #22312d}
.confirm-summary{margin:12px 0;font-weight:700;color:var(--ink)}
.confirm-summary span{color:var(--muted);font-weight:600}
.confirm-table{width:100%;border-collapse:collapse}
.confirm-table th{color:var(--muted);font-size:0.85rem;text-align:left;padding:8px 6px}
.confirm-table td{padding:10px 6px;border-top:1px solid var(--line)}
.dark .confirm-summary{color:var(--ink)}
.dark .confirm-table td{border-top:1px solid #22312d}
.available-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:8px;border:1px solid var(--line);background:#ffffff;font-weight:700;font-size:0.85rem}
.dark .order-line{background:rgba(31,111,92,0.16);border-color:#22312d}
.dark .summary-item{background:#16221f;border-color:#22312d;color:var(--ink)}
.dark .summary-row{background:#101b18;border-color:#22312d;color:var(--ink)}
.dark .filter-btn{background:#16221f;color:var(--ink);border-color:#22312d}
.dark .available-pill{background:#101b18;border-color:#22312d;color:var(--ink)}
.dark input,.dark select,.dark textarea{background:#16221f;color:var(--ink);border-color:#22312d}
.form-row select,
select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  padding:10px 38px 10px 12px;
  border-radius:10px;
  border:1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(31,111,92,0.08), rgba(19,42,36,0.06)) padding-box,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%231b2522' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 12px center;
  font-weight:700;
  color:#1b2522;
  box-shadow:0 8px 18px rgba(24,36,32,0.08);
  transition:border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.form-row select:focus,
select:focus{
  outline:none;
  border-color:rgba(31,111,92,0.6);
  box-shadow:0 0 0 3px rgba(31,111,92,0.18), 0 10px 22px rgba(24,36,32,0.12);
}
.form-row select:hover,
select:hover{
  transform:translateY(-1px);
  border-color:rgba(31,111,92,0.4);
}
.form-row select:disabled,
select:disabled{
  opacity:0.6;
  cursor:not-allowed;
  box-shadow:none;
}
.dark .form-row select,
.dark select{
  background:
    linear-gradient(135deg, rgba(31,111,92,0.22), rgba(9,20,17,0.35)) padding-box,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23f6fbf8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 12px center;
  border-color:#22312d;
  color:var(--ink);
}
.report-detail td{background:var(--surface-2)}
.report-detail .detail-table{width:100%;border-collapse:collapse;font-size:0.85rem}
.report-detail .detail-table th{padding:6px;text-align:left;color:var(--muted);font-size:0.8rem}
.report-detail .detail-table td{padding:6px;border-top:1px solid var(--line)}
.dark .report-detail td{background:#16221f}
.dark .report-detail .detail-table td{border-top:1px solid #22312d}
.compact .card{padding:10px}
.compact .form-row{gap:6px}
.compact .line-items{gap:6px}
.suggestions{position:absolute;top:100%;left:0;background:#fff;border:1px solid #e1d5c7;border-radius:6px;max-height:200px;overflow-y:auto;z-index:10;width:100%;min-width:200px;box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.with-suggest{position:relative;display:block}
.form-row label{display:flex;flex-direction:column;flex:1;font-size:0.9rem}
.form-row input,.form-row textarea,.form-row select{padding:8px;border-radius:6px;border:1px solid var(--line)}
.eta-input{padding-right:40px}
.eta-input::-webkit-calendar-picker-indicator{cursor:pointer;padding:6px;border-radius:8px;background-color:rgba(31,111,92,0.16)}
.dark .eta-input::-webkit-calendar-picker-indicator{background-color:rgba(31,111,92,0.32)}
.inventory-form button{padding:10px 12px;border-radius:10px;border:none;background:linear-gradient(135deg,#1f6f5c,#164d41);color:#fff;font-weight:800;box-shadow:0 8px 16px rgba(31,111,92,0.3);text-transform:uppercase;letter-spacing:0.12em;font-size:0.8rem}
.inventory-form button.muted{background:var(--surface-2);color:var(--ink);border:1px solid var(--line)}
.dark .inventory-form button.muted{background:#16221f;color:var(--ink);border:1px solid #22312d}
@media(max-width:680px){.form-row{flex-direction:column}}
@media(max-width:680px){
  .line-items{gap:12px}
  .line-row{border:1px solid var(--line);padding:12px;border-radius:12px;background:rgba(15,122,87,0.06)}
  .dark .line-row{background:#16221f;border-color:#22312d}
  .line-row label{width:100%}
  .line-row .remove-line{width:100%}
  .line-row button{width:100%}
  .line-row input,.line-row select,.line-row textarea{font-size:16px}
}

.tab-btn{background:var(--surface-2);border:1px solid var(--line);color:var(--ink);font-weight:700;text-transform:uppercase;letter-spacing:0.12em;font-size:0.75rem}
.tab-btn.active{background:linear-gradient(135deg,#132a24,#1f6f5c);color:#fff;border-color:rgba(31,111,92,0.45);box-shadow:0 10px 24px rgba(24,36,32,0.2)}
.mode-tabs{display:flex;gap:8px;margin:0 0 6px 0}
.inventory-tabs{flex-wrap:wrap}
.mode-btn{flex:1;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:var(--card);color:var(--ink);font-weight:800;cursor:pointer;box-shadow:0 6px 16px rgba(24,36,32,0.08);transition:all .15s ease;text-transform:uppercase;letter-spacing:0.12em;font-size:0.78rem}
.mode-btn.active{background:linear-gradient(135deg,#132a24,#1f6f5c);color:#fff;border-color:rgba(31,111,92,0.45);box-shadow:0 10px 24px rgba(24,36,32,0.22)}
.mode-btn:disabled{opacity:0.5;cursor:not-allowed;box-shadow:none}
.mode-content{display:none}
.mode-content.active{display:block}
:is(button,.mode-btn,.tab-btn,.filter-btn,.action-btn,.settings-action,.nav-toggle,.bottom-nav a,.sidebar a,.user-chip):focus-visible{
  outline:3px solid rgba(31,111,92,0.35);
  outline-offset:2px;
}
.dark :is(button,.mode-btn,.tab-btn,.filter-btn,.action-btn,.settings-action,.nav-toggle,.bottom-nav a,.sidebar a,.user-chip):focus-visible{
  outline-color:rgba(124,225,196,0.6);
}
@media(max-width:720px){
  .mode-tabs{flex-wrap:wrap}
  .mode-btn{flex:1 1 120px;white-space:nowrap;padding:6px 8px;font-size:0.7rem;letter-spacing:0.08em}
  table{display:block;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  th,td{white-space:nowrap}
}
.report-cards{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.report-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:0 10px 24px rgba(24,36,32,0.1)}
.dark .report-card{background:#16221f;border-color:#22312d;color:var(--ink)}
.report-card-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.report-card-title{font-weight:800;font-size:1rem}
.report-card-sub{color:var(--muted);font-size:0.85rem;margin-top:2px}
.report-card-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.report-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;margin-top:10px}
.report-chip{background:rgba(31,111,92,0.08);border:1px solid rgba(31,111,92,0.2);border-radius:10px;padding:8px 10px;display:flex;flex-direction:column;gap:4px}
.dark .report-chip{background:#101b18;border-color:#22312d;color:var(--ink)}
.report-chip span{font-size:0.75rem;color:var(--muted);font-weight:700;letter-spacing:0.2px;text-transform:uppercase}
.report-chip strong{font-size:0.95rem;color:inherit}
.report-metrics{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}
.report-metric{flex:1 1 140px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:10px}
.report-metric span{font-size:0.75rem;color:#64748b;font-weight:700;text-transform:uppercase;letter-spacing:0.2px}
.report-metric strong{display:block;font-size:1.1rem;margin-top:4px;color:#1f6f5c}
.dark .report-metric span{color:var(--muted)}
.dark .report-metric strong{color:#7ce1c4}
.report-notes{margin-top:12px;border-top:1px dashed var(--line);padding-top:10px;font-size:0.9rem;color:var(--muted)}
.report-card-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.report-detail{margin-top:10px}
.report-empty{padding:16px;border:1px dashed var(--line);border-radius:12px;color:var(--muted);text-align:center;background:rgba(31,111,92,0.05)}
.dark .report-empty{background:#101b18;border-color:#22312d;color:var(--muted)}
.dark .report-metric{background:#16221f;border-color:#22312d}
.page-grid{display:grid;grid-template-columns:2fr 1.3fr;gap:14px;align-items:start}
@media(max-width:960px){
  .page-grid{grid-template-columns:1fr}
}
.muted-text{color:var(--muted);font-size:0.9rem;margin:0 0 8px 0}
.dark [style*="color:#6b7280"],
.dark [style*="color: #6b7280"]{color:var(--muted)!important}
.data-toolbar{display:flex;align-items:center;gap:10px;margin:8px 0}
.data-toolbar input{max-width:200px}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:0.75rem;font-weight:700;line-height:1;border:1px solid var(--line);color:var(--ink);background:var(--card)}
.badge.info{background:rgba(31,111,92,0.12);color:#1b2522;border-color:rgba(31,111,92,0.3)}
.dark .badge{background:#101b18;color:var(--ink);border-color:#22312d}
.dark .badge.info{background:rgba(31,111,92,0.22);color:var(--ink);border-color:rgba(31,111,92,0.4)}
.badge.warn{background:rgba(234,179,8,0.14);color:#854d0e;border-color:rgba(234,179,8,0.4)}
.badge.danger{background:rgba(239,68,68,0.14);color:#7f1d1d;border-color:rgba(239,68,68,0.4)}
.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:0.75rem;font-weight:800;line-height:1;border:1px solid transparent;text-transform:capitalize}
.status-pill.active{background:rgba(31,111,92,0.12);color:#1b2522;border-color:rgba(31,111,92,0.3)}
.status-pill.trial{background:rgba(59,130,246,0.12);color:#1e3a8a;border-color:rgba(59,130,246,0.3)}
.status-pill.past_due{background:rgba(239,68,68,0.16);color:#7f1d1d;border-color:rgba(239,68,68,0.4)}
.status-pill.cancelled{background:rgba(148,163,184,0.2);color:#334155;border-color:rgba(148,163,184,0.4)}
.status-pill.low{background:rgba(16,185,129,0.12);color:#065f46;border-color:rgba(16,185,129,0.3)}
.status-pill.medium{background:rgba(234,179,8,0.16);color:#854d0e;border-color:rgba(234,179,8,0.4)}
.status-pill.high{background:rgba(239,68,68,0.16);color:#7f1d1d;border-color:rgba(239,68,68,0.4)}
.status-pill.open{background:rgba(59,130,246,0.12);color:#1e3a8a;border-color:rgba(59,130,246,0.3)}
.status-pill.pending{background:rgba(234,179,8,0.16);color:#854d0e;border-color:rgba(234,179,8,0.4)}
.status-pill.closed{background:rgba(148,163,184,0.2);color:#334155;border-color:rgba(148,163,184,0.4)}
.dark .status-pill.active{background:rgba(31,111,92,0.22);color:#ecfeff;border-color:rgba(31,111,92,0.4)}
.dark .status-pill.trial,.dark .status-pill.open{background:rgba(59,130,246,0.2);color:#dbeafe;border-color:rgba(59,130,246,0.35)}
.dark .status-pill.past_due,.dark .status-pill.high{background:rgba(239,68,68,0.2);color:#fee2e2;border-color:rgba(239,68,68,0.35)}
.dark .status-pill.cancelled,.dark .status-pill.closed{background:rgba(148,163,184,0.25);color:#d7e0da;border-color:rgba(148,163,184,0.35)}
.dark .status-pill.low{background:rgba(16,185,129,0.2);color:#d1fae5;border-color:rgba(16,185,129,0.35)}
.dark .status-pill.medium,.dark .status-pill.pending{background:rgba(234,179,8,0.22);color:#fef3c7;border-color:rgba(234,179,8,0.4)}
.sticky-actions-mobile{position:sticky;bottom:0;padding:8px 0;background:var(--card);z-index:5}
.dark .sticky-actions-mobile{background:#16221f}
.bulk-box textarea{font-family:ui-monospace,SFMono-Regular,Consolas,"Liberation Mono",Menlo,monospace}

/* Role visibility helpers */
body.role-admin .sidebar a[data-role='admin']{display:flex}
body.role-employee .sidebar a[data-role='employee']{display:flex}
body.role-none .sidebar a[data-role]{display:none}
body.role-admin .bottom-nav a[data-role='admin']{display:inline-flex}
body.role-employee .bottom-nav a[data-role='employee']{display:inline-flex}
body.role-none .bottom-nav a[data-role]{display:none}
body.role-employee .admin-only{display:none}
.settings-tabs{margin-bottom:12px;flex-wrap:wrap}
.settings-panel{display:flex;flex-direction:column;gap:12px}
.settings-msg{font-size:0.9rem;color:#6b7280;margin-top:8px}
.settings-action{padding:10px 12px;border-radius:10px;border:none;background:linear-gradient(135deg,#1f6f5c,#164d41);color:#fff;font-weight:800;box-shadow:0 8px 16px rgba(31,111,92,0.3);cursor:pointer;text-transform:uppercase;letter-spacing:0.12em;font-size:0.8rem}
.settings-action:disabled{opacity:0.6;cursor:not-allowed;box-shadow:none}
.ticket-subject{font-weight:700;color:#1b2522}
.ticket-body{color:var(--muted);font-size:0.85rem;margin-top:4px}
.dark .ticket-subject{color:var(--ink)}

/* Pro polish (dashboard + operations) */
[data-ds="pro"]{
  --pro-bg:#f5f7f9;
  --pro-surface:#ffffff;
  --pro-surface-2:#eef2f6;
  --pro-border:#d9e0e6;
  --pro-text:#1f2933;
  --pro-muted:#55626f;
  --pro-accent:#1f6f5c;
  --pro-accent-2:#132a24;
  --pro-radius:16px;
  --pro-radius-lg:20px;
  --pro-shadow:0 14px 34px rgba(24,36,32,0.1);
  --pro-shadow-soft:0 10px 22px rgba(24,36,32,0.06);
  background:var(--pro-bg);
  color:var(--pro-text);
  background-image:
    radial-gradient(900px 500px at -10% -20%, rgba(31,111,92,0.08), transparent 60%),
    radial-gradient(900px 450px at 110% 0%, rgba(19,42,36,0.06), transparent 55%);
}
.dark [data-ds="pro"]{
  --pro-bg:#0f1916;
  --pro-surface:#16221f;
  --pro-surface-2:#111b18;
  --pro-border:#22312d;
  --pro-text:#f6fbf8;
  --pro-muted:#9aa9a3;
  --pro-accent:#4bb39a;
  --pro-accent-2:#0b2b26;
  background-image:
    radial-gradient(900px 500px at -10% -20%, rgba(79,178,151,0.2), transparent 60%),
    repeating-radial-gradient(circle at 20% 18%, rgba(79,178,151,0.14) 0 1px, transparent 1px 22px),
    radial-gradient(900px 450px at 110% 0%, rgba(9,20,17,0.45), transparent 55%);
}
[data-ds="pro"] .main{padding:24px}
[data-ds="pro"] .topbar{
  border-radius:var(--pro-radius-lg);
  background:linear-gradient(120deg,var(--pro-accent-2),var(--pro-accent));
  box-shadow:var(--pro-shadow);
}
[data-ds="pro"] .topbar h1{letter-spacing:0.4px}
[data-ds="pro"] .topbar .muted{
  background:rgba(255,255,255,0.18)!important;
  border:1px solid rgba(255,255,255,0.28)!important;
}
[data-ds="pro"] .card,
[data-ds="pro"] .chart-card,
[data-ds="pro"] .table-card{
  border-radius:var(--pro-radius);
  border:1px solid var(--pro-border);
  box-shadow:var(--pro-shadow-soft);
}
[data-ds="pro"] .card{background:var(--pro-surface)}
[data-ds="pro"] .card h3{
  text-transform:uppercase;
  letter-spacing:0.16em;
  font-size:0.78rem;
  color:var(--pro-muted);
}
[data-ds="pro"] .panel{gap:16px}
[data-ds="pro"] .action-tile{
  border-radius:18px;
  background:linear-gradient(140deg,rgba(31,111,92,0.14),rgba(19,42,36,0.1));
  border:1px solid rgba(31,111,92,0.25);
}
[data-ds="pro"] .action-tile .tile-title{color:var(--pro-accent-2)}
[data-ds="pro"] .action-tile .tile-sub{color:var(--pro-muted)}
[data-ds="pro"] .mode-tabs{
  background:var(--pro-surface-2);
  border:1px solid var(--pro-border);
  border-radius:999px;
  padding:6px;
}
[data-ds="pro"] .mode-btn{
  background:transparent;
  border-radius:999px;
  box-shadow:none;
}
[data-ds="pro"] .mode-btn.active{
  background:var(--pro-surface);
  color:var(--pro-text);
  border-color:transparent;
  box-shadow:var(--pro-shadow-soft);
}
[data-ds="pro"] table{border-collapse:separate;border-spacing:0 8px}
[data-ds="pro"] thead th{
  color:var(--pro-muted);
  font-size:0.72rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  padding:0 12px 6px;
}
[data-ds="pro"] tbody tr{
  background:var(--pro-surface);
  box-shadow:0 8px 18px rgba(12,20,33,0.08);
}
[data-ds="pro"] tbody td{
  border-top:none;
  padding:12px;
}
[data-ds="pro"] tbody tr td:first-child{border-radius:12px 0 0 12px}
[data-ds="pro"] tbody tr td:last-child{border-radius:0 12px 12px 0}
[data-ds="pro"] .ops-metric{
  background:linear-gradient(160deg,rgba(31,111,92,0.1),rgba(19,42,36,0.08));
  border:1px solid rgba(31,111,92,0.2);
}
[data-ds="pro"] .ops-metric .value{color:var(--pro-accent)}
[data-ds="pro"] .ops-list{color:var(--pro-muted)}
[data-ds="pro"] .data-toolbar input{border-radius:12px}
[data-ds="pro"] .summary-item{
  border-radius:18px;
  background:linear-gradient(160deg,#fff,#f5f7f9);
  border:1px solid var(--pro-border);
}
[data-ds="pro"] .summary-item strong{color:var(--pro-accent)}
[data-ds="pro"] :is(button,input,select,textarea):focus-visible{
  outline:3px solid rgba(31,111,92,0.35);
  outline-offset:2px;
}
[data-ds="pro"] .main > *{
  animation:pro-rise .35s ease both;
}
[data-ds="pro"] .main > *:nth-child(1){animation-delay:0.02s}
[data-ds="pro"] .main > *:nth-child(2){animation-delay:0.06s}
[data-ds="pro"] .main > *:nth-child(3){animation-delay:0.1s}
[data-ds="pro"] .main > *:nth-child(4){animation-delay:0.14s}
[data-ds="pro"] .main > *:nth-child(5){animation-delay:0.18s}
@keyframes pro-rise{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
@media(max-width:900px){
  [data-ds="pro"] .main{padding:16px;padding-bottom:110px}
}

/* Design system preview scope (order-register.html) */
[data-ds="v1"]{
  --ds-bg:#f5f7f9;
  --ds-surface:#ffffff;
  --ds-surface-2:#eef2f6;
  --ds-text:#1f2933;
  --ds-muted:#55626f;
  --ds-accent:#1f6f5c;
  --ds-accent-strong:#132a24;
  --ds-border:#d9e0e6;
  --ds-radius-sm:10px;
  --ds-radius-md:14px;
  --ds-radius-lg:18px;
  --ds-shadow-1:0 8px 20px rgba(24,36,32,0.06);
  --ds-shadow-2:0 16px 32px rgba(24,36,32,0.1);
  --ds-space-1:4px;
  --ds-space-2:8px;
  --ds-space-3:12px;
  --ds-space-4:16px;
  --ds-space-5:20px;
  --ds-space-6:24px;
  --ds-space-7:32px;
  background:var(--ds-bg);
  color:var(--ds-text);
  background-image:
    radial-gradient(1200px 500px at -10% -10%, rgba(31,111,92,0.06), transparent 60%),
    radial-gradient(900px 400px at 110% 0%, rgba(19,42,36,0.05), transparent 55%);
}
[data-ds="v1"] .main{padding:var(--ds-space-6)}
[data-ds="v1"] .topbar{
  background:linear-gradient(120deg,#132a24,#1f6f5c);
  border-radius:var(--ds-radius-lg);
  box-shadow:var(--ds-shadow-2);
}
[data-ds="v1"] .topbar h1{font-size:1.35rem;letter-spacing:0.2px}
[data-ds="v1"] .card{
  border-radius:var(--ds-radius-lg);
  padding:var(--ds-space-6);
  box-shadow:var(--ds-shadow-1);
  border:1px solid var(--ds-border);
}
[data-ds="v1"] .card:hover{transform:none}
[data-ds="v1"] .card h3{
  font-size:0.85rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--ds-muted);
}
[data-ds="v1"] .page-grid{gap:var(--ds-space-5)}
[data-ds="v1"] .form-row{gap:var(--ds-space-3)}
[data-ds="v1"] label{gap:var(--ds-space-1);font-weight:600;color:var(--ds-muted)}
[data-ds="v1"] input,
[data-ds="v1"] select,
[data-ds="v1"] textarea{
  background:var(--ds-surface);
  border:1px solid var(--ds-border);
  border-radius:var(--ds-radius-md);
  padding:10px 12px;
  min-height:44px;
  font-size:0.95rem;
  color:var(--ds-text);
  box-shadow:inset 0 1px 2px rgba(11,18,32,0.05);
}
[data-ds="v1"] input::placeholder,
[data-ds="v1"] textarea::placeholder{color:#94a3b8}
[data-ds="v1"] .eta-input{padding-right:44px}
[data-ds="v1"] .toggle-inline{color:var(--ds-text)}
[data-ds="v1"] .mode-tabs{
  background:var(--ds-surface-2);
  border:1px solid var(--ds-border);
  padding:6px;
  border-radius:999px;
}
[data-ds="v1"] .mode-btn{
  border-radius:999px;
  background:transparent;
  border:1px solid transparent;
  box-shadow:none;
  min-height:42px;
}
[data-ds="v1"] .mode-btn.active{
  background:var(--ds-surface);
  color:var(--ds-text);
  border-color:var(--ds-border);
  box-shadow:var(--ds-shadow-1);
}
[data-ds="v1"] button,
[data-ds="v1"] .action-btn,
[data-ds="v1"] .filter-btn{
  border-radius:var(--ds-radius-md);
  padding:10px 14px;
  min-height:44px;
  font-weight:700;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
}
[data-ds="v1"] button:active,
[data-ds="v1"] .action-btn:active,
[data-ds="v1"] .filter-btn:active{transform:translateY(1px)}
[data-ds="v1"] .muted,
[data-ds="v1"] .action-btn,
[data-ds="v1"] .filter-btn{
  background:var(--ds-surface-2);
  border:1px solid var(--ds-border);
  color:var(--ds-text);
  box-shadow:0 6px 14px rgba(11,18,32,0.08);
}
[data-ds="v1"] .inventory-form button:not(.muted){
  background:linear-gradient(135deg,#1f6f5c,#2b8a71);
  border:1px solid rgba(31,111,92,0.4);
  box-shadow:0 10px 18px rgba(31,111,92,0.25);
}
[data-ds="v1"] .filter-btn.active{
  background:linear-gradient(135deg,#132a24,#1f6f5c);
  color:#fff;
  border-color:rgba(31,111,92,0.5);
}
[data-ds="v1"] .badge{
  border-radius:999px;
  padding:6px 12px;
  font-weight:800;
  letter-spacing:0.02em;
  background:rgba(15,122,87,0.12);
  border-color:rgba(15,122,87,0.32);
}
[data-ds="v1"] .summary-item{
  background:linear-gradient(135deg,#ffffff,#f3f6fb);
  border-radius:var(--ds-radius-lg);
  border:1px solid var(--ds-border);
}
[data-ds="v1"] .summary-item strong{color:var(--ds-accent)}
[data-ds="v1"] .summary-row{
  border-radius:var(--ds-radius-md);
  border:1px solid var(--ds-border);
  background:var(--ds-surface);
  box-shadow:0 6px 14px rgba(11,18,32,0.06);
}
[data-ds="v1"] table{border-collapse:separate;border-spacing:0 6px}
[data-ds="v1"] thead th{
  padding:0 12px 6px;
  font-size:0.72rem;
  text-transform:uppercase;
  letter-spacing:0.16em;
  color:var(--ds-muted);
}
[data-ds="v1"] tbody tr{
  background:var(--ds-surface);
  box-shadow:0 6px 16px rgba(11,18,32,0.08);
}
[data-ds="v1"] tbody td{
  padding:12px;
  border-top:none;
}
[data-ds="v1"] tbody tr td:first-child{border-radius:var(--ds-radius-md) 0 0 var(--ds-radius-md)}
[data-ds="v1"] tbody tr td:last-child{border-radius:0 var(--ds-radius-md) var(--ds-radius-md) 0}
[data-ds="v1"] .ds-empty{
  border:1px dashed var(--ds-border);
  border-radius:var(--ds-radius-md);
  padding:12px;
  text-align:center;
  color:var(--ds-muted);
  background:rgba(15,122,87,0.04);
}
[data-ds="v1"] .ds-table-empty{
  text-align:center;
  color:var(--ds-muted);
  font-weight:600;
  background:rgba(15,122,87,0.04);
}
[data-ds="v1"] :is(button,input,select,textarea):focus-visible{
  outline:3px solid rgba(31,111,92,0.35);
  outline-offset:2px;
}
@media(max-width:800px){
  [data-ds="v1"] .main{padding:var(--ds-space-4);padding-bottom:110px}
  [data-ds="v1"] .card{padding:var(--ds-space-5)}
  [data-ds="v1"] .mode-tabs{border-radius:16px}
  [data-ds="v1"] input,
  [data-ds="v1"] select,
  [data-ds="v1"] textarea{font-size:16px}
}

