/* Dark RTL CRM */
:root{--bg:#0b0b0e;--card:rgba(255,255,255,.06);--border:rgba(255,255,255,.12);--text:#f2f2f2;--muted:#b8b8b8;--red:#b30000;--shadow:0 18px 40px rgba(0,0,0,.45);--radius:18px;--max:1360px;--mono:ui-monospace,Menlo,Consolas,monospace;--font:"Tajawal","Cairo",system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Kufi Arabic","Noto Sans Arabic",Tahoma,sans-serif;}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;}
html,body{height:100%}
body{margin:0;font-family:var(--font);font-size:15px;direction:rtl;background:radial-gradient(1100px 650px at 10% 10%, rgba(179,0,0,.25), transparent 55%),radial-gradient(900px 500px at 90% 20%, rgba(255,42,42,.12), transparent 60%),linear-gradient(180deg,#050507,#0b0b0e 55%,#050507);color:var(--text);overflow-x:hidden;overscroll-behavior:contain;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);line-height:1.55;}
a{color:#ffd1d1;text-decoration:none}a:hover{text-decoration:underline}
.container{max-width:var(--max);margin:18px auto;padding:0 18px;}
.header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;background:linear-gradient(135deg, rgba(0,0,0,.72), rgba(179,0,0,.35));border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);}
.brand{display:flex;align-items:center;gap:10px;}
.badge{width:44px;height:44px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.18), rgba(179,0,0,.55));border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;font-weight:900}
.brand h1{margin:0;font-size:20px;letter-spacing:.2px}.brand .sub{margin-top:2px;color:var(--muted);font-size:13px}
.nav{display:none;flex-direction:column;gap:8px;align-items:stretch;justify-content:flex-start;width:100%;flex:0 0 100%;min-width:100%}
.nav.open{display:flex}
.nav a{padding:9px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.26);font-size:13px;line-height:1;white-space:nowrap;transition:transform .08s ease, background .15s ease, border-color .15s ease;display:flex;align-items:center;gap:8px}
.nav .nav-ico{width:26px;min-width:26px;height:26px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);display:inline-flex;align-items:center;justify-content:center;opacity:.95}
.nav .nav-ico i{font-size:18px;line-height:1}
.nav .nav-txt{display:inline-block}
.nav a:hover{background:rgba(179,0,0,.18)}
.nav a:active{transform:scale(.98)}
.nav a.active{border-color:rgba(179,0,0,.55);background:linear-gradient(135deg, rgba(179,0,0,.55), rgba(0,0,0,.22));box-shadow:0 10px 24px rgba(0,0,0,.35)}
.nav a.active .nav-ico{background:rgba(179,0,0,.22);border-color:rgba(179,0,0,.45)}
.nav a.logout{padding:9px 12px;border-radius:12px;border:1px solid rgba(255,42,42,.35);background:rgba(179,0,0,.18);font-weight:900;line-height:1;display:flex;align-items:center;gap:8px;justify-content:center}
.nav a.logout:hover{background:rgba(179,0,0,.26)}

/* Top menu button (hamburger) */
.menu-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.26);cursor:pointer;transition:transform .08s ease, background .15s ease, border-color .15s ease}
.menu-btn:hover{background:rgba(179,0,0,.14)}
.menu-btn:active{transform:scale(.98)}
.menu-icon{width:18px;height:2px;border-radius:2px;background:rgba(255,255,255,.85);display:block;box-shadow:0 5px 0 rgba(255,255,255,.85),0 10px 0 rgba(255,255,255,.85)}

/* Section sub-navigation (employee) */
.subnav-wrap{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:10px}
.subnav-toggle{display:none;align-items:center;justify-content:center;gap:10px;padding:10px 12px;min-height:42px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.26);color:var(--text);cursor:pointer;font-weight:900;font-size:13px;line-height:1;transition:transform .08s ease, background .15s ease, border-color .15s ease}
.subnav-toggle:hover{background:rgba(179,0,0,.14)}
.subnav-toggle:active{transform:scale(.98)}
.subnav-title{color:var(--text)}
.subnav{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.subnav a{padding:8px 10px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.22);font-size:13px}
.subnav a:hover{background:rgba(179,0,0,.14)}
.subnav a.active{border-color:rgba(179,0,0,.55);background:rgba(179,0,0,.18)}
.card{margin-top:14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card-h{padding:14px 16px;background:linear-gradient(135deg, rgba(0,0,0,.62), rgba(179,0,0,.25));border-bottom:1px solid rgba(255,255,255,.10);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-b{padding:14px 16px}
h2{margin:0;font-size:16px}
.muted{color:var(--muted)}
.grid{display:grid;gap:12px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.grid-2,.grid-3{grid-template-columns:1fr}.grid-4{grid-template-columns:1fr}}

/* Dashboard filters: responsive (4 per row on desktop, 2-3 per row on mobile) */
.dash-filters{display:grid;gap:12px;align-items:end;grid-template-columns:repeat(4,minmax(0,1fr))}
/* Ensure filter inputs don't overflow their grid cells */
.dash-filters .input{width:100%;max-width:100%;}

@media(max-width:992px){.dash-filters{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){.dash-filters{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}}
.dash-filters .span-all{grid-column:1/-1;display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-start}
/* Admin filter full-width on mobile only */
@media(max-width:720px){.dash-filters .mobile-full{grid-column:1/-1}}

/* Dashboard filters: tighten date inputs on mobile (avoid overlap) */
@media(max-width:720px){
  .dash-filters > div{min-width:0}
  .dash-filters input,.dash-filters select{min-width:0}
  .dash-filters input[type="date"]{padding:8px 10px;font-size:13px;line-height:1.2}
}


/* Comparison KPI (with side strip) */
.compare-card{display:flex;gap:12px;align-items:stretch;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.25);box-shadow:0 14px 28px rgba(0,0,0,.22)}
.compare-card .strip{width:6px;border-radius:999px;background:rgba(255,255,255,.18)}
.compare-card.up .strip{background:rgba(34,197,94,.55)}
.compare-card.down .strip{background:rgba(255,42,42,.55)}
.compare-card.flat .strip{background:rgba(255,255,255,.22)}
.compare-card .cmp-body{display:flex;flex-direction:column;gap:4px;min-width:0}
.compare-card .k{color:var(--muted);font-size:12px}
.compare-card .v{font-size:22px;font-weight:950;line-height:1.15}
label{display:block;font-size:12px;color:var(--muted);margin:0 0 6px}
.input,select,textarea{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.35);color:var(--text);outline:none}
textarea{min-height:90px;resize:vertical}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* Filter rows (compact, non-full-width fields) */
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.filters .f{flex:1 1 220px;min-width:180px;max-width:340px}
.filters .f-sm{flex:0 1 170px;min-width:150px;max-width:210px}
.filters-actions{flex:1 1 100%;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn-grid{display:flex;gap:10px;flex-wrap:wrap;align-items:stretch}
.btn-grid .btn{flex:1 1 160px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 13px;min-height:42px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.35);color:var(--text);cursor:pointer;font-weight:900;font-size:13px;line-height:1;white-space:nowrap;transition:transform .08s ease, background .15s ease, border-color .15s ease}
.btn:hover{background:rgba(255,255,255,.06)}
.btn:active{transform:scale(.98)}
.btn.primary{background:linear-gradient(135deg, rgba(179,0,0,.85), rgba(255,42,42,.45))}
.btn.danger{background:rgba(179,0,0,.22);border-color:rgba(255,42,42,.35)}
.btn.success{background:rgba(34,197,94,.22);border-color:rgba(34,197,94,.35)}
.btn.warn{background:rgba(245,158,11,.20);border-color:rgba(245,158,11,.35)}
.btn.info{background:rgba(59,130,246,.20);border-color:rgba(59,130,246,.35)}
.btn.purple{background:rgba(168,85,247,.20);border-color:rgba(168,85,247,.35)}
.btn.wa{background:rgba(34,197,94,.22);border-color:rgba(34,197,94,.35)}

.btn:disabled{opacity:.6;cursor:not-allowed}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid rgba(255,255,255,.08);font-size:13px;vertical-align:top}
.table th{text-align:right;background:rgba(0,0,0,.35);position:sticky;top:0}
.actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.actions form{margin:0;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.actions .btn{min-height:40px;padding:10px 12px}
.actions .input{width:auto}
.pill{display:inline-block;padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.30);font-size:12px}
.pill.red{background:rgba(179,0,0,.25)}
.flash{padding:10px 12px;border-radius:12px;margin:12px 0;border:1px solid rgba(255,255,255,.14)}
.flash.ok{background:rgba(0,160,80,.12);border-color:rgba(0,160,80,.22)}
.flash.err{background:rgba(179,0,0,.14);border-color:rgba(255,42,42,.22)}

.stat{padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.25);box-shadow:0 14px 28px rgba(0,0,0,.22)}
.stat:hover{border-color:rgba(255,255,255,.18)}
.stat .k{color:var(--muted);font-size:12px;margin-bottom:6px}
.stat .v{font-size:22px;font-weight:950}
.kpi{display:flex;gap:10px;flex-wrap:wrap}
.box{flex:1;min-width:170px;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.25);box-shadow:0 14px 28px rgba(0,0,0,.25)}
.box:hover{border-color:rgba(255,255,255,.18)}
.kpi .n{font-size:22px;font-weight:950}
.kpi .t{color:var(--muted);font-size:12px}
.sep{border:none;border-top:1px solid rgba(255,255,255,.10);margin:14px 0}
.footer{color:rgba(255,255,255,.45);font-size:12px;padding:16px 0 32px;text-align:center}
.footer-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.footer-credit{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.22);color:rgba(255,255,255,.75);text-decoration:none;line-height:1.2;max-width:100%}
.footer-credit:hover{background:rgba(0,0,0,.32);border-color:rgba(255,255,255,.18);text-decoration:none}
.footer-credit-logo{width:28px;height:28px;border-radius:999px;background:#000;border:1px solid rgba(255,255,255,.14);display:grid;place-items:center;flex:0 0 28px}
.footer-credit-logo img{width:18px;height:18px;object-fit:contain;display:block}
.footer-credit-txt{font-size:12px;white-space:nowrap}
.footer-credit-txt b{color:#fff}

/* Tables wrapper for mobile */
.table-wrap{overflow:auto;-webkit-overflow-scrolling:touch;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.20)}
.table-wrap .table{min-width:720px}
code{font-family:var(--mono)}

/* Dashboard charts (PowerBI-like) */
.chart-wrap{height:260px;min-height:220px;}
.chart-wrap canvas{width:100% !important;height:100% !important;}

@media (min-width:900px){.nav{overflow:visible;white-space:normal}}

/* Responsive polish */
@media (max-width:720px){
  .container{padding:0 12px}
  .header{padding:14px 14px;position:sticky;top:0;z-index:50;backdrop-filter:blur(10px)}
  .brand h1{font-size:18px}
  .menu-btn{display:inline-flex}
  .nav{display:none;justify-content:flex-start;width:100%;flex-direction:column;align-items:stretch;gap:8px;min-width:100%}
  .nav.open{display:flex}
  .nav a{padding:12px 12px}
  .nav a.logout{width:100%;text-align:center}
  .nav .btn{width:auto}

  .subnav-wrap{width:100%}
  .subnav-toggle{display:flex;width:100%;justify-content:flex-start}
  .subnav{display:none;flex-direction:column;align-items:stretch;width:100%}
  .subnav.open{display:flex}
  .subnav a{padding:12px 12px}
  .row{gap:8px}
  .row .btn{flex:1 1 46%}
  .row .input{flex:1 1 100%}
  .filters .f{flex:1 1 100%;max-width:none}
  .filters .f-sm{flex:1 1 46%;max-width:none}
  .filters-actions .btn{flex:1 1 46%}
  .btn-grid .btn{flex:1 1 46%}

  /* Prevent iOS zoom on focus */
  .input,select,textarea{font-size:16px}

  /* Tighter buttons inside tables */
  .table .btn{min-height:38px;padding:10px 10px;font-size:12px}
}

@media (min-width:1200px){
  .container{padding:0 22px}
}


/* ==== Branding banner overrides (ExXxcellency) ==== */
.brand{flex:1;min-width:220px;gap:12px}
.brand-meta{display:flex;flex-direction:column;justify-content:center;min-width:120px}
.brand-bubble{
  /*
    Mobile/Safari-safe sizing:
    We intentionally avoid clamp() here to prevent edge cases where
    unsupported CSS functions make the bubble/image blow up on mobile.
  */
  width:280px;
  max-width:68vw;
  min-width:180px;
  height:62px;
  max-height:84px;
  border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:8px 12px;
}
.brand-logo{
  /* Keep the logo contained without stretching */
  width:auto;
  height:auto;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  display:block;
}
.brand-placeholder{
  font-weight:800;
  color:rgba(255,255,255,.75);
  font-size:14px;
}

@media (max-width: 520px){
  .brand-bubble{max-width:78vw;height:56px;padding:8px 12px;border-radius:16px}
}

/* Prevent old title from showing in banner */
.brand h1{display:none !important;}


/* ===== Desktop Sidebar Layout ===== */
.container.layout{display:block}
.sidebar{display:none}
.page-content{margin-top:14px}

@media (min-width: 992px){
  body{padding:0}
  .container.layout{max-width:none;margin:18px auto;padding:0 18px;display:flex;gap:14px;align-items:flex-start}
  /* Desktop sidebar as a compact "bubble" card */
  .sidebar{display:block;width:clamp(220px, 18vw, 270px);position:sticky;top:18px;align-self:flex-start}
  /* Sidebar bubble: no internal scrollbar (scroll the page instead) */
  .sb-wrap{background:var(--card);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow);padding:12px;overflow:visible;max-height:none}
  .main{flex:1;min-width:0}
  /* Hide mobile header nav on desktop */
  .header .menu-btn{display:none!important}
  .header .nav{display:none!important}
}

/* Sidebar brand */
.sb-brand{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08)}
.sb-bubble{width:44px;height:44px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(179,0,0,.55), rgba(0,0,0,.35));display:grid;place-items:center;overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.sb-logo{width:100%;height:100%;object-fit:cover;display:block}
.sb-placeholder{font-size:10px;color:rgba(255,255,255,.7);text-align:center;padding:0 6px}
.sb-meta{min-width:0}
.sb-app{font-weight:800;font-size:14px;line-height:1.1}
.sb-user{color:rgba(255,255,255,.70);font-size:12px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Sidebar nav */
.sb-nav{display:flex;flex-direction:column;gap:8px}
.sb-link{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22);display:flex;align-items:center;gap:10px;transition:transform .08s ease, background .15s ease, border-color .15s ease}
.sb-link:hover{background:rgba(179,0,0,.14)}
.sb-link:active{transform:scale(.99)}
.sb-link.active{border-color:rgba(179,0,0,.55);background:linear-gradient(135deg, rgba(179,0,0,.22), rgba(0,0,0,.22))}
.sb-ico{width:28px;min-width:28px;height:28px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);display:inline-flex;align-items:center;justify-content:center;opacity:.95;color:rgba(255,255,255,.88)}
.sb-ico i{font-size:18px;line-height:1}
.sb-link.active .sb-ico{background:rgba(179,0,0,.22);border-color:rgba(179,0,0,.45);color:#fff}
.sb-txt{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:20px;padding:0 7px;border-radius:999px;background:var(--red);color:#fff;font-size:12px;font-weight:800;line-height:1;box-shadow:0 10px 22px rgba(0,0,0,.35)}

.sb-sep{height:1px;background:rgba(255,255,255,.08);margin:6px 0}
.sb-logout{justify-content:center}

/* Accordion groups */
.sb-group{border:1px solid rgba(255,255,255,.10);border-radius:14px;background:rgba(0,0,0,.18);overflow:hidden}
.sb-group-btn{width:100%;padding:10px 12px;background:transparent;border:0;color:var(--text);display:flex;align-items:center;gap:10px;cursor:pointer}
.sb-group-btn:hover{background:rgba(179,0,0,.10)}
.sb-caret{opacity:.75;transform:rotate(0deg);transition:transform .15s ease;margin-inline-start:auto}
.sb-items{display:none;flex-direction:column;gap:6px;padding:0 10px 10px}
.sb-items .sb-link{border-radius:12px;background:rgba(0,0,0,.22)}
.sb-group.open .sb-items{display:flex}
.sb-group.open .sb-caret{transform:rotate(180deg)}


/* OVERRIDE: make date filters narrower on mobile */
@media(max-width:720px){
  .dash-filters{gap:10px}
  .dash-filters .input{width:100%;max-width:100%}
  .dash-filters input,.dash-filters select{min-width:0;max-width:100%}
  .dash-filters input[type="date"]{padding:5px 7px;font-size:12px;line-height:1.1}
  .dash-filters input[type="date"]::-webkit-calendar-picker-indicator{margin:0;padding:0;opacity:.75}
}


/* Dashboard - make date inputs same width as selects on mobile */
@media (max-width: 768px){
  .dash-filters *,
  .dash-filters .filter-item{
    min-width: 0 !important;            /* prevent overflow forcing wide items */
  }

  .dash-filters input[type="date"]{
    width: 100% !important;             /* match select width */
    max-width: 100% !important;
    box-sizing: border-box !important;
    min-width: 0 !important;

    height: 38px !important;
    padding: 8px 10px !important;
    font-size: 13px !important;
    line-height: 1.2 !important;

    max-inline-size: 100% !important;
    appearance: none;
    -webkit-appearance: none;
  }
}


/* Searchable select */
.search-select{position:relative}
.search-select-menu{display:none;position:absolute;top:calc(100% + 6px);right:0;left:0;z-index:40;max-height:240px;overflow:auto;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(10,10,14,.98);box-shadow:0 18px 40px rgba(0,0,0,.45);padding:6px}
.search-select-menu.open{display:block}
.search-select-menu.empty:before{content:'لا توجد نتائج';display:block;padding:10px 12px;color:var(--muted)}
.search-select-option{display:block;width:100%;text-align:right;padding:10px 12px;border:0;background:transparent;color:var(--text);border-radius:10px;cursor:pointer;font:inherit}
.search-select-option:hover,.search-select-option.active{background:rgba(179,0,0,.16)}
.search-select-option.is-empty{color:var(--muted)}
