/* ============================================================================
   crm-theme.css  —  Modern UI overlay for DR Infosoft Travel CRM
   ----------------------------------------------------------------------------
   • Load AFTER material-dashboard.css (you have it as NEW_UI_CSS constant).
   • Pure presentation. Does NOT touch any markup IDs, JS, AJAX or operations.
   • Brand accent = #093f66.
   ============================================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

:root{
  --crm-bg:#EAEEF5;
  --crm-surface:#FFFFFF;
  --crm-surface-alt:#F1F3F9;
  --crm-border:#DDE3EC;
  --crm-border-light:#F0F2F7;
  --crm-text:#1A1D26;
  --crm-text-2:#6B7186;
  --crm-text-3:#9CA3B8;
  --crm-accent:#093f66;
  --crm-accent-light:#EFF5FF;
  --crm-green:#10B981;  --crm-green-l:#ECFDF5;
  --crm-red:#EF4444;    --crm-red-l:#FEF2F2;
  --crm-orange:#F59E0B; --crm-orange-l:#FFFBEB;
  --crm-cyan:#06B6D4;   --crm-cyan-l:#ECFEFF;
  --crm-purple:#8B5CF6; --crm-purple-l:#F5F3FF;
  --crm-radius:14px;
  --crm-radius-sm:10px;
  --crm-shadow-sm:0 1px 3px rgba(0,0,0,.04),0 1px 2px rgba(0,0,0,.02);
  --crm-shadow-md:0 4px 16px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04);
  --crm-trans:.2s cubic-bezier(.4,0,.2,1);
}

/* ---------------------------------------------------------------- BASE ---- */
body,
body.sidebar-mini{
  font-family:'DM Sans',-apple-system,"Segoe UI",Roboto,sans-serif !important;
  background:var(--crm-bg) !important;
  color:var(--crm-text);
  -webkit-font-smoothing:antialiased;
}
.wrapper{ background:var(--crm-bg); }
.main-panel{ background:var(--crm-bg) !important; }

/* -------------------------------------------------------------- SIDEBAR ---- */
.sidebar,
.sidebar[data-background-color="white"]{
  background:var(--crm-surface) !important;
  border-right:1px solid var(--crm-border) !important;
}
.sidebar .logo{ border-bottom:1px solid var(--crm-border-light); padding:12px 0; }
.sidebar .logo:after{ display:none !important; }

.sidebar .nav{ margin-top:14px; }
.sidebar .nav .nav-item{ margin:2px 0; }
.sidebar .nav .nav-item > .nav-link{
  display:flex !important; align-items:center;
  margin:2px 12px !important; padding:10px 14px !important;
  border-radius:var(--crm-radius-sm) !important;
  color:var(--crm-text-2) !important; font-weight:500;
  opacity:1 !important; transition:all var(--crm-trans);
}
.sidebar .nav .nav-item > .nav-link:hover{
  background:var(--crm-surface-alt) !important; color:var(--crm-text) !important;
}
.sidebar .nav .nav-item > .nav-link i,
.sidebar .nav .nav-item > .nav-link svg{
  margin-right:14px; width:22px; height:22px; font-size:22px;
  stroke:currentColor; stroke-width:1.8; fill:none; flex-shrink:0;
}
.sidebar .nav .nav-item > .nav-link p{ margin:0; font-size:.9rem; line-height:1.2; }

.sidebar[data-color] .nav .nav-item.active > .nav-link,
.sidebar .nav .nav-item.active > .nav-link{
  background:var(--crm-accent) !important; color:#fff !important;
  box-shadow:0 2px 8px rgba(9,63,102,.30) !important;
}
.sidebar .nav .nav-item.active > .nav-link i,
.sidebar .nav .nav-item.active > .nav-link svg{ color:#fff !important; stroke:#fff !important; }
.sidebar[data-color] .nav .nav-item.active > .nav-link:before,
.sidebar[data-color] .nav .nav-item.active > .nav-link:after{ display:none !important; }

.sidebar .nav .dropdown-menu{
  border:1px solid var(--crm-border); border-radius:var(--crm-radius-sm); box-shadow:var(--crm-shadow-md);
}
.sidebar .nav .dropdown-menu .dropdown-item{ font-size:.82rem; color:var(--crm-text-2); border-radius:8px; }
.sidebar .nav .dropdown-menu .dropdown-item:hover{ background:var(--crm-accent-light); color:var(--crm-accent); }
#minimizeSidebar{ border-color:var(--crm-accent) !important; color:var(--crm-accent) !important; }

/* --------------------------------------------------------- TOP NAVBAR ---- */
.main-panel > .navbar,
.navbar.navbar-absolute{
  background:rgba(255,255,255,.88) !important;
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--crm-border);
  box-shadow:none !important; min-height:64px; padding-top:8px; padding-bottom:8px;
}
.navbar .navbar-brand{
  font-size:1.45rem !important; font-weight:400 !important;
  letter-spacing:-.02em; color:var(--crm-text) !important;
}
/* search */
.navbar .navbar-form .input-group{ margin:0; }
.navbar .navbar-form .input-group .form-control{
  background:var(--crm-surface-alt) !important; border:1px solid var(--crm-border) !important;
  border-radius:20px !important; font-size:.85rem; padding-left:10px; min-width:125px;
}
.navbar .navbar-form .btn{ color:var(--crm-text-3) !important; box-shadow:none !important; }

/* trip pill buttons */
.navbar .navbar-nav .btn[class*="btn-outline-"]{
  border-radius:20px !important; padding:6px 16px !important; font-size:.7rem !important;
  text-transform:uppercase; letter-spacing:.04em; font-weight:700 !important; box-shadow:none !important;
}
.navbar .navbar-nav > .nav-item{ display:flex; align-items:center; }
.navbar .navbar-nav > .nav-item > .nav-link{ color:var(--crm-text-2) !important; font-weight:500; }

/* circular bell */
.crm-bell-link{ position:relative; padding:0 6px !important; }
.crm-bell-btn{
  width:40px; height:40px; border-radius:50%; border:1px solid var(--crm-border);
  background:#fff; display:inline-flex; align-items:center; justify-content:center; transition:all var(--crm-trans);
}
.crm-bell-btn:hover{ border-color:var(--crm-accent); }
.crm-bell-btn i{ color:var(--crm-text-2); font-size:20px; }
.crm-bell-link .notification{
  position:absolute; top:4px; right:6px; width:9px; height:9px;
  background:var(--crm-red); border-radius:50%; border:2px solid #fff; padding:0 !important;
}

/* user chip */
.crm-user-chip{
  display:inline-flex; align-items:center; gap:10px;
  padding:4px 14px 4px 4px; border:1px solid var(--crm-border);
  border-radius:28px; background:#fff; transition:all var(--crm-trans);
}
.crm-user-chip:hover{ border-color:var(--crm-accent); }
.crm-avatar{
  width:34px; height:34px; border-radius:50%; background:var(--crm-accent); color:#fff;
  display:inline-flex; align-items:center; justify-content:center; font-weight:600; font-size:.85rem; flex-shrink:0;
}
.crm-user-meta{ display:flex; flex-direction:column; line-height:1.15; text-align:left; }
.crm-user-name{ font-size:.8rem; font-weight:600; color:var(--crm-text); }
.crm-user-role{ font-size:.62rem; font-weight:700; color:var(--crm-green); text-transform:uppercase; letter-spacing:.05em; }
.navbar .dropdown-menu{ border:1px solid var(--crm-border); border-radius:var(--crm-radius-sm); box-shadow:var(--crm-shadow-md); }

/* ------------------------------------------------------------- CARDS ----- */
.card{
  border:1px solid var(--crm-border) !important; border-radius:var(--crm-radius) !important;
  box-shadow:var(--crm-shadow-sm) !important; background:var(--crm-surface);
  transition:box-shadow var(--crm-trans), transform var(--crm-trans);
}
.card:hover{ box-shadow:var(--crm-shadow-md) !important; }
.card .card-header[class*="card-header-"]{
  background:transparent !important; box-shadow:none !important; color:var(--crm-text) !important;
  margin:0 !important; padding:14px 20px !important; border-bottom:1px solid var(--crm-border);
}
.card .card-header h4,
.card .card-title{ color:var(--crm-text) !important; font-size:.95rem !important; font-weight:600 !important; margin:0; }
.card .card-body{ padding:20px; }
.card .card-category{ color:var(--crm-text-2) !important; font-size:.8rem; }

/* ============================================================================
   DASHBOARD (index.php) GRID LAYOUT  — matches the designer mockup
   ============================================================================ */
.main-panel .content{ padding:24px 24px 24px !important; }
.main-panel .content > .container-fluid{ padding:0 !important; max-width:none !important; }

/* ---- KPI grid: 4 cards + tall notification panel, then 4 more cards ---- */
/* ---- card lift: soft shadow so cards stand out from the new background ---- */
.kpi-card,
.three-col .card, .two-col .card, .full-col .card,
.notif-panel{
  box-shadow:0 1px 2px rgba(16,24,40,.04), 0 4px 12px rgba(16,24,40,.06) !important;
}
.kpi-card:hover,
.three-col .card:hover, .two-col .card:hover, .full-col .card:hover{
  box-shadow:0 2px 4px rgba(16,24,40,.05), 0 8px 20px rgba(16,24,40,.08) !important;
}

.kpi-row{
  display:grid;
  grid-template-columns:repeat(4,1fr) 280px;
  gap:16px;
  margin-bottom:20px;
}
.kpi-card{
  background:var(--crm-surface); border:1px solid var(--crm-border);
  border-radius:var(--crm-radius); padding:18px 20px;
  position:relative; overflow:hidden; transition:all var(--crm-trans);
}
.kpi-card:hover{ box-shadow:var(--crm-shadow-md); transform:translateY(-1px); }
.kpi-card::before{ content:''; position:absolute; top:0; left:0; right:0; height:3px; }
.kpi-card.kpi-green::before { background:var(--crm-green); }
.kpi-card.kpi-red::before   { background:var(--crm-red); }
.kpi-card.kpi-blue::before  { background:var(--crm-accent); }
.kpi-card.kpi-cyan::before  { background:var(--crm-cyan); }
.kpi-card.kpi-orange::before{ background:var(--crm-orange); }
.kpi-card.kpi-purple::before{ background:var(--crm-purple); }

.kpi-head{ display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.kpi-icon{ width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.kpi-icon svg{ width:22px; height:22px; stroke-width:1.8; fill:none; }
.kpi-green  .kpi-icon{ background:var(--crm-green-l); }   .kpi-green  .kpi-icon svg{ stroke:var(--crm-green); }
.kpi-red    .kpi-icon{ background:var(--crm-red-l); }     .kpi-red    .kpi-icon svg{ stroke:var(--crm-red); }
.kpi-blue   .kpi-icon{ background:var(--crm-accent-light);}.kpi-blue   .kpi-icon svg{ stroke:var(--crm-accent); }
.kpi-cyan   .kpi-icon{ background:var(--crm-cyan-l); }    .kpi-cyan   .kpi-icon svg{ stroke:var(--crm-cyan); }
.kpi-orange .kpi-icon{ background:var(--crm-orange-l); }  .kpi-orange .kpi-icon svg{ stroke:var(--crm-orange); }
.kpi-purple .kpi-icon{ background:var(--crm-purple-l); }  .kpi-purple .kpi-icon svg{ stroke:var(--crm-purple); }

.kpi-label{ font-size:.85rem; color:var(--crm-text-2); font-weight:500; }
.kpi-bottom{ display:flex; align-items:center; justify-content:space-between; }
.kpi-value{ font-size:2rem; font-weight:700; letter-spacing:-.03em; line-height:1.1; color:#083c64; }
.kpi-value .fa-spinner{ font-size:1.05rem; color:var(--crm-accent); }
.kpi-view{ display:inline-flex; align-items:center; color:var(--crm-accent); text-decoration:none; }
.kpi-view svg{ width:22px; height:22px; stroke:var(--crm-accent); stroke-width:2; fill:none; }
.kpi-view:hover svg{ stroke:#062a45; }

/* ---- combined Notification + Active Users panel (spans 2 rows) ---- */
.notif-panel{
  grid-row:span 2;
  background:var(--crm-surface); border:1px solid var(--crm-border);
  border-radius:var(--crm-radius); padding:20px; display:flex; flex-direction:column;
}
.notif-panel-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.notif-panel-head h3{ font-size:.92rem; font-weight:600; margin:0; }
.notif-panel-head a{ font-size:.75rem; color:var(--crm-accent); font-weight:600; text-decoration:none; }
.notif-panel .notif-body{ overflow:auto; font-size:.82rem; color:var(--crm-text-2); max-height:230px; }
.notif-panel .active-users-block{ margin-top:16px; padding-top:14px; border-top:1px solid var(--crm-border-light); }
.notif-panel .active-users-block h4{ font-size:.85rem; font-weight:600; color:var(--crm-text-2); margin:0 0 10px; }
.notif-panel .active-users-block .active-body{ font-size:.82rem; color:var(--crm-text-2); overflow:auto; max-height:170px; }

/* ---- three / two / full column sections ---- */
.three-col{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; margin-bottom:20px; }
.two-col{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:20px; }
.full-col{ margin-bottom:20px; }
.three-col .card, .two-col .card, .full-col .card{ margin:0 !important; height:100%; }

/* ---- responsive ---- */
@media (max-width:1300px){
  .kpi-row{ grid-template-columns:repeat(4,1fr) 260px; }
}
@media (max-width:1200px){
  .kpi-row{ grid-template-columns:repeat(4,1fr); }
  .notif-panel{ grid-column:1 / -1; grid-row:auto; }
}
@media (max-width:1024px){
  .kpi-row{ grid-template-columns:repeat(2,1fr); }
  .three-col{ grid-template-columns:1fr; }
  .main-panel .content{ padding:14px 14px 14px !important; }
}
@media (max-width:640px){
  .kpi-row{ grid-template-columns:1fr; }
  .two-col{ grid-template-columns:1fr; }
}

/* --------------------------------------------------------- BUTTONS ------- */
.btn{ border-radius:var(--crm-radius-sm) !important; text-transform:none !important; letter-spacing:0; box-shadow:none !important; font-weight:600; }
.btn:hover{ box-shadow:0 2px 8px rgba(0,0,0,.12) !important; }
.btn.btn-primary{ background:var(--crm-accent) !important; }
.btn.btn-info{ background:var(--crm-cyan) !important; }

/* --------------------------------------------------------- TABLES -------- */
.table{ background:transparent !important; }
/* navy header band with white text */
.table thead th,
.table > thead > tr > th,
.table thead.text-primary th{
  background:var(--crm-accent) !important;
  color:var(--crm-surface) !important;
  text-transform:uppercase;
  font-size:.72rem; font-weight:600; letter-spacing:.05em;
  white-space:nowrap;
  border-top:0 !important;
  border-bottom:2px solid var(--crm-accent) !important;
  padding:12px 14px !important;
}
/* rounded ends so the navy header looks like a neat bar */
.table thead th:first-child{ border-radius:8px 0 0 8px; }
.table thead th:last-child { border-radius:0 8px 8px 0; }
/* clean body rows — no mystery gray bands, subtle hover only */
.table tbody tr{ background:transparent !important; }
.table tbody td,
.table > tbody > tr > td{
  background:transparent !important;
  font-size:.85rem; color:var(--crm-text);
  border-top:0 !important;
  border-bottom:1px solid var(--crm-border-light) !important;
  vertical-align:middle;
  padding:12px 14px;
}
.table tbody tr:hover,
.table tbody tr:hover td{ background:#F2F5FB !important; }

/* --------------------------------------------------------- FORMS --------- */
.form-control, textarea.form-control{
  border:1px solid var(--crm-border) !important; border-radius:var(--crm-radius-sm) !important;
  background:var(--crm-surface-alt) !important; background-image:none !important; color:var(--crm-text) !important;
}
.form-control:focus, textarea.form-control:focus{
  border-color:var(--crm-accent) !important; background:#fff !important; box-shadow:0 0 0 3px rgba(9,63,102,.10) !important;
}

/* ---------------------------------------------- EMBED CHART CONTAINERS --- */
#r8 embed, #r10 embed, #r13 embed, #r13_1 embed{ border:0; border-radius:var(--crm-radius-sm); background:#fff; }

/* --------------------------------------------------------- POPUPS -------- */
.popup .card, .popup .card-border{ border-radius:var(--crm-radius) !important; box-shadow:var(--crm-shadow-md) !important; }
.popup .card-header.card-header-primary{
  background:var(--crm-accent) !important; color:#fff !important;
  border-radius:var(--crm-radius) var(--crm-radius) 0 0 !important; border-bottom:0 !important;
}
.popup .card-header.card-header-primary .card-title,
.popup .card-header.card-header-primary h4{ color:#fff !important; }
#notifyFullid .alert{ border-radius:var(--crm-radius-sm); }

/* --------------------------------------------------------- FOOTER -------- */
.footer{ border-top:1px solid var(--crm-border-light); color:var(--crm-text-3); font-size:.75rem; }
.footer a{ color:var(--crm-accent) !important; font-weight:600; }

/* ============================================================================
   FIX: minimized sidebar (sidebar-mini)
   - reliable collapse: sidebar AND content stay in sync (no "didn't close")
   - labels appear as clean fly-out tooltips on hover (never clipped)
   ============================================================================ */

.sidebar{ transition:width .2s ease; }

/* COLLAPSED widths — sidebar and main-panel use the SAME value, so no shift/desync */
body.sidebar-mini .sidebar,
body.sidebar-mini .sidebar .sidebar-wrapper{ width:84px !important; overflow:visible !important; }
body.sidebar-mini .main-panel{ width:calc(100% - 84px) !important; }

/* hide the big logo, keep the minimize button */
body.sidebar-mini .sidebar .logo .logo-normal{ display:none !important; }

/* center icons, remove right gap */
body.sidebar-mini .sidebar .nav .nav-item > .nav-link{ justify-content:center; position:relative; }
body.sidebar-mini .sidebar .nav .nav-item > .nav-link i,
body.sidebar-mini .sidebar .nav .nav-item > .nav-link svg{ margin-right:0; width:26px; min-width:26px; text-align:center; }

/* label = fly-out tooltip (NOT a full-width expand, so content never moves) */
/* !important here overrides Material's native "show ALL labels on sidebar hover" rule */
body.sidebar-mini .sidebar .nav .nav-item > .nav-link p{
  position:absolute !important; left:calc(100% + 6px); top:50% !important;
  transform:translateY(-50%) !important;
  margin:0; padding:7px 12px; white-space:nowrap;
  background:var(--crm-accent); color:#fff; font-weight:500; border-radius:8px;
  box-shadow:var(--crm-shadow-md); opacity:0 !important; pointer-events:none;
  transition:opacity .12s ease; z-index:1050;
}
/* reveal ONLY the label of the icon currently under the mouse */
body.sidebar-mini .sidebar .nav .nav-item > .nav-link:hover p{ opacity:1 !important; }

/* dropdown sub-menus fly out cleanly when collapsed */
body.sidebar-mini .sidebar .nav .dropdown-menu{ min-width:200px; white-space:nowrap; }

/* ============================================================================
   LIST / LEADS PAGES — migrated here from leads/index.php inline <style>
   Recolored to the navy brand (#093f66). Class names unchanged, so the
   leads page JS (chips, source field, panel toggle) keeps working.
   The leads page now needs ONLY the crm-theme.css link — delete its inline
   <style> block entirely.
   ============================================================================ */

/* small helpers */
.red       { color:#f00; }
.tdp1      { padding:4px 8px !important; }
.sub-info  { font-size:11px; color:var(--crm-text-3); }
.fb-color        { color:#1877F2; }
.instagram-color { color:#E4405F; }
.whatsapp-color  { color:#25D366; }
.windows-color   { color:#0078D6; transition:color .3s ease; }
.windows-color:hover { color:#005A9E; }
.google-color    { color:#4285F4; }

/* status badges (semantic colors, kept) */
.s-fresh     { background:#e3f2fd; color:#1565c0; padding:2px 9px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.s-ongoing   { background:#fff8e1; color:#f57f17; padding:2px 9px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.s-won       { background:#e8f5e9; color:#2e7d32; padding:2px 9px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.s-loss      { background:#fce4ec; color:#c62828; padding:2px 9px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.s-cancelled { background:#fce4ec; color:#b71c1c; padding:2px 9px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.s-datechange{ background:#f3e5f5; color:#6a1b9a; padding:2px 9px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.s-default   { background:#f5f5f5; color:#555;    padding:2px 9px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }

/* card header layout (title + action buttons row) */
.card-header-inner{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.card-header-inner .card-title{ margin:0; }
.card-header-inner .card-category{ margin:4px 0 0; }

/* Apply Filter button — navy OUTLINE (header is light now) */
.btn-apply-filter{
  display:inline-flex; align-items:center; gap:5px; padding:6px 16px;
  background:#fff; border:1px solid var(--crm-accent);
  border-radius:20px; color:var(--crm-accent);
  font-size:13px; font-weight:600; cursor:pointer; text-decoration:none;
  transition:all .15s; white-space:nowrap;
}
.btn-apply-filter:hover{ background:var(--crm-accent-light); color:#062a45; text-decoration:none; }
.btn-apply-filter:focus{ outline:none; }
.btn-apply-filter .material-icons{ font-size:16px; }

/* Add New Lead button — navy FILL (primary action) */
.btn-add-lead{
  display:inline-flex; align-items:center; gap:5px; padding:6px 16px;
  background:var(--crm-accent); border:1px solid var(--crm-accent);
  border-radius:20px; color:#fff;
  font-size:13px; font-weight:600; cursor:pointer; text-decoration:none;
  transition:all .15s; white-space:nowrap;
}
.btn-add-lead:hover{ background:#062a45; color:#fff; text-decoration:none; }
.btn-add-lead .material-icons{ font-size:16px; }

/* active filter summary bar */
.active-filter-bar{
  display:none; align-items:center; flex-wrap:wrap; gap:8px;
  background:#fff; border:1px solid #cfdbe8; border-radius:10px;
  padding:10px 14px; margin-bottom:10px; box-shadow:0 1px 4px rgba(9,63,102,.08);
}
.active-filter-bar.has-filters{ display:flex; }
.active-filter-bar .afb-label{
  font-size:12px; font-weight:700; color:var(--crm-accent);
  text-transform:uppercase; letter-spacing:.4px; white-space:nowrap;
  display:inline-flex; align-items:center; gap:4px;
}
.active-filter-bar .afb-label .material-icons{ font-size:15px; }
.active-filter-bar .afb-chips{ display:flex; flex-wrap:wrap; gap:5px; flex:1; }
.active-filter-bar .btn-reset-filter{
  display:inline-flex; align-items:center; gap:4px; padding:5px 13px;
  background:#fce4ec; border:1px solid #f48fb1; border-radius:20px;
  color:#c62828; font-size:12px; font-weight:600; cursor:pointer;
  text-decoration:none; white-space:nowrap; transition:background .15s; margin-left:auto;
}
.active-filter-bar .btn-reset-filter:hover{ background:#f8bbd0; color:#b71c1c; text-decoration:none; }
.active-filter-bar .btn-reset-filter .material-icons{ font-size:14px; }

/* chips (shared) */
.filter-chip{
  display:inline-flex; align-items:center; gap:4px; padding:3px 10px;
  border-radius:20px; background:#EAF0F7; color:var(--crm-accent);
  font-size:12px; font-weight:500; border:1px solid #bcd0e3;
}
.filter-chip .rm{ color:var(--crm-accent); text-decoration:none; font-size:17px; line-height:1; margin-left:2px; }
.filter-chip .rm:hover{ color:#d32f2f; }

/* chips row inside panel (edit mode) */
.filter-chips-row{ display:flex; flex-wrap:wrap; gap:6px; padding:10px 16px; background:#F4F7FB; border-bottom:1px solid #dde6f0; }

/* filter panel */
.adv-filter-panel{
  display:none; background:#fff; border:1px solid #cfdbe8; border-radius:10px;
  box-shadow:0 4px 18px rgba(0,0,0,.10); margin-bottom:16px; overflow:hidden;
}
.adv-filter-panel.open{ display:block; }

/* filter grid */
.filter-body-inner{ padding:16px 18px; border-bottom:1px solid #eef2f7; }
.filter-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr)); gap:12px 16px; }
.filter-section-label{
  grid-column:1 / -1; font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.5px; color:var(--crm-accent);
  border-bottom:1px solid #cfdbe8; padding-bottom:4px; margin-top:4px;
}
.adv-field-group{ display:flex; flex-direction:column; gap:3px; }
.adv-field-group label{ font-size:11px; font-weight:600; color:#666; text-transform:uppercase; letter-spacing:.3px; }
.adv-field-group input,
.adv-field-group select{
  padding:6px 10px; font-size:13px; border:1px solid #ccc; border-radius:8px;
  background:#fff; color:#333; transition:border-color .15s, box-shadow .15s;
}
.adv-field-group input:focus,
.adv-field-group select:focus{ border-color:var(--crm-accent); box-shadow:0 0 0 2px rgba(9,63,102,.13); outline:none; }

/* source details sub-field */
#sourceDetailsWrap{ display:none; flex-direction:column; gap:3px; }
#sourceDetailsWrap.visible{ display:flex; }
#sourceDetailsWrap label{ font-size:11px; font-weight:600; color:#666; text-transform:uppercase; letter-spacing:.3px; }
#sourceDetailsWrap select,
#sourceDetailsWrap input{
  padding:6px 10px; font-size:13px; border:1px solid #ccc; border-radius:8px;
  background:#fff; color:#333; transition:border-color .15s, box-shadow .15s;
}
#sourceDetailsWrap select:focus,
#sourceDetailsWrap input:focus{ border-color:var(--crm-accent); box-shadow:0 0 0 2px rgba(9,63,102,.13); outline:none; }
.source-loading{ font-size:12px; color:#888; padding:6px 2px; }

/* action buttons bar */
.filter-actions-bar{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; padding:12px 18px; background:#F4F7FB; }
.filter-actions-bar .active-lbl{ margin-left:auto; font-size:12px; color:#888; }

/* ============================================================================
   MATERIAL CARD TABS (leads/view.php, trip/view.php …)
   The colored tab banner is now transparent, so white tab text was invisible.
   Restyle as clean light underline-tabs (dark text, navy active underline).
   ============================================================================ */
.card-header.card-header-tabs{
  background:transparent !important;
  box-shadow:none !important;
  margin:0 !important;
  padding:0 10px !important;
  border-bottom:1px solid var(--crm-border) !important;
}
.card-header-tabs .nav-tabs-navigation,
.card-header-tabs .nav-tabs-wrapper{ background:transparent !important; }

.card-header-tabs .nav-tabs{ border:0 !important; background:transparent !important; }
.card-header-tabs .nav-tabs .nav-item{ margin:0 !important; }

.card-header-tabs .nav-tabs .nav-item .nav-link,
.card-header-tabs .nav-tabs .nav-link{
  color:var(--crm-text-2) !important;
  background:transparent !important;
  border:0 !important;
  border-bottom:2px solid transparent !important;
  border-radius:0 !important;
  margin:0 !important;
  padding:14px 16px !important;
  font-size:.85rem; font-weight:600;
  text-transform:none !important;
  display:inline-flex; align-items:center; gap:6px;
  opacity:1 !important;
  transition:color .15s, border-color .15s;
}
.card-header-tabs .nav-tabs .nav-link i{ font-size:18px; }
.card-header-tabs .nav-tabs .nav-link:hover{ color:var(--crm-accent) !important; }
.card-header-tabs .nav-tabs .nav-item .nav-link.active,
.card-header-tabs .nav-tabs .nav-link.active{
  color:var(--crm-accent) !important;
  background:transparent !important;
  border-bottom:2px solid var(--crm-accent) !important;
}
/* hide Material's sliding white underline bar (we use a static one) */
.card-header-tabs .nav-tabs .nav-link::after,
.card-header-tabs .nav-tabs-navigation::after{ display:none !important; }

/* ============================================================================
   MOBILE TUNING — Nav drawer + Dashboard (narrow screens)
   Placed last so it wins over earlier responsive rules.
   ============================================================================ */
@media (max-width:991px){
  /* navbar: compact + in normal flow → removes the big empty gap under it */
  .navbar.navbar-absolute{
    position:relative !important;
    min-height:auto !important;
    padding:8px 14px !important;
    background:#fff !important;
    backdrop-filter:none !important; -webkit-backdrop-filter:none !important;
    box-shadow:none !important;
  }
  .navbar .navbar-brand{ font-size:1.2rem !important; }
  .main-panel .content{ padding:14px !important; }
  .kpi-row{ margin-top:0 !important; }

  /* header items collapse into the drawer — tidy them */
  .navbar .navbar-form{ width:100%; margin:8px 0; }
  .navbar .navbar-form .input-group{ width:100%; }
  .navbar .navbar-form .input-group .form-control{ width:100% !important; min-width:0 !important; }
  .navbar .navbar-nav{ gap:6px; padding:4px 0; align-items:flex-start; }
  /* drop the redundant "Notification's" / "Account" mobile text labels */
  .navbar .navbar-nav .nav-link p{ display:none !important; }
}

@media (max-width:640px){
  .kpi-card{ padding:16px; }
  .kpi-value{ font-size:1.7rem !important; }
  .crm-user-chip{ padding:4px 12px 4px 4px; }
  .notif-panel{ padding:16px; }
}

/* ============================================================================
   TRIP / CONFIRMED BOOKING PAGES — trip-specific bits migrated from
   trip/index.php inline <style>. (Filter panel, chips, buttons, fields are
   already shared above from the leads migration.)
   ============================================================================ */

/* amount helpers */
.text-due{ color:#e53935; font-weight:600; font-size:12px; }
.text-tot{ color:var(--crm-accent); font-weight:600; font-size:12px; }

/* status badges */
.badge-won       { background:#e8f5e9; color:#2e7d32; padding:2px 10px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.badge-cancelled { background:#fce4ec; color:#c62828; padding:2px 10px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }

/* cancelled row tint — needs high specificity to beat the transparent-row rule */
.table tbody tr.row-cancelled,
.table tbody tr.row-cancelled td{ background:#fff0f3 !important; }

/* trip-mode banner */
.trip-mode-banner{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding:10px 16px; border-radius:10px; margin-bottom:12px;
  font-size:13px; font-weight:600;
}
.trip-mode-banner .material-icons{ font-size:18px; }
.trip-mode-banner a{
  margin-left:auto; font-size:12px; font-weight:500;
  padding:3px 12px; border-radius:20px; text-decoration:none; white-space:nowrap;
}
.trip-banner-upcoming  { background:#e3f2fd; color:#1565c0; border:1px solid #90caf9; }
.trip-banner-upcoming a { background:#1565c0; color:#fff; }
.trip-banner-completed { background:#f3e5f5; color:#6a1b9a; border:1px solid #ce93d8; }
.trip-banner-completed a { background:#6a1b9a; color:#fff; }
.trip-banner-ongoing   { background:#e8f5e9; color:#2e7d32; border:1px solid #a5d6a7; }
.trip-banner-ongoing a { background:#2e7d32; color:#fff; }
.trip-banner-webcheckin{ background:#fff8e1; color:#f57f17; border:1px solid #ffe082; }
.trip-banner-webcheckin a { background:#f57f17; color:#fff; }

/* trip source-details sub-field (navy focus) */
#tripSourceDetailsWrap{ display:none; flex-direction:column; gap:3px; }
#tripSourceDetailsWrap.visible{ display:flex; }
#tripSourceDetailsWrap label{ font-size:11px; font-weight:600; color:#666; text-transform:uppercase; letter-spacing:.3px; }
#tripSourceDetailsWrap select,
#tripSourceDetailsWrap input{
  padding:6px 10px; font-size:13px; border:1px solid #ccc; border-radius:8px;
  background:#fff; color:#333; transition:border-color .15s, box-shadow .15s;
}
#tripSourceDetailsWrap select:focus,
#tripSourceDetailsWrap input:focus{ border-color:var(--crm-accent); box-shadow:0 0 0 2px rgba(9,63,102,.13); outline:none; }
.s3x{font-family:'DM Sans',sans-serif;color:#093f66}
.s3x-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.s3x-crumbs{font-size:14px;font-weight:500}
.s3x-crumbs a{color:#093f66;cursor:pointer;text-decoration:none}
.s3x-crumbs a:hover{text-decoration:underline}
.s3x-crumbs span.sep{color:#aab4bd;margin:0 6px}
.s3x-actions{display:flex;gap:8px}
.s3x-b{border:0;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}
.s3x-pri{background:#093f66;color:#fff}
.s3x-pri:hover{background:#0c5288}
.s3x-ghost{background:#eef2f5;color:#093f66}
.s3x-ghost:hover{background:#e0e7ec}
.s3x-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:14px;min-height:140px;border-radius:12px;transition:.15s}
.s3x-grid.drag{outline:2px dashed #093f66;outline-offset:6px;background:#f3f7fa}
.s3x-tile{position:relative;border:1px solid #eaeef1;border-radius:12px;padding:16px 8px 12px;text-align:center;cursor:pointer;transition:.12s;background:#fff}
.s3x-tile:hover{border-color:#093f66;box-shadow:0 4px 14px rgba(9,63,102,.10);transform:translateY(-1px)}
.s3x-ico{width:46px;height:46px;margin:0 auto 8px;display:block}
.s3x-name{font-size:12.5px;line-height:1.3;word-break:break-word;max-height:34px;overflow:hidden}
.s3x-meta{font-size:10.5px;color:#9aa7b1;margin-top:3px}
.s3x-meta-warn{color:#c77b00}
.s3x-warn{position:absolute;top:4px;left:6px;color:#e8a200;font-size:14px;line-height:1}
.s3x-kebab{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#9aa7b1;font-size:16px;opacity:0}
.s3x-tile:hover .s3x-kebab{opacity:1}
.s3x-kebab:hover{background:#eef2f5}
.s3x-empty{text-align:center;color:#9aa7b1;padding:34px;font-size:13px}
.s3x-busy{font-size:12px;color:#093f66;margin-top:12px;display:flex;align-items:center;gap:8px}
.s3x-busy span{width:14px;height:14px;border:2px solid #cdd8e0;border-top-color:#093f66;border-radius:50%;animation:s3xspin .7s linear infinite}
@keyframes s3xspin{to{transform:rotate(360deg)}}
.s3x-cm{position:fixed;z-index:9000;background:#fff;border:1px solid #e6ebee;border-radius:10px;box-shadow:0 10px 30px rgba(9,63,102,.18);padding:6px;min-width:170px;display:none}
.s3x-cm button{display:flex;align-items:center;gap:10px;width:100%;border:0;background:none;padding:9px 12px;border-radius:7px;font-size:13px;color:#093f66;cursor:pointer;text-align:left;font-family:inherit}
.s3x-cm button:hover{background:#f1f5f8}
.s3x-cm button.danger{color:#d9352c}
.s3x-cm .div{height:1px;background:#eef2f5;margin:5px 4px}
.s3x-bg{position:fixed;inset:0;background:rgba(9,30,48,.45);z-index:9100;display:none;align-items:center;justify-content:center;padding:20px}
.s3x-bg.show{display:flex}
.s3x-modal{background:#fff;border-radius:14px;padding:22px;width:100%;max-width:420px;font-family:inherit}
.s3x-modal h4{margin:0 0 14px;color:#093f66;font-size:16px;font-weight:700}
.s3x-modal input{width:100%;border:1px solid #d6dde2;border-radius:9px;padding:10px 12px;font-size:14px;font-family:inherit;margin-bottom:6px}
.s3x-modal input:focus{outline:0;border-color:#093f66}
.s3x-picker{max-height:240px;overflow:auto;border:1px solid #eef2f5;border-radius:9px;margin:6px 0 14px}
.s3x-picker button{display:block;width:100%;text-align:left;border:0;background:none;padding:9px 12px;font-size:13px;color:#093f66;cursor:pointer;font-family:inherit;border-bottom:1px solid #f3f6f8}
.s3x-picker button:hover{background:#f1f5f8}
.s3x-mbtns{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}
.s3x-prev{background:#fff;border-radius:14px;max-width:90vw;max-height:90vh;overflow:auto;padding:10px}
.s3x-prev img,.s3x-prev video{max-width:86vw;max-height:80vh;display:block;border-radius:8px}
.s3x-prev iframe{width:86vw;height:80vh;border:0;border-radius:8px}
.s3x-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#093f66;color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;font-family:'DM Sans',sans-serif;z-index:9300;opacity:0;transition:.25s;pointer-events:none}
.s3x-toast.show{opacity:1}
.s3x-toast.err{background:#d9352c}