/* ============================================================
   Orbit CRM — glassmorphism design system
   Pairs with Bootstrap 5.3 (utility classes, grid, modal, etc.)
   ============================================================ */

:root{
  --ink:#1c1410;
  --ink-soft:#5c4a3f;
  --ink-mute:#a89486;
  --line:rgba(28,20,16,.08);
  --line-strong:rgba(28,20,16,.14);
  --primary:#f97316;
  --primary-600:#ea580c;
  --primary-700:#c2410c;
  --primary-soft:rgba(249,115,22,.12);
  --success:#10b981;
  --warning:#f59e0b;
  --danger:#ef4444;
  --info:#0ea5e9;
  --glass-bg:rgba(255,255,255,.62);
  --glass-bg-strong:rgba(255,255,255,.80);
  --glass-border:rgba(255,255,255,.6);
  --shadow-sm:0 1px 2px rgba(28,20,16,.04),0 1px 1px rgba(28,20,16,.03);
  --shadow:0 10px 30px -12px rgba(194,65,12,.18),0 4px 10px -6px rgba(28,20,16,.08);
  --shadow-lg:0 30px 60px -20px rgba(194,65,12,.28);
  --radius:18px;
  --radius-sm:12px;
}

/* Bootstrap primary overrides — keep BS utilities visually consistent */
:root{
  --bs-primary:#f97316;
  --bs-primary-rgb:249,115,22;
  --bs-link-color:var(--primary-700);
  --bs-link-hover-color:var(--primary-600);
  --bs-border-radius:12px;
  --bs-border-radius-sm:9px;
  --bs-border-radius-lg:16px;
  --bs-font-sans-serif:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --bs-body-color:var(--ink);
  --bs-body-font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 700px at 8% -10%, #ffd9b8 0%, transparent 60%),
    radial-gradient(1000px 600px at 95% 5%, #fecaca 0%, transparent 55%),
    radial-gradient(900px 700px at 50% 110%, #fef3c7 0%, transparent 55%),
    linear-gradient(180deg,#fffbf7 0%, #fef6ee 100%);
  background-attachment:fixed;
  min-height:100%;
  letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary-700);text-decoration:none}
a:hover{color:var(--primary-600)}
hr{border-color:var(--line);opacity:1}

/* ---------- Glass primitives ---------- */
.glass{
  background:var(--glass-bg);
  backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.glass-strong{background:var(--glass-bg-strong)}
.glass-flat{
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
}

/* ---------- App shell ---------- */
.app{display:grid;grid-template-columns:264px minmax(0,1fr);gap:22px;padding:22px;min-height:100vh}
.app-main{display:flex;flex-direction:column;gap:14px;min-width:0}

/* ---------- Sidebar ---------- */
.sidebar{
  position:sticky;top:22px;align-self:start;
  height:calc(100vh - 44px);
  padding:22px 18px;
  display:flex;flex-direction:column;gap:6px;
}
.sidebar-backdrop{display:none}
.hamburger{display:none}

.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 18px;border-bottom:1px solid var(--line);margin-bottom:14px}
.brand-logo{
  width:38px;height:38px;border-radius:12px;
  background:linear-gradient(135deg,#fb923c,#f97316 55%,#ea580c);
  display:grid;place-items:center;color:#fff;font-size:18px;
  box-shadow:0 8px 20px -6px rgba(249,115,22,.6);
}
.brand-name{font-weight:700;font-size:17px;letter-spacing:-.01em}
.brand-sub{font-size:11px;color:var(--ink-mute);letter-spacing:.06em;text-transform:uppercase}

.nav-section{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);padding:14px 12px 6px;font-weight:600}
.nav-link-mod{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:12px;
  color:var(--ink-soft);text-decoration:none;font-weight:500;font-size:14px;
  transition:all .15s ease;
}
.nav-link-mod i{width:18px;text-align:center;color:var(--ink-mute)}
.nav-link-mod:hover{background:rgba(249,115,22,.08);color:var(--ink)}
.nav-link-mod.active{
  background:linear-gradient(135deg,rgba(249,115,22,.2),rgba(251,146,60,.12));
  color:var(--primary-700);
  box-shadow:inset 0 0 0 1px rgba(249,115,22,.25);
}
.nav-link-mod.active i{color:var(--primary-600)}
.nav-badge{margin-left:auto;background:rgba(249,115,22,.16);color:var(--primary-700);font-size:11px;padding:2px 8px;border-radius:999px;font-weight:600}
.nav-submenu-toggle{cursor:pointer}
.nav-submenu-toggle .nav-submenu-arrow{margin-left:auto;font-size:10px;transition:transform .2s ease}
.nav-submenu-toggle[aria-expanded="true"] .nav-submenu-arrow{transform:rotate(180deg)}
.nav-submenu{padding-left:14px}
.nav-submenu .nav-link-mod{font-size:13px;padding:7px 12px}

.sidebar-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}
.sidebar-foot .user-info{flex:1;min-width:0;overflow:hidden}
.sidebar-foot .user-info .name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-foot .user-info .mail{font-size:11px;color:var(--ink-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#fb923c,#f43f5e);color:#fff;display:grid;place-items:center;font-weight:600;font-size:14px;flex-shrink:0}

/* ---------- Topbar ---------- */
.topbar{display:flex;align-items:center;gap:14px;padding:14px 20px}
.topbar-actions{display:flex;align-items:center;gap:10px;margin-left:auto}

.search{flex:1;max-width:480px;position:relative}
.search input{
  width:100%;border:1px solid var(--line);background:rgba(255,255,255,.7);
  backdrop-filter:blur(10px);
  border-radius:12px;padding:10px 14px 10px 40px;font-size:14px;
  transition:all .15s ease;
}
.search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(249,115,22,.18);background:#fff}
.search i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--ink-mute);font-size:14px}

.icon-btn{
  width:40px;height:40px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.7);backdrop-filter:blur(10px);
  display:grid;place-items:center;color:var(--ink-soft);
  position:relative;transition:all .15s ease;cursor:pointer;
  text-decoration:none;
}
.icon-btn:hover{background:#fff;color:var(--ink);transform:translateY(-1px)}
.icon-btn .dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid #fff}

/* ---------- Page header ---------- */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;padding:8px 22px 18px;flex-wrap:wrap;gap:12px}
.page-head h1{font-size:26px;font-weight:700;margin:0;letter-spacing:-.02em}
.page-head .sub{color:var(--ink-soft);font-size:14px;margin-top:2px}
.page-head .breadcrumb-mod{display:flex;gap:6px;font-size:12px;color:var(--ink-mute);margin-bottom:4px}
.page-head .breadcrumb-mod a{color:var(--ink-mute)}
.page-head .breadcrumb-mod a:hover{color:var(--primary-700)}
.page-head .breadcrumb-mod .sep::before{content:"/";margin:0 2px;color:var(--ink-mute)}

/* ---------- KPI cards ---------- */
.kpi{padding:20px 22px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}
.kpi .label{font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--ink-mute);text-transform:uppercase}
.kpi .value{font-size:30px;font-weight:700;letter-spacing:-.02em}
.kpi .delta{font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;width:fit-content}
.delta.up{background:rgba(16,185,129,.14);color:#047857}
.delta.down{background:rgba(239,68,68,.14);color:#b91c1c}
.kpi .ico{position:absolute;right:18px;top:18px;width:44px;height:44px;border-radius:14px;display:grid;place-items:center;font-size:18px;color:#fff}
.kpi .ico.indigo{background:linear-gradient(135deg,#f97316,#ea580c)}
.kpi .ico.pink  {background:linear-gradient(135deg,#fb923c,#f43f5e)}
.kpi .ico.teal  {background:linear-gradient(135deg,#fbbf24,#f97316)}
.kpi .ico.amber {background:linear-gradient(135deg,#f59e0b,#c2410c)}

/* ---------- Card ---------- */
.card-mod{overflow:hidden}
.card-mod+.card-mod{margin-top:16px}
.card-title-mod{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line);gap:12px}
.card-title-mod h3{font-size:15px;font-weight:600;margin:0;display:flex;align-items:center;gap:8px}
.card-title-mod h3 i{color:var(--primary-600)}
.card-title-mod .actions{display:flex;gap:6px;align-items:center}
.card-body-mod{padding:20px 22px}
.card-body-mod.flush{padding:0}
.card-foot-mod{padding:14px 22px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-mute)}

/* ---------- Buttons ---------- */
.btn-mod{
  border-radius:11px;padding:8px 16px;font-weight:600;font-size:13px;
  border:1px solid transparent;display:inline-flex;align-items:center;gap:8px;
  transition:all .15s ease;cursor:pointer;text-decoration:none;white-space:nowrap;
}
.btn-mod:disabled{opacity:.55;cursor:not-allowed}
.btn-primary-mod{background:linear-gradient(135deg,#fb923c,#f97316 50%,#ea580c);color:#fff;box-shadow:0 8px 18px -8px rgba(249,115,22,.65)}
.btn-primary-mod:hover{transform:translateY(-1px);box-shadow:0 12px 24px -8px rgba(249,115,22,.75);color:#fff}
.btn-ghost{background:rgba(255,255,255,.7);border-color:var(--line);color:var(--ink-soft)}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-soft{background:var(--primary-soft);color:var(--primary-700);border-color:transparent}
.btn-soft:hover{background:rgba(249,115,22,.2);color:var(--primary-700)}
.btn-danger-soft{background:rgba(239,68,68,.1);color:#b91c1c;border-color:transparent}
.btn-danger-soft:hover{background:rgba(239,68,68,.18);color:#b91c1c}
.btn-sm-mod{padding:6px 12px;font-size:12px;border-radius:9px}
.btn-lg-mod{padding:12px 22px;font-size:14px;border-radius:13px}

/* ---------- Pills / badges ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.01em}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.85}
.pill.success{background:rgba(16,185,129,.14);color:#047857}
.pill.warning{background:rgba(245,158,11,.16);color:#92400e}
.pill.danger {background:rgba(239,68,68,.14);color:#b91c1c}
.pill.info   {background:rgba(14,165,233,.14);color:#0369a1}
.pill.muted  {background:rgba(100,116,139,.14);color:#475569}
.pill.primary{background:var(--primary-soft);color:var(--primary-700)}
.pill-plain{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600}
.pill-plain::before{display:none}

/* ---------- Tables ---------- */
.table-mod{width:100%;border-collapse:separate;border-spacing:0}
.table-mod thead th{
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);
  font-weight:600;text-align:left;padding:12px 22px;border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.4);
}
.table-mod tbody td{padding:14px 22px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
.table-mod tbody tr:hover{background:rgba(249,115,22,.05)}
.table-mod tbody tr:last-child td{border-bottom:none}
.table-mod a{color:var(--ink);text-decoration:none;font-weight:600}
.table-mod a:hover{color:var(--primary-700)}
.table-mod .text-end{text-align:right}

.row-avatar{display:flex;align-items:center;gap:12px}
.row-avatar .av{width:36px;height:36px;border-radius:11px;color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0;background:linear-gradient(135deg,#fb923c,#ea580c)}
.row-avatar .meta{min-width:0}
.row-avatar .meta a{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-avatar .meta small{display:block;color:var(--ink-mute);font-weight:500;font-size:12px;margin-top:1px}

.table-foot{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-soft);gap:12px;flex-wrap:wrap}

/* DataTables 1.x Bootstrap integration — neutralize default styles */
.table-mod.dataTable{border-collapse:separate !important}
.dataTables_wrapper{padding:0 !important}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter{padding:14px 22px 0;margin:0}
.dataTables_wrapper .dataTables_filter input{
  border:1px solid var(--line);background:rgba(255,255,255,.7);
  border-radius:11px;padding:8px 14px;margin-left:8px;font-size:13px;
}
.dataTables_wrapper .dataTables_filter input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(249,115,22,.18);background:#fff}
.dataTables_wrapper .dataTables_length select{
  border:1px solid var(--line);background:rgba(255,255,255,.7);
  border-radius:9px;padding:4px 8px;font-size:13px;
}
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate{padding:14px 22px;font-size:13px;color:var(--ink-soft)}
.dataTables_wrapper .dataTables_paginate .pagination{gap:4px;margin:0}
.dataTables_wrapper .dataTables_paginate .page-link{
  padding:6px 12px;border-radius:9px;border:1px solid var(--line);
  background:rgba(255,255,255,.7);color:var(--ink-soft);font-size:13px;
}
.dataTables_wrapper .dataTables_paginate .page-item.active .page-link,
.dataTables_wrapper .dataTables_paginate .page-item.active .page-link:hover{
  background:linear-gradient(135deg,#fb923c,#ea580c);color:#fff;
  border-color:transparent;box-shadow:0 6px 14px -6px rgba(249,115,22,.6);
}
.dataTables_wrapper .dataTables_paginate .page-item:not(.active):not(.disabled) .page-link:hover{
  background:var(--primary-soft);color:var(--primary-700);border-color:transparent;
}
.dataTables_wrapper .dataTables_paginate .page-item.disabled .page-link{
  background:transparent;color:var(--ink-mute);border-color:var(--line);opacity:.5;
}

/* ---------- Forms ---------- */
.field{margin-bottom:14px}
.field label, .form-label-mod{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:6px;letter-spacing:.01em}
.field .hint{font-size:11px;color:var(--ink-mute);margin-top:4px}
.input-mod, textarea.input-mod, select.input-mod{
  width:100%;padding:10px 14px;border-radius:11px;border:1px solid var(--line);
  background:rgba(255,255,255,.78);backdrop-filter:blur(8px);
  font-size:14px;font-family:inherit;color:var(--ink);transition:all .15s ease;
}
.input-mod:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(249,115,22,.18);background:#fff}
.input-mod::placeholder{color:var(--ink-mute)}
.input-mod:disabled{background:rgba(0,0,0,.04);color:var(--ink-mute)}
textarea.input-mod{min-height:90px;resize:vertical}
select.input-mod{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.input-group-mod{display:flex;gap:8px}
.input-group-mod .input-mod{flex:1}
.input-group{flex-wrap:nowrap}
.input-group .input-mod{border-top-right-radius:0;border-bottom-right-radius:0;width:auto;flex:1 1 0%;min-width:0}
.input-group .input-group-text{border-radius:0 11px 11px 0;border:1px solid var(--line);border-left:0;background:rgba(255,255,255,.55);backdrop-filter:blur(8px);font-size:13px;color:var(--ink-soft);padding:0 12px;display:flex;align-items:center}

/* Select2 v4 integration */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple{
  border:1px solid var(--line) !important;background:rgba(255,255,255,.78) !important;
  border-radius:11px !important;min-height:42px !important;padding:4px 8px !important;
}
.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--open .select2-selection--single{
  border-color:var(--primary) !important;box-shadow:0 0 0 4px rgba(249,115,22,.18) !important;background:#fff !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered{line-height:32px !important;color:var(--ink) !important;padding-left:6px}
.select2-container--default .select2-selection--single .select2-selection__arrow{height:40px !important}
.select2-dropdown{border:1px solid var(--line) !important;border-radius:11px !important;box-shadow:var(--shadow) !important;overflow:hidden}
.select2-container--default .select2-results__option--highlighted[aria-selected]{background:var(--primary) !important}
.select2-container--default .select2-selection--multiple .select2-selection__choice{
  background:var(--primary-soft) !important;border:1px solid rgba(249,115,22,.25) !important;color:var(--primary-700) !important;
  border-radius:8px !important;padding:2px 8px !important;
}

/* ---------- Dropdown menu (custom popover) ---------- */
.dropdown-mod{
  position:absolute;z-index:1100;min-width:240px;
  background:var(--glass-bg-strong);backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
  border:1px solid var(--glass-border);border-radius:14px;
  box-shadow:var(--shadow-lg);padding:6px;
  opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;
  transition:opacity .15s ease, transform .15s ease;
}
.dropdown-mod.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.dropdown-mod .dd-item{
  display:flex;align-items:center;gap:12px;width:100%;
  padding:10px 12px;border-radius:10px;border:none;background:transparent;
  font:500 13.5px 'Inter',sans-serif;color:var(--ink);text-align:left;cursor:pointer;
  transition:background .12s ease;text-decoration:none;
}
.dropdown-mod .dd-item i{width:16px;color:var(--ink-mute);font-size:13px}
.dropdown-mod .dd-item:hover{background:var(--primary-soft);color:var(--primary-700)}
.dropdown-mod .dd-item:hover i{color:var(--primary-700)}
.dropdown-mod .dd-item.danger{color:var(--danger)}
.dropdown-mod .dd-item.danger i{color:var(--danger)}
.dropdown-mod .dd-item.danger:hover{background:rgba(239,68,68,.10)}
.dropdown-mod .dd-sep{height:1px;background:var(--line);margin:6px 4px}
.dropdown-mod .dd-label{padding:8px 12px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-mute)}

/* ---------- Status badges & select ---------- */
.status-badge{display:inline-block;padding:8px 20px;border-radius:10px;font-weight:700;font-size:15px;letter-spacing:.01em}
.status-badge.status-draft{background:rgba(249,115,22,.14);color:#c2410c}
.status-badge.status-sent{background:rgba(59,130,246,.12);color:#1d4ed8}
.status-badge.status-accepted{background:rgba(34,197,94,.12);color:#15803d}
.status-badge.status-rejected{background:rgba(239,68,68,.12);color:#b91c1c}
.status-badge.status-expired{background:rgba(239,68,68,.08);color:#b91c1c}
.status-select.status-opt-draft{border-color:#fb923c;background:rgba(249,115,22,.06);color:#c2410c}
.status-select.status-opt-sent{border-color:#60a5fa;background:rgba(59,130,246,.06);color:#1d4ed8}
.status-select.status-opt-accepted{border-color:#4ade80;background:rgba(34,197,94,.06);color:#15803d}
.status-select.status-opt-rejected{border-color:#f87171;background:rgba(239,68,68,.06);color:#b91c1c}
.status-select.status-opt-expired{border-color:#f87171;background:rgba(239,68,68,.04);color:#b91c1c}

/* ---------- Modal (BS5) style override ---------- */
.modal-content{
  background:var(--glass-bg-strong);
  backdrop-filter:saturate(180%) blur(24px);
  -webkit-backdrop-filter:saturate(180%) blur(24px);
  border:1px solid var(--glass-border);
  border-radius:20px;
  box-shadow:var(--shadow-lg);
}
.modal-header{border-bottom:1px solid var(--line);padding:18px 22px 14px}
.modal-body{padding:14px 20px}
.modal-footer{border-top:1px solid var(--line);padding:12px 20px 16px}
.modal-body .card-mod{margin-bottom:12px;box-shadow:none;border-radius:14px}
.modal-body .card-mod:last-child{margin-bottom:0}
.modal-body .card-body-mod{padding:14px 16px}
.modal-body .card-header-mod{padding:12px 16px}
.modal-body form > .d-flex:last-child{margin-bottom:0 !important;margin-top:14px}
.modal-body .address-row,.modal-body .person-row{padding:12px !important;margin-bottom:10px !important}

/* ---------- Activity timeline ---------- */
.timeline{padding:18px 22px}
.timeline-item{position:relative;padding:0 0 18px 28px;border-left:2px solid var(--line);margin-left:8px}
.timeline-item:last-child{padding-bottom:0;border-left-color:transparent}
.timeline-item::before{
  content:"";position:absolute;left:-7px;top:2px;width:12px;height:12px;border-radius:50%;
  background:#fff;border:2px solid var(--primary);
  box-shadow:0 0 0 3px rgba(249,115,22,.15);
}
.timeline-item .t{font-weight:600;font-size:14px}
.timeline-item .b{font-size:13px;color:var(--ink-soft);margin-top:2px}
.timeline-item .when{font-size:11px;color:var(--ink-mute);margin-top:4px}

/* ---------- Toast ---------- */
.toast-mod{
  position:fixed;bottom:24px;right:24px;z-index:1100;
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 18px;min-width:300px;max-width:380px;
  background:var(--glass-bg-strong);backdrop-filter:saturate(180%) blur(20px);
  border:1px solid var(--glass-border);border-radius:14px;
  box-shadow:var(--shadow-lg);
  transform:translateY(20px);opacity:0;pointer-events:none;
  transition:all .25s ease;
}
.toast-mod.show{transform:translateY(0);opacity:1;pointer-events:auto}
.toast-mod .ti{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#fb923c,#ea580c);flex-shrink:0}
.toast-mod .tt{font-weight:600;font-size:14px}
.toast-mod .tb{font-size:12px;color:var(--ink-soft);margin-top:2px}

/* ---------- Flash alerts (custom, BS5-aware) ---------- */
.alert-mod{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 16px;border-radius:12px;font-size:13.5px;font-weight:500;
  border:1px solid transparent;margin-bottom:12px;
}
.alert-mod i{margin-top:2px;font-size:14px}
.alert-mod .btn-close{margin-left:auto;opacity:.55}
.alert-mod.success{background:rgba(16,185,129,.10);color:#047857;border-color:rgba(16,185,129,.25)}
.alert-mod.danger {background:rgba(239,68,68,.10); color:#b91c1c;border-color:rgba(239,68,68,.25)}
.alert-mod.warning{background:rgba(245,158,11,.12);color:#92400e;border-color:rgba(245,158,11,.25)}
.alert-mod.info   {background:rgba(14,165,233,.10);color:#0369a1;border-color:rgba(14,165,233,.25)}

/* ---------- Misc ---------- */
.divider{height:1px;background:var(--line);margin:18px 0}
.empty{padding:40px 20px;text-align:center;color:var(--ink-mute);font-size:13px}
.checkbox-mod{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--ink-soft)}
.checkbox-mod input{width:16px;height:16px;border-radius:5px;accent-color:var(--primary)}
.kv{display:grid;grid-template-columns:140px 1fr;gap:6px 16px;font-size:13.5px}
.kv dt{color:var(--ink-mute);font-weight:500}
.kv dd{margin:0;color:var(--ink);font-weight:500;word-break:break-word}

/* ---------- Responsive ---------- */
@media (max-width:992px){
  .app{grid-template-columns:minmax(0,1fr);gap:14px;padding:14px}
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;z-index:1050;
    width:280px;height:100vh;border-radius:0 var(--radius) var(--radius) 0;
    transform:translateX(-105%);transition:transform .28s ease;margin:0;
  }
  .sidebar.open{transform:translateX(0)}
  .sidebar-backdrop{
    display:block;position:fixed;inset:0;background:rgba(28,20,16,.35);
    backdrop-filter:blur(4px);z-index:1040;
    opacity:0;pointer-events:none;transition:opacity .2s ease;
  }
  .sidebar-backdrop.show{opacity:1;pointer-events:auto}
  .hamburger{display:grid}
  .topbar{padding:12px 14px;gap:8px}
  .search{max-width:none}
  .search input{padding:9px 12px 9px 36px;font-size:13px}
  .search i{left:12px}
  .page-head{padding:10px 14px 14px}
  .page-head h1{font-size:22px}
  .kpi{padding:16px 18px}
  .kpi .value{font-size:24px}
  .kpi .ico{width:38px;height:38px;font-size:15px;top:14px;right:14px}
  .card-title-mod{padding:14px 16px}
  .card-title-mod h3{font-size:14px}
  .card-body-mod{padding:16px 18px}
  .kv{grid-template-columns:110px 1fr}

  /* Table → stacked card on mobile */
  .table-mod thead{display:none}
  .table-mod, .table-mod tbody{display:block;width:100%}
  .table-mod tbody tr{display:block;position:relative;padding:14px 54px 14px 16px;border-bottom:1px solid var(--line)}
  .table-mod tbody tr:hover{background:transparent}
  .table-mod tbody td{display:inline;padding:0;border:none !important;background:transparent}
  .table-mod tbody td[data-role="select"]{display:none}
  .table-mod tbody td[data-role="primary"]{display:block;margin-bottom:10px}
  .table-mod tbody td[data-role="actions"]{position:absolute;top:14px;right:12px;display:block;width:32px;height:32px;padding:0;text-align:center}
  .table-mod tbody td[data-role="actions"] .icon-btn{width:32px;height:32px}
  .table-mod tbody td[data-role="meta"]{
    display:inline-flex;align-items:center;
    font-size:12px;color:var(--ink-soft);font-weight:500;
    margin:4px 14px 4px 0;white-space:nowrap;vertical-align:middle;
  }
  .table-mod tbody td[data-role="meta"] + td[data-role="meta"]::before{content:"·";margin-right:14px;color:var(--ink-mute)}
  .table-foot{padding:12px 14px;flex-direction:column;gap:10px}
  .timeline{padding:14px 18px}
  .brand-sub{display:none}
  body{background-attachment:scroll}
}

@media (max-width:576px){
  .topbar{gap:6px;padding:10px 12px}
  .topbar .hide-xs{display:none}
  .topbar .btn-primary-mod{padding:10px 13px}
  .topbar .btn-primary-mod .lbl{display:none}
  .search input{font-size:13px}
  .page-head{padding:10px 12px 14px}
  .page-head > .head-actions{width:100%;flex-wrap:wrap}
  .page-head h1{font-size:20px}
}

/* ---------- Auth (login) shell ---------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}
.auth-card{width:min(420px,100%);padding:32px 32px 28px}
.auth-card h1{font-size:22px;font-weight:700;text-align:center;margin:12px 0 6px}
.auth-card .sub{text-align:center;color:var(--ink-soft);font-size:13px;margin-bottom:22px}
