:root{
  --primary:#1a3a5c;--primary-light:#5776ad;--accent:#8b1a1a;--accent-light:#b22222;
  --success:#1aab5c;--danger:#e84040;--warning:#f4c430;--info:#1a8fa8;
  --bg:#f0f4f8;--card:#ffffff;--sidebar:#0f2540;--text:#1a2535;--text-muted:#6b7c93;
  --border:#dde3ea;--shadow:0 4px 24px rgba(26,58,92,.10);--radius:14px;--radius-sm:8px;
}
body.dark{
  --bg:#0f1923;--card:#172030;--text:#cfddef;--text-muted:#7d97b3;
  --border:#1f3347;--shadow:0 4px 24px rgba(0,0,0,.45);
}
/* ── Dark mode: نصوص تحتاج لون فاتح (بدون المساس بالخلفيات) ── */
body.dark #menu-toggle{color:#cfddef;}
body.dark .topbar-title{color:#cfddef;}
body.dark .code-cell{color:#cfddef;}
body.dark .section-title{color:#cfddef!important;border-bottom-color:rgba(207,221,239,.25)!important;}
body.dark .badge-scheduled{color:#cfddef;}
body.dark .stat-card.blue .stat-icon{color:#cfddef;}
body.dark .btn-outline:hover{color:#cfddef;}
body.dark .search-box:focus-within{border-color:rgba(207,221,239,.3);}
body.dark .filter-select:focus,.date-wrap:focus-within{border-color:rgba(207,221,239,.3);}
body.dark .login-box{background:var(--card);}
body.dark input,body.dark select,body.dark textarea{color:var(--text);border-color:var(--border);}
body.dark input::placeholder,body.dark textarea::placeholder{color:var(--text-muted);}
body.dark .user-btn{background:var(--bg);border-color:var(--border);}
body.dark .user-btn:hover{background:var(--card);}
body.dark .user-dropdown{background:var(--card);border-color:var(--border);}
body.dark .user-dropdown-item:hover{background:rgba(255,255,255,.05);}
body.dark .topbar{background:var(--card);}
body.dark #sidebar{background:var(--card);}
body.dark .modal .modal-inner{background:var(--card);}
body.dark .modal .modal-body{background:var(--card);}
body.dark .modal .modal-footer{background:var(--card);border-color:var(--border);}
body.dark .modal .modal-header{border-color:var(--border);}
body.dark .ss-display{background:var(--bg);border-color:var(--border);color:var(--text);}
body.dark .ss-dropdown{background:var(--card);border-color:var(--border);}
body.dark .ss-option:hover{background:rgba(255,255,255,.06);}
body.dark .ss-search input{background:var(--bg);color:var(--text);border-color:var(--border);}
body.dark .filter-select{background:var(--bg);color:var(--text);border-color:var(--border);}
body.dark .perm-item{background:var(--bg);}
body.dark .table-wrap table tbody tr:hover{background:rgba(255,255,255,.03);}
body.dark .phone-chip{border-color:var(--border);color:var(--text);}
body.dark .modal-header h2{color:var(--text);}
body.dark .schedule-card-time{color: var(--primary-light);}
body.dark .schedule-card-detail .dval{color: var(--primary-light);}
body.dark .upcoming-time .time{color:var(--primary-light);}
body.dark #page-settings .card h3{color:var(--primary-light)!important;}
body.dark .autocomplete-list{background: var(--bg);}
body.dark .log-expand-btn{background: var(--primary-bg, rgba(42, 82, 152, .07)); color: var(--primary-light);}

/* زر تبديل الثيم */
.btn-theme-toggle{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .2s;flex-shrink:0;}
.btn-theme-toggle:hover{border-color:var(--primary-light);color:var(--primary-light);transform:rotate(20deg);}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Tajawal',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;}

/* ── LOGIN ─────────────────────────────────────── */
#login-screen{position:fixed;inset:0;background:linear-gradient(135deg,#0a1628 0%,#1a3a5c 50%,#0f2540 100%);display:flex;align-items:center;justify-content:center;z-index:9999;}
.login-card{background:#fff;border-radius:24px;padding:48px 44px;width:100%;max-width:440px;box-shadow:0 30px 80px rgba(0,0,0,.35);}
.login-logo{text-align:center;margin-bottom:32px;}
.login-logo img{width:110px;height:auto;margin-bottom:16px;}
.login-logo h1{font-size:20px;font-weight:900;color:#1a3a5c;line-height:1.3;}
.login-logo p{font-size:12px;color:#6b7c93;margin-top:6px;}
.login-field{margin-bottom:18px;}
.login-field label{font-size:12px;font-weight:700;color:#6b7c93;display:block;margin-bottom:6px;letter-spacing:.3px;}
.login-input{width:100%;padding:12px 16px;border:1.5px solid #dde3ea;border-radius:10px;font-family:'Tajawal',sans-serif;font-size:15px;outline:none;transition:all .2s;background:#f8fafc;}
.login-input:focus{border-color:#2a5298;background:#fff;box-shadow:0 0 0 3px rgba(42,82,152,.1);}
.login-input-wrap{position:relative;}
.login-input-wrap .toggle-pw{position:absolute;left:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#6b7c93;font-size:14px;}
.btn-login{width:100%;padding:14px;background:linear-gradient(135deg,#8b1a1a,#b22222);color:#fff;border:none;border-radius:10px;font-family:'Tajawal',sans-serif;font-size:16px;font-weight:800;cursor:pointer;transition:all .2s;margin-top:8px;}
.btn-login:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(139,26,26,.35);}
.login-error{background:rgba(232,64,64,.1);color:#e84040;border:1px solid rgba(232,64,64,.2);border-radius:8px;padding:10px 14px;font-size:13px;font-weight:600;display:none;margin-top:12px;text-align:center;}


/* ── SIDEBAR ────────────────────────────────────── */
#sidebar{width:220px;min-width:220px;background:var(--sidebar);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;box-shadow:4px 0 28px rgba(0,0,0,.2);z-index:100;transition:width .22s ease,min-width .22s ease;overflow:hidden;}
.sidebar-logo{padding:20px 20px 18px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:14px;}
.sidebar-logo img{width:44px;height:44px;object-fit:contain;border-radius:10px;background:#fff;padding:3px;flex-shrink:0;}
.logo-text h2{color:#fff;font-size:13px;font-weight:800;line-height:1.3;}
.logo-text span{color:rgba(255,255,255,.45);font-size:10px;}
.sidebar-nav{flex:1;padding:14px 10px;overflow-y:auto;}
.nav-section-title{color:rgba(255,255,255,.3);font-size:9px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:12px 12px 5px;}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 13px;border-radius:10px;color:rgba(255,255,255,.6);cursor:pointer;transition:all .2s;font-size:13.5px;font-weight:500;margin-bottom:2px;text-decoration:none;}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff;}
.nav-item.active{background:linear-gradient(90deg,#8b1a1a,#b22222);color:#fff;box-shadow:0 4px 14px rgba(139,26,26,.35);}
.nav-sub{overflow:hidden;max-height:0;transition:max-height .3s ease;}
.nav-sub.open{max-height:300px;}
.nav-sub-item{display:flex;align-items:center;gap:10px;padding:8px 13px 8px 24px;border-radius:8px;color:rgba(255,255,255,.5);cursor:pointer;font-size:12.5px;font-weight:500;margin-bottom:1px;text-decoration:none;}
.nav-sub-item:hover{background:rgba(255,255,255,.06);color:#fff;}
.nav-sub-item.active{background:rgba(139,26,26,.5);color:#fff;}
.nav-parent{display:flex;align-items:center;gap:11px;padding:10px 13px;border-radius:10px;color:rgba(255,255,255,.6);cursor:pointer;transition:all .2s;font-size:13.5px;font-weight:500;margin-bottom:2px;justify-content:space-between;}
.nav-parent:hover{background:rgba(255,255,255,.07);color:#fff;}
.nav-parent.open{background:rgba(255,255,255,.05);color:#fff;}
.nav-parent-left{display:flex;align-items:center;gap:11px;}
.nav-chevron{font-size:10px;transition:transform .3s;}
.nav-parent.open .nav-chevron{transform:rotate(180deg);}
.perm-role-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:20px;margin-bottom:16px;}
.perm-role-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--border);}
.perm-role-title{font-size:16px;font-weight:800;color:var(--text);}
.perm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;}
.perm-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-radius:8px;padding:10px 14px;border:1px solid var(--border);}
.perm-label{font-size:12.5px;font-weight:600;color:var(--text);}
.perm-sublabel{font-size:10px;color:var(--text-muted);margin-top:2px;}
.toggle-switch{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0;}
.toggle-switch input{opacity:0;width:0;height:0;}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:#ccc;border-radius:22px;transition:.3s;}
.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;right:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;}
input:checked + .toggle-slider{background:var(--primary);}
input:checked + .toggle-slider:before{transform:translateX(-18px);}
.fields-select{width:100%;margin-top:8px;font-size:12px;}
.nav-item i{width:19px;text-align:center;font-size:14px;}
.nav-badge{margin-right:auto;background:rgba(255,255,255,.15);color:#fff;border-radius:20px;padding:1px 8px;font-size:11px;font-weight:700;}
.nav-item.active .nav-badge{background:rgba(255,255,255,.25);}
.sidebar-footer{padding:12px 10px;border-top:1px solid rgba(255,255,255,.08);}

/* ── TOPBAR ─────────────────────────────────────── */
#main{flex:1;display:flex;flex-direction:column;min-width:0;overflow-x:hidden;}
.topbar{background:var(--card);padding:12px 24px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.05);position:sticky;top:0;z-index:50;}
.topbar-title{font-size:17px;font-weight:800;color:var(--primary);flex:1;}
.topbar-title span{color:var(--accent);}

/* User menu */
.user-menu-wrap{position:relative;}
.user-btn{display:flex;align-items:center;gap:10px;padding:7px 14px 7px 10px;border-radius:10px;cursor:pointer;border:1.5px solid var(--border);background:var(--bg);transition:all .2s;}
.user-btn:hover{border-color:var(--primary-light);background:#fff;}
.user-avatar-sm{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0;}
.user-name-sm{font-size:13px;font-weight:700;color:var(--text);}
.user-role-sm{font-size:10px;color:var(--text-muted);}
.user-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);border:1px solid var(--border);min-width:180px;display:none;z-index:200;overflow:hidden;}
.user-dropdown.open{display:block;animation:dropIn .15s ease;}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:none;}}
.user-dropdown-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:background .15s;}
.user-dropdown-item:hover{background:var(--bg);}
.user-dropdown-item.danger{color:var(--danger);}
.user-dropdown-item.danger:hover{background:rgba(232,64,64,.06);}
.user-dropdown-divider{height:1px;background:var(--border);margin:4px 0;}

/* ── BUTTONS ────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);font-family:'Tajawal',sans-serif;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s;white-space:nowrap;}
.btn-primary{background:linear-gradient(135deg,var(--primary-light),var(--primary));color:#fff;box-shadow:0 4px 12px rgba(26,58,92,.2);}
.btn-primary:hover{box-shadow:0 6px 18px rgba(26,58,92,.3);transform:translateY(-1px);}
.btn-accent{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;box-shadow:0 4px 12px rgba(139,26,26,.25);}
.btn-accent:hover{box-shadow:0 6px 18px rgba(139,26,26,.35);transform:translateY(-1px);}
.btn-success{background:var(--success);color:#fff;}
.btn-danger{background:var(--danger);color:#fff;}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text-muted);}
.btn-outline:hover{box-shadow:0 6px 18px rgba(26,58,92,.3);transform:translateY(-1px);}
.btn-today{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;box-shadow:0 4px 12px rgba(139,26,26,.25);}
.btn-today:hover{box-shadow:0 6px 18px rgba(139,26,26,.35);transform:translateY(-1px);}
.btn-icon{padding:7px 9px;}
.btn-icon:hover{box-shadow:0 6px 18px rgba(26,58,92,.3);transform:translateY(-1px);}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;}

.content{padding:22px 26px;flex:1;}
.page-section{display:none;}.page-section.active{display:block;}

/* ── STATS ──────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;}
.stat-card{background:var(--card);border-radius:var(--radius);padding:20px 18px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);border:1px solid var(--border);transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;}
.stat-card::before{content:'';position:absolute;top:0;right:0;width:4px;height:100%;border-radius:0 var(--radius) var(--radius) 0;}
.stat-card.blue::before{background:var(--primary-light);}
.stat-card.red::before{background:var(--accent);}
.stat-card.green::before{background:var(--success);}
.stat-card.orange::before{background:#e8871a;}
.stat-card.teal::before{background:var(--info);}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(26,58,92,.12);}
.stat-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.stat-card.blue .stat-icon{background:rgba(42,82,152,.1);color:var(--primary-light);}
.stat-card.red .stat-icon{background:rgba(139,26,26,.1);color:var(--accent);}
.stat-card.green .stat-icon{background:rgba(26,171,92,.1);color:var(--success);}
.stat-card.orange .stat-icon{background:rgba(232,135,26,.1);color:#e8871a;}
.stat-card.teal .stat-icon{background:rgba(26,143,168,.1);color:var(--info);}
.stat-info h3{font-size:24px;font-weight:800;color:var(--text);line-height:1;}
.stat-info p{font-size:12px;color:var(--text-muted);margin-top:3px;font-weight:500;}
.stat-info small{font-size:11px;color:var(--success);font-weight:600;}

/* ── CHARTS ─────────────────────────────────────── */
.charts-row{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:22px;}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden;}
.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.card-header h3{font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;}
.card-header h3 i{color:var(--accent);}
.card-body{padding:18px 20px;}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:150px;}
.bar-wrap{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1;}
.bar{width:100%;border-radius:5px 5px 0 0;transition:height .5s cubic-bezier(.4,2,.6,1);min-height:3px;cursor:pointer;position:relative;}
.bar:hover::after{content:attr(data-val);position:absolute;top:-24px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;padding:2px 7px;border-radius:5px;font-size:10px;white-space:nowrap;}
.bar-label{font-size:10px;color:var(--text-muted);font-weight:500;}
.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;}
.donut-svg{width:150px;height:150px;}
.legend-item{display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:12.5px;}
.legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.legend-label{flex:1;color:var(--text-muted);}
.legend-val{font-weight:700;color:var(--text);}

/* ── TABLE ──────────────────────────────────────── */
.table-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px;}
.search-box{display:flex;align-items:center;gap:8px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 13px;flex:1;min-width:180px;transition:border-color .2s;}
.search-box:focus-within{border-color:var(--primary-light);}
.search-box i{color:var(--text-muted);font-size:13px;}
.search-box input{border:none;outline:none;font-family:'Tajawal',sans-serif;font-size:13px;background:transparent;color:var(--text);width:100%;}
.filter-select{padding:8px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Tajawal',sans-serif;font-size:13px;color:var(--text);background:var(--card);cursor:pointer;outline:none;transition:border-color .2s;}
.filter-select:focus{border-color:var(--primary-light);}
input[type="date"].filter-select,input[type="date"].form-control,
input[type="datetime-local"].filter-select,input[type="datetime-local"].form-control{direction:ltr;text-align:left;}
/* Date picker wrapper */
.date-wrap{display:inline-flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--card);overflow:hidden;transition:border-color .2s;cursor:pointer;}
.date-wrap:hover,.date-wrap:focus-within{border-color:var(--primary-light);}
.date-wrap .date-icon{padding:0 9px;color:var(--text-muted);font-size:13px;pointer-events:none;flex-shrink:0;}
.date-wrap input[type="date"]{border:none!important;outline:none!important;background:transparent!important;font-family:'Tajawal',sans-serif;font-size:13px;color:var(--text);padding:8px 10px 8px 0;cursor:pointer;width:100%;box-shadow:none!important;text-align:center;}
.date-wrap input[type="date"]::-webkit-calendar-picker-indicator{opacity:.6;cursor:pointer;}
body.dark .date-wrap{background:var(--bg);}
body.dark .date-wrap input[type="date"]{color:var(--text);}
body.dark .date-wrap input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1);}
/* Range Picker */
.range-picker{display:inline-flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--card);overflow:hidden;transition:border-color .2s;cursor:pointer;}
.range-picker:hover,.range-picker:focus-within{border-color:var(--primary-light);}
.range-picker .rp-icon{padding:0 9px;color:var(--text-muted);font-size:13px;pointer-events:none;flex-shrink:0;}
.range-picker .rp-sep{padding:0 5px;color:var(--text-muted);font-size:12px;pointer-events:none;flex-shrink:0;}
.range-picker input[type="date"]{border:none!important;outline:none!important;background:transparent!important;font-family:'Tajawal',sans-serif;font-size:13px;color:var(--text);padding:7px 4px 7px 0;cursor:pointer;width:116px;box-shadow:none!important;text-align:center;}
.range-picker input[type="date"]::-webkit-calendar-picker-indicator{opacity:.6;cursor:pointer;}
body.dark .range-picker{background:var(--bg);}
body.dark .range-picker input[type="date"]{color:var(--text);}
body.dark .range-picker input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1);}
/* ── Date Range Picker Popup (DRP) ── */
.drp-trigger{display:inline-flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--card);color:var(--text);font-family:'Tajawal',sans-serif;font-size:13px;cursor:pointer;transition:border-color .2s;white-space:nowrap;height:36px;overflow:hidden;padding:0;}
.drp-trigger:hover,.drp-trigger.drp-active{border-color:var(--primary-light);}
.drp-field{display:inline-flex;align-items:center;gap:6px;padding:0 10px;height:100%;}
.drp-date-text{font-size:13px;color:var(--text);min-width:72px;letter-spacing:.3px;}
.drp-date-text.drp-ph{color:var(--text-muted);}
.drp-field i{color:var(--text-muted);font-size:12px;flex-shrink:0;}
.drp-dash{color:var(--text-muted);font-size:13px;padding:0 2px;flex-shrink:0;}
#drp-popup{position:fixed;z-index:9999;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px rgba(0,0,0,.2);padding:16px;width:280px;direction:rtl;}
.drp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;direction:ltr;}
.drp-month-label{font-size:14px;font-weight:700;color:var(--text);direction:rtl;}
.drp-nav{background:none;border:1.5px solid var(--border);border-radius:50%;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .15s;font-size:11px;flex-shrink:0;}
.drp-nav:hover{border-color:var(--primary-light);color:var(--primary-light);}
.drp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px;direction:ltr;}
.drp-weekdays span{text-align:center;font-size:10px;font-weight:700;color:var(--text-muted);padding:3px 0;}
.drp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;direction:ltr;}
.drp-day{display:flex;align-items:center;justify-content:center;height:34px;border-radius:50%;font-size:12px;cursor:pointer;color:var(--text);position:relative;transition:background .12s,color .12s;user-select:none;}
.drp-day:hover:not(.drp-empty){background:rgba(87,118,173,.12);}
.drp-day.drp-empty{cursor:default;}
.drp-day.drp-future{color:var(--text-muted);opacity:.65;}
.drp-day.drp-today::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent);}
.drp-day.drp-start,.drp-day.drp-end{background:var(--primary)!important;color:#fff!important;border-radius:50%!important;z-index:1;}
.drp-day.drp-in-range{background:rgba(87,118,173,.15);border-radius:0;color:var(--text);}
.drp-day.drp-start.drp-in-range{border-radius:50% 0 0 50%!important;}
.drp-day.drp-end.drp-in-range{border-radius:0 50% 50% 0!important;}
.drp-day.drp-start.drp-same-day,.drp-day.drp-end.drp-same-day{border-radius:50%!important;}
.drp-footer{display:flex;gap:8px;justify-content:space-between;margin-top:12px;padding-top:10px;border-top:1px solid var(--border);}
body.dark #drp-popup{background:var(--card);border-color:var(--border);}
body.dark .drp-day.drp-start,body.dark .drp-day.drp-end{background:var(--primary-light)!important;}
body.dark .drp-trigger{background:var(--bg);}
body.dark .drp-date-text{color:var(--text);}
body.dark .drp-date-text.drp-ph{color:var(--text-muted);}
.table-wrap{overflow-x:auto;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);}
table{width:100%;border-collapse:collapse;font-size:13px;}
.tbl-clients{min-width:700px;}
thead{background:var(--primary);color:#fff;}
thead th{padding:12px 11px;text-align:center;font-weight:700;font-size:11.5px;white-space:nowrap;cursor:pointer;user-select:none;transition:background .15s;position:relative;}
thead th:hover{background:#1e4a7a;}
thead th .sort-icon{font-size:9px;opacity:.5;margin-right:3px;}
thead th.sort-asc .sort-icon::before{content:'\f0de';}
thead th.sort-desc .sort-icon::before{content:'\f0dd';}
tbody tr{border-bottom:1px solid var(--border);transition:background .15s;}
tbody tr:hover{background:rgba(42,82,152,.03);}
tbody tr:last-child{border-bottom:none;}
tbody td{padding:10px 11px;vertical-align:middle;}
td.wrap-cell{white-space:normal;max-width:200px;word-break:break-word;font-size:12px;}
td.nowrap{white-space:nowrap;}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;}
.badge-scheduled{background:rgba(42,82,152,.12);color:var(--primary-light);}
.badge-inprogress{background:rgba(244,196,48,.15);color:#9a7100;}
.badge-completed{background:rgba(26,171,92,.12);color:var(--success);}
.badge-delayed{background:rgba(26,143,168,.12);color:var(--info);}
.badge-cancelled{background:rgba(232,64,64,.12);color:var(--danger);}
.badge-new-client{background:rgba(232,135,26,.12);color:#c06800;font-size:10px;padding:2px 6px;}
.action-btns{display:flex;gap:3px;white-space:nowrap;}
.code-cell{font-family:monospace;background:rgba(26,58,92,.07);padding:2px 6px;border-radius:4px;font-size:11.5px;font-weight:700;color:var(--primary);}
.row-num{font-size:12px;font-weight:700;color:var(--text-muted);}
.pagination{display:flex;align-items:center;gap:5px;padding:14px 18px;border-top:1px solid var(--border);justify-content:space-between;flex-wrap:wrap;}
.pagination-info{font-size:12px;color:var(--text-muted);}
.page-btns{display:flex;gap:4px;}
.page-btn{width:32px;height:32px;border-radius:7px;border:1.5px solid var(--border);background:var(--card);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;font-weight:600;color:var(--text-muted);transition:all .15s;font-family:'Tajawal',sans-serif;}
.page-btn:hover,.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;}

/* ── MODAL ──────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(5,15,35,.6);backdrop-filter:blur(4px);z-index:1000;align-items:center;justify-content:center;padding:14px;}
.modal-overlay.open{display:flex;}
.modal{background:var(--card);border-radius:var(--radius);box-shadow:0 24px 70px rgba(0,0,0,.28);width:100%;max-width:920px;max-height:93vh;overflow-y:auto;animation:modalIn .22s cubic-bezier(.4,1.3,.6,1);}
.modal.sm{max-width:480px;}
.modal.md{max-width:600px;}
@keyframes modalIn{from{opacity:0;transform:scale(.92) translateY(18px);}to{opacity:1;transform:none;}}
.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;position:sticky;top:0;background:var(--card);z-index:2;}
.modal-header h2{font-size:16px;font-weight:800;color:var(--primary);flex:1;}
.modal-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;flex-shrink:0;}
.modal-close{width:32px;height:32px;border-radius:7px;border:1.5px solid var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-muted);transition:all .15s;}
.modal-close:hover{background:var(--danger);border-color:var(--danger);color:#fff;}
.modal-body{padding:22px 24px;}
.modal-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;gap:9px;justify-content:flex-end;position:sticky;bottom:0;background:var(--card);}

/* ── FORM ───────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.form-grid.g2{grid-template-columns:repeat(2,1fr);}
.form-grid.g4{grid-template-columns:repeat(4,1fr);}
.form-grid.g1{grid-template-columns:1fr;}
.span2{grid-column:span 2;}
.span3{grid-column:span 3;}
.span4{grid-column:span 4;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-group label{font-size:11.5px;font-weight:700;color:var(--text-muted);display:flex;align-items:center;gap:4px;}
.form-group label i{color:var(--accent);font-size:10px;}
.req::after{content:' *';color:var(--danger);}
.form-control{padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Tajawal',sans-serif;font-size:13.5px;color:var(--text);background:var(--bg);outline:none;transition:all .2s;width:100%;}
.form-control:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px rgba(42,82,152,.09);}
.form-control.error{border-color:var(--danger);}
textarea.form-control{min-height:70px;resize:vertical;}
.section-title{grid-column:1/-1;font-size:12px;font-weight:800;color:var(--primary);padding-bottom:7px;border-bottom:2px solid var(--accent);margin-top:6px;display:flex;align-items:center;gap:6px;letter-spacing:.3px;}

/* Smart dropdown */
.autocomplete-wrap{position:relative;}
.autocomplete-list{position:absolute;top:calc(100% + 4px);right:0;left:0;background:#fff;border:1.5px solid var(--primary-light);border-radius:var(--radius-sm);box-shadow:0 8px 28px rgba(0,0,0,.13);max-height:220px;overflow-y:auto;z-index:500;display:none;}
.autocomplete-list.open{display:block;}
.ac-item{padding:9px 13px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--border);transition:background .12s;}
.ac-item:hover,.ac-item.selected{background:rgba(42,82,152,.07);}
.ac-item:last-child{border-bottom:none;}
.ac-item .ac-code{font-size:11px;color:var(--text-muted);margin-top:1px;}
.ac-new{color:var(--accent);font-weight:700;}

/* Client indicator */
.client-indicator{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;margin-top:3px;}
.ci-existing{background:rgba(26,171,92,.1);color:var(--success);}
.ci-new{background:rgba(232,135,26,.12);color:#c06800;}
/* Phone suggestions */
#phone-suggestions,#date-suggestions,#actual-date-suggestions,#location-suggestions,#supervisor-suggestions,#concrete-type-suggestions,#pour-type-suggestions,#equipment-suggestions{display:none;flex-wrap:wrap;gap:6px;margin-top:5px;}
.phone-chip{display:inline-flex;align-items:center;gap:5px;padding:2px 4px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-size:12px;font-weight:600;cursor:pointer;font-family:'Tajawal',sans-serif;transition:all .15s;direction:ltr;}
.phone-chip:hover{border-color:var(--primary-light);background:rgba(42,82,152,.07);}
.phone-chip.active{border-color:var(--primary);background:var(--primary);color:#fff;}
/* Locked SS delegate */
.ss-display.locked{pointer-events:none;background:#f5f7fa;cursor:not-allowed;}

/* Searchable select */
.ss-wrap{position:relative;}
.ss-display{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;transition:all .2s;min-height:40px;font-size:13.5px;color:var(--text);}
.ss-display:hover,.ss-display.open{border-color:var(--primary-light);background:#fff;}
.ss-display .placeholder{color:var(--text-muted);}
.ss-dropdown{position:absolute;top:calc(100% + 4px);right:0;left:0;background:#fff;border:1.5px solid var(--primary-light);border-radius:var(--radius-sm);box-shadow:0 8px 28px rgba(0,0,0,.13);z-index:500;display:none;overflow:hidden;}
.ss-dropdown.open{display:block;}
.ss-search{padding:8px 10px;border-bottom:1px solid var(--border);}
.ss-search input{width:100%;border:1.5px solid var(--border);border-radius:6px;padding:6px 10px;font-family:'Tajawal',sans-serif;font-size:13px;outline:none;}
.ss-search input:focus{border-color:var(--primary-light);}
.ss-options{max-height:200px;overflow-y:auto;}
/* Multi-select tags */
.ss-tags{display:flex;flex-wrap:wrap;gap:4px;flex:1;}
.ss-tag{display:inline-flex;align-items:center;gap:4px;background:var(--primary);color:#fff;border-radius:5px;padding:2px 8px;font-size:12px;font-weight:600;}
.ss-tag .ss-tag-x{cursor:pointer;font-size:11px;opacity:.8;margin-right:2px;}
.ss-tag .ss-tag-x:hover{opacity:1;}
.ss-option.checked{background:rgba(42,82,152,.08);font-weight:700;}
.ss-option.checked::before{content:'✓ ';color:var(--primary-light);}
.ss-option{padding:9px 13px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--border);transition:background .12s;}
.ss-option:hover,.ss-option.active{background:rgba(42,82,152,.07);}
.ss-option:last-child{border-bottom:none;}
.ss-option.selected{color:var(--primary-light);font-weight:700;}
.ss-empty{padding:12px;text-align:center;color:var(--text-muted);font-size:12px;}

/* ── USERS ──────────────────────────────────────── */
.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.user-card{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border);display:flex;flex-direction:column;gap:12px;transition:transform .2s,box-shadow .2s;}
.user-card:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(26,58,92,.12);}
.user-card-header{display:flex;align-items:center;gap:12px;}
.user-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;flex-shrink:0;}
.user-info h4{font-size:14px;font-weight:700;}
.user-info span{font-size:11px;color:var(--text-muted);}
.role-badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;}
.role-sm{background:rgba(42,82,152,.12);color:var(--primary-light);}
.role-admin{background:rgba(139,26,26,.12);color:var(--accent);}
.role-user{background:rgba(26,143,168,.12);color:var(--info);}
.role-booking{background:rgba(26,143,168,.12);color:var(--info);}
.role-viewer{background:rgba(100,100,100,.12);color:#6b7c93;}
.role-executor{background:rgba(230,126,34,.12);color:#e67e22;}
body.no-select *{user-select:none;-webkit-user-select:none;}
body.no-select input,body.no-select textarea,body.no-select select{user-select:text;-webkit-user-select:text;}
.user-card-footer{display:flex;gap:7px;border-top:1px solid var(--border);padding-top:12px;}

/* ── UPCOMING ────────────────────────────────────── */
.upcoming-list{display:flex;flex-direction:column;gap:9px;}
.upcoming-item{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:10px;border:1px solid var(--border);transition:background .15s;}
.upcoming-item:hover{background:var(--bg);}
.upcoming-time{text-align:center;min-width:54px;background:var(--bg);border-radius:8px;padding:6px;}
.upcoming-time .time{font-size:13px;font-weight:800;color:var(--primary);}
.upcoming-time .date{font-size:9px;color:var(--text-muted);}
.upcoming-info{flex:1;min-width:0;}
.upcoming-info h4{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.upcoming-info p{font-size:11px;color:var(--text-muted);margin-top:2px;}

/* ── SCHEDULE ────────────────────────────────────── */
.schedule-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;}
.schedule-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden;transition:box-shadow .2s,transform .15s,border-color .2s;display:flex;flex-direction:column;cursor:pointer;}
.schedule-card:hover{box-shadow:0 8px 24px rgba(26,58,92,.18);transform:translateY(-2px);border-color:var(--primary-light);}
.schedule-card-bar{height:4px;flex-shrink:0;}
.schedule-card-body{padding:11px 13px;flex:1;display:flex;flex-direction:column;gap:7px;}
.schedule-card-time{font-size:18px;font-weight:800;color:var(--primary);line-height:1;unicode-bidi:isolate;}
.schedule-card-sub{font-size:10px;color:var(--text-muted);margin-top:1px;}
.schedule-card-client{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.schedule-card-loc{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.schedule-card-details{display:grid;grid-template-columns:1fr 1fr;gap:5px;}
.schedule-card-detail{background:var(--bg);border-radius:6px;padding:4px 6px;text-align:center;min-width:0;}
.schedule-card-detail .dval{font-size:11px;font-weight:800;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.schedule-card-detail .dlbl{font-size:9px;color:var(--text-muted);margin-top:1px;}
.schedule-card-footer{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-top:auto;padding-top:6px;border-top:1px solid var(--border);}
.schedule-card-notes{font-size:10px;color:var(--text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ── LOGS ───────────────────────────────────────── */
.log-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);}
.log-item:last-child{border-bottom:none;}
.log-dot{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff;flex-shrink:0;margin-top:2px;}
.log-info{flex:1;}
.log-action{font-size:13px;font-weight:700;}
.log-meta{font-size:11px;color:var(--text-muted);margin-top:3px;display:flex;gap:12px;flex-wrap:wrap;}
.log-time{font-size:11px;color:var(--text-muted);text-align:left;white-space:nowrap;}
/* Collapse group */
.log-group-wrap{border-bottom:1px solid var(--border);padding-bottom:2px;}
.log-group-wrap .log-item{border-bottom:none;}
.log-group-rest .log-item{border-top:1px dashed var(--border);padding-top:10px;}
.log-expand-btn{display:inline-flex;align-items:center;gap:6px;margin:4px 0 8px 46px;padding:3px 10px;font-size:11px;font-weight:700;color:var(--primary);background:var(--primary-bg,rgba(42,82,152,.07));border:1px solid rgba(42,82,152,.18);border-radius:20px;cursor:pointer;transition:background .15s;}
.log-expand-btn:hover{background:rgba(42,82,152,.14);}
.log-expand-btn i{font-size:9px;}
.log-item-important{background:rgba(244,196,48,.06);border-radius:8px;padding-right:8px;border-right:3px solid #f4c430;}

/* ── ALERTS / TOASTS ────────────────────────────── */
.alert{padding:11px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;display:flex;align-items:center;gap:9px;margin-bottom:11px;}
.alert-danger{background:rgba(232,64,64,.08);color:var(--danger);border:1px solid rgba(232,64,64,.18);}
.alert-warning{background:rgba(244,196,48,.1);color:#9a7100;border:1px solid rgba(244,196,48,.25);}
/* ── LOADING SCREEN ─────────────────────────────────── */
#loading-screen{position:fixed;inset:0;background:rgba(15,37,64,.88);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:99998;flex-direction:column;gap:16px;}
#loading-screen.hidden{display:none;}
.spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.15);border-top-color:#8b1a1a;border-radius:50%;animation:spin .7s linear infinite;}
.loading-text{color:#fff;font-size:15px;font-weight:600;letter-spacing:.5px;}
@keyframes spin{to{transform:rotate(360deg);}}
#toast-container{position:fixed;bottom:22px;left:22px;z-index:9999;display:flex;flex-direction:column;gap:9px;}
.toast{background:var(--primary);color:#fff;padding:12px 16px;border-radius:10px;font-size:13.5px;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.2);display:flex;align-items:center;gap:9px;animation:toastIn .28s cubic-bezier(.4,1.3,.6,1);min-width:240px;max-width:340px;}
.toast.success{background:var(--success);}
.toast.error{background:var(--danger);}
.toast.warning{background:#c07800;}
@keyframes toastIn{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}

/* ── CONFIRM MODAL ──────────────────────────────── */
.confirm-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 16px;}
.confirm-title{font-size:18px;font-weight:800;text-align:center;color:var(--text);margin-bottom:8px;}
.confirm-msg{font-size:13.5px;text-align:center;color:var(--text-muted);line-height:1.6;}

/* ── EMPTY STATE ────────────────────────────────── */
.empty-state{text-align:center;padding:50px 20px;color:var(--text-muted);}
.empty-state i{font-size:52px;opacity:.15;margin-bottom:14px;display:block;}
.empty-state h3{font-size:17px;font-weight:700;margin-bottom:6px;}
.empty-state p{font-size:13px;}

/* ── REPORTS ────────────────────────────────────── */
.report-filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px;background:var(--card);padding:14px 18px;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);}

/* ── MISC ───────────────────────────────────────── */
/* Two-column block in modals (large screens only) */
.stats-detail-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.stats-detail-two-col > div{min-width:0;overflow:hidden;}
.highlight{background:rgba(255,220,0,.3);border-radius:2px;}
@media print{#sidebar,.topbar,.table-controls,.action-btns,.pagination,#login-screen{display:none!important;}body{background:#fff;}.content{padding:0;}}

/* ═══════════════════════════════════════════════════
   RESPONSIVE — Mobile & Tablet
   ═══════════════════════════════════════════════════ */

/* ── Hamburger button ── */
#menu-toggle{display:flex;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:var(--primary);font-size:20px;line-height:1;transition:background .15s;}
#menu-toggle:hover{background:var(--bg);}

/* ── Sidebar overlay (mobile only) ── */
#sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:99;backdrop-filter:blur(2px);}
#sidebar-overlay.active{display:block;}

/* ── Mini sidebar (desktop — icons only) ── */
#sidebar.mini{width:62px;min-width:62px;}
#sidebar.mini .logo-text{display:none;}
#sidebar.mini .sidebar-logo{justify-content:center;padding:16px 8px;}
#sidebar.mini .nav-section-title{display:none;}
#sidebar.mini .nav-item{justify-content:center;padding:10px 8px;}
#sidebar.mini .nav-item span{display:none;}
#sidebar.mini .nav-item i{width:auto;font-size:16px;}
#sidebar.mini .nav-badge{display:none;}
#sidebar.mini .sidebar-footer{padding:8px;}
#sidebar.mini .sidebar-footer .btn span{display:none;}
#sidebar.mini .nav-parent{justify-content:center;padding:10px 8px;}
#sidebar.mini .nav-parent span{display:none;}
#sidebar.mini .nav-parent .nav-chevron{display:none;}
#sidebar.mini .nav-sub{display:none !important;}

/* ═══════ TABLET (max 1024px) ═══════ */
@media (max-width:1024px){
  #sidebar{width:230px;min-width:230px;}
  .content{padding:16px 18px;}
  .stats-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));}
  .form-grid.g2{grid-template-columns:1fr 1fr;}
  .modal .modal-body{padding:16px 18px;}
}

/* ═══════ MOBILE (max 768px) ═══════ */
@media (max-width:768px){

  /* Layout */
  body{flex-direction:column;overflow-x:hidden;}
  #menu-toggle{display:flex;}
  #main{width:100%;min-width:0;}

  /* Sidebar — drawer */
  #sidebar{
    position:fixed;top:0;right:0;height:100vh;
    width:220px;min-width:220px;
    z-index:100;
    transform:translateX(100%);
    transition:transform .28s cubic-bezier(.4,0,.2,1);
  }
  #sidebar.open{transform:translateX(0);}

  /* Topbar */
  .topbar{padding:10px 14px;gap:8px;}
  .topbar-title{font-size:14px;}
  .user-name-sm{display:none;}
  .user-role-sm{display:none;}
  .user-btn{padding:6px 8px;}
  .user-dropdown{left:auto;right:0;min-width:200px;}

  /* Content */
  .content{padding:12px 10px;}

  /* Stats */
  .stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
  .stat-card{padding:14px 12px;gap:10px;}
  .stat-icon{width:38px;height:38px;font-size:15px;}
  .stat-info h3{font-size:18px;}

  /* Tables */
  table{min-width:900px;}
  .tbl-clients{min-width:600px;}

  /* Table controls */
  .table-controls{flex-wrap:wrap;gap:6px;padding:10px;}
  .table-controls .search-box{width:100%;order:-1;}
  .filter-select{font-size:12px;padding:6px 8px;}

  /* Forms */
  .form-grid.g2,.form-grid,.form-grid.g4{grid-template-columns:1fr 1fr!important;}
  .form-grid .span4{grid-column:span 2!important;}
  .form-grid .span3{grid-column:span 2!important;}
  .form-grid .span2{grid-column:span 2!important;}
  .form-grid .section-title{grid-column:1/-1!important;}
  .form-grid.g2{grid-template-columns:1fr 1fr!important;}

  /* Modals */
  .modal-overlay{align-items:flex-end;padding:0;}
  .modal,.modal.sm,.modal.md{
    width:100%!important;max-width:100%!important;
    border-radius:20px 20px 0 0;
    max-height:90vh;
    overflow-y:auto;
    margin:0;
  }
  .modal-header{padding:16px 18px 14px;}
  .modal-body{padding:14px 18px;}
  .modal-footer{padding:12px 18px 20px;flex-direction:column;gap:8px;}
  .modal-footer .btn{width:100%;justify-content:center;}

  /* Buttons */
  .btn{font-size:13px;padding:8px 14px;}
  .btn-sm{padding:5px 10px;font-size:11px;}

  /* Charts */
  .charts-row{flex-direction:column;gap:14px;}
  .chart-card{width:100%!important;}

  /* Schedule cards */
  .schedule-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));}

  /* Users grid */
  .users-grid,.grid-2{grid-template-columns:1fr!important;}

  /* Log items */
  .log-item{flex-wrap:wrap;}
  .log-time{font-size:10px;}

  /* Login */
  .login-card{padding:28px 20px;border-radius:16px;max-width:100%;}
  #login-screen{padding:12px;}

  /* Page title on mobile */
  .page-section > h2{font-size:15px;}

  /* Pagination */
  .pagination{flex-direction:column;gap:8px;align-items:center;}
  .pagination-info{text-align:center;}

  /* Nav badge */
  .nav-badge{font-size:10px;padding:1px 6px;}

  /* Booking table action buttons */
  .action-btns{flex-direction:column;gap:3px;}

  /* Report filter bar */
  .report-filter-bar{flex-direction:column;align-items:stretch;gap:8px;}
  .report-filter-bar .btn{justify-content:center;}
  .stats-detail-two-col{grid-template-columns:1fr;}
}

/* ═══════ SMALL MOBILE (max 480px) ═══════ */
@media (max-width:480px){
  .user-dropdown{position:fixed!important;top:54px!important;left:6px!important;right:auto!important;max-width:calc(100vw - 12px);min-width:180px;}
  .stats-grid{grid-template-columns:repeat(6,1fr);gap:8px;}
  .stats-grid .stat-card:nth-child(-n+4){grid-column:span 3;}
  .stats-grid .stat-card:nth-child(n+5){grid-column:span 2;}
  .charts-row{grid-template-columns:1fr !important;}
  #page-stats .stats-grid{grid-template-columns:1fr !important;}
  #page-stats .stats-grid .stat-card{grid-column:auto !important;}
  #page-bookings .table-controls{flex-wrap:wrap;gap:6px;}
  #page-bookings .table-controls .search-box{width:100%;order:-1;}
  #page-bookings .table-controls #filter-status,
  #page-bookings .table-controls #filter-type,
  #page-bookings .table-controls .date-wrap,
  #page-bookings .table-controls .btn.btn-outline.btn-sm{flex:1 1 auto;min-width:0;}
  #page-bookings .table-controls #btn-add-booking{order:10;margin-top:4px;}
  .upcoming-item{padding:6px 8px;gap:7px;}
  .upcoming-time{min-width:40px;padding:4px;}
  .upcoming-time .time{font-size:11px;}
  .upcoming-info h4{font-size:11px;}
  .upcoming-info p{font-size:9px;}
  #schedule-cards{grid-template-columns:repeat(6,1fr)!important;gap:6px;}
  #schedule-cards>div:nth-child(-n+4){grid-column:span 3;}
  #schedule-cards>div:nth-child(n+5){grid-column:span 2;}
  .form-grid,.form-grid.g2,.form-grid.g4{grid-template-columns:1fr 1fr!important;gap:8px;}
  .form-grid .section-title{grid-column:1/-1!important;}
  .form-grid .span4{grid-column:span 2!important;}
  .form-grid .span3{grid-column:span 2!important;}
  .form-grid .span2{grid-column:span 1!important;}
  .form-grid .form-group:has(textarea){grid-column:span 2!important;}
  /* الموعد والكميات في مودال الحجز — موبايل صغير */
  #booking-date-qty-row{flex-wrap:wrap;gap:8px!important;}
  #booking-date-qty-row>.form-group:nth-child(1),
  #booking-date-qty-row>.form-group:nth-child(2){flex:0 0 calc(50% - 4px)!important;min-width:0;}
  #booking-date-qty-row>.form-group:nth-child(n+3){flex:1 1 calc(25% - 6px)!important;min-width:60px;}
  #booking-date-qty-row>.form-group:nth-child(n+3) input{width:100%!important;}
  .stat-card{padding:12px;}
  .content{padding:8px 6px;}
  .topbar{padding:8px 10px;}
  .modal,.modal.sm,.modal.md{max-height:95vh;}
  table{min-width:800px;}
}
/* ── Schedule card: time row + collection indicator ── */
.sc-time-row{display:flex;align-items:center;justify-content:space-between;gap:4px;}
.sc-col-badge{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:700;flex-shrink:0;}
.sc-col-ok{color:var(--success);}
.sc-col-stop{color:var(--danger);}
.sc-col-num{font-weight: 800;background: rgba(232, 135, 26, .12);color: #b88a00;font-size: 15px;padding: 2px 6px;border-radius: 20px;}
body.dark .sc-col-num{color:var(--warning);}
/* ── Collection Modal Radio Buttons ── */
.col-radio-group{display:flex;flex-direction:column;gap:8px;}
.col-radio-opt{display:flex;cursor:pointer;}
.col-radio-opt input[type="radio"]{position:absolute;opacity:0;width:0;height:0;}
.col-radio-box{display:flex;align-items:center;gap:8px;padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:600;width:100%;transition:all .15s;color:var(--text);background:var(--bg);}
.col-radio-opt input:checked + .col-radio-box{border-width:2px;}
.col-radio-opt input:checked + .col-ok{border-color:var(--success);background:rgba(26,171,92,.08);color:var(--success);}
.col-radio-opt input:checked + .col-stop{border-color:var(--danger);background:rgba(232,64,64,.08);color:var(--danger);}
.col-radio-opt input:checked + .col-qty{border-color:var(--warning);background:rgba(244,196,48,.1);color:#9a7100;}
.col-radio-box:hover{border-color:var(--primary-light);}
body.dark .col-radio-box{background:var(--card);}

/* ══════════════════════════════════════════════════════════════
   FIELD TESTS — مراقبو المواقع
══════════════════════════════════════════════════════════════ */

/* صفحة الاختبارات — نفس grid الجدول اليومي */
#fieldtest-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;}
.ft-locked-card{pointer-events:none;}

/* ── المودال — أزرار وحقول ──────────────────────────────────── */
.ft-add-btn{
  border-style:dashed !important;
  color:var(--text-muted) !important;
  border-color:var(--border) !important;
}
.ft-add-btn:hover{border-color:var(--accent) !important;color:var(--accent) !important;}
.ft-del-btn{
  background:rgba(232,64,64,.08) !important;
  color:var(--danger) !important;
  border:1px solid rgba(232,64,64,.2) !important;
  width:32px;height:32px;padding:0 !important;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.ft-del-btn:hover{background:rgba(232,64,64,.18) !important;}
.ft-inp{
  height:36px;font-size:13px;padding:0 10px;
  border-radius:var(--radius-sm);
  border:1.5px solid var(--border);
  background:var(--bg);color:var(--text);
  transition:border-color .2s;width:90%;box-sizing:border-box;
}
.ft-inp:focus{outline:none;border-color:var(--primary-light);background:var(--card);}
body.dark .ft-inp{background:var(--bg);color:var(--text);}

/* ── responsive mobile ────────────────────────────────────────── */
@media(max-width:600px){
  #fieldtest-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));}
  /* جميع الأقسام (2 حقول + زر) في صف واحد */
  .ft-row{grid-template-columns:1fr 1fr auto !important;}
}

