/* ============================================================
   NOUR DEVELOPMENTS — DASHBOARD CSS  v2.1
   Bugs fixed vs v2.0:
   1. main-content margin NOT removed on mobile  →  fixed
   2. view height collapses (charts render at 0px) → fixed
   3. chart-wrap had no min-height → fixed
   4. table overflows/crushes on mobile → fixed (min-width + scroll)
   5. modal too tall / off-screen on mobile → fixed (bottom sheet)
   6. sidebar z-index lower than overlay → fixed
   7. .dash-input always had 38px left-pad even without icon → fixed
   8. settings grid didn't collapse on tablet → fixed
   NEW: .modal-design-image and .modal-design-pdf styles added
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,300;12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=JetBrains+Mono:wght@400;500;600&family=Cairo:wght@300;400;600;700;800&display=swap');

/* ─────────────────────────────────────────────────────────────
   DESIGN TOKENS
───────────────────────────────────────────────────────────── */
:root {
  --bg-base:       #080D17;
  --bg-surface:    #0E1624;
  --bg-card:       #111E30;
  --bg-card-hover: #162438;
  --bg-input:      #0A1220;
  --bg-sidebar:    #090E1A;

  --text-primary:   #E8F0FF;
  --text-secondary: #8B9EC4;
  --text-muted:     #4A5A7A;

  --accent:        #3B82F6;
  --accent-glow:   rgba(59,130,246,0.15);
  --accent-bright: #60A5FA;
  --accent-2:      #8B5CF6;
  --success:       #10B981;
  --warning:       #F59E0B;
  --danger:        #EF4444;
  --info:          #06B6D4;

  --border:        rgba(255,255,255,0.06);
  --border-accent: rgba(59,130,246,0.3);

  --sidebar-w:     240px;
  --topbar-h:      64px;

  --radius-sm:     8px;
  --radius-md:     14px;
  --radius-lg:     20px;
  --radius-full:   9999px;

  --shadow-card:   0 4px 24px rgba(0,0,0,0.4);
  --shadow-glow:   0 0 32px rgba(59,130,246,0.2);

  --font:          'Bricolage Grotesque', sans-serif;
  --font-mono:     'JetBrains Mono', monospace;
  --font-arabic:   'Cairo', sans-serif;

  --transition:    all 0.2s cubic-bezier(0.4,0,0.2,1);
  --transition-md: all 0.35s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="light"] {
  --bg-base:       #F0F4FF;
  --bg-surface:    #E8EEFF;
  --bg-card:       #FFFFFF;
  --bg-card-hover: #F5F8FF;
  --bg-input:      #F8FAFF;
  --bg-sidebar:    #1A2540;

  --text-primary:  #0F172A;
  --text-secondary:#475569;
  --text-muted:    #94A3B8;

  --accent:        #2563EB;
  --accent-glow:   rgba(37,99,235,0.1);
  --accent-bright: #3B82F6;

  --border:        rgba(0,0,0,0.08);
  --border-accent: rgba(37,99,235,0.3);

  --shadow-card:   0 2px 16px rgba(0,0,0,0.08);
  --shadow-glow:   0 0 24px rgba(37,99,235,0.12);
}

/* ─────────────────────────────────────────────────────────────
   RESET
───────────────────────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 16px; scroll-behavior: smooth; }
body {
  font-family: var(--font);
  background: var(--bg-base);
  color: var(--text-primary);
  line-height: 1.6;
  overflow-x: hidden;
  transition: background 0.3s ease, color 0.3s ease;
}
[dir="rtl"] body    { font-family: var(--font-arabic); }
a                   { text-decoration: none; color: inherit; }
button              { cursor: pointer; border: none; background: none; font-family: inherit; }
input,textarea,select { font-family: inherit; }
img                 { max-width: 100%; display: block; }
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg-surface); }
::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 3px; }
::selection { background: var(--accent); color: #fff; }

/* ─────────────────────────────────────────────────────────────
   UTILITY
───────────────────────────────────────────────────────────── */
.accent       { color: var(--accent); }
.accent-link  { color: var(--accent); transition: var(--transition); }
.accent-link:hover { color: var(--accent-bright); text-decoration: underline; }
.mono         { font-family: var(--font-mono); font-size: 0.85em; }

/* ─────────────────────────────────────────────────────────────
   LOGIN SCREEN
───────────────────────────────────────────────────────────── */
.login-screen {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 9999; background: var(--bg-base); padding: 16px;
  transition: opacity 0.35s ease, visibility 0.35s ease;
}
.login-screen.hidden { opacity: 0; pointer-events: none; visibility: hidden; }

.login-bg    { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.login-orb   { position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.12; animation: floatOrb 8s ease-in-out infinite; }
.login-orb-1 { width:500px; height:500px; background: radial-gradient(circle, var(--accent),transparent 70%); top:-100px; right:-100px; }
.login-orb-2 { width:400px; height:400px; background: radial-gradient(circle, var(--accent-2),transparent 70%); bottom:-100px; left:-100px; animation-delay:-4s; opacity:0.08; }
.login-grid  { position:absolute; inset:0; background-image: linear-gradient(rgba(59,130,246,0.04) 1px,transparent 1px), linear-gradient(90deg,rgba(59,130,246,0.04) 1px,transparent 1px); background-size:48px 48px; }

@keyframes floatOrb { 0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(20px,-20px) scale(1.05);} }

.login-card {
  position: relative; z-index: 1; width: 100%; max-width: 420px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 44px 40px;
  box-shadow: var(--shadow-card), 0 0 60px rgba(59,130,246,0.08);
  animation: slideUp 0.5s cubic-bezier(0.4,0,0.2,1) forwards;
}
@keyframes slideUp { from{opacity:0;transform:translateY(24px);} to{opacity:1;transform:translateY(0);} }

.login-logo       { display:flex; align-items:center; gap:10px; margin-bottom:28px; }
.login-logo-text  { font-size:1.6rem; font-weight:800; color:var(--text-primary); letter-spacing:-0.03em; }
.login-logo-badge { background:var(--accent-glow); border:1px solid var(--border-accent); color:var(--accent); font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:3px 10px; border-radius:var(--radius-full); }
.login-title      { font-size:1.5rem; font-weight:700; margin-bottom:6px; }
.login-sub        { font-size:0.9rem; color:var(--text-secondary); margin-bottom:28px; }
.login-hint       { text-align:center; font-size:0.75rem; color:var(--text-muted); margin-top:16px; font-family:var(--font-mono); }

/* ─────────────────────────────────────────────────────────────
   FORM ELEMENTS
───────────────────────────────────────────────────────────── */
.form-group  { margin-bottom: 18px; }
.form-label  { display:block; font-size:0.8rem; font-weight:600; color:var(--text-secondary); margin-bottom:7px; letter-spacing:0.03em; }
.input-wrap  { position:relative; }
.input-prefix-icon { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--text-muted); font-size:0.85rem; pointer-events:none; z-index:1; }
[dir="rtl"] .input-prefix-icon { left:auto; right:13px; }

/* FIX: base input has no left padding — icon wrap adds it */
.dash-input {
  width: 100%; padding: 11px 14px;
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-primary);
  font-size: 0.92rem; transition: var(--transition); outline: none;
}
/* Only apply left padding when there is a prefix icon */
.input-wrap .dash-input { padding-left: 38px; }
[dir="rtl"] .input-wrap .dash-input { padding-left: 14px; padding-right: 38px; }

.dash-input:focus    { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.dash-input::placeholder { color: var(--text-muted); }
.dash-textarea       { resize:vertical; min-height:100px; }

.input-eye { position:absolute; right:12px; top:50%; transform:translateY(-50%); color:var(--text-muted); font-size:0.85rem; padding:4px; transition:var(--transition); }
[dir="rtl"] .input-eye { right:auto; left:12px; }
.input-eye:hover { color:var(--accent); }

.login-feedback { display:none; padding:10px 14px; border-radius:var(--radius-sm); font-size:0.85rem; font-weight:500; margin-bottom:16px; background:rgba(239,68,68,0.1); border:1px solid rgba(239,68,68,0.3); color:var(--danger); }
.login-feedback.show { display:block; }

/* ─────────────────────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────────────────────── */
.btn-login  { width:100%; padding:13px; margin-top:8px; background:var(--accent); color:#fff; font-family:var(--font); font-weight:700; font-size:0.95rem; border-radius:var(--radius-full); display:flex; align-items:center; justify-content:center; gap:8px; transition:var(--transition); }
.btn-login:hover { background:var(--accent-bright); transform:translateY(-1px); box-shadow:var(--shadow-glow); }

.btn-accent { display:inline-flex; align-items:center; gap:7px; padding:9px 18px; background:var(--accent); color:#fff; font-family:var(--font); font-weight:600; font-size:0.875rem; border-radius:var(--radius-sm); transition:var(--transition); white-space:nowrap; }
.btn-accent:hover { background:var(--accent-bright); transform:translateY(-1px); }

.btn-sm     { padding:7px 14px; font-size:0.82rem; font-weight:600; border:1px solid var(--border-accent); color:var(--accent); border-radius:var(--radius-sm); transition:var(--transition); white-space:nowrap; }
.btn-sm:hover { background:var(--accent-glow); }

.btn-text   { font-size:0.85rem; color:var(--accent); font-weight:600; transition:var(--transition); white-space:nowrap; }
.btn-text:hover { color:var(--accent-bright); }

/* ─────────────────────────────────────────────────────────────
   DASHBOARD SHELL
───────────────────────────────────────────────────────────── */
.dashboard {
  display: flex; min-height: 100vh;
  opacity: 0; pointer-events: none; visibility: hidden;
  transition: opacity 0.35s ease, visibility 0.35s ease;
}
.dashboard.active { opacity:1; pointer-events:all; visibility:visible; }

/* ── Sidebar ── */
.sidebar {
  width: var(--sidebar-w); flex-shrink: 0;
  background: var(--bg-sidebar); border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  position: fixed; top:0; left:0; bottom:0;
  z-index: 300;                   /* FIX was 200 */
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  will-change: transform;
}
[dir="rtl"] .sidebar { left:auto; right:0; border-right:none; border-left:1px solid var(--border); }

.sidebar-header    { display:flex; align-items:center; justify-content:space-between; padding:20px 20px 16px; border-bottom:1px solid var(--border); flex-shrink:0; }
.sidebar-logo      { font-size:1.3rem; font-weight:800; color:var(--text-primary); letter-spacing:-0.03em; }
.sidebar-close     { display:none; width:30px; height:30px; align-items:center; justify-content:center; color:var(--text-muted); font-size:1.05rem; border-radius:6px; border:1px solid var(--border); transition:var(--transition); }
.sidebar-close:hover { color:var(--text-primary); border-color:var(--border-accent); }

.sidebar-nav       { flex:1; padding:16px 12px; display:flex; flex-direction:column; gap:4px; overflow-y:auto; }
.nav-item          { display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:var(--radius-sm); color:var(--text-secondary); font-size:0.9rem; font-weight:500; transition:var(--transition); border:1px solid transparent; }
.nav-item:hover    { background:rgba(255,255,255,0.04); color:var(--text-primary); }
.nav-item.active   { background:var(--accent-glow); color:var(--accent); border-color:var(--border-accent); }
.nav-icon          { width:20px; text-align:center; font-size:0.9rem; flex-shrink:0; }
.nav-badge         { margin-left:auto; background:var(--accent); color:#fff; font-size:0.68rem; font-weight:700; padding:2px 7px; border-radius:var(--radius-full); display:none; }
[dir="rtl"] .nav-badge { margin-left:0; margin-right:auto; }
.nav-badge.show    { display:inline-block; }

.sidebar-footer    { padding:14px 16px; border-top:1px solid var(--border); display:flex; align-items:center; gap:10px; flex-shrink:0; }
.sidebar-avatar    { width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,var(--accent),var(--accent-2)); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:0.875rem; color:#fff; flex-shrink:0; }
.sidebar-user-info { flex:1; min-width:0; }
.sidebar-user-name { font-size:0.85rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sidebar-user-role { font-size:0.72rem; color:var(--text-muted); }
.btn-logout        { color:var(--text-muted); font-size:0.95rem; padding:6px; border-radius:var(--radius-sm); transition:var(--transition); flex-shrink:0; }
.btn-logout:hover  { color:var(--danger); }

.sidebar-overlay   { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.65); z-index:299; backdrop-filter:blur(3px); }
.sidebar-overlay.show { display:block; }

/* ── Main content ── */
.main-content {
  flex: 1;
  margin-left: var(--sidebar-w);   /* desktop: push right of sidebar */
  display: flex; flex-direction: column;
  min-height: 100vh; min-width: 0; /* FIX: prevents child overflow */
}
[dir="rtl"] .main-content { margin-left:0; margin-right:var(--sidebar-w); }

/* ── Topbar ── */
.topbar {
  height: var(--topbar-h); position:sticky; top:0; z-index:100;
  background: var(--bg-surface); border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding: 0 24px; gap:12px; backdrop-filter:blur(12px); flex-shrink:0;
}
.topbar-left       { display:flex; align-items:center; gap:12px; min-width:0; }
.hamburger-dash    { display:none; width:36px; height:36px; align-items:center; justify-content:center; color:var(--text-secondary); font-size:1.05rem; border-radius:var(--radius-sm); border:1px solid var(--border); transition:var(--transition); flex-shrink:0; }
.hamburger-dash:hover { color:var(--accent); border-color:var(--border-accent); }
.page-title        { font-size:1.1rem; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.page-date         { font-size:0.75rem; color:var(--text-muted); white-space:nowrap; }

.topbar-right      { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.topbar-btn        { width:36px; height:36px; border-radius:var(--radius-sm); border:1px solid var(--border); background:var(--bg-card); color:var(--text-secondary); font-size:0.9rem; display:flex; align-items:center; justify-content:center; transition:var(--transition); position:relative; }
.topbar-btn:hover  { border-color:var(--border-accent); color:var(--accent); }
.lang-toggle       { font-size:0.7rem; font-weight:700; letter-spacing:0.05em; width:auto; padding:0 10px; }
.notif-dot         { position:absolute; top:5px; right:5px; width:7px; height:7px; border-radius:50%; background:var(--danger); display:none; }
.notif-dot.show    { display:block; }

/* ── Views ──
   FIX: never combine display:none with flex-direction in same rule.
   Set flex-direction only when active so browsers don't pre-calculate
   flex sizing on hidden elements (causes chart height = 0).
──────────────────────────────────────────────────────────── */
.view          { display: none; flex: 1; }
.view.active   { display: flex; flex-direction: column; gap: 24px; padding: 24px; min-height: 0; }

/* ─────────────────────────────────────────────────────────────
   STAT CARDS
───────────────────────────────────────────────────────────── */
.stats-grid    { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.stat-card     { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-md); padding:20px 18px; display:flex; align-items:center; gap:14px; transition:var(--transition-md); position:relative; overflow:hidden; }
.stat-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; border-radius:var(--radius-md) var(--radius-md) 0 0; }
.stat-card--total::before    { background:var(--accent); }
.stat-card--new::before      { background:var(--warning); }
.stat-card--progress::before { background:var(--info); }
.stat-card--done::before     { background:var(--success); }
.stat-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-card); border-color:var(--border-accent); }

.stat-card-icon  { width:44px; height:44px; border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.stat-card--total    .stat-card-icon { background:var(--accent-glow); color:var(--accent); }
.stat-card--new      .stat-card-icon { background:rgba(245,158,11,0.12); color:var(--warning); }
.stat-card--progress .stat-card-icon { background:rgba(6,182,212,0.12); color:var(--info); }
.stat-card--done     .stat-card-icon { background:rgba(16,185,129,0.12); color:var(--success); }
.stat-card-num   { font-size:1.9rem; font-weight:800; line-height:1; font-variant-numeric:tabular-nums; }
.stat-card-label { font-size:0.76rem; color:var(--text-muted); margin-top:3px; }

/* ─────────────────────────────────────────────────────────────
   CHARTS
   FIX: chart-wrap MUST have explicit min-height
   so Chart.js canvas gets a non-zero bounding box to render into
───────────────────────────────────────────────────────────── */
.charts-row      { display:grid; grid-template-columns:2fr 1fr; gap:16px; }
.charts-row--3   { grid-template-columns:repeat(3,1fr); }

.chart-card      { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-md); padding:20px; display:flex; flex-direction:column; }
.chart-card-header { margin-bottom:14px; flex-shrink:0; }
.chart-card-title  { font-size:0.82rem; font-weight:700; color:var(--text-secondary); text-transform:uppercase; letter-spacing:0.06em; }

.chart-wrap          { position:relative; flex:1; min-height:200px; } /* FIX */
.chart-wrap canvas   { width:100% !important; }
.chart-wrap--doughnut { display:flex; justify-content:center; align-items:center; min-height:200px; }

.chart-legend    { display:flex; flex-direction:column; gap:7px; margin-top:12px; flex-shrink:0; }
.legend-item     { display:flex; align-items:center; gap:8px; font-size:0.78rem; color:var(--text-secondary); }
.legend-dot      { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

/* ─────────────────────────────────────────────────────────────
   SECTION CARD
───────────────────────────────────────────────────────────── */
.section-card        { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-md); padding:20px; }
.section-card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; gap:12px; }
.section-card-title  { font-size:0.95rem; font-weight:700; }

/* ─────────────────────────────────────────────────────────────
   TABLES
   FIX: min-width forces horizontal scroll on mobile
   instead of crushing columns to unreadable widths
───────────────────────────────────────────────────────────── */
.table-wrap  { overflow-x:auto; -webkit-overflow-scrolling:touch; }
.dash-table  { width:100%; border-collapse:collapse; font-size:0.875rem; min-width:600px; } /* FIX */
.dash-table thead tr { border-bottom:1px solid var(--border); }
.dash-table th { padding:10px 12px; text-align:left; font-size:0.7rem; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.08em; white-space:nowrap; }
[dir="rtl"] .dash-table th { text-align:right; }
.dash-table td { padding:12px; border-bottom:1px solid var(--border); color:var(--text-secondary); vertical-align:middle; }
.dash-table tbody tr     { transition:var(--transition); cursor:pointer; }
.dash-table tbody tr:hover { background:var(--bg-card-hover); }
.dash-table tbody tr:last-child td { border-bottom:none; }
.table-loading td { text-align:center; padding:40px !important; color:var(--text-muted); cursor:default !important; }
.table-loading:hover { background:transparent !important; }
.table-empty td   { text-align:center; padding:48px !important; color:var(--text-muted); font-size:0.9rem; cursor:default !important; }

.table-actions { display:flex; gap:5px; }
.tbl-btn { width:30px; height:30px; border-radius:6px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:0.8rem; transition:var(--transition); flex-shrink:0; }
.tbl-btn:hover        { border-color:var(--border-accent); color:var(--accent); }
.tbl-btn.danger:hover { border-color:rgba(239,68,68,0.4); color:var(--danger); }
.cell-name  { font-weight:600; color:var(--text-primary) !important; }
.cell-email { font-size:0.78rem !important; }

.status-badge    { display:inline-flex; align-items:center; gap:5px; padding:3px 9px; border-radius:var(--radius-full); font-size:0.7rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; white-space:nowrap; }
.status-badge--new         { background:rgba(59,130,246,0.12);  color:var(--accent);     border:1px solid rgba(59,130,246,0.3); }
.status-badge--in_progress { background:rgba(245,158,11,0.12);  color:var(--warning);    border:1px solid rgba(245,158,11,0.3); }
.status-badge--done        { background:rgba(16,185,129,0.12);  color:var(--success);    border:1px solid rgba(16,185,129,0.3); }
.status-badge--archived    { background:rgba(107,114,128,0.12); color:var(--text-muted); border:1px solid rgba(107,114,128,0.3); }

/* ─────────────────────────────────────────────────────────────
   TOOLBAR
───────────────────────────────────────────────────────────── */
.inquiries-toolbar { display:flex; align-items:flex-start; gap:10px; flex-wrap:wrap; }
.search-wrap       { position:relative; flex:1; min-width:200px; }
.search-icon       { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--text-muted); font-size:0.82rem; pointer-events:none; }
[dir="rtl"] .search-icon { left:auto; right:13px; }
.search-input      { padding-left:36px !important; }
[dir="rtl"] .search-input { padding-left:14px !important; padding-right:36px !important; }

.filter-group { display:flex; gap:6px; flex-wrap:wrap; }
.filter-chip  { padding:8px 14px; border-radius:var(--radius-full); border:1px solid var(--border); color:var(--text-secondary); font-size:0.8rem; font-weight:600; transition:var(--transition); white-space:nowrap; }
.filter-chip:hover  { border-color:var(--border-accent); color:var(--accent); }
.filter-chip.active { background:var(--accent); color:#fff; border-color:var(--accent); }

.pagination { display:flex; align-items:center; justify-content:center; gap:14px; padding:14px; border-top:1px solid var(--border); }
.page-btn   { width:32px; height:32px; border-radius:var(--radius-sm); border:1px solid var(--border); color:var(--text-secondary); display:flex; align-items:center; justify-content:center; font-size:0.8rem; transition:var(--transition); }
.page-btn:hover:not(:disabled) { border-color:var(--border-accent); color:var(--accent); }
.page-btn:disabled { opacity:0.35; cursor:not-allowed; }
.page-info  { font-size:0.82rem; color:var(--text-muted); font-family:var(--font-mono); }

.spinner { display:inline-block; width:22px; height:22px; border:2px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin 0.7s linear infinite; }
@keyframes spin { to{transform:rotate(360deg);} }

/* ─────────────────────────────────────────────────────────────
   ANALYTICS
───────────────────────────────────────────────────────────── */
.analytics-summary { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.summary-card      { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-md); padding:22px 18px; text-align:center; transition:var(--transition-md); }
.summary-card:hover{ transform:translateY(-3px); border-color:var(--border-accent); }
.summary-icon      { font-size:1.4rem; color:var(--accent); margin-bottom:10px; }
.summary-num       { font-size:1.7rem; font-weight:800; color:var(--text-primary); line-height:1; margin-bottom:6px; }
.summary-label     { font-size:0.75rem; color:var(--text-muted); }

/* ─────────────────────────────────────────────────────────────
   SETTINGS
───────────────────────────────────────────────────────────── */
.settings-grid       { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; align-content:start; }
.settings-card       { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-md); padding:24px; }
.settings-card--info { grid-column:1/-1; }
.settings-title      { font-size:0.95rem; font-weight:700; margin-bottom:18px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.settings-row        { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:12px 0; border-bottom:1px solid var(--border); }
.settings-row:last-of-type { border-bottom:none; }
.settings-row-label  { font-size:0.88rem; font-weight:600; color:var(--text-primary); margin-bottom:2px; }
.settings-row-sub    { font-size:0.76rem; color:var(--text-muted); }
.settings-feedback   { margin-top:10px; font-size:0.82rem; min-height:20px; }
.settings-feedback.success { color:var(--success); }
.settings-feedback.error   { color:var(--danger); }

.toggle-switch { width:46px; height:26px; border-radius:var(--radius-full); background:var(--border); position:relative; transition:var(--transition); flex-shrink:0; }
.toggle-switch[aria-checked="true"] { background:var(--accent); }
.toggle-knob   { position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:50%; background:#fff; transition:var(--transition); box-shadow:0 1px 4px rgba(0,0,0,0.3); }
.toggle-switch[aria-checked="true"] .toggle-knob { transform:translateX(20px); }

.about-info { display:flex; flex-direction:column; }
.about-row  { display:flex; align-items:center; justify-content:space-between; font-size:0.86rem; padding:10px 0; border-bottom:1px solid var(--border); }
.about-row:last-child { border-bottom:none; }
.about-row span:first-child { color:var(--text-muted); }

/* ─────────────────────────────────────────────────────────────
   MODAL
   FIX: proper max-height, mobile bottom-sheet, column flex
───────────────────────────────────────────────────────────── */
.modal-backdrop {
  position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,0.75); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center; padding:16px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity 0.25s ease, visibility 0.25s ease;
}
.modal-backdrop.open { opacity:1; visibility:visible; pointer-events:all; }

.modal {
  background:var(--bg-card); border:1px solid var(--border-accent);
  border-radius:var(--radius-lg); width:100%; max-width:680px;
  max-height:calc(100vh - 32px); /* FIX */
  overflow:hidden;               /* FIX: let inner divs scroll */
  box-shadow:0 24px 60px rgba(0,0,0,0.5), var(--shadow-glow);
  transform:translateY(16px) scale(0.98);
  transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);
  display:flex; flex-direction:column; /* FIX */
}
.modal-backdrop.open .modal { transform:translateY(0) scale(1); }

.modal-header  { display:flex; align-items:flex-start; justify-content:space-between; padding:22px 24px 16px; border-bottom:1px solid var(--border); position:sticky; top:0; background:var(--bg-card); z-index:2; flex-shrink:0; }
.modal-name    { font-size:1.15rem; font-weight:700; margin-bottom:4px; }
.modal-meta    { font-size:0.78rem; color:var(--text-muted); }
.modal-close   { width:32px; height:32px; border-radius:var(--radius-sm); border:1px solid var(--border); color:var(--text-muted); display:flex; align-items:center; justify-content:center; font-size:0.95rem; transition:var(--transition); flex-shrink:0; }
.modal-close:hover { color:var(--text-primary); border-color:var(--border-accent); }

.modal-body    { padding:20px 24px; display:flex; flex-direction:column; gap:20px; flex:1; overflow-y:auto; }

.modal-info-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.modal-info-cell { background:var(--bg-surface); border:1px solid var(--border); border-radius:var(--radius-sm); padding:11px 13px; }
.modal-info-label{ font-size:0.67rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-muted); margin-bottom:4px; }
.modal-info-val  { font-size:0.86rem; color:var(--text-primary); font-weight:500; word-break:break-all; }

.modal-section-label { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-muted); margin-bottom:10px; }
.modal-message       { background:var(--bg-surface); border:1px solid var(--border); border-radius:var(--radius-sm); padding:13px 15px; font-size:0.88rem; color:var(--text-secondary); line-height:1.7; white-space:pre-wrap; }

/* ── Design file display (NEW) ─── */
.modal-design-image {
  width:100%; max-height:320px; object-fit:contain;
  border-radius:var(--radius-sm); border:1px solid var(--border);
  background:var(--bg-surface); display:block; cursor:zoom-in;
  transition:var(--transition);
}
.modal-design-image:hover { border-color:var(--border-accent); }

.modal-design-pdf {
  display:flex; align-items:center; gap:12px;
  background:var(--bg-surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:14px 16px;
}
.modal-design-pdf i      { font-size:1.5rem; color:var(--danger); flex-shrink:0; }
.modal-design-pdf-info   { flex:1; min-width:0; }
.modal-design-pdf-name   { font-size:0.88rem; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.modal-design-pdf a      { display:inline-flex; align-items:center; gap:6px; color:var(--accent); font-size:0.8rem; margin-top:4px; transition:var(--transition); }
.modal-design-pdf a:hover{ color:var(--accent-bright); text-decoration:underline; }

.status-buttons { display:flex; gap:8px; flex-wrap:wrap; }
.status-btn     { padding:8px 14px; border-radius:var(--radius-full); border:1px solid var(--border); color:var(--text-secondary); font-size:0.8rem; font-weight:600; transition:var(--transition); white-space:nowrap; }
.status-btn:hover  { border-color:var(--border-accent); color:var(--text-primary); }
.status-btn.active { background:var(--accent-glow); border-color:var(--accent); color:var(--accent); }

.modal-footer { padding:14px 24px 20px; display:flex; gap:8px; flex-wrap:wrap; border-top:1px solid var(--border); flex-shrink:0; }

.btn-reply, .btn-wa, .btn-delete {
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 16px; border-radius:var(--radius-sm);
  font-family:var(--font); font-size:0.83rem; font-weight:600;
  transition:var(--transition); white-space:nowrap;
}
.btn-reply  { background:var(--accent-glow); border:1px solid var(--border-accent); color:var(--accent); }
.btn-reply:hover { background:var(--accent); color:#fff; }
.btn-wa     { background:rgba(37,211,102,0.1); border:1px solid rgba(37,211,102,0.3); color:#25D366; }
.btn-wa:hover { background:#25D366; color:#fff; }
.btn-delete { background:rgba(239,68,68,0.08); border:1px solid rgba(239,68,68,0.3); color:var(--danger); margin-left:auto; }
[dir="rtl"] .btn-delete { margin-left:0; margin-right:auto; }
.btn-delete:hover { background:var(--danger); color:#fff; }

/* ─────────────────────────────────────────────────────────────
   TOAST
───────────────────────────────────────────────────────────── */
.dash-toast { position:fixed; bottom:24px; right:24px; background:var(--bg-card); border:1px solid var(--border-accent); border-radius:var(--radius-md); padding:12px 16px; display:flex; align-items:center; gap:9px; font-size:0.86rem; font-weight:500; color:var(--text-primary); transform:translateX(130%); transition:transform 0.35s cubic-bezier(0.4,0,0.2,1); z-index:9000; box-shadow:var(--shadow-card); max-width:300px; }
[dir="rtl"] .dash-toast { right:auto; left:24px; transform:translateX(-130%); }
.dash-toast.show { transform:translateX(0); }
.dash-toast-icon { color:var(--success); }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════ */
@media (max-width:1100px) {
  .stats-grid        { grid-template-columns:repeat(2,1fr); }
  .analytics-summary { grid-template-columns:repeat(2,1fr); }
  .charts-row--3     { grid-template-columns:1fr 1fr; }
}

@media (max-width:900px) {
  .charts-row        { grid-template-columns:1fr; }
  .modal-info-grid   { grid-template-columns:repeat(2,1fr); }
  .settings-grid     { grid-template-columns:1fr; }
  .settings-card--info { grid-column:1; }
}

/* ── MOBILE ≤768px ── */
@media (max-width:768px) {
  /* Sidebar hidden by default, slides in */
  .sidebar            { transform:translateX(-100%); width:270px; }
  [dir="rtl"] .sidebar{ transform:translateX(100%); }
  .sidebar.open       { transform:translateX(0); }
  .sidebar-close      { display:flex; }

  /* FIX: remove sidebar margin on mobile */
  .main-content {
    margin-left:0 !important;
    margin-right:0 !important;
    width:100%;
  }

  .hamburger-dash { display:flex; }
  .topbar         { padding:0 12px; gap:8px; }
  .page-date      { display:none; }

  .view.active    { padding:14px; gap:14px; }

  .stats-grid     { grid-template-columns:repeat(2,1fr); gap:10px; }
  .stat-card      { padding:16px 12px; gap:10px; }
  .stat-card-num  { font-size:1.5rem; }

  .charts-row     { grid-template-columns:1fr; }
  .charts-row--3  { grid-template-columns:1fr; }
  .chart-wrap     { min-height:180px; }

  .analytics-summary  { grid-template-columns:repeat(2,1fr); gap:10px; }
  .inquiries-toolbar  { flex-direction:column; align-items:stretch; }
  .search-wrap        { min-width:0; width:100%; }
  .filter-group       { overflow-x:auto; padding-bottom:4px; flex-wrap:nowrap; }
  .filter-chip        { flex-shrink:0; }

  /* Modal: bottom sheet on mobile */
  .modal-backdrop { padding:0; align-items:flex-end; }
  .modal          { max-width:100%; max-height:92vh; border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
  .modal-info-grid{ grid-template-columns:repeat(2,1fr); gap:8px; }
  .modal-body     { padding:16px; gap:14px; }
  .modal-header   { padding:18px 16px 14px; }
  .modal-footer   { padding:12px 16px 20px; gap:8px; }

  .settings-grid  { grid-template-columns:1fr; }
  .settings-card  { padding:18px; }
}

/* ── SMALL MOBILE ≤480px ── */
@media (max-width:480px) {
  .stats-grid        { grid-template-columns:1fr; gap:8px; }
  .analytics-summary { grid-template-columns:1fr; gap:8px; }
  .login-card        { padding:28px 18px; }
  .modal-info-grid   { grid-template-columns:1fr; }
  .modal-footer      { flex-direction:column; }
  .btn-delete        { margin-left:0 !important; margin-right:0 !important; }
}