/* ===========================================================================
   TravelPro ERP - Admin Theme
   Modern, premium, clean UI with green gradient identity
   =========================================================================== */

:root {
  --primary-1: #00b894;
  --primary-2: #00cec9;
  --primary-gradient: linear-gradient(135deg, #00b894 0%, #00cec9 100%);
  --primary-gradient-soft: linear-gradient(135deg, #00b89414, #00cec914);
  --text-dark: #2d3436;
  --text-muted: #6c757d;
  --bg-body: #f6f8fa;
  --bg-card: #ffffff;
  --border-light: #eef1f4;
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 6px 24px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 14px 40px rgba(0, 184, 148, 0.12);
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --sidebar-w: 260px;
  --topbar-h: 68px;
}

* { box-sizing: border-box; }

body {
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  background: var(--bg-body);
  color: var(--text-dark);
  margin: 0;
  font-size: 14.5px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--primary-1); text-decoration: none; transition: color .15s; }
a:hover { color: #009176; }

/* ----- Sidebar ----- */
.sidebar {
  position: fixed; left: 0; top: 0; bottom: 0;
  width: var(--sidebar-w);
  background: #ffffff;
  border-right: 1px solid var(--border-light);
  display: flex; flex-direction: column;
  z-index: 1030;
  transition: transform .3s ease;
}
.sidebar-brand {
  height: var(--topbar-h);
  display: flex; align-items: center; gap: 12px;
  padding: 0 24px;
  border-bottom: 1px solid var(--border-light);
  font-weight: 800; font-size: 1.2rem;
  color: var(--text-dark);
}
.sidebar-brand .logo-dot {
  width: 38px; height: 38px;
  background: var(--primary-gradient);
  border-radius: 12px;
  display: grid; place-items: center;
  color: #fff; font-weight: 800;
  box-shadow: 0 6px 16px rgba(0, 184, 148, 0.35);
}
.sidebar-nav {
  flex: 1; overflow-y: auto;
  padding: 18px 14px;
}
.sidebar-nav::-webkit-scrollbar { width: 4px; }
.sidebar-nav::-webkit-scrollbar-thumb { background: #d0d7de; border-radius: 4px; }

.nav-group-title {
  font-size: 11px; text-transform: uppercase;
  letter-spacing: 1.4px; color: #adb5bd;
  padding: 16px 14px 8px;
  font-weight: 700;
}
.sidebar .nav-link {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 14px;
  border-radius: var(--radius-sm);
  color: #54606b;
  font-weight: 500;
  margin-bottom: 2px;
  transition: all .15s ease;
  font-size: 14px;
}
.sidebar .nav-link i {
  font-size: 18px; width: 22px; text-align: center;
  color: #8a96a3;
  transition: color .15s;
}
.sidebar .nav-link:hover {
  background: var(--primary-gradient-soft);
  color: var(--primary-1);
}
.sidebar .nav-link:hover i { color: var(--primary-1); }
.sidebar .nav-link.active {
  background: var(--primary-gradient);
  color: #fff;
  box-shadow: 0 8px 22px rgba(0, 184, 148, 0.28);
}
.sidebar .nav-link.active i { color: #fff; }

/* ----- Topbar ----- */
.topbar,
.tms-topbar {
  position: fixed; top: 0; right: 0; left: var(--sidebar-w);
  height: var(--topbar-h);
  background: #fff;
  border-bottom: 1px solid var(--border-light);
  display: flex; align-items: center;
  padding: 0 28px;
  z-index: 1020;
}
.topbar .search-box,
.tms-topbar .search-box {
  flex: 1; max-width: 360px; position: relative;
}
.topbar .search-box input {
  width: 100%;
  height: 42px;
  border: 1px solid var(--border-light);
  border-radius: 12px;
  padding: 0 14px 0 42px;
  background: #f7f9fa;
  outline: none; transition: all .2s;
  font-size: 14px;
}
.topbar .search-box input:focus {
  background: #fff;
  border-color: var(--primary-1);
  box-shadow: 0 0 0 4px rgba(0, 184, 148, 0.1);
}
.topbar .search-box i {
  position: absolute; left: 14px; top: 12px;
  color: #adb5bd; font-size: 18px;
}
.topbar-actions { margin-left: auto; display: flex; gap: 8px; align-items: center; }
.icon-btn {
  width: 42px; height: 42px;
  border-radius: 12px;
  background: #f7f9fa;
  display: grid; place-items: center;
  color: #54606b;
  position: relative;
  cursor: pointer; transition: all .15s;
  border: none;
}
.icon-btn:hover { background: var(--primary-gradient-soft); color: var(--primary-1); }
.icon-btn .badge-dot {
  position: absolute; top: 9px; right: 9px;
  width: 8px; height: 8px;
  background: #ff5e62; border-radius: 50%;
  border: 2px solid #fff;
}
.user-chip {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 14px 6px 6px;
  background: #f7f9fa;
  border-radius: 30px; cursor: pointer;
  transition: background .15s;
  border: none;
}
.user-chip:hover { background: var(--primary-gradient-soft); }
.user-chip .avatar {
  width: 34px; height: 34px;
  background: var(--primary-gradient);
  border-radius: 50%;
  display: grid; place-items: center;
  color: #fff; font-weight: 700; font-size: 13px;
}
.user-chip .name {
  font-weight: 600; font-size: 13.5px;
  color: var(--text-dark);
}

/* ----- Layout ----- */
.main-wrapper,
.tms-main {
  margin-left: var(--sidebar-w);
  padding-top: var(--topbar-h);
  min-height: 100vh;
}
.page-body,
.tms-main-inner { padding: 28px; }
.tms-shell { min-height: 100vh; }
.page-header {
  display: flex; align-items: center;
  justify-content: space-between; gap: 16px;
  flex-wrap: wrap; margin-bottom: 24px;
}
.page-title {
  font-size: 1.55rem; font-weight: 800; margin: 0;
  color: var(--text-dark);
  letter-spacing: -0.02em;
}
.page-subtitle { color: var(--text-muted); margin: 4px 0 0; font-size: 14px; }
.breadcrumb-mini { color: var(--text-muted); font-size: 13px; }
.breadcrumb-mini a { color: var(--text-muted); }
.breadcrumb-mini .sep { margin: 0 6px; }

/* ----- Cards ----- */
.card-tms {
  background: var(--bg-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-light);
  box-shadow: var(--shadow-sm);
  transition: transform .2s, box-shadow .2s;
}
.card-tms:hover { box-shadow: var(--shadow-md); }
.card-tms .card-tms-head {
  padding: 20px 24px;
  border-bottom: 1px solid var(--border-light);
  display: flex; align-items: center; justify-content: space-between;
}
.card-tms .card-tms-head h5 { margin: 0; font-weight: 700; font-size: 1.05rem; }
.card-tms .card-tms-body { padding: 22px 24px; }

/* ----- Stat cards ----- */
.stat-card {
  background: var(--bg-card);
  border-radius: var(--radius-md);
  padding: 22px;
  border: 1px solid var(--border-light);
  box-shadow: var(--shadow-sm);
  display: flex; align-items: flex-start; gap: 16px;
  position: relative; overflow: hidden;
  transition: transform .2s, box-shadow .2s;
}
.stat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.stat-card::after {
  content: ''; position: absolute;
  right: -30px; top: -30px;
  width: 100px; height: 100px;
  background: var(--primary-gradient-soft);
  border-radius: 50%; opacity: .6;
}
.stat-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  background: var(--primary-gradient);
  color: #fff;
  display: grid; place-items: center;
  font-size: 24px;
  box-shadow: 0 8px 22px rgba(0, 184, 148, 0.3);
  flex-shrink: 0; z-index: 1;
}
.stat-card.alt-blue .stat-icon { background: linear-gradient(135deg, #4facfe, #00f2fe); box-shadow: 0 8px 22px rgba(79, 172, 254, 0.3); }
.stat-card.alt-orange .stat-icon { background: linear-gradient(135deg, #ff9966, #ff5e62); box-shadow: 0 8px 22px rgba(255, 94, 98, 0.3); }
.stat-card.alt-purple .stat-icon { background: linear-gradient(135deg, #a18cd1, #fbc2eb); box-shadow: 0 8px 22px rgba(161, 140, 209, 0.3); }
.stat-label {
  color: var(--text-muted); font-size: 13px;
  text-transform: uppercase; letter-spacing: .8px;
  font-weight: 600; margin: 0 0 6px;
}
.stat-value {
  font-size: 1.7rem; font-weight: 800;
  color: var(--text-dark); margin: 0;
  letter-spacing: -0.02em;
}
.stat-change {
  font-size: 12.5px; margin-top: 6px; font-weight: 600;
}
.stat-change.up { color: #00b894; }
.stat-change.down { color: #d63031; }

/* ----- Buttons ----- */
.btn-gradient {
  background: var(--primary-gradient);
  color: #fff !important;
  border: none;
  padding: 10px 22px;
  border-radius: 10px;
  font-weight: 600;
  transition: all .2s;
  box-shadow: 0 6px 18px rgba(0, 184, 148, 0.28);
}
.btn-gradient:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0, 184, 148, 0.42);
  color: #fff;
}
.btn-gradient:focus { color: #fff; }
.btn-outline-gradient {
  background: transparent;
  border: 1.5px solid var(--primary-1);
  color: var(--primary-1);
  padding: 9px 20px;
  border-radius: 10px;
  font-weight: 600;
  transition: all .2s;
}
.btn-outline-gradient:hover {
  background: var(--primary-gradient);
  color: #fff;
  border-color: transparent;
}
.btn-soft {
  background: var(--primary-gradient-soft);
  color: var(--primary-1);
  border: none;
  padding: 8px 16px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 13px;
}
.btn-icon-sm {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: inline-grid; place-items: center;
  background: #f7f9fa;
  color: #54606b;
  border: none;
  margin: 0 2px;
  transition: all .15s;
}
.btn-icon-sm:hover {
  background: var(--primary-gradient-soft);
  color: var(--primary-1);
}
.btn-icon-sm.danger:hover { background: #ffe5e5; color: #d63031; }

/* ----- Forms ----- */
.form-control, .form-select {
  border-radius: 10px;
  border: 1px solid var(--border-light);
  padding: 10px 14px;
  font-size: 14px;
  background: #fafbfc;
  transition: all .2s;
}
.form-control:focus, .form-select:focus {
  background: #fff;
  border-color: var(--primary-1);
  box-shadow: 0 0 0 4px rgba(0, 184, 148, 0.1);
}
.form-label { font-weight: 600; font-size: 13.5px; margin-bottom: 6px; color: #495057; }

/* ----- Tables ----- */
.table-tms {
  width: 100%; border-collapse: separate;
  border-spacing: 0;
}
.table-tms thead th {
  background: #f7f9fa;
  font-size: 12px; text-transform: uppercase;
  letter-spacing: .8px; color: var(--text-muted);
  padding: 14px 16px; text-align: left;
  font-weight: 700;
  border: none;
}
.table-tms thead th:first-child { border-top-left-radius: 10px; border-bottom-left-radius: 10px; }
.table-tms thead th:last-child { border-top-right-radius: 10px; border-bottom-right-radius: 10px; }
.table-tms tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-light);
  font-size: 14px; vertical-align: middle;
}
.table-tms tbody tr:hover { background: #f8fbfa; }
.table-tms tbody tr:last-child td { border-bottom: none; }

/* ----- Badges ----- */
.badge {
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 6px;
  font-size: 11.5px;
  letter-spacing: .3px;
}

/* ----- Login page ----- */
.auth-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #f0fffd 0%, #f6f9fa 100%);
  padding: 20px;
  position: relative; overflow: hidden;
}
.auth-page::before, .auth-page::after {
  content: ''; position: absolute;
  border-radius: 50%;
  background: var(--primary-gradient);
  opacity: 0.08;
  filter: blur(60px);
}
.auth-page::before { width: 400px; height: 400px; top: -100px; left: -100px; }
.auth-page::after { width: 500px; height: 500px; bottom: -200px; right: -150px; }
.auth-card {
  width: 100%; max-width: 440px;
  background: #fff;
  border-radius: 20px;
  padding: 40px 36px;
  box-shadow: 0 30px 80px rgba(0, 184, 148, 0.12);
  position: relative; z-index: 1;
}
.auth-card .brand-mark {
  width: 64px; height: 64px;
  background: var(--primary-gradient);
  border-radius: 18px;
  display: grid; place-items: center;
  color: #fff; font-size: 28px; font-weight: 800;
  margin: 0 auto 20px;
  box-shadow: 0 14px 34px rgba(0, 184, 148, 0.35);
}
.auth-card h2 {
  text-align: center; font-weight: 800;
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}
.auth-card .sub { text-align: center; color: var(--text-muted); margin-bottom: 28px; }

/* ----- Responsive ----- */
.sidebar-toggle { display: none; }
@media (max-width: 992px) {
  .sidebar { transform: translateX(-100%); }
  .sidebar.show { transform: translateX(0); box-shadow: 0 0 60px rgba(0,0,0,.15); }
  .topbar, .main-wrapper,
  .tms-topbar, .tms-main { left: 0; margin-left: 0; }
  .sidebar-toggle { display: grid; }
  .sidebar-backdrop {
    display: none; position: fixed; inset: 0;
    background: rgba(0,0,0,.4); z-index: 1025;
  }
  .sidebar-backdrop.show { display: block; }
}
@media (max-width: 576px) {
  .page-body, .tms-main-inner { padding: 18px; }
  .topbar, .tms-topbar { padding: 0 16px; }
  .topbar .search-box, .tms-topbar .search-box { display: none; }
  .stat-value { font-size: 1.35rem; }
}

/* ----- Animations ----- */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.fade-up { animation: fadeUp .4s ease-out both; }
.fade-up-1 { animation-delay: .05s; }
.fade-up-2 { animation-delay: .1s; }
.fade-up-3 { animation-delay: .15s; }
.fade-up-4 { animation-delay: .2s; }

/* ----- Misc ----- */
.text-gradient {
  background: var(--primary-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.divider { height: 1px; background: var(--border-light); margin: 20px 0; }
.text-soft { color: var(--text-muted); }

/* ===== Dashboard / Page Head ===== */
.page-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin:0 0 1.5rem;}
.page-head .page-title{font-size:1.5rem;font-weight:800;margin:0;color:var(--text-1);}
.page-head .page-sub{margin:.25rem 0 0;font-size:.95rem;}
.page-actions{display:flex;gap:.5rem;flex-wrap:wrap;}

/* ===== Input groups with leading icon ===== */
.input-group-icon{position:relative;}
.input-group-icon .input-icon{display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border);border-right:0;color:var(--text-3);padding:0 .85rem;border-top-left-radius:var(--radius-sm);border-bottom-left-radius:var(--radius-sm);}
.input-group-icon .form-control{border-left:0;}
.input-group-icon .form-control:focus{box-shadow:none;border-color:var(--primary-1);}
.input-group-icon .input-trail{border:1px solid var(--border);border-left:0;background:#fff;color:var(--text-3);}

/* ===== Stat card enhancements ===== */
.stat-card .stat-icon{position:absolute;top:1rem;right:1rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:rgba(255,255,255,.18);color:#fff;font-size:1.2rem;backdrop-filter:blur(8px);}
.stat-card .stat-body{position:relative;z-index:1;}
.stat-card .stat-label{font-size:.85rem;opacity:.9;text-transform:uppercase;letter-spacing:.4px;font-weight:600;}
.stat-card .stat-value{font-size:1.85rem;font-weight:800;margin:.25rem 0 .35rem;}
.stat-card .stat-delta{font-size:.8rem;opacity:.95;display:inline-flex;align-items:center;gap:.25rem;}

/* ===== Legend ===== */
.legend-dots{display:flex;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:var(--text-2);}
.legend-dots .dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:.35rem;vertical-align:middle;}

/* ===== Progress rows ===== */
.prog-row{margin-bottom:1rem;}
.prog-row:last-child{margin-bottom:0;}
.prog-row .prog-label{font-weight:600;color:var(--text-1);font-size:.92rem;}
.prog-bar{height:8px;background:#eef2f4;border-radius:99px;overflow:hidden;margin-top:.4rem;}
.prog-bar span{display:block;height:100%;background:var(--primary-gradient);border-radius:99px;transition:width .6s ease;}

/* ===== Inquiry list ===== */
.inquiry-list li{display:flex;align-items:center;gap:.85rem;padding:.85rem 0;border-bottom:1px dashed var(--border);}
.inquiry-list li:last-child{border-bottom:0;}
.inq-avatar{width:42px;height:42px;border-radius:12px;background:var(--primary-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0;}

/* ===== Topbar additions ===== */
.tms-topbar .user-chip{display:flex;align-items:center;gap:.6rem;padding:.35rem .65rem .35rem .35rem;border:1px solid var(--border);background:#fff;border-radius:99px;cursor:pointer;transition:.2s;}
.tms-topbar .user-chip:hover{box-shadow:var(--shadow-1);}
.tms-topbar .user-chip .avatar,.tms-topbar .user-chip .avatar-letter{width:34px;height:34px;border-radius:50%;object-fit:cover;display:flex;align-items:center;justify-content:center;background:var(--primary-gradient);color:#fff;font-weight:700;}
.tms-topbar .user-meta{display:flex;flex-direction:column;line-height:1.1;}
.tms-topbar .user-meta .u-name{font-weight:600;font-size:.88rem;color:var(--text-1);}
.tms-topbar .user-meta .u-role{font-size:.72rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;}
.tms-topbar .icon-btn{position:relative;width:40px;height:40px;border-radius:50%;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-2);transition:.2s;text-decoration:none;}
.tms-topbar .icon-btn:hover{color:var(--primary-1);box-shadow:var(--shadow-1);}
.tms-topbar .icon-btn .dot{position:absolute;top:9px;right:10px;width:8px;height:8px;border-radius:50%;background:#ff6b6b;border:2px solid #fff;}
.tms-topbar .topbar-actions{display:flex;align-items:center;gap:.6rem;}

/* ===== Auth page additions ===== */
.auth-page .alert{border-radius:12px;font-size:.92rem;border:0;}
.link-muted{color:var(--text-3);text-decoration:none;font-size:.9rem;transition:.2s;}
.link-muted:hover{color:var(--primary-1);}

/* ===== Filters bar / page wrappers ===== */
.filters-bar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1rem;}
.filters-bar .form-control,.filters-bar .form-select{min-width:160px;}

/* ===== Empty state ===== */
.empty-state{padding:2rem 1rem;text-align:center;}

/* ===== Tag badges ===== */
.tag-soft{display:inline-block;padding:.25rem .65rem;border-radius:99px;background:rgba(0,184,148,.1);color:var(--primary-1);font-size:.78rem;font-weight:600;}

/* ===== Image preview thumbs ===== */
.img-thumb{width:48px;height:48px;border-radius:10px;object-fit:cover;border:1px solid var(--border);}
.gallery-thumb{width:90px;height:70px;border-radius:10px;object-fit:cover;border:1px solid var(--border);position:relative;}
.gallery-thumb .remove-x{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;background:#e74c3c;color:#fff;border:0;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;}

/* ===== Pagination ===== */
.pagination .page-link{color:var(--text-2);border-color:var(--border);}
.pagination .page-item.active .page-link{background:var(--primary-gradient);border-color:transparent;color:#fff;}

/* ===== Form section title ===== */
.form-section-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);font-weight:700;margin:1.5rem 0 .85rem;padding-bottom:.5rem;border-bottom:1px dashed var(--border);}
.form-section-title:first-child{margin-top:0;}


/* ===========================================================================
   LAYOUT FIX OVERRIDE (highest specificity, explicit values)
   Ensures the sidebar/topbar/main work together regardless of class naming.
   =========================================================================== */

/* Defined-but-missing tokens used by topbar block above */
:root {
  --text-1: #2d3436;
  --text-2: #6c757d;
  --text-3: #95a5a6;
  --border: #eef1f4;
  --shadow-1: 0 6px 20px rgba(0,0,0,.06);
}

/* The shell is a simple block container */
body > .tms-shell,
.tms-shell { display: block; min-height: 100vh; }

/* Sidebar: fixed left, 260px wide */
.tms-shell > .sidebar,
aside.sidebar {
  position: fixed !important;
  top: 0 !important; left: 0 !important; bottom: 0 !important;
  width: 260px !important;
  background: #fff;
  border-right: 1px solid #eef1f4;
  z-index: 1030;
  overflow-y: auto;
}

/* Main column: pushed right by sidebar width, with top padding for the topbar */
.tms-shell > main.tms-main,
main.tms-main {
  margin-left: 260px !important;
  padding-top: 68px !important;
  min-height: 100vh;
  background: #f6f8fa;
  position: relative;
}

/* Topbar: fixed across the right portion, starting after the sidebar */
main.tms-main > header.tms-topbar,
header.tms-topbar {
  position: fixed !important;
  top: 0 !important;
  left: 260px !important;
  right: 0 !important;
  height: 68px !important;
  background: #fff;
  border-bottom: 1px solid #eef1f4;
  display: flex; align-items: center;
  padding: 0 24px;
  z-index: 1020;
  gap: 12px;
}

/* Topbar search */
.tms-topbar .topbar-search {
  position: relative;
  flex: 1;
  max-width: 380px;
}
.tms-topbar .topbar-search i {
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  color: #adb5bd; pointer-events: none;
}
.tms-topbar .topbar-search input.form-control {
  width: 100%;
  padding-left: 40px;
  height: 42px;
  border-radius: 12px;
  background: #f7f9fa;
  border: 1px solid #eef1f4;
}
.tms-topbar .topbar-search input.form-control:focus {
  background: #fff;
  border-color: #00b894;
  box-shadow: 0 0 0 4px rgba(0,184,148,.1);
}

/* Inner content padding */
.tms-main-inner { padding: 28px; }

/* Responsive: collapse sidebar on small screens */
@media (max-width: 992px) {
  .tms-shell > main.tms-main,
  main.tms-main { margin-left: 0 !important; }
  main.tms-main > header.tms-topbar,
  header.tms-topbar { left: 0 !important; }
  .tms-shell > .sidebar,
  aside.sidebar { transform: translateX(-100%); }
  .tms-shell > .sidebar.show,
  aside.sidebar.show { transform: translateX(0); }
}
@media (max-width: 576px) {
  .tms-main-inner { padding: 16px; }
  .tms-topbar { padding: 0 12px; }
  .tms-topbar .topbar-search { display: none; }
}

/* Mobile sidebar backdrop (shown by JS toggling .show) */
.sidebar-backdrop {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 1025;
  backdrop-filter: blur(2px);
}
.sidebar-backdrop.show { display: block; }

/* Make sure the hamburger button is actually visible on mobile */
@media (max-width: 992px) {
  #sidebarToggle { display: inline-grid !important; place-items: center; }
  .sidebar-backdrop { display: none; }
  .sidebar-backdrop.show { display: block; }
}