/* BonusDostavkaBot UI (light + dark theme)
   If styles “suddenly disappear”, check that this file has no syntax error.
*/

:root{
  --bg1:#f5f7ff;
  --bg2:#eef2ff;
  --text:#0f172a;
  --muted:rgba(15,23,42,.68);
  --card:rgba(255,255,255,.86);
  --card2:rgba(255,255,255,.62);
  --border:rgba(15,23,42,.12);
  --shadow:0 14px 40px rgba(2,6,23,.12);

  --primary:#2563eb;
  --success:#16a34a;
  --danger:#ef4444;
  --warn:#f59e0b;

  --link:#2563eb;
  --input-bg:rgba(255,255,255,.78);
  --btn-muted-bg:rgba(15,23,42,.06);
  --focus:rgba(96,165,250,.55);
}

html[data-theme="dark"]{
  color-scheme: dark;
  --bg1:#071225;
  --bg2:#0b1220;
  --text:#e5e7eb;
  --muted:rgba(229,231,235,.72);
  --card:rgba(16,26,47,.78);
  --card2:rgba(16,26,47,.55);
  --border:rgba(255,255,255,.12);
  --shadow:0 18px 55px rgba(0,0,0,.38);

  --primary:#3b82f6;
  --success:#22c55e;
  --danger:#f87171;
  --warn:#fbbf24;

  --link:#93c5fd;
  --input-bg:rgba(9,19,40,.75);
  --btn-muted-bg:rgba(255,255,255,.06);
  --focus:rgba(147,197,253,.55);
}

*{ box-sizing:border-box; }
html, body{ height:100%; }

body{
  margin:0;
  color:var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  line-height:1.55;
  background:
    radial-gradient(1100px 520px at 10% 0%, rgba(59,130,246,.22), transparent 55%),
    radial-gradient(900px 520px at 90% 10%, rgba(34,197,94,.18), transparent 52%),
    linear-gradient(180deg, var(--bg1), var(--bg2));
}

img{ max-width:100%; height:auto; }

a, a:visited{ color:var(--link); text-decoration:none; }
a:hover{ text-decoration:underline; }

.container{
  max-width:1120px;
  margin:0 auto;
  padding:18px 16px 30px;
}

.header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:18px;
  background:var(--card);
  backdrop-filter: blur(10px);
  box-shadow:var(--shadow);
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--text);
  font-weight:900;
  letter-spacing:.2px;
}

.brand-badge{
  width:14px;
  height:14px;
  border-radius:6px;
  background: linear-gradient(135deg, #22c55e, #3b82f6);
  box-shadow: 0 0 0 4px rgba(37,99,235,.10);
}

.nav{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.nav a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
  font-weight:800;
  text-decoration:none;
  transition: transform .12s ease, filter .12s ease, background-color .12s ease, border-color .12s ease;
}

.nav a:hover{ transform: translateY(-1px); filter: brightness(1.04); text-decoration:none; }

.grid{
  display:grid;
  grid-template-columns: 1.25fr 0.85fr;
  gap:18px;
  margin-top:18px;
}

@media (max-width: 900px){
  .grid{ grid-template-columns: 1fr; }
}

.card{
  border:1px solid var(--border);
  background:var(--card);
  border-radius:22px;
  box-shadow:var(--shadow);
  backdrop-filter: blur(10px);
}

.padded{ padding:22px; }

h1, h2, h3{ line-height:1.15; margin: 0 0 10px; }
h1{ font-size:40px; letter-spacing:-.5px; }
h2{ font-size:24px; }
h3{ font-size:18px; }

p{ margin: 0 0 12px; color: var(--muted); }
ul, ol{ margin: 0 0 12px 18px; color: var(--muted); }
li{ margin: 4px 0; }

hr{
  border:0;
  height:1px;
  background:var(--border);
  margin:16px 0;
}

.actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.btn, button.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:10px 16px;
  border-radius:14px;
  border:1px solid transparent;
  font-weight:900;
  cursor:pointer;
  user-select:none;
  text-decoration:none;
  transition: transform .12s ease, filter .12s ease, background-color .12s ease, border-color .12s ease;
  font: inherit;
}

.btn:hover{ filter: brightness(1.05); text-decoration:none; }
.btn:active{ transform: translateY(1px); }

.btn-primary{ background:var(--primary); color:#fff; }
.btn-success{ background:var(--success); color:#fff; }
.btn-danger{ background:var(--danger); color:#fff; }
.btn-warn{ background:var(--warn); color:#1f2937; }

.btn-ghost{
  background: transparent;
  border-color: var(--border);
  color: var(--text);
}

.btn-ghost:hover{ background: var(--btn-muted-bg); }

.kbd{
  display:inline-block;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
  font-weight:800;
  font-size:12px;
}

.small{
  font-size:12px;
  color:var(--muted);
}

.form{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.form-row{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.label{
  font-weight:900;
  font-size:13px;
  color:var(--text);
}

.helper{ font-size:12px; color:var(--muted); }

input[type="text"],
input[type="password"],
input[type="number"],
input[type="email"],
select,
textarea{
  width:100%;
  background:var(--input-bg);
  color:var(--text);
  border:1px solid var(--border);
  border-radius:14px;
  padding:10px 12px;
  font: inherit;
}

input::placeholder, textarea::placeholder{ color: rgba(127,127,127,.85); }

html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder{ color: rgba(229,231,235,.55); }

input[type="file"]{
  color:var(--muted);
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.btn:focus-visible,
.theme-toggle:focus-visible,
.nav a:focus-visible{
  outline:3px solid var(--focus);
  outline-offset:2px;
}

.notice{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
  font-weight:800;
}

.notice.success{ border-color: rgba(22,163,74,.35); background: rgba(22,163,74,.14); }
.notice.error{ border-color: rgba(239,68,68,.35); background: rgba(239,68,68,.14); }
.notice.warn{ border-color: rgba(245,158,11,.35); background: rgba(245,158,11,.16); }

.footer{
  margin-top:16px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  padding:8px 2px;
}

.toast-container{
  position: fixed;
  right: 16px;
  bottom: 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index: 9999;
}

.toast{
  min-width: 260px;
  max-width: 360px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--card);
  box-shadow: var(--shadow);
  padding: 12px 14px;
}

/* ===== Toast improvements (close button + type accent) ===== */
.toast{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding-right:46px; /* space for close */
  color:var(--text);
  animation: toastIn .18s ease both;
}

.toast .toast-msg{
  font-size:14px;
  line-height:1.35;
  font-weight:800;
}

.toast .toast-close{
  position:absolute;
  top:8px;
  right:8px;
  width:28px;
  height:28px;
  border-radius:10px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
}

.toast .toast-close:hover{ filter:brightness(1.06); }
.toast .toast-close:active{ transform: translateY(1px); }

.toast.success, .toast.toast-success{ border-left:4px solid var(--success); }
.toast.error,   .toast.toast-error{   border-left:4px solid var(--danger); }
.toast.warn,    .toast.toast-warn{    border-left:4px solid var(--warn); }
.toast.info,    .toast.toast-info{    border-left:4px solid var(--primary); }

.toast.toast-out{ animation: toastOut .18s ease both; }

@keyframes toastIn{
  from{ opacity:0; transform: translateY(10px); }
  to{ opacity:1; transform:none; }
}
@keyframes toastOut{
  from{ opacity:1; transform:none; }
  to{ opacity:0; transform: translateY(10px); }
}

@media (max-width: 520px){
  .toast-container{ left:12px; right:12px; bottom:12px; }
  .toast{ max-width:none; width:100%; min-width:unset; }
}


/* Tables (used on some admin pages) */
table{ width:100%; border-collapse:collapse; background:transparent; }
th, td{ border-bottom:1px solid var(--border); padding:10px 8px; text-align:left; }
tr:hover td{ background: var(--btn-muted-bg); }

/* ===== Theme toggle button ===== */
.theme-toggle{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
  cursor:pointer;
  font-weight:900;
  line-height:1;
  transition: transform .12s ease, filter .12s ease, background-color .12s ease, border-color .12s ease;
  font: inherit;
}

.theme-toggle:hover{ transform: translateY(-1px); filter: brightness(1.04); }
.theme-toggle:active{ transform: translateY(1px); }
.theme-toggle .theme-ico{ font-size:16px; }
.theme-toggle .theme-txt{ font-size:13px; }

/* Dashboard legacy helpers */
.page-dashboard h1{ font-size: 34px; margin-top: 18px; }
.page-dashboard p, .page-dashboard li{ color: var(--muted); }

/* ===== Dark theme: fix legacy inline styles on dashboard/settings blocks ===== */
/* Many dashboard blocks still use inline styles like background: #f8f9fa / #fff / white and color: #333.
   In dark theme those look "white inside". This patch maps them to theme tokens. */

html[data-theme="dark"] .page-dashboard [style*="background:#f8f9fa"],
html[data-theme="dark"] .page-dashboard [style*="background: #f8f9fa"],
html[data-theme="dark"] .page-dashboard [style*="background:#fff"],
html[data-theme="dark"] .page-dashboard [style*="background: #fff"],
html[data-theme="dark"] .page-dashboard [style*="background:white"],
html[data-theme="dark"] .page-dashboard [style*="background: white"]{
  background: var(--card) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
  box-shadow: var(--shadow) !important;
}

html[data-theme="dark"] .page-dashboard [style*="color:#333"],
html[data-theme="dark"] .page-dashboard [style*="color: #333"],
html[data-theme="dark"] .page-dashboard [style*="color:#222"],
html[data-theme="dark"] .page-dashboard [style*="color: #222"],
html[data-theme="dark"] .page-dashboard [style*="color:#444"],
html[data-theme="dark"] .page-dashboard [style*="color: #444"],
html[data-theme="dark"] .page-dashboard [style*="color:#555"],
html[data-theme="dark"] .page-dashboard [style*="color: #555"]{
  color: var(--text) !important;
}

html[data-theme="dark"] .page-dashboard [style*="color:#777"],
html[data-theme="dark"] .page-dashboard [style*="color: #777"],
html[data-theme="dark"] .page-dashboard [style*="color:#aaa"],
html[data-theme="dark"] .page-dashboard [style*="color: #aaa"]{
  color: var(--muted) !important;
}

/* Inline borders often hardcode #eee/#ccc */
html[data-theme="dark"] .page-dashboard [style*="border:1px solid #eee"],
html[data-theme="dark"] .page-dashboard [style*="border: 1px solid #eee"],
html[data-theme="dark"] .page-dashboard [style*="border:1px solid #ccc"],
html[data-theme="dark"] .page-dashboard [style*="border: 1px solid #ccc"],
html[data-theme="dark"] .page-dashboard [style*="border:2px dashed #28a745"],
html[data-theme="dark"] .page-dashboard [style*="border: 2px dashed #28a745"]{
  border-color: var(--border) !important;
}

/* Inputs in dashboard have inline borders (#ccc) — keep them consistent */
html[data-theme="dark"] .page-dashboard input[style*="border:1px solid #ccc"],
html[data-theme="dark"] .page-dashboard input[style*="border: 1px solid #ccc"],
html[data-theme="dark"] .page-dashboard input[style*="border:1px solid #eee"],
html[data-theme="dark"] .page-dashboard input[style*="border: 1px solid #eee"],
html[data-theme="dark"] .page-dashboard textarea[style*="border:1px solid #ccc"],
html[data-theme="dark"] .page-dashboard textarea[style*="border: 1px solid #ccc"],
html[data-theme="dark"] .page-dashboard select[style*="border:1px solid #ccc"],
html[data-theme="dark"] .page-dashboard select[style*="border: 1px solid #ccc"]{
  border-color: var(--border) !important;
  background: var(--input-bg) !important;
  color: var(--text) !important;
}

/* Light placeholders/empty-photo blocks */
html[data-theme="dark"] .page-dashboard [style*="background:#f0f0f0"],
html[data-theme="dark"] .page-dashboard [style*="background: #f0f0f0"]{
  background: rgba(255,255,255,.05) !important;
  border-color: var(--border) !important;
  color: var(--muted) !important;
}


/* Fix: visited links inside buttons should not change contrast */
a.btn:visited{ color: var(--text); }
a.btn-primary:visited,
a.btn-success:visited,
a.btn-danger:visited{ color:#fff; }
a.btn-warn:visited{ color:#1f2937; }
a.btn-ghost:visited,
a.btn-gray:visited{ color: var(--text); }


.tg-open-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid rgba(37,99,235,.35);
  background: rgba(37,99,235,.08);
  color: #1d4ed8;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}

.tg-open-btn:hover{
  background: rgba(37,99,235,.14);
  border-color: rgba(37,99,235,.55);
  transform: translateY(-1px);
}

.tg-open-btn:active{ transform: translateY(0); }

/* Тёмная тема */
html[data-theme="dark"] .tg-open-btn{
  color: #93c5fd;
  border-color: rgba(147,197,253,.35);
  background: rgba(59,130,246,.12);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}
html[data-theme="dark"] .tg-open-btn:hover{
  background: rgba(59,130,246,.18);
  border-color: rgba(147,197,253,.55);
}

/* Миниатюры для категорий/подкатегорий в строке меню (dashboard) */
.page-dashboard .thumb{
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--card2);
  flex: 0 0 auto;
  display: block;
}

.page-dashboard .thumb--cat{
  width: 120px;
  height: 120px;
}

.page-dashboard .thumb--subcat{
  width: 120px;
  height: 120px;
  border-radius: 9px;
}


/* Аватар бота в ЛК */
.page-dashboard .bot-avatar-line{
  display:flex;
  align-items:center;
  gap:12px;
  margin: 10px 0;
}
.page-dashboard .bot-avatar-img{
  width: 96px;
  height: 96px;
  object-fit: cover;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--card2);
  flex: 0 0 auto;
  display:block;
}

/* =========================================================
   Dashboard: Menu Tree (accordion like screenshot)
   ========================================================= */
.page-dashboard .menu-tree{
  margin-top: 10px;
}

.page-dashboard .menu-tree details{
  border:1px solid var(--border);
  background: var(--card);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(2,6,23,.06);
}

.page-dashboard .menu-tree details + details{ margin-top: 10px; }

.page-dashboard .menu-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 12px 14px;
  cursor:pointer;
  list-style:none;
}

.page-dashboard .menu-row::-webkit-details-marker{ display:none; }

.page-dashboard .menu-row__left{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.page-dashboard .menu-thumb{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--card2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.page-dashboard .menu-row--sub .menu-thumb{
  width: 30px;
  height: 30px;
  border-radius: 9px;
}
.page-dashboard .menu-thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.page-dashboard .menu-thumb__ph{
  font-size: 14px;
  color: var(--muted);
  line-height: 1;
}

.page-dashboard .menu-row__right{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.page-dashboard .menu-title{
  font-weight: 900;
  letter-spacing:.1px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width: 520px;
}

@media (max-width: 720px){
  .page-dashboard .menu-title{ max-width: 240px; }
}

.page-dashboard .menu-price{
  font-weight: 900;
  color: color-mix(in srgb, var(--danger) 82%, var(--text));
  margin-left: 6px;
  white-space:nowrap;
}

.page-dashboard .menu-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height: 22px;
  padding: 0 10px;
  border-radius: 999px;
  border:1px solid var(--border);
  background: var(--card2);
  font-weight: 900;
  font-size: 12px;
  color: var(--muted);
  white-space:nowrap;
}

.page-dashboard .menu-chevron{
  width: 10px;
  height: 10px;
  border-right: 2px solid color-mix(in srgb, var(--muted) 80%, var(--text));
  border-bottom: 2px solid color-mix(in srgb, var(--muted) 80%, var(--text));
  transform: rotate(-45deg);
  transition: transform .14s ease;
  flex: 0 0 auto;
}

.page-dashboard details[open] > summary .menu-chevron{
  transform: rotate(45deg);
}

.page-dashboard .menu-actions{ cursor: default; }

.page-dashboard .btn-mini{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 7px 10px;
  border-radius: 10px;
  border:1px solid var(--border);
  background: var(--card2);
  color: var(--text);
  font-weight: 900;
  font-size: 13px;
  line-height: 1;
  text-decoration:none;
  user-select:none;
  cursor:pointer;
}

.page-dashboard .btn-mini:hover{ filter: brightness(1.04); text-decoration:none; }

.page-dashboard .btn-mini--primary{
  background: var(--primary);
  border-color: transparent;
  color:#fff;
}

.page-dashboard .btn-mini--danger{
  background: var(--danger);
  border-color: transparent;
  color:#fff;
}

.page-dashboard .btn-mini--muted{
  background: var(--btn-muted-bg);
}

.page-dashboard .btn-mini--ghost{
  background: transparent;
}

.page-dashboard .btn-mini--icon{
  padding: 7px 8px;
  width: 36px;
  min-width: 36px;
  justify-content: center;
  gap: 0;
}

.page-dashboard .menu-inline{ display:inline; margin:0; }
.page-dashboard .menu-block{ display:block; margin: 8px 0 0 0; }
.page-dashboard .menu-block:first-child{ margin-top:0; }

.page-dashboard .menu-body{
  padding: 12px 14px 14px;
  border-top:1px solid var(--border);
  background: color-mix(in srgb, var(--card) 80%, var(--card2));
}

.page-dashboard .menu-body--inner{
  background: color-mix(in srgb, var(--card) 68%, var(--card2));
  border-top:1px solid color-mix(in srgb, var(--border) 75%, transparent);
}

.page-dashboard .menu-subcats > details{ margin-top: 10px; }
.page-dashboard .menu-subcats > details:first-child{ margin-top: 0; }

.page-dashboard .menu-empty{
  padding: 12px 14px;
  border: 1px dashed color-mix(in srgb, var(--border) 75%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--card2) 65%, transparent);
  color: var(--muted);
  font-weight: 800;
}

.page-dashboard .menu-add{
  margin-top: 12px;
  border-style: dashed;
  background: color-mix(in srgb, var(--card2) 72%, transparent);
}

.page-dashboard .menu-add--root{ margin-top: 16px; }

.page-dashboard .menu-add > summary{
  justify-content:center;
  color: var(--primary);
}

.page-dashboard .menu-add-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 14px;
  font-weight: 950;
  cursor:pointer;
}

.page-dashboard .menu-add-panel{
  padding: 12px 14px 14px;
  border-top:1px dashed color-mix(in srgb, var(--border) 75%, transparent);
}

.page-dashboard .menu-form{
  display:grid;
  gap:10px;
  margin:0;
}

.page-dashboard .menu-form input[type="text"],
.page-dashboard .menu-form input[type="number"],
.page-dashboard .menu-form textarea,
.page-dashboard .menu-form select{
  width: 100%;
}

.page-dashboard .menu-form__row{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.page-dashboard .menu-form__row input[type="file"]{
  flex: 1 1 220px;
}

.page-dashboard .menu-tag{
  display:inline-flex;
  align-items:center;
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card2);
  font-weight: 950;
  font-size: 12px;
  color: var(--muted);
  white-space:nowrap;
}

.page-dashboard .menu-tag--off{
  background: color-mix(in srgb, var(--danger) 18%, var(--card));
  border-color: color-mix(in srgb, var(--danger) 35%, var(--border));
  color: color-mix(in srgb, var(--danger) 80%, var(--text));
}

/* Kebab menu */
.page-dashboard .menu-kebab,
.page-dashboard .menu-kebab-inner{
  position: relative;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.page-dashboard .menu-kebab > summary,
.page-dashboard .menu-kebab-inner > summary{
  list-style:none;
}

.page-dashboard .menu-kebab__panel{
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  width: 220px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--card);
  box-shadow: var(--shadow);
  z-index: 20;
}

.page-dashboard .menu-kebab__panel--inner{
  position: static;
  width: auto;
  margin-top: 10px;
  box-shadow: none;
  background: color-mix(in srgb, var(--card) 80%, var(--card2));
}

.page-dashboard .menu-kebab__title{
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .2px;
  color: var(--muted);
  margin: 0 0 8px 0;
}

.page-dashboard .menu-kebab-sep{
  height: 1px;
  background: var(--border);
  margin: 10px 0;
}

/* Product details body */
.page-dashboard .menu-prod{ margin-top: 10px; }
.page-dashboard .menu-products .menu-prod:first-child{ margin-top: 0; }

.page-dashboard .menu-prod__body{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap: 14px;
  padding: 12px 14px 14px;
  border-top:1px solid var(--border);
  background: color-mix(in srgb, var(--card) 76%, var(--card2));
}

@media (max-width: 720px){
  .page-dashboard .menu-prod__body{ grid-template-columns: 1fr; }
}

.page-dashboard .menu-prod__img{
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 14px;
  border:1px solid var(--border);
}

.page-dashboard .menu-prod__noimg{
  width: 120px;
  height: 120px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 14px;
  border:1px dashed var(--border);
  background: var(--card2);
  color: var(--muted);
  font-weight: 900;
  font-size: 12px;
}

.page-dashboard .menu-prod__desc{
  color: var(--muted);
  font-weight: 650;
}

/* Small switch for product row */
.page-dashboard .switch-sm{
  transform: scale(.88);
  transform-origin: center;
}

/* Category image in kebab */
.page-dashboard .menu-cat__img{
  width: 100%;
  max-height: 180px;
  object-fit: cover;
  border-radius: 12px;
  border:1px solid var(--border);
  margin-bottom: 10px;
}

.page-dashboard .menu-cat__noimg{
  padding: 10px 12px;
  border-radius: 12px;
  border:1px dashed var(--border);
  background: var(--card2);
  color: var(--muted);
  font-weight: 900;
  margin-bottom: 10px;
}



/* =========================================================
   Dashboard Menu Tree: Hierarchy v4 (clear nesting)
   - No "branches" lines, but strong level blocks + indentation
   - Small thumbs inside the tree (do not affect other pages)
   ========================================================= */

/* Make thumbs in menu tree compact */
.page-dashboard .menu-tree .thumb{
  width: 34px;
  height: 34px;
  border-radius: 10px;
}

/* In case some templates use menu-thumb instead of thumb */
.page-dashboard .menu-tree .menu-thumb{
  width: 34px;
  height: 34px;
  border-radius: 10px;
}

/* Ensure left block uses flex (support both legacy and new markup) */
.page-dashboard .menu-tree .menu-left,
.page-dashboard .menu-tree .menu-row__left{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.page-dashboard .menu-tree .menu-actions,
.page-dashboard .menu-tree .menu-row__right{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

/* CATEGORY level (top) */
.page-dashboard .menu-tree > details.menu-cat{
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--primary) 28%, var(--border));
  box-shadow: 0 10px 26px rgba(2,6,23,.08);
  overflow:hidden;
}

.page-dashboard .menu-tree > details.menu-cat > summary.menu-row{
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--primary) 14%, var(--card)) 0%,
    var(--card) 62%
  );
}

.page-dashboard .menu-tree > details.menu-cat > .menu-body{
  background: color-mix(in srgb, var(--primary) 5%, var(--card2));
  padding: 14px;
}

/* SUBCATEGORY level */
.page-dashboard .menu-cat .menu-body > details.menu-subcat{
  margin-left: 16px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--warn) 24%, var(--border));
  box-shadow: 0 8px 20px rgba(2,6,23,.06);
  overflow:hidden;
}

.page-dashboard .menu-cat .menu-body > details.menu-subcat > summary.menu-row{
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--warn) 13%, var(--card)) 0%,
    var(--card) 62%
  );
}

/* Nested body gets a stronger inset to show "inside" */
.page-dashboard .menu-cat .menu-body > details.menu-subcat > .menu-body{
  background: color-mix(in srgb, var(--warn) 5%, var(--card2));
  padding: 14px;
}

/* SUB-SUBCATEGORY level */
.page-dashboard .menu-subcat .menu-body--inner > details.menu-subcat--nested{
  margin-left: 16px;
  border-radius: 16px;
  border: 1px dashed color-mix(in srgb, var(--warn) 34%, var(--border));
  background: color-mix(in srgb, var(--warn) 3%, var(--card));
  box-shadow: none;
  overflow:hidden;
}

.page-dashboard .menu-subcat .menu-body--inner > details.menu-subcat--nested > summary.menu-row{
  background: color-mix(in srgb, var(--warn) 6%, var(--card));
}

/* PRODUCTS block inside any level */
.page-dashboard .menu-tree .menu-section{
  margin-top: 12px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card) 72%, var(--card2));
}

/* Make section title look like a clear label (override inline weight if any) */
.page-dashboard .menu-tree .menu-section__title{
  margin: 0 0 10px !important;
  font-size: 12px;
  font-weight: 900 !important;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Product rows: more visible, slightly indented */
.page-dashboard .menu-tree details.menu-prod{
  margin-left: 16px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--success) 22%, var(--border));
  box-shadow: 0 6px 16px rgba(2,6,23,.05);
  overflow:hidden;
}

.page-dashboard .menu-tree details.menu-prod > summary.menu-row{
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--success) 10%, var(--card)) 0%,
    var(--card) 62%
  );
}

/* Deeper products (inside sub-subcategory) a bit more offset */
.page-dashboard .menu-subcat--nested details.menu-prod{ margin-left: 22px; }

/* Meta line under title – slightly dimmer but readable */
.page-dashboard .menu-tree .menu-meta{
  color: var(--muted);
  margin-top: 2px;
}

/* Make the "Add ..." blocks stand out as "actions", not content */
.page-dashboard .menu-tree details.menu-add{
  border-style: dashed;
  background: color-mix(in srgb, var(--primary) 6%, var(--card2));
}
.page-dashboard .menu-tree details.menu-add > summary{
  background: transparent;
}
