/* =============================================
   Digital Safari CRM - Main Stylesheet v2.0
   Theme: Red #dc1f26 + Black #1a1a1a + White
   ============================================= */

:root{
  --ds-red:#dc1f26;
  --ds-red-dark:#b3171d;
  --ds-red-light:#ff4d54;
  --ds-black:#1a1a1a;
  --ds-grey:#f4f5f7;
  --ds-border:#e5e7eb;
  --sidebar-w:240px;
  --topbar-h:56px;
  --radius:10px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06);
  --shadow:0 4px 12px rgba(0,0,0,.08);
  --shadow-lg:0 10px 25px rgba(0,0,0,.12);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

[data-bs-theme="dark"]{
  --ds-grey:#1c1d22;
  --ds-border:#2c2d33;
  --bs-body-bg:#0f1014;
  --bs-body-color:#e4e6eb;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  font-family:var(--font);
  background:var(--ds-grey);
  font-size:14px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ── Top Bar ── */
.topbar{
  height:var(--topbar-h);
  background:linear-gradient(135deg,var(--ds-black) 0%,#2a2a2a 100%);
  position:sticky;top:0;z-index:1030;
  border-bottom:3px solid var(--ds-red);
}
.brand{font-weight:700;font-size:1.05rem}
.brand-mark{
  width:36px;height:36px;background:var(--ds-red);border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:14px;letter-spacing:.5px;
}
.brand-logo{height:34px;width:auto;border-radius:6px;background:#fff;padding:3px}
.brand-text{font-weight:600;letter-spacing:.3px}
.btn-icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.1rem}
.btn-icon:hover{background:rgba(255,255,255,.1)}
.notif-badge{position:absolute;top:-2px;right:-2px;font-size:.65rem;padding:.25em .45em;border-radius:50%}
.avatar-sm{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid #fff}
.avatar-initial{
  background:var(--ds-red);color:#fff;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:14px;
}

/* ── Layout ── */
.layout-wrap{display:flex;min-height:calc(100vh - var(--topbar-h))}
.sidebar{
  width:var(--sidebar-w);background:#fff;
  border-right:1px solid var(--ds-border);
  position:sticky;top:var(--topbar-h);
  height:calc(100vh - var(--topbar-h));
  overflow-y:auto;transition:transform .25s ease;z-index:1020;
}
[data-bs-theme="dark"] .sidebar{background:#16171c;border-color:var(--ds-border)}
.sidebar-inner{display:flex;flex-direction:column;height:100%;padding:1rem 0}
.sidebar .nav-link{
  display:flex;align-items:center;gap:.75rem;
  padding:.65rem 1.25rem;color:#444;
  border-left:3px solid transparent;
  font-weight:500;font-size:.92rem;transition:all .15s;
}
[data-bs-theme="dark"] .sidebar .nav-link{color:#bcc1cc}
.sidebar .nav-link:hover{background:var(--ds-grey);color:var(--ds-red)}
.sidebar .nav-link.active{
  background:linear-gradient(90deg,rgba(220,31,38,.1),transparent);
  color:var(--ds-red);border-left-color:var(--ds-red);font-weight:600;
}
.sidebar .nav-link i{font-size:1.1rem;width:22px;text-align:center}
.sidebar-footer{margin-top:auto;padding:1rem;border-top:1px solid var(--ds-border)}
.sidebar-backdrop{
  display:none;position:fixed;inset:var(--topbar-h) 0 0 0;
  background:rgba(0,0,0,.5);z-index:1019;
}
.sidebar-backdrop.show{display:block}
.main-content{flex:1;min-width:0;overflow-x:hidden}

@media(max-width:991.98px){
  .sidebar{position:fixed;left:0;top:var(--topbar-h);transform:translateX(-100%)}
  .sidebar.show{transform:translateX(0)}
  :root{--sidebar-w:260px}
}

/* ── Page Header ── */
.page-header{margin-bottom:1.25rem}
.page-header h2{font-weight:700;font-size:1.4rem;display:flex;align-items:center;gap:.5rem;margin:0}
.page-header h2 i{color:var(--ds-red)}
.page-title{font-weight:700;margin-bottom:1rem;font-size:1.4rem;display:flex;align-items:center;gap:.5rem}
.page-title i{color:var(--ds-red)}

/* ── Cards ── */
.card{border:1px solid var(--ds-border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
[data-bs-theme="dark"] .card{background:#1c1d22;border-color:var(--ds-border)}
.card-header{background:transparent;border-bottom:1px solid var(--ds-border);font-weight:600;padding:.85rem 1rem}

/* ── Stat Cards ── */
.stat-card{
  background:#fff;border-radius:var(--radius);padding:1rem;
  display:flex;align-items:center;gap:.85rem;
  box-shadow:var(--shadow-sm);border:1px solid var(--ds-border);
  border-left:4px solid var(--ds-red);
  transition:transform .15s,box-shadow .15s;
}
[data-bs-theme="dark"] .stat-card{background:#1c1d22}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.stat-card .stat-icon{
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.4rem;flex-shrink:0;
}
.stat-card .stat-num,.stat-card h3{font-size:1.5rem;font-weight:700;line-height:1;margin:0}
.stat-card .stat-lbl,.stat-card p{color:#6c757d;font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem;margin-bottom:0}

.bg-red{background:var(--ds-red)!important}
.bg-black{background:var(--ds-black)!important}
.text-red{color:var(--ds-red)!important}

/* ── Buttons ── */
.btn-primary{background:var(--ds-red);border-color:var(--ds-red)}
.btn-primary:hover,.btn-primary:focus{background:var(--ds-red-dark);border-color:var(--ds-red-dark)}
.btn-ds,.btn-primary-ds{
  background:var(--ds-red);border-color:var(--ds-red);color:#fff;
  border-radius:8px;font-weight:500;
}
.btn-ds:hover,.btn-primary-ds:hover{background:var(--ds-red-dark);border-color:var(--ds-red-dark);color:#fff}
.btn-dark{background:var(--ds-black);border-color:var(--ds-black)}
.btn-outline-primary{color:var(--ds-red);border-color:var(--ds-red)}
.btn-outline-primary:hover{background:var(--ds-red);border-color:var(--ds-red)}
.btn{border-radius:8px;font-weight:500}
.btn-sm{border-radius:6px}

/* ── Forms ── */
.form-control,.form-select{
  border-radius:8px;border-color:#cfd2d6;             /* darker border for visibility against light grey body */
  background-color:#ffffff;
  font-size:.92rem;padding:.5rem .75rem;
}
.form-select{                                          /* explicit caret + bg so dropdowns are findable */
  background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23495057' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat:no-repeat;
  background-position:right .75rem center;
  background-size:16px 12px;
}
.form-control:focus,.form-select:focus{
  border-color:var(--ds-red);box-shadow:0 0 0 .2rem rgba(220,31,38,.15);
}
/* Dark-mode select / input contrast — Bootstrap defaults blend into the page */
[data-bs-theme="dark"] .form-select,
[data-bs-theme="dark"] .form-control{
  background-color:#22232a;color:#e4e6eb;border-color:#3a3b42;
}
[data-bs-theme="dark"] .form-select{
  background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23bcc1cc' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
}
[data-bs-theme="dark"] .form-select option{
  background-color:#22232a;color:#e4e6eb;
}
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus{
  background-color:#2a2b33;color:#e4e6eb;
  border-color:var(--ds-red);box-shadow:0 0 0 .2rem rgba(220,31,38,.25);
}
[data-bs-theme="dark"] .form-control::placeholder{color:#8b8f99}
.form-label{font-weight:500;font-size:.85rem;margin-bottom:.3rem}

/* ── Tables ── */
.table{font-size:.9rem}
.table thead th{
  background:var(--ds-grey);font-size:.78rem;
  text-transform:uppercase;letter-spacing:.5px;
  font-weight:600;border-bottom:2px solid var(--ds-border);
  padding:.75rem;color:#555;white-space:nowrap;
}
[data-bs-theme="dark"] .table thead th{background:#22232a;color:#bbb}
.table tbody td{padding:.75rem;vertical-align:middle;border-color:var(--ds-border)}
.table-hover tbody tr:hover{background:rgba(220,31,38,.04)}
[data-bs-theme="dark"] .table-hover tbody tr:hover{background:rgba(220,31,38,.1)}

/* ── Compact actions cell on the leads table ─────────────────────────────
   Buttons may wrap onto a second line on narrow screens (which is better
   than horizontal scroll). Smaller padding makes them fit. */
.actions-cell{white-space:normal !important;line-height:1.6}
.actions-cell .btn{padding:.2rem .4rem;margin:1px;font-size:.78rem;border-radius:5px}
.actions-cell .btn i{font-size:.85rem}
.actions-cell .btn .bi{vertical-align:-.05em}

/* Hide the "Created" column on screens narrower than xl (1200px).
   Information still available via the lead detail modal. */
@media (max-width:1199.98px){
  .leads-table .col-created{display:none !important}
}
/* Smaller screens also hide the "Created" header and the table's
   padding shrinks slightly to fit. */
@media (max-width:991.98px){
  .leads-table thead th,.leads-table tbody td{padding:.5rem .55rem}
  .leads-table{font-size:.85rem}
}

/* ── Status Badges ── */
.status-badge{
  display:inline-block;padding:.3rem .65rem;border-radius:20px;
  font-size:.72rem;font-weight:600;color:#fff;
  text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;
}
.priority-low{color:#6c757d}
.priority-medium{color:#17a2b8}
.priority-high{color:#fd7e14;font-weight:600}
.priority-urgent{color:#dc3545;font-weight:700}

/* ── Login ── */
.login-page{
  min-height:100vh;
  background:linear-gradient(135deg,var(--ds-black) 0%,var(--ds-red) 100%);
  display:flex;align-items:center;justify-content:center;padding:1rem;
}
.login-card{
  background:#fff;border-radius:16px;
  box-shadow:0 20px 50px rgba(0,0,0,.3);
  width:100%;max-width:420px;padding:2.5rem 2rem;
}
.login-brand{text-align:center;margin-bottom:1.5rem}
.login-brand .brand-mark{width:60px;height:60px;font-size:22px}
.login-brand h2{margin-top:.75rem;font-weight:700;color:var(--ds-black)}
.login-brand p{color:#888;font-size:.9rem;margin:0}

/* ── Chat Drawer ── */
.chat-drawer{
  position:fixed;right:0;top:0;bottom:0;width:360px;
  background:#fff;border-left:1px solid var(--ds-border);
  box-shadow:-5px 0 20px rgba(0,0,0,.1);
  transform:translateX(100%);transition:transform .3s ease;
  z-index:1050;display:flex;flex-direction:column;
}
[data-bs-theme="dark"] .chat-drawer{background:#1c1d22}
.chat-drawer.show{transform:translateX(0)}
.chat-header{
  background:var(--ds-red);color:#fff;padding:1rem;
  display:flex;align-items:center;justify-content:space-between;
}
.chat-body{flex:1;display:flex;flex-direction:column;overflow:hidden}
.chat-users{overflow-y:auto;flex:1}
.chat-user{
  padding:.85rem 1rem;border-bottom:1px solid var(--ds-border);
  display:flex;align-items:center;gap:.75rem;cursor:pointer;
}
.chat-user:hover{background:var(--ds-grey)}
.chat-user .avatar-sm{width:40px;height:40px}
.chat-user .badge{margin-left:auto}
.chat-messages-pane{flex:1;display:flex;flex-direction:column;overflow:hidden}
.chat-back-btn{
  background:var(--ds-grey);border:0;padding:.5rem 1rem;
  text-align:left;border-bottom:1px solid var(--ds-border);
  font-size:.85rem;color:#555;width:100%;cursor:pointer;
}
.chat-messages{flex:1;overflow-y:auto;padding:1rem;background:var(--ds-grey)}
[data-bs-theme="dark"] .chat-messages{background:#0f1014}
.chat-msg{
  margin-bottom:.5rem;padding:.55rem .8rem;border-radius:12px;
  max-width:80%;font-size:.88rem;word-wrap:break-word;
}
.chat-msg.in{background:#fff;border:1px solid var(--ds-border)}
[data-bs-theme="dark"] .chat-msg.in{background:#22232a;border-color:#2e2f36}
.chat-msg.out{background:var(--ds-red);color:#fff;margin-left:auto}
.chat-msg .meta{display:block;font-size:.7rem;opacity:.7;margin-top:.2rem}
.chat-form{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--ds-border)}
@media(max-width:575.98px){.chat-drawer{width:100%}}

/* ── Sticky Notes ── */
.sticky-note{
  background:#fff8c5;padding:1rem;border-radius:8px;
  box-shadow:var(--shadow-sm);font-size:.88rem;
  position:relative;border-left:4px solid #fbc02d;margin-bottom:.75rem;
}
/* color-* prefix (admin dashboard) */
.sticky-note.color-yellow{background:#fff8c5;border-left-color:#fbc02d}
.sticky-note.color-blue{background:#d0e8ff;border-left-color:#0d6efd}
.sticky-note.color-green{background:#d4edda;border-left-color:#28a745}
.sticky-note.color-pink{background:#fad6dc;border-left-color:#dc1f26}
.sticky-note.color-orange{background:#ffe5cc;border-left-color:#fd7e14}
.sticky-note.color-purple{background:#e2d6fa;border-left-color:#6f42c1}
/* sticky-* prefix (agent dashboard) */
.sticky-note.sticky-yellow{background:#fff8c5;border-left-color:#fbc02d}
.sticky-note.sticky-blue{background:#d0e8ff;border-left-color:#0d6efd}
.sticky-note.sticky-green{background:#d4edda;border-left-color:#28a745}
.sticky-note.sticky-pink{background:#fad6dc;border-left-color:#dc1f26}
.sticky-note.sticky-orange{background:#ffe5cc;border-left-color:#fd7e14}
.sticky-note.sticky-purple{background:#e2d6fa;border-left-color:#6f42c1}
/* color swatches */
.sticky-yellow{background:#fff8c5!important}
.sticky-blue{background:#d0e8ff!important}
.sticky-green{background:#d4edda!important}
.sticky-pink{background:#fad6dc!important}
.sticky-orange{background:#ffe5cc!important}
.sticky-purple{background:#e2d6fa!important}

.sticky-note .del-note{
  position:absolute;top:.35rem;right:.5rem;
  background:transparent;border:0;color:#666;font-size:.9rem;cursor:pointer;
}
.btn-close-note{
  position:absolute;top:4px;right:6px;border:none;background:transparent;
  font-size:18px;cursor:pointer;opacity:.4;transition:opacity .15s;color:#333;
}
.btn-close-note:hover{opacity:1}

/* ── Color picker for notes ── */
.color-picker{display:inline-block;cursor:pointer}
.color-picker input{display:none}
.color-swatch{
  display:inline-block;width:28px;height:28px;border-radius:50%;
  border:3px solid transparent;transition:border-color .15s;
}
.color-picker input:checked + .color-swatch{border-color:var(--ds-black)}

/* ── Calendar ── */
.calendar-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:1px;
  background:var(--ds-border);border:1px solid var(--ds-border);
}
.cal-header{
  background:var(--ds-black);color:#fff;padding:8px;text-align:center;
  font-size:.85rem;font-weight:600;
}
.cal-cell{
  background:#fff;min-height:90px;padding:4px;
  cursor:pointer;transition:background .15s;position:relative;
}
[data-bs-theme="dark"] .cal-cell{background:#1c1d22}
.cal-cell:hover{background:rgba(220,31,38,.05)}
.cal-cell.empty{background:var(--ds-grey);cursor:default}
[data-bs-theme="dark"] .cal-cell.empty{background:#16171c}
.cal-cell.today{background:rgba(220,31,38,.08)}
.cal-cell.today .cal-date{color:var(--ds-red);font-weight:700}
.cal-date{font-size:.85rem;font-weight:600;margin-bottom:2px}
.cal-events{display:flex;flex-direction:column;gap:2px}
.cal-event{
  color:#fff;font-size:.7rem;padding:1px 4px;border-radius:3px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.cal-more{font-size:.65rem;color:#888}
@media(max-width:768px){
  .cal-cell{min-height:60px;padding:2px}
  .cal-date{font-size:.75rem}
  .cal-event{font-size:.6rem;padding:0 2px}
}

/* ── Timeline ── */
.timeline-list{list-style:none;padding:0;position:relative;margin-left:1rem}
.timeline-list::before{
  content:'';position:absolute;left:8px;top:0;bottom:0;
  width:2px;background:var(--ds-border);
}
.timeline-item{position:relative;padding:0 0 1.25rem 1.75rem}
.timeline-item::before{
  content:'';position:absolute;left:2px;top:4px;width:14px;height:14px;
  background:var(--ds-red);border-radius:50%;border:3px solid #fff;
  box-shadow:0 0 0 2px var(--ds-red);
}
.timeline-item .ti-time{font-size:.72rem;color:#888;display:block}
.timeline-item .ti-desc{margin:.2rem 0 0}

/* ── Status dot ── */
.status-dot{
  display:inline-block;width:10px;height:10px;border-radius:50%;
  margin-right:6px;vertical-align:middle;
}

/* ── Misc ── */
.dropdown-menu{border-radius:10px;border-color:var(--ds-border);box-shadow:var(--shadow-lg)}
[data-bs-theme="dark"] .dropdown-menu{background:#22232a}
.notif-dropdown{width:320px;max-height:380px;overflow-y:auto}
.notif-item{padding:.65rem 1rem;border-bottom:1px solid var(--ds-border);font-size:.85rem}
.notif-item:last-child{border-bottom:none}
.modal-content{border-radius:var(--radius);border:0}
.modal-header{background:var(--ds-grey);border-radius:var(--radius) var(--radius) 0 0}
[data-bs-theme="dark"] .modal-header{background:#22232a}
.empty-state{text-align:center;padding:3rem 1rem;color:#888}
.empty-state i{font-size:3rem;opacity:.4;display:block;margin-bottom:.5rem}
.search-box{position:relative}
.search-box i{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#888}
.search-box input{padding-left:2.25rem}

::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#bbb;border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:#888}

@media print{
  .topbar,.sidebar,.chat-drawer,.no-print{display:none!important}
  .main-content{margin:0}
}
