/* 4D Plus — Admin / CRM v4 — SPA + Real-time */
:root{
  --white:#fff;--bg:#f8f9fb;--surface:#fff;--border:#e8eaed;--border2:#d0d5dd;
  --text:#101828;--text2:#344054;--muted:#667085;--muted2:#98a2b3;
  --accent:#c8a24a;--accent-light:#fbf6ea;--accent-hover:#b08e3c;
  --green:#12b76a;--green-light:#ecfdf3;--amber:#f59e0b;--amber-light:#fffaeb;
  --red:#f04438;--red-light:#fef3f2;--purple:#7c3aed;--purple-light:#f5f3ff;
  --font:'Cairo',sans-serif;--mono:'JetBrains Mono',monospace;
  --radius:10px;--radius-lg:14px;
  --shadow-sm:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.04);
  --shadow:0 4px 8px -2px rgba(16,24,40,.08),0 2px 4px -2px rgba(16,24,40,.04);
  --shadow-lg:0 12px 24px -4px rgba(16,24,40,.1),0 4px 8px -2px rgba(16,24,40,.04);
}

/* ══════════════════════════════════════
   Dark Mode
══════════════════════════════════════ */
[data-theme="dark"]{
  --bg:#0f1117;--surface:#1a1d27;--white:#1a1d27;
  --border:#2a2d3a;--border2:#363a4d;
  --text:#e8eaf0;--text2:#a8adc4;--muted:#6b7194;--muted2:#4a4f6b;
  /* اللون الأساسي يُشتق من --accent المختار، ودرجة الخلفية تُحسب تلقائياً لتناسب الوضع الليلي */
  --accent-light:color-mix(in srgb,var(--accent) 16%,#13151d);
  --green-light:#0d2018;--amber-light:#1e1600;
  --red-light:#1f0a09;--purple-light:#150d2e;
  --shadow-sm:0 1px 3px rgba(0,0,0,.4);
  --shadow:0 4px 8px rgba(0,0,0,.35);
  --shadow-lg:0 12px 24px rgba(0,0,0,.45);
}
[data-theme="dark"] .sidebar{background:#141720;border-left:1px solid var(--border)}
[data-theme="dark"] .topbar{background:#1a1d27;border-bottom:1px solid var(--border)}
[data-theme="dark"] .card,[data-theme="dark"] .kpi,[data-theme="dark"] .kpi-card{background:var(--surface);border-color:var(--border)}
[data-theme="dark"] th{background:#141720}
[data-theme="dark"] .leads-table tbody tr:hover td{background:color-mix(in srgb,var(--accent) 8%,#1a1d27)}
[data-theme="dark"] .field input,[data-theme="dark"] .field select,[data-theme="dark"] .field textarea{background:#1e2130;color:var(--text);border-color:var(--border2)}
[data-theme="dark"] .filter-bar input,[data-theme="dark"] .filter-bar select{background:#1e2130;color:var(--text);border-color:var(--border2)}
[data-theme="dark"] .date-btn,[data-theme="dark"] .btn-outline,[data-theme="dark"] .ntype-btn{background:#1e2130;color:var(--text2);border-color:var(--border2)}
[data-theme="dark"] .date-btn.active{background:var(--accent);color:#fff}
[data-theme="dark"] .status-sel.bk-badge{color:var(--text)}
[data-theme="dark"] .drawer,[data-theme="dark"] .modal{background:#1a1d27}
[data-theme="dark"] .drawer-head{background:#141720}
[data-theme="dark"] .drawer-tabs{background:#141720}
[data-theme="dark"] .note-add{background:#141720}
[data-theme="dark"] .nt-body{background:#1e2130;border-color:var(--border)}
[data-theme="dark"] .user-tile{background:#141720;border-color:var(--border)}
[data-theme="dark"] .nav-item:hover{background:#1e2130}
[data-theme="dark"] .nav-item.active{background:#1e2130;color:var(--accent)}
[data-theme="dark"] .modal-overlay{background:rgba(0,0,0,.65)}
[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1)}

/* زر Dark Mode + Color Picker */
.theme-toggle{width:40px;height:40px;border:1px solid var(--border2);border-radius:9px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:.2s;flex-shrink:0}
.theme-toggle:hover{background:var(--accent-light);border-color:var(--accent)}

.color-picker-wrap{position:relative;flex-shrink:0}
.color-picker-popup{
  display:none;position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  padding:14px;box-shadow:var(--shadow-lg);z-index:500;min-width:200px;max-width:calc(100vw - 24px);
}
.color-picker-popup.show{display:block}
.cp-label{font-size:11px;font-weight:700;color:var(--muted);margin-bottom:10px;text-align:center;letter-spacing:.5px}
.cp-swatches{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.cp-swatch{
  width:32px;height:32px;border-radius:50%;cursor:pointer;border:3px solid transparent;
  transition:.15s;position:relative;
}
.cp-swatch:hover{transform:scale(1.15)}
.cp-swatch.active{border-color:var(--text2);box-shadow:0 0 0 2px var(--surface),0 0 0 4px currentColor}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.6}
a{text-decoration:none;color:inherit}

/* ── SPA progress bar ── */
.spa-bar{position:fixed;top:0;left:0;right:0;height:3px;background:var(--accent);width:0;opacity:0;z-index:9999;pointer-events:none;border-radius:0 2px 2px 0}

/* ── Content fade ── */
#spaContent{transition:opacity .15s ease}

/* ══════════════════════════════════════
   Notification Bell + Popup
══════════════════════════════════════ */
.notif-wrap{position:relative;flex-shrink:0}

.notif-btn{position:relative;width:40px;height:40px;border:1px solid var(--border);border-radius:9px;background:#fff;cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0}
.notif-btn:hover{background:var(--accent-light);border-color:var(--accent)}

.notif-count{
  position:absolute;top:-6px;left:-6px;
  min-width:18px;height:18px;padding:0 5px;
  background:var(--red);color:#fff;
  font-size:10px;font-weight:700;font-family:var(--mono);
  border-radius:20px;border:2px solid #fff;
  display:flex;align-items:center;justify-content:center;
  line-height:1;
}
@keyframes notifPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.notif-pulse .notif-count{animation:notifPulse .35s ease 4}

/* Popup */
.notif-popup{
  position:absolute;top:calc(100% + 10px);left:0;
  width:320px;max-width:calc(100vw - 24px);background:#fff;
  border:1px solid var(--border);border-radius:14px;
  box-shadow:0 16px 40px rgba(16,24,40,.14);
  z-index:500;overflow:hidden;
  opacity:0;transform:translateY(-8px) scale(.97);
  transition:opacity .22s ease, transform .22s ease;
}
.notif-popup.open{opacity:1;transform:translateY(0) scale(1)}

.np-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border)}
.np-title{font-size:14px;font-weight:700}
.np-clear{font-size:12px;color:var(--muted);background:none;border:none;cursor:pointer;font-family:var(--font)}
.np-clear:hover{color:var(--red)}

.np-list{max-height:280px;overflow-y:auto}
.np-item{display:flex;align-items:flex-start;gap:10px;padding:11px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:.15s}
.np-item:last-child{border-bottom:none}
.np-item:hover{background:var(--bg)}
.np-unread{background:var(--accent-light)}
.np-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.np-body{flex:1;min-width:0}
.np-body b{display:block;font-size:13px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-body span{font-size:12px;color:var(--muted)}
.np-time{font-size:11px;color:var(--muted2);white-space:nowrap;flex-shrink:0}
.np-empty{text-align:center;padding:28px 16px;color:var(--muted2);font-size:13px}

/* Footer الصوت */
.np-foot{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border);background:var(--bg);font-size:13px;font-weight:600}
.np-switch{position:relative;display:inline-block;width:40px;height:22px;cursor:pointer}
.np-switch::before{content:'';position:absolute;inset:-10px -4px} /* توسيع منطقة اللمس لـ42px دون تغيير الشكل */
.np-switch input{opacity:0;width:0;height:0}
.np-slider{position:absolute;inset:0;background:var(--border2);border-radius:22px;transition:.25s}
.np-slider:before{content:'';position:absolute;width:16px;height:16px;right:3px;top:3px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.np-switch input:checked + .np-slider{background:var(--accent)}
.np-switch input:checked + .np-slider:before{right:unset;left:3px}
.np-test-btn{width:36px;height:36px;border-radius:7px;border:1px solid var(--border2);background:var(--bg);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:.15s;flex-shrink:0}
.np-test-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}

/* ── بانر تفعيل صلاحية الإشعارات ── */
.notif-banner{
  display:flex;align-items:center;gap:14px;
  margin:14px 22px 0;padding:14px 18px;border-radius:14px;
  background:linear-gradient(135deg, #fff6e0 0%, #ffe9c4 100%);
  border:1px solid #f5c97a;color:#5a4112;
  box-shadow:0 4px 14px rgba(245,201,122,.22);
  position:relative;animation:nbFadeIn .4s ease;
}
.notif-banner .nb-ico{font-size:28px;line-height:1;flex-shrink:0}
.notif-banner .nb-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.notif-banner .nb-text b{font-size:14.5px;font-weight:800;color:#3d2c08}
.notif-banner .nb-text span{font-size:12.5px;color:#7a5a1b;line-height:1.4}
.notif-banner .nb-btn{
  background:#1e1e1e;color:#fff;border:0;border-radius:10px;
  padding:10px 18px;font-size:13px;font-weight:700;cursor:pointer;
  font-family:inherit;flex-shrink:0;transition:.2s;
}
.notif-banner .nb-btn:hover{background:#000;transform:translateY(-1px)}
.notif-banner .nb-close{
  background:transparent;border:0;cursor:pointer;color:#8a6a23;
  font-size:18px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  line-height:1;border-radius:6px;flex-shrink:0;
}
.notif-banner .nb-close:hover{background:rgba(0,0,0,.06);color:#000}
.notif-banner.is-error{background:linear-gradient(135deg,#fde2e2,#fbcaca);border-color:#f08080;color:#7a1f1f}
.notif-banner.is-error .nb-text b{color:#5a1010}
.notif-banner.is-error .nb-text span{color:#8a3030}
.notif-banner.is-error .nb-close{color:#a23030}
.notif-banner.is-ok{background:linear-gradient(135deg,#e2f7e6,#caf2d3);border-color:#7fc88b;color:#1f5a2a}
.notif-banner.is-ok .nb-text b{color:#10401a}
.notif-banner.is-ok .nb-text span{color:#2f6a3a}
@keyframes nbFadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:700px){
  .notif-banner{flex-wrap:wrap;margin:12px 12px 0;padding:12px 14px}
  .notif-banner .nb-text{order:1;width:100%}
  .notif-banner .nb-ico{order:0}
  .notif-banner .nb-btn{order:2;width:100%}
  .notif-banner .nb-close{position:absolute;top:8px;left:8px}
}

/* ── Toast notifications ── */
.toast-area{position:fixed;bottom:24px;left:24px;z-index:2000;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:320px}
.toast{
  background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:14px 16px 14px 14px;box-shadow:var(--shadow-lg);font-size:13.5px;line-height:1.5;
  width:min(300px,calc(100vw - 48px));pointer-events:all;position:relative;
  opacity:0;transform:translateY(16px) scale(.97);transition:.35s cubic-bezier(.4,0,.2,1);
}
.toast.show{opacity:1;transform:translateY(0) scale(1)}
.toast-lead{border-right:4px solid var(--accent)}
.toast-booking{border-right:4px solid var(--green)}
.toast b{display:block;margin-bottom:3px;font-size:14px}
.toast-close{position:absolute;top:2px;left:2px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--muted2);font-size:14px;line-height:1}
.toast-close:hover{color:var(--text)}


/* ══════════════════════════════════════
   Lead Table — Redesigned
══════════════════════════════════════ */
.leads-table tbody tr{cursor:pointer;transition:background .12s}
.leads-table tbody tr:hover td{background:color-mix(in srgb,var(--accent) 4%,var(--surface))}
.lead-cell{display:flex;align-items:center;gap:10px}
.lead-av{width:36px;height:36px;border-radius:10px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;letter-spacing:.5px}
.text-muted{color:var(--muted);font-size:13px}
.text-mono{font-family:var(--mono);font-size:12px}

/* Status badges — جديدة */
.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:11.5px;font-weight:700;white-space:nowrap}
.s-new      {background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe} /* أزرق */
.s-contact  {background:#fffaeb;color:#92400e;border:1px solid #fde68a} /* أصفر */
.s-interest {background:#f5f3ff;color:#5b21b6;border:1px solid #ddd6fe} /* بنفسجي */
.s-closed   {background:#ecfdf3;color:#065f46;border:1px solid #a7f3d0} /* أخضر */
.s-lost     {background:#fef2f2;color:#991b1b;border:1px solid #fecaca} /* أحمر */

/* ══════════════════════════════════════
   Drawer — Lead Detail Panel
══════════════════════════════════════ */
.drawer-overlay{display:none;position:fixed;inset:0;background:rgba(16,24,40,.35);backdrop-filter:blur(2px);z-index:200}
.drawer-overlay.show{display:block}

.drawer{
  position:fixed;top:50%;left:50%;width:480px;max-width:calc(100vw - 32px);max-height:90vh;max-height:90dvh;
  background:#fff;border-radius:16px;box-shadow:0 24px 64px rgba(16,24,40,.28);
  z-index:210;display:flex;flex-direction:column;
  transform:translate(-50%,-50%) scale(.96);opacity:0;visibility:hidden;
  transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .2s ease,visibility .25s;
  overflow:hidden;
}
.drawer.open{transform:translate(-50%,-50%) scale(1);opacity:1;visibility:visible}

.drawer-head{
  display:flex;align-items:center;gap:12px;
  padding:18px 20px;border-bottom:1px solid var(--border);
  background:linear-gradient(135deg,#fafafa,#fff);
  flex-shrink:0;
}
.drawer-av{width:46px;height:46px;border-radius:12px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0;background:var(--accent)}
#drawerAvWrap{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.drawer-name{font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.drawer-phone{font-size:13px;color:var(--muted);font-family:var(--mono)}
.drawer-close{width:40px;height:40px;border:1px solid var(--border);border-radius:9px;background:#fff;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.15s}
.drawer-close:hover{background:var(--red-light);color:var(--red);border-color:#fecaca}

.drawer-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;background:#fafafa}
.dtab{flex:1;height:44px;border:none;background:none;font-family:var(--font);font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:.15s;display:flex;align-items:center;justify-content:center;gap:6px}
.dtab:hover{color:var(--text2);background:#f0f0f0}
.dtab.active{color:var(--accent-hover);border-bottom-color:var(--accent)}
.dtab-count{background:var(--accent-light);color:var(--accent-hover);font-size:11px;font-weight:700;padding:1px 7px;border-radius:20px;min-width:20px;text-align:center}

.drawer-body{flex:1;overflow-y:auto;padding:20px}

.dform-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.drawer-actions{display:flex;align-items:center;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border);flex-wrap:wrap}
.drawer-actions .btn{flex:1;min-width:80px}

/* ── Activity Log ── */
.note-add{background:var(--bg);border-radius:12px;padding:14px;margin-bottom:20px;border:1px solid var(--border)}
.note-types{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.ntype-btn{height:30px;padding:0 12px;border:1px solid var(--border2);border-radius:8px;background:#fff;font-family:var(--font);font-size:12.5px;cursor:pointer;color:var(--text2);transition:.15s}
.ntype-btn:hover{border-color:var(--accent);color:var(--accent-hover)}
.ntype-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}

.note-timeline{display:flex;flex-direction:column;gap:12px}
.nt-item{display:flex;gap:12px;align-items:flex-start}
.nt-ico{width:32px;height:32px;border-radius:9px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;margin-top:2px}
.nt-body{flex:1;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 14px}
.nt-content{font-size:13.5px;line-height:1.6;margin-bottom:6px;overflow-wrap:anywhere}
.nt-meta{font-size:11px;color:var(--muted2)}

/* ══════════════════════════════════════
   Highlight row
══════════════════════════════════════ */
@keyframes hlPulse{
  0%,100%{background:color-mix(in srgb,var(--accent) 8%,var(--surface))}
  50%{background:color-mix(in srgb,var(--accent) 22%,var(--surface))}
}
.hl-row td{animation:hlPulse 1.4s ease 3}

/* ══════════════════════════════════════
   Toast & Notif link
══════════════════════════════════════ */
.toast-link{display:inline-block;margin-right:8px;color:var(--accent);font-weight:700;font-size:12px;cursor:pointer;text-decoration:underline}
.np-link{cursor:pointer}
.np-link:hover{background:var(--accent-light)!important}
.np-arrow{color:var(--accent);font-size:12px;font-weight:700;flex-shrink:0;margin-right:4px}

/* ══════════════════════════════════════
   Responsive Drawer
══════════════════════════════════════ */
@media(max-width:600px){
  .drawer{width:calc(100vw - 24px);max-height:92vh;max-height:92dvh}
  .dform-row{grid-template-columns:1fr}
}

/* login */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden;background:radial-gradient(1200px 600px at 50% -10%,color-mix(in srgb,var(--accent) 10%,transparent),transparent 60%),var(--bg)}
.login-screen::before,.login-screen::after{content:"";position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;pointer-events:none;z-index:0}
.login-screen::before{width:340px;height:340px;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 35%,transparent),transparent 70%);top:-120px;right:-80px}
.login-screen::after{width:300px;height:300px;background:radial-gradient(circle,rgba(124,58,237,.18),transparent 70%);bottom:-110px;left:-70px}
.login-wrap{width:100%;max-width:404px;position:relative;z-index:1;animation:loginIn .5s cubic-bezier(.16,1,.3,1) both}
@keyframes loginIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.login-brand{text-align:center;margin-bottom:26px}
.login-logo{width:58px;height:58px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:19px;font-weight:900;color:#fff;margin-bottom:14px;box-shadow:0 8px 22px color-mix(in srgb,var(--accent) 40%,transparent),inset 0 1px 0 rgba(255,255,255,.25)}
.login-brand h1{font-size:24px;font-weight:800;letter-spacing:-.3px}
.login-brand p{font-size:13px;color:var(--muted);margin-top:5px}
.login-card{background:rgba(255,255,255,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:18px;padding:32px;box-shadow:0 20px 50px -16px rgba(16,24,40,.22),0 4px 12px -4px rgba(16,24,40,.08)}
.login-card h2{font-size:19px;font-weight:800;margin-bottom:6px}
.login-card>p{color:var(--muted);font-size:13px;margin-bottom:22px}
/* input with leading icon */
.field-ico{position:relative}
.field-ico>svg{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--muted2);pointer-events:none;transition:.15s}
.field .field-ico input{padding-right:42px}
.field-ico:focus-within>svg{color:var(--accent)}
/* password reveal button */
.pwd-toggle{position:absolute;left:6px;top:50%;transform:translateY(-50%);width:40px;height:40px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted2);border-radius:8px;transition:.15s;padding:0}
.pwd-toggle:hover{background:var(--bg);color:var(--text2)}
[data-theme="dark"] .login-card{background:rgba(26,29,39,.92)}
[data-theme="dark"] .login-screen{background:radial-gradient(1200px 600px at 50% -10%,rgba(212,168,85,.10),transparent 60%),var(--bg)}

/* fields */
.field{margin-bottom:15px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;min-height:42px;padding:9px 14px;border:1px solid var(--border2);border-radius:var(--radius);font-family:var(--font);font-size:14px;color:var(--text);background:#fff;outline:none;transition:.15s}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 14%,transparent)}
.hint{font-size:11px;color:var(--muted2);margin-top:5px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:40px;padding:0 18px;border-radius:var(--radius);font-family:var(--font);font-size:13.5px;font-weight:600;cursor:pointer;border:none;transition:.15s;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover)}
.btn-outline{background:#fff;color:var(--text2);border:1px solid var(--border2)}
.btn-outline:hover{background:var(--bg)}
.btn-ghost{background:none;color:var(--muted);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--bg);color:var(--text2)}
.btn-danger{background:var(--red-light);color:var(--red);border:1px solid #fecdca}
.btn-danger:hover{background:#fee4e2}
.btn-sm{height:32px;padding:0 12px;font-size:12.5px}
.btn-wa{background:#25d366;color:#fff;border:none}
.btn-wa:hover{background:#1da851}

/* ══ Dashboard Grids ══ */
.dash-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.dash-row2{display:grid;grid-template-columns:1fr 240px 220px;gap:16px;margin-bottom:20px}
.dash-row3{display:grid;grid-template-columns:1fr 1fr 280px;gap:16px}

/* ══ KPI Cards ══ */
.kpi-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);transition:.2s;overflow:hidden}
.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.kpi-ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.kpi-val{font-size:30px;font-weight:800;letter-spacing:-.8px;line-height:1.1;color:var(--text)}
.kpi-lbl{font-size:12px;color:var(--muted);margin-bottom:4px;font-weight:500}
.kpi-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.kpi-trend{font-size:11px;font-weight:700;padding:2px 7px;border-radius:20px;font-family:var(--mono)}
.kpi-trend.up{background:#ecfdf3;color:#065f46}
.kpi-trend.down{background:#fef2f2;color:#991b1b}
.kpi-trend.flat{background:var(--bg);color:var(--muted);border:1px solid var(--border)}
.kpi-period{font-size:11px;color:var(--muted2)}
.kpi-spark{margin-top:4px;opacity:.85}

/* Responsive Dashboard */
@media(max-width:1200px){
  .dash-kpi-grid{grid-template-columns:repeat(2,1fr)}
  .dash-row2{grid-template-columns:1fr 1fr}
  .dash-row2 > .card:last-child{grid-column:1/-1}
  .dash-row3{grid-template-columns:1fr 1fr}
  .dash-row3 > .card:last-child{grid-column:1/-1}
}
@media(max-width:700px){
  .dash-kpi-grid{grid-template-columns:1fr 1fr}
  .dash-row2,.dash-row3{grid-template-columns:1fr}
  .dash-row2 > .card:last-child,.dash-row3 > .card:last-child{grid-column:auto}
}

/* ── Trash empty state ── */
.trash-empty{text-align:center;padding:80px 20px;color:var(--muted)}
.trash-empty-ico{font-size:64px;margin-bottom:16px}
.trash-empty h3{font-size:20px;font-weight:700;margin-bottom:8px;color:var(--text2)}
.trash-empty p{font-size:14px}
.btn-block{width:100%}

/* ══════════════════════════════════════
   Scrollbar
══════════════════════════════════════ */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--muted2)}

/* layout */
.app{display:flex;min-height:100vh}
.sidebar{
  width:248px;
  background:linear-gradient(180deg,var(--surface) 0%,var(--surface) 100%);
  border-left:1px solid var(--border);
  display:flex;flex-direction:column;
  position:fixed;top:0;right:0;bottom:0;z-index:100;overflow-y:auto;
  transition:transform .3s cubic-bezier(.4,0,.2,1), width .3s cubic-bezier(.4,0,.2,1);
  box-shadow:-2px 0 12px rgba(16,24,40,.04);
}
/* حالة الإغلاق على الديسك توب */
.app.sidebar-collapsed .sidebar{transform:translateX(100%)}
.app.sidebar-collapsed .main{margin-right:0}

.sidebar-logo{
  padding:16px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 6%,var(--surface)),var(--surface));
}
.logo-icon{
  width:36px;height:36px;
  background:linear-gradient(135deg,var(--accent),var(--accent-hover));
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:900;color:#fff;flex-shrink:0;
  box-shadow:0 3px 8px color-mix(in srgb,var(--accent) 35%,transparent);
}
.logo-name{font-size:15px;font-weight:800;letter-spacing:-.2px}
.logo-sub{font-size:10px;color:var(--muted2);letter-spacing:.8px;text-transform:uppercase}
.side-sec{padding:12px 10px 0}
.side-label{font-size:10px;font-weight:700;color:var(--muted2);letter-spacing:1px;text-transform:uppercase;padding:0 8px;margin-bottom:6px}
/* nav-item مع مؤشر جانبي للعنصر النشط */
.nav-item{
  display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;
  font-size:13.5px;font-weight:500;color:var(--muted);
  transition:background .15s,color .15s;margin-bottom:2px;
  position:relative;
}
.nav-item:hover{background:color-mix(in srgb,var(--accent) 6%,var(--bg));color:var(--text2)}
.nav-item.active{
  background:var(--accent-light);color:var(--accent-hover);font-weight:600;
}
.nav-item.active::after{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:60%;background:var(--accent);border-radius:2px;
  box-shadow:0 0 8px color-mix(in srgb,var(--accent) 50%,transparent);
}
.nav-item.active .nav-icon svg{stroke:var(--accent)}
.nav-icon{width:20px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.nav-badge{margin-right:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:20px;font-family:var(--mono);line-height:18px}
.sidebar-footer{padding:12px 10px;border-top:1px solid var(--border);margin-top:auto}
.user-tile{
  display:flex;align-items:center;gap:10px;padding:10px;
  border-radius:var(--radius);
  background:color-mix(in srgb,var(--accent) 5%,var(--bg));
  border:1px solid color-mix(in srgb,var(--accent) 20%,var(--border));
  transition:.15s;
}
.user-tile:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}
.user-avatar{
  width:34px;height:34px;border-radius:8px;
  background:linear-gradient(135deg,var(--accent),var(--accent-hover));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;
  box-shadow:0 2px 6px color-mix(in srgb,var(--accent) 35%,transparent);
}
.user-name{font-size:13px;font-weight:600}
.user-role{font-size:11px;color:var(--muted)}

.main{flex:1;min-width:0;margin-right:248px;display:flex;flex-direction:column;min-height:100vh;transition:margin-right .3s cubic-bezier(.4,0,.2,1)}
.topbar{
  height:64px;background:var(--surface);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 8px rgba(16,24,40,.05);
  display:flex;align-items:center;padding:0 28px;gap:14px;
  position:sticky;top:0;z-index:50;
}
.page-title{font-size:17px;font-weight:700;letter-spacing:-.2px}
.page-subtitle{font-size:12px;color:var(--muted)}
.topbar-actions{margin-right:auto;display:flex;align-items:center;gap:10px}
.content{padding:28px;flex:1;min-width:0;max-width:100%;background:var(--bg);overflow-x:hidden}

/* cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow .2s}
.card:hover{box-shadow:var(--shadow)}
.card-head{
  display:flex;align-items:center;gap:10px;padding:16px 20px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(to bottom,var(--bg),var(--surface));
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
}
.card-title{font-size:14px;font-weight:700;flex:1}
.card-count{font-size:12px;color:var(--muted);background:var(--bg);border:1px solid var(--border);padding:2px 8px;border-radius:20px;font-family:var(--mono)}
.card-pad{padding:24px}

/* kpi */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);transition:.2s}
.kpi:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.kpi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.kpi-icon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center}
.kpi-icon.blue{background:var(--accent-light)}.kpi-icon.green{background:var(--green-light)}
.kpi-icon.amber{background:var(--amber-light)}.kpi-icon.purple{background:var(--purple-light)}
.kpi-val{font-size:28px;font-weight:800;letter-spacing:-.6px}
.kpi-label{font-size:12px;color:var(--muted);font-weight:500}

/* table */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;min-width:0}
table{width:100%;border-collapse:collapse}
th{text-align:right;padding:10px 16px;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);background:linear-gradient(to bottom,var(--bg),color-mix(in srgb,var(--bg) 80%,var(--surface)));white-space:nowrap}
td{text-align:right;padding:12px 16px;font-size:13.5px;border-bottom:1px solid var(--border);vertical-align:middle;transition:background .1s}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:color-mix(in srgb,var(--accent) 4%,var(--surface))}
.lead-name{font-weight:600;font-size:14px}
.lead-phone{font-family:var(--mono);font-size:12px;color:var(--muted)}
.av{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}

/* badges */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}
.badge-new{background:var(--accent-light);color:var(--accent-hover);border:1px solid color-mix(in srgb,var(--accent) 38%,var(--white))}
.badge-contacted{background:var(--amber-light);color:#92400e;border:1px solid #fde68a}
.badge-interested{background:var(--purple-light);color:var(--purple);border:1px solid #ddd6fe}
.badge-closed{background:var(--green-light);color:#065f46;border:1px solid #a7f3d0}
.badge-lost{background:var(--red-light);color:var(--red);border:1px solid #fecdca}
.src-pill{display:inline-flex;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:600;border:1px solid var(--border);background:var(--bg);color:var(--text2)}

.actions{display:flex;gap:5px}
.icon-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:7px;border:1px solid var(--border);background:none;cursor:pointer;font-size:13px;color:var(--muted);transition:.15s}
.icon-btn:hover{background:var(--bg);border-color:var(--border2);color:var(--text)}
.icon-btn.green{color:#16a34a}
.icon-btn.green:hover{background:var(--green-light);border-color:#a7f3d0;color:var(--green)}
.icon-btn.red:hover{background:var(--red-light);border-color:#fecdca;color:var(--red)}
.status-sel{border:1px solid var(--border);border-radius:7px;padding:4px 8px;font-family:var(--font);font-size:12px;color:var(--text2);background:#fff;cursor:pointer;outline:none}

/* status badge-style select (bookings) */
.status-sel.bk-badge{appearance:none;-webkit-appearance:none;border-radius:20px;font-size:11.5px;font-weight:700;padding:5px 12px;cursor:pointer;transition:.15s}
.status-sel.bk-badge:disabled{opacity:.6;cursor:wait}
.status-sel.bk-badge.badge-new{background:var(--accent-light);color:var(--accent-hover);border-color:color-mix(in srgb,var(--accent) 38%,var(--white))}
.status-sel.bk-badge.badge-interested{background:var(--purple-light);color:var(--purple);border-color:#ddd6fe}
.status-sel.bk-badge.badge-closed{background:var(--green-light);color:#065f46;border-color:#a7f3d0}
.status-sel.bk-badge.badge-lost{background:var(--red-light);color:var(--red);border-color:#fecdca}

.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.filter-bar input,.filter-bar select{
  height:38px;border:1px solid var(--border2);border-radius:var(--radius);
  padding:0 12px;font-family:var(--font);font-size:13px;
  background:var(--surface);outline:none;transition:.15s;color:var(--text);
}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 12%,transparent)}
.filter-bar input{flex:1;min-width:160px}

/* ── فلاتر التاريخ السريعة ── */
.date-btns{display:flex;gap:4px;flex-wrap:wrap}
.date-btn{height:36px;padding:0 14px;border:1px solid var(--border2);border-radius:8px;background:#fff;font-family:var(--font);font-size:13px;cursor:pointer;color:var(--text2);transition:.15s;white-space:nowrap}
.date-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent-hover)}
.date-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
.date-custom{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.date-custom input[type=date]{height:36px;border:1px solid var(--border2);border-radius:8px;padding:0 10px;font-family:var(--font);font-size:13px;background:#fff;outline:none;color:var(--text)}

.grid-2{display:grid;grid-template-columns:1fr 360px;gap:20px}
.alert{padding:11px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;margin-bottom:16px}
.alert-ok{background:var(--green-light);border:1px solid #a7f3d0;color:#065f46}
.alert-err{background:var(--red-light);border:1px solid #fecdca;color:var(--red)}
.empty{text-align:center;padding:40px 20px;color:var(--muted)}

/* funnel */
.funnel-item{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.funnel-label{width:90px;font-size:12px;color:var(--muted);text-align:left;flex-shrink:0}
.funnel-bar-wrap{flex:1;background:var(--bg);border-radius:4px;height:26px;overflow:hidden}
.funnel-bar{height:100%;border-radius:4px;display:flex;align-items:center;padding:0 10px;font-size:12px;font-weight:600;color:#fff}
.funnel-count{width:36px;font-size:12px;font-weight:700;font-family:var(--mono);text-align:left}
.src-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.src-row .nm{width:110px;font-size:13px;flex-shrink:0}
.src-bar-wrap{flex:1;background:var(--bg);border-radius:4px;height:24px;overflow:hidden}
.src-bar{height:100%;border-radius:4px;display:flex;align-items:center;padding:0 8px;font-size:11px;font-weight:700;color:#fff}

/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(16,24,40,.45);backdrop-filter:blur(3px);z-index:300;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:16px;width:100%;max-width:480px;padding:26px;box-shadow:var(--shadow-lg);max-height:90vh;max-height:90dvh;overflow-y:auto}
.modal-title{font-size:17px;font-weight:700;margin-bottom:4px}
.modal-sub{font-size:13px;color:var(--muted);margin-bottom:20px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal-actions{display:flex;gap:10px;margin-top:22px;justify-content:flex-end}

.cms-list{display:flex;flex-direction:column;gap:10px}
.cms-row{display:flex;align-items:center;gap:14px;padding:14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}
.cms-row .body{flex:1}
.cms-row .body b{font-size:14px}
.cms-row .body p{font-size:12.5px;color:var(--muted);margin-top:2px}

/* ===== زر القائمة (ظاهر دائماً على كل الشاشات) ===== */
.menu-toggle{
  display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;border:1px solid var(--border);border-radius:9px;
  background:#fff;cursor:pointer;flex-shrink:0;
  transition:.2s;color:var(--text2);
}
.menu-toggle:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent-hover)}

.sidebar-close{display:none;margin-right:auto;width:40px;height:40px;border:none;background:var(--bg);border-radius:8px;font-size:15px;color:var(--muted);cursor:pointer;line-height:1}
.sidebar-close:hover{background:var(--red-light);color:var(--red)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(16,24,40,.5);backdrop-filter:blur(2px);z-index:90}
.sidebar-overlay.show{display:block}

/* ============================================================
   RESPONSIVE — Tablet & Mobile
============================================================ */
@media(max-width:1100px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
}
@media(max-width:900px){
  /* على الموبايل: السايدبار منزلق + overlay */
  .sidebar{
    transform:translateX(100%);
    box-shadow:-8px 0 30px rgba(0,0,0,.15);
    width:280px;
  }
  /* إعادة ضبط collapsed على الموبايل لأن السلوك مختلف */
  .app.sidebar-collapsed .sidebar{transform:translateX(100%)}
  .app.sidebar-collapsed .main{margin-right:0}

  /* فتح السايدبار — !important يضمن الأولوية فوق أي حالة collapsed */
  .sidebar.open,
  .app.sidebar-collapsed .sidebar.open{transform:translateX(0) !important}
  .main{margin-right:0 !important}
  .sidebar-close{display:flex;align-items:center;justify-content:center}
  .nav-item{padding:12px 12px;font-size:14.5px}
  .field-row{grid-template-columns:1fr}
  .topbar{padding:0 16px}
  .content{padding:18px 16px}
}
@media(max-width:700px){
  /* تمرير أفقي للجداول بدل ضغط الأعمدة — على الموبايل فقط */
  .tbl-wrap table{min-width:600px}
}
@media(max-width:600px){
  .kpi-grid{grid-template-columns:1fr}
  .page-title{font-size:15px}
  .page-subtitle{display:none}
  .sidebar{width:86%;max-width:300px}
  .filter-bar{flex-direction:column;align-items:stretch}
  .filter-bar input,.filter-bar select{width:100%}
  .modal{padding:20px}
  .modal-actions{flex-direction:column-reverse}
  .modal-actions .btn{width:100%}
}
/* منع تكبير iOS التلقائي عند التركيز على الحقول (يتطلّب ≥16px) — يشمل كل الحقول النصية */
@media(max-width:820px){
  .field input,.field select,.field textarea,
  .filter-bar input,.filter-bar select,
  input[type=text],input[type=email],input[type=password],
  input[type=tel],input[type=number],input[type=search],input[type=url],
  select,textarea{font-size:16px}
}

/* أهداف لمس ≥40px على الموبايل (أزرار الجداول والفلاتر والشيبس) */
@media(max-width:700px){
  .icon-btn{width:40px;height:40px}
  .actions{gap:8px}
  .date-btn{height:40px}
  .ntype-btn{height:38px}
  .btn-sm{height:38px}
}
@media(max-width:600px){
  .hide-mobile{display:none}
}
/* popup الإشعارات على الموبايل: لوحة بعرض الشاشة بدل المثبتة على الجرس */
@media(max-width:600px){
  .notif-popup{position:fixed;top:72px;left:12px;right:12px;width:auto;max-width:none}
}

/* ============================================================
   حالة إذن الإشعار (pill صغير في popup الإشعارات)
============================================================ */
.np-perm-pill{
  font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;
  border:1px solid var(--border);background:var(--bg);color:var(--muted);
  display:inline-block;line-height:1.2;
}
.np-perm-pill.perm-granted{background:#ecfdf3;color:#065f46;border-color:#a7f3d0}
.np-perm-pill.perm-denied{background:#fef2f2;color:#b91c1c;border-color:#fecaca}
.np-perm-pill.perm-default{background:#fffaeb;color:#92400e;border-color:#fcd34d}

/* ============================================================
   فوتر الأدمن (mindpro)
============================================================ */
.admin-footer{
  margin-top:28px;padding:18px 16px 8px;
  border-top:1px solid var(--border);
  display:flex;flex-direction:column;align-items:center;gap:3px;
  text-align:center;font-size:12px;color:var(--muted2);line-height:1.7;
}
.admin-footer .admin-footer-by{font-size:11.5px}
.admin-footer a{color:var(--accent-hover);text-decoration:none;font-weight:600}
.admin-footer a:hover{text-decoration:underline}
