/* ========== Theme tokens ========== */
:root{
  --bg:#0b0c10; --ink:#e9ecf4; --muted:#9aa3b2; --panel:#10131a; --line:#1c2230;
  --gold:#d6b26c; --radius:16px; --shadow:0 10px 30px rgba(0,0,0,.35);
}

/* ========== Base / Layout ========== */
*{ box-sizing:border-box }
html, body { height:100%; max-width:100%; overflow-x:hidden }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font:500 15px/1.55 Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}
img{ max-width:100%; height:auto; }

/* Top bar */
.bar{
  position:sticky; top:0; z-index:40;
  background:linear-gradient(180deg,#0f1218,#0b0f15);
  border-bottom:1px solid var(--line);
  padding:10px 14px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.brand{ display:flex; align-items:center; gap:10px; flex-wrap:wrap }
.brand strong{ font-size:1.15rem; letter-spacing:0.02em; }
.title-with-badge{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.title-with-badge .badge{ margin-top:0; }
.mark{ width:28px; height:28px; border-radius:50%; background:linear-gradient(145deg,var(--gold),rgba(200,173,112,.6)) }
.row{ display:flex; gap:10px; flex-wrap:wrap }

/* Added: live visitor indicator */
.live-indicator{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  color:var(--muted);
  white-space:nowrap;
}

/* Buttons */
.btn{ border:1px solid var(--line); background:#0e121a; color:var(--ink); padding:10px 14px; border-radius:12px; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; height:auto }
.btn.gold{ background:linear-gradient(180deg,rgba(214,178,108,.95),rgba(200,173,112,.8)); color:#161616 }
.btn.small{ padding:6px 10px; font-size:.85rem; border-radius:10px }
.btn.danger{ background:#ff5a5a; color:#fff }
.btn.danger:hover{ background:#d93b3b }
.btn.btn-danger{ background:#ff5a5a; color:#fff }
.btn.btn-danger:hover{ background:#d93b3b }
.btn.btn-secondary{ background:#151a24; color:var(--ink) }
.btn.btn-secondary:hover{ background:#1b2230 }
.hidden{ display:none !important }

/* Page grid */
.layout{
  display:flex;
  min-height:100vh;
  width:100%;
  position:relative;
}
/* Added: admin home header spacing fix */
body.admin-home .layout{ padding-top:6px; }
/* Added: center admin home title to avoid sidebar clipping */
body.admin-home .bar{
  justify-content:center;
}
body.admin-home .bar .hamburger{
  position:absolute;
  left:14px;
}
body.admin-home .bar .brand{
  margin:0 auto;
  justify-content:center;
  text-align:center;
}

/* Sidebar (desktop default) */
#sidebar{
  position:fixed;
  top:0;
  left:-260px;
  width:260px;
  height:100%;
  transition:left .3s ease;
  z-index:9999;
}
#sidebar.open{ left:0; }
.sidebar{
  background:#0f141c; border-right:1px solid #1c2230; padding:20px 16px;
  width:260px;
  max-width:260px;
  height:100%;
  overflow:auto;
}
.sb-brand{ display:flex; gap:10px; align-items:center; margin-bottom:14px; font-size:14px; color:#c9cfdd }
.sb-brand .mark{ width:12px; height:12px; display:inline-block; border-radius:50%; background:linear-gradient(145deg,#d6b26c,#a98c55) }
.sb-nav{ display:flex; flex-direction:column; gap:6px; margin-top:10px }
.sb-nav a{ color:#c9cfdd; text-decoration:none; padding:8px 10px; border-radius:10px; display:block }
.sb-nav a:hover{ background:#141a24 }
.sb-nav a.active{ background:#1b2230; color:#fff; border:1px solid #2a3242 }

/* Main column */
#content,
.content{
  width:100%;
  padding:1rem;
  min-width:0;
  margin-left:0;
}
.content > .bar{
  position:static;
  margin-bottom:18px;
  border-radius:var(--radius);
}

/* Wide content wrapper */
.wrap{
  width:100%;
  max-width:min(96vw, 1720px);
  margin:22px auto;
  padding:0 18px;
  display:grid; gap:18px;
}
@media (min-width:1920px){ .wrap{ max-width:min(96vw, 1880px); } }
@media (min-width:2300px){ .wrap{ max-width:min(96vw, 2040px); } }

/* Panels */
.panel{
  background:linear-gradient(180deg,#11151d,#0d1017);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:18px;
}
h2{ font:700 22px "Playfair Display", serif; margin:0 0 10px }

/* Added: analytics range selector */
.panel-analytics{ position:relative; }
.panel-analytics .range-selector{
  position:absolute;
  top:18px;
  right:18px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.panel-analytics .range-label{
  font-size:12px;
  color:var(--muted);
  letter-spacing:.08em;
  text-transform:uppercase;
}
.panel-analytics .range-custom{
  display:flex;
  align-items:center;
  gap:6px;
}
.panel-analytics .range-sep{
  font-size:12px;
  color:var(--muted);
}
.panel-analytics .range-custom input[type="date"]::-webkit-calendar-picker-indicator{
  filter: invert(1);
  opacity: 0.85;
}
@media (max-width:900px){
  .panel-analytics .range-selector{
    position:static;
    margin-top:8px;
    justify-content:flex-start;
  }
}

/* ---------- Add/Edit form layout fixes ---------- */
.grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; align-items:start }
.grid .col2{ grid-column:span 2 }
.grid > .btn, .grid > button, .grid > .row{ align-self:start; justify-self:start } /* prevent tall stretch */

.admin-form label,
.admin-form fieldset,
.admin-form .col2{
  width:100%;
}
.admin-form fieldset{
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px;
}
.admin-form legend{
  font-size:.9rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:6px;
  color:var(--muted);
}

/* ensure Save Draft / Publish row acts like a row and spans nicely */
.grid .row{ display:flex; gap:10px; flex-wrap:wrap }
.grid .row.col2{ grid-column:span 2 }
.admin-form .form-actions .btn{
  flex:1 1 160px;
}

/* Print sizes editor */
.print-sizes{
  display:grid;
  gap:10px;
  margin-bottom:10px;
}
.print-size-row{
  display:grid;
  grid-template-columns: 1.2fr 0.9fr 0.9fr 0.9fr 0.9fr 0.9fr auto;
  gap:8px;
  align-items:end;
}
.print-size-field{
  display:grid;
  gap:4px;
  font-size:12px;
  color:var(--muted);
}
.print-size-field input{
  font-size:14px;
}
.print-size-remove{
  height:32px;
  align-self:end;
}

/* Inputs fill their cells with consistent control height */
label{ display:grid; gap:6px; min-width:0 }
input, select, textarea{
  background:#0e121a; color:var(--ink);
  border:1px solid var(--line); border-radius:10px; padding:10px;
  min-width:0; width:100%;
  height:42px;                 /* consistent field height */
}
textarea{ height:auto; min-height:42px }
input.locked[readonly],
textarea.locked[readonly]{
  color:var(--muted);
  background:#0b0f16;
  border-style:dashed;
  cursor:not-allowed;
}
input.locked[readonly]::placeholder,
textarea.locked[readonly]::placeholder{
  color:rgba(154,163,178,0.6);
}
.status-text{
  margin-top:8px;
  font-size:.9rem;
  color:var(--muted);
}

/* Drag & drop */
.drop{ border:1px dashed var(--line); border-radius:12px; padding:16px; text-align:center; margin-bottom:12px }
.drop p{ margin:0; word-break:break-word }
.drop .thumbs{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px }
input.drag-over{ outline:2px dashed rgba(212, 175, 55, 0.9); background: rgba(212, 175, 55, 0.08); }
.thumb{ width:90px; height:90px; border:1px solid var(--line); border-radius:8px; overflow:hidden; background:#0e121a; display:grid; place-items:center }
.thumb img{ max-width:100%; max-height:100%; object-fit:contain }
.link{ background:none; border:none; color:var(--gold); cursor:pointer; text-decoration:underline }
.inv{ display:none }

/* Filters */
.filters{ display:flex; gap:10px; margin:10px 0; flex-wrap:wrap }
.bulk-actions{
  display:flex;
  gap:10px;
  align-items:center;
  margin:12px 0;
}
.bulk-actions .bulk-count{
  font-size:12px;
  color:var(--muted);
}

/* Inbox threads */
.thread-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}
.thread-item{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:12px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#0f141c;
  cursor:pointer;
  transition:background .15s ease, box-shadow .15s ease, border-color .15s ease;
  align-items:flex-start;
}
.thread-item:hover{
  background:rgba(255,255,255,.04);
  border-color:#2a3242;
  box-shadow:inset 3px 0 0 #c9a14a;
}
.thread-item.active{
  border-color:#2a3242;
  box-shadow:inset 3px 0 0 #c9a14a;
}
.thread-check{
  display:flex;
  align-items:flex-start;
  padding-top:2px;
}
.thread-checkbox{
  width:16px;
  height:16px;
  cursor:pointer;
  accent-color:var(--gold);
}
.thread-content{
  display:grid;
  gap:6px;
  min-width:0;
}
.thread-snippet{
  color:var(--muted);
  font-size:13px;
}
.thread-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.message-history{
  display:grid;
  gap:10px;
  max-height:60vh;
  overflow:auto;
}
.message{
  display:grid;
  gap:8px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#0f141c;
  padding:12px;
}
.message header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
}
.message header span{
  color:var(--muted);
  font-size:12px;
}
.message p{
  margin:0;
  white-space:pre-wrap;
  word-break:break-word;
}
.message-attachments{
  display:grid;
  gap:8px;
}
.message-attachments-title{
  color:var(--muted);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.message-attachment{
  display:grid;
  gap:8px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#0b1017;
  padding:10px;
}
.message-attachment-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.message-attachment-meta span{
  font-size:13px;
  word-break:break-word;
}
.message-attachment-meta a{
  color:var(--gold);
  font-size:12px;
  text-decoration:none;
}
.message-attachment-meta a:hover,
.message-attachment-meta a:focus-visible{
  text-decoration:underline;
}
.message-attachment video{
  width:100%;
  max-width:560px;
  border-radius:8px;
  border:1px solid var(--line);
  background:#000;
}

/* Tables */
.table-container,
.table-wrap{
  width:100%;
  overflow-x:auto;
  overflow-y:visible;
  -webkit-overflow-scrolling:touch;
  border-radius:12px;
}
.table-scroll{ width:100%; overflow:auto; -webkit-overflow-scrolling:touch; }
.table-scroll table{ min-width:640px; }
.table-wrap::-webkit-scrollbar{ height:8px }
.table-wrap::-webkit-scrollbar-thumb{ background:#1f2533; border-radius:999px }
.tbl{ width:100%; border-collapse:collapse; border:1px solid var(--line); border-radius:12px; overflow:hidden; min-width:720px }
.tbl th, .tbl td{ border-bottom:1px solid var(--line); padding:10px; text-align:left }
.badge{ font-size:12px; color:var(--muted) }

/* Gallery table fixes (scoped) */
.actions-col{
  min-width:110px;
  text-align:right;
}
th.actions-col{
  text-align:right;
}
/* Keep actions visible even when the table needs horizontal scroll. */
.gallery-table th.actions-col,
.gallery-table td.actions{
  position:sticky;
  right:0;
  background:linear-gradient(180deg,#11151d,#0d1017);
}
.gallery-table th.actions-col{
  z-index:3;
}
.gallery-table td.actions{
  z-index:2;
  box-shadow:-1px 0 0 var(--line);
}
td.actions{
  display:flex;
  gap:6px;
  justify-content:flex-end;
  white-space:nowrap;
  flex-wrap:nowrap;
}
.gallery-table{
  table-layout:fixed;
  width:100%;
  min-width:0;
  overflow:visible; /* override .tbl overflow:hidden so actions don't get clipped */
}
.gallery-table tr{
  overflow:visible;
}
.gallery-table th,
.gallery-table td{
  overflow:hidden;
  text-overflow:ellipsis;
}
.gallery-table td.actions{
  overflow:visible;
}
.gallery-table td.actions .btn.small{
  padding:6px 8px;
}
.gallery-table .col-section{ width:110px; }
.gallery-table .col-published{ width:110px; }
.gallery-table .col-featured{ width:110px; }
.gallery-table .col-media{ width:70px; }
.gallery-table .col-updated{ width:170px; }
.gallery-table .col-actions{ width:110px; }

/* ===== Collections (card list) ===== */
#collectionsLayout{
  display:grid;
  grid-template-columns: minmax(260px, 320px) 1fr;
  gap:24px;
  align-items:flex-start;
}
@media (max-width:960px){
  #collectionsLayout{
    grid-template-columns:1fr;
  }
}
#collectionsLayout .card-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap:18px;
}
#cSummary.card-grid{
  grid-template-columns:1fr;
}
#cItems.card-grid .card{ display:flex; flex-direction:column; }
#cSummary.card-grid .card{ cursor:default; }

.card{
  background:#0f1218; border:1px solid #1c2230; border-radius:14px;
  overflow:hidden; box-shadow:0 6px 18px rgba(0,0,0,.25);
}
.card[data-derived-card][data-active="true"]{
  border-color:#d6b26c;
  box-shadow:0 0 0 1px rgba(214,178,108,.35), 0 6px 18px rgba(0,0,0,.25);
}
#collectionsLayout #cItems .card[data-item-card] .item-thumb{
  width:100%;
  height:150px;
  margin-bottom:12px;
  border-radius:10px;
  overflow:hidden;
}
#collectionsLayout #cItems .card[data-item-card] .item-thumb img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
#collectionsLayout #cItems .card[data-item-card] .body{
  padding:12px 14px 14px;
}
#collectionsLayout #cItems .card[data-item-card] .meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:4px;
}

/* keep images tidy; cards will naturally be smaller with more columns */
.card .ph{ aspect-ratio:3/4; background:#0b0e13; display:flex; align-items:center; justify-content:center; overflow:hidden }
.card img{ width:100%; height:100%; object-fit:cover; display:block }
.collection-thumb{width:100%;aspect-ratio:16/9;border-radius:10px;overflow:hidden;background:#0b0e13;margin-bottom:10px;border:1px solid #1c2230;display:flex;align-items:center;justify-content:center;}
.collection-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.collection-thumb.placeholder{color:#5b6374;font-size:.8rem;letter-spacing:.02em;}
.card.empty-card{ justify-content:center; text-align:center; color:#9aa3b2; padding:20px; }

/* tighten text a bit so 6-up looks neat */
.card .body{ padding:10px 12px }
.card .title{ font-weight:600; color:#e8ecf7; font-size:.95rem }
.card .meta{ font-size:.8rem;  color:#9aa3b2; margin-top:2px }
.card .price{ margin-top:6px; color:#d6b26c; font-size:.9rem }
.card .actions{ display:flex; gap:8px; margin-top:8px }
.badge{ font-size:.72rem; padding:2px 8px; border-radius:999px; border:1px solid #2a3242; color:#9aa3b2 }
.badge.success{ border-color:#3aa76d; color:#9ef7c5; }
.badge.muted{ opacity:.85; }
.badge.subtle{ background:rgba(154,163,178,.12); }

/* ===== Mobile / small screens ===== */
.hamburger,
.nav-btn{
  display:inline-flex;
  align-items:center; justify-content:center;
  height:36px; padding:0 10px; border-radius:10px;
  border:1px solid #1c2230; background:#0e121a; color:#e9ecf4;
  font-size:16px; line-height:1; cursor:pointer;
}

.nav-scrim[hidden]{ display:none }
.nav-scrim{ position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:45 }

@media (max-width:900px){
  .layout{ flex-direction:column; }
  #sidebar{ left:-260px; height:100vh; }
  #sidebar.open{
    left:0;
    box-shadow:0 0 0 9999px rgba(0,0,0,.45);
  }
  #content{ margin-left:0 !important; padding:12px 10px; }
  .wrap{ padding:0; margin:12px 0 }
  .panel{ padding:16px }
  .grid{ grid-template-columns:1fr }
  .grid .col2{ grid-column:1 / -1 }
  .content > .bar{
    border-radius:12px;
    flex-wrap:wrap;
    gap:8px;
  }
  .content > .bar .brand{
    flex:1 0 100%;
    justify-content:space-between;
  }
  .content > .bar .brand strong{ font-size:1.05rem; }
  .hamburger{ display:block; }

  .admin-form fieldset{ padding:14px }
  .admin-form label,
  .grid label{
    display:block;
    width:100%;
    margin-bottom:6px;
  }
  .admin-form input,
  .admin-form select,
  .admin-form textarea,
  .grid input,
  .grid select,
  .grid textarea{
    width:100%;
    max-width:100%;
  }
  .admin-form .row,
  .admin-form .row-4{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
  }
  .admin-form .row > *,
  .admin-form .row-4 > *{
    width:100%;
  }
  .admin-form .form-actions{
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }
  .admin-form .form-actions .btn{
    width:100%;
    flex:1 1 auto;
  }
  .items-inline .controls{
    flex-wrap:wrap;
  }
  .items-inline .controls > *{
    flex:1 1 140px;
  }
  .table-container,
  .table-wrap{
    width:100%;
    margin:12px 0 0;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .table-container table,
  .table-wrap table{
    min-width:640px;
  }
  .tbl th, .tbl td{
    padding:8px;
    font-size:.9rem;
  }
  .brand strong{
    font-size:1rem;
  }
  .title-with-badge{
    justify-content:flex-start;
  }
}

@media (min-width:901px){
  .hamburger{ display:none; }
  #sidebar{
    left:0;
    position:fixed;
  }
  #content{
    margin-left:260px;
    padding:24px;
  }
}

/* Tiny: extra padding safety */
@media (max-width:380px){
  .wrap{ padding:0 10px }
}

/* ====== Added: Collapsible folder sidebar & KPI cards ====== */
.sb-tree { display:block; padding:6px 0 8px }
.sb-group { margin:6px 0 }
.sb-toggle {
  width:100%; background:transparent; border:0; color:#c9cfdd;
  font-weight:600; text-align:left; padding:8px 10px; border-radius:10px;
  display:flex; align-items:center; gap:8px; cursor:pointer; text-decoration:none;
}
.sb-toggle:hover { color:#fff; background:#141a24 }
.sb-toggle .carat { margin-left:auto; transition:transform .2s ease }
.sb-toggle.has-badge .carat { margin-left:8px; }
.nav-badge{
  margin-left:auto;
  background:#c9a14a;
  color:#151515;
  font-size:11px;
  font-weight:700;
  padding:2px 6px;
  border-radius:10px;
  line-height:1.2;
}
.sb-group.open > .sb-toggle .carat { transform:rotate(90deg) }
.sb-sub { display:none; padding:4px 0 6px 8px }
.sb-group.open > .sb-sub { display:block }
.sb-sub a {
  display:flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:10px;
  color:#c9cfdd; text-decoration:none; font-weight:500;
}
.submenu-badge{
  margin-left:auto;
  background:#c9a14a;
  color:#151515;
  font-size:11px;
  font-weight:700;
  padding:2px 6px;
  border-radius:10px;
  line-height:1.2;
}
.sb-sub a:hover{ background:#141a24; color:#fff }
.sb-sub a.active{ background:#1b2230; color:#fff; border:1px solid #2a3242 }

/* KPI cards */
.metric{ font-size:24px; font-weight:700 }
.kpi-card{
  background:#0f1218; border:1px solid #1c2230; border-radius:14px;
  padding:12px 14px; min-width:180px;
}
.small{ font-size:.85rem }
.muted{ color:var(--muted) }
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
/* --- Dashboard chart polish --- */
.chart {
  position: relative;
  height: 260px;
  background: var(--panel);
  border-radius: var(--radius);
  overflow: hidden;
}
.chart svg { display:block; width:100%; height:100%; color:var(--gold); }
.chart .grid line { stroke:#1c2230; opacity:.7 }
.chart .area { fill: currentColor; opacity:.08 }
.chart .line-now { stroke: currentColor; stroke-width:2.25; fill:none }
.chart .line-prev { stroke: currentColor; stroke-width:2; fill:none; opacity:.55; stroke-dasharray:4 6 }
.chart .cursor { stroke: #8a93a6; stroke-width:1; opacity:.9 }
.chart .marker { fill: currentColor; stroke:#0f141c; stroke-width:2 }

.chart-tip{
  position:absolute; inset:auto auto 10px 10px;
  background:#0f141c; border:1px solid #1c2230; border-radius:12px;
  padding:10px 12px; font-size:12px; line-height:1.35; color:#e9ecf4;
  box-shadow:0 12px 30px rgba(0,0,0,.35); pointer-events:none; display:none;
  min-width:180px;
}
.chart-tip .muted{opacity:.8}
.chart-up{color:#65d48c}
.chart-down{color:#ff8a8a}
/* Smaller controls sitewide */
/* Compact controls */
input, select, textarea{
  background:#0e121a; color:var(--ink);
  border:1px solid var(--line); border-radius:8px;
  padding:6px 8px;           /* was 10px */
  height:32px;               /* was 42px */
  min-width:0; width:100%;
}
textarea{ height:auto; min-height:32px; }

.btn{ padding:6px 10px; border-radius:8px; font-size:14px; height:32px; }
.btn.small{ padding:4px 8px; font-size:13px; border-radius:8px; }


.img-row { padding: 4px; border-radius: 8px; }
.img-row img { width: 42px; height: 42px; border-radius: 7px; }
/* ===== Compact Admin Controls ===== */
body.compact .panel{ padding:12px; }
body.compact .wrap{ gap:14px; }
body.compact .grid{ gap:8px; }

/* Labels + spacing */
body.compact label{ gap:4px; }

/* Inputs / selects / textareas */
body.compact input,
body.compact select,
body.compact textarea{
  height:30px;                 /* smaller */
  padding:4px 8px;
  border-radius:6px;
  font-size:14px;
}

/* Textareas grow but start compact */
body.compact textarea{
  min-height:70px; height:auto; line-height:1.35;
}

/* Checkboxes / radios */
body.compact input[type="checkbox"],
body.compact input[type="radio"]{
  width:16px; height:16px;
  inline-size:16px; block-size:16px;
  accent-color: var(--gold);
  padding:0; margin:0;
}

/* Select arrow + hit area */
body.compact select{
  appearance:none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='%23c9cfdd'><path d='M1 1l4 4 4-4'/></svg>");
  background-repeat:no-repeat;
  background-position: right 8px center;
  padding-right:28px;
}

/* Buttons */
body.compact .btn{ height:30px; padding:4px 10px; border-radius:6px; font-size:14px; }
body.compact .btn.small{ height:28px; padding:3px 8px; font-size:13px; border-radius:6px; }

/* Image rows on Products page (override inline block) */
body.compact .img-row{ grid-template-columns:36px 1fr auto auto !important; gap:6px !important; padding:4px !important; border-radius:6px !important; }
body.compact .img-row img{ width:36px !important; height:36px !important; border-radius:6px !important; }

/* Mobile improvements */
@media (max-width: 900px) {

  .layout {
    display: block;
  }

  #sidebar {
    position: fixed;
    left: -260px;
    top: 0;
    width: 260px;
    height: 100vh;
    background: var(--panel);
    z-index: 999;
    overflow-y: auto;
    transition: left 0.25s ease;
  }

  #sidebar.open {
    left: 0;
  }

  #navScrim {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.45);
    z-index: 998;
    display: none;
  }

  #navScrim.show {
    display: block;
  }

  .content {
    padding: 20px;
  }

  .wrap{
    width:100% !important;
    max-width:100% !important;
    padding:0 12px !important;
  }
  .panel{
    width:100%;
  }

  .grid,
  .row,
  .row-2,
  .row-3,
  .row-4,
  .grid.col2,
  .grid.col3,
  .grid.col4,
  .address-grid,
  .panel-grid,
  .vendor-grid,
  .support-grid,
  .calendar-grid,
  .stats,
  .card-grid{
    grid-template-columns:1fr !important;
  }
  .grid > .col2,
  .grid > .col3,
  .grid > .col4,
  .col2,
  .col3,
  .col4{
    grid-column:1 / -1 !important;
  }

  .table-wrap,
  .table-container{
    max-width:100%;
  }
  .table-wrap table,
  .table-container table{
    min-width:100% !important;
  }
}

/* ===== Mobile app layout overrides ===== */
@media (max-width: 900px) {
  body{
    font-size:15px;
  }
  body.nav-open{
    overflow:hidden;
  }
  .bar{
    position:sticky;
    top:0;
    z-index:1000;
    padding:12px 14px;
    border-radius:0;
  }
  .bar .brand{
    flex:1;
    min-width:0;
  }
  #menu-toggle{
    display:inline-flex !important;
    width:42px;
    height:42px;
    font-size:20px;
    border-radius:12px;
  }
  #sidebar{
    width:min(82vw, 320px);
    left:-100%;
    z-index:1000;
  }
  #sidebar.open{ left:0; }
  .sidebar{
    width:100%;
    max-width:100%;
  }
  .nav-scrim{
    z-index:900;
  }
  #content,
  .content{
    padding:12px;
  }
  .wrap{
    width:100%;
    max-width:100%;
    margin:10px 0 24px;
    padding:0;
    gap:12px;
  }
  .panel{
    padding:14px;
    border-radius:14px;
  }
  .wrap .row,
  .wrap .row-2,
  .wrap .row-3,
  .wrap .row-4,
  .wrap .grid,
  .wrap .grid.col2,
  .wrap .grid.col3,
  .wrap .grid.col4,
  .wrap .address-grid,
  .wrap .panel-grid,
  .wrap .vendor-grid,
  .wrap .support-grid,
  .wrap .calendar-grid,
  .wrap .stats,
  .wrap .card-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px;
  }
  .wrap .col2,
  .wrap .col3,
  .wrap .col4{
    grid-column:1 / -1 !important;
  }

  .table-wrap,
  .table-container,
  .table-scroll{
    overflow:visible !important;
  }
  .table-wrap table,
  .table-container table,
  .table-scroll table{
    width:100%;
    min-width:0 !important;
    border:0;
  }
  .table-wrap thead,
  .table-container thead,
  .table-scroll thead{
    display:none;
  }
  .table-wrap tbody,
  .table-container tbody,
  .table-scroll tbody,
  .table-wrap tr,
  .table-container tr,
  .table-scroll tr{
    display:block;
    width:100%;
  }
  .table-wrap tbody tr,
  .table-container tbody tr,
  .table-scroll tbody tr{
    border:1px solid var(--line);
    border-radius:14px;
    padding:10px 12px;
    margin-bottom:12px;
    background:#0f141c;
  }
  .table-wrap tbody td,
  .table-container tbody td,
  .table-scroll tbody td{
    border:0;
    padding:6px 0;
    display:grid;
    gap:4px;
    word-break:break-word;
  }
  .table-wrap tbody td::before,
  .table-container tbody td::before,
  .table-scroll tbody td::before{
    content:attr(data-label);
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:0.08em;
    color:var(--muted);
    font-weight:600;
  }
  .table-wrap tbody td[data-label=""]::before,
  .table-container tbody td[data-label=""]::before,
  .table-scroll tbody td[data-label=""]::before{
    content:"";
    display:none;
  }
  .table-wrap tbody td.actions,
  .table-container tbody td.actions,
  .table-scroll tbody td.actions{
    justify-items:end;
  }
  .table-wrap tbody td.actions::before,
  .table-container tbody td.actions::before,
  .table-scroll tbody td.actions::before{
    content:"";
    display:none;
  }
  .table-wrap tbody td input,
  .table-wrap tbody td select,
  .table-wrap tbody td textarea,
  .table-container tbody td input,
  .table-container tbody td select,
  .table-container tbody td textarea,
  .table-scroll tbody td input,
  .table-scroll tbody td select,
  .table-scroll tbody td textarea{
    width:100%;
  }
  .print-size-row{
    grid-template-columns:1fr 1fr;
  }
  .print-size-remove{
    grid-column:1 / -1;
    width:100%;
  }
}
