/* ============================================================
   Mowasat Report Portal – shared stylesheet
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* Android PWA: replace grey tap-highlight with brand colour (transparent removes all feedback on Android) */
*{-webkit-tap-highlight-color:rgba(0,105,148,.18)}
/* Eliminate 300ms touch delay on ALL interactive elements globally */
a,button,input,label,select,textarea,[role="button"],[role="tab"],[role="menuitem"],[role="option"],[tabindex]{touch-action:manipulation}
:root{
  --brand:#006994; --brand2:#00a5cf; --brand-dk:#004d6e; --brand-green:#009BA4;
  --bg:#f0f4f8; --card:#fff; --txt:#1a2733; --muted:#5a7184;
  --border:#dde4ec; --r-card:16px; --r-btn:10px;
  --shadow:0 4px 24px rgba(0,0,0,.08); --t:.18s ease;
  --avail:#0d9467; --avail-bg:#ecfdf5; --avail-bd:#6ee7b7;
  --miss:#6b7280;  --miss-bg:#f3f4f6;  --miss-bd:#d1d5db;
  --warn:#d97706;  --warn-bg:#fffbeb;  --warn-bd:#fcd34d;
  --err:#dc2626;   --err-bg:#fef2f2;   --err-bd:#fca5a5;
  --ok:#0d9467;    --info:#1d4ed8;
}
/* Sticky-footer layout — body is flex column.  Use min-height not height so
   page scrolls when content overflows (Android Chrome breaks scroll with
   `height:100vh`).  100dvh accounts for the dynamic browser toolbar; 100vh
   stays as fallback for older browsers.  Avoid `overflow-x:hidden` here; it
   can lock vertical scroll on certain Android builds. */
html{min-height:100%;overflow-x:clip}
body{
  font-family:'Inter','Cairo',sans-serif;
  background:var(--bg);color:var(--txt);
  display:flex;flex-direction:column;
  width:100%;max-width:100%;
  min-height:100vh;
  min-height:100dvh;
  overflow-x:clip;
}
.wrap{flex:1 0 auto;max-width:100%}
.ar{font-family:'Cairo',sans-serif}

/* ---------- Header ---------- */
.hdr{background:linear-gradient(rgba(251,253,255,.84),rgba(243,248,252,.9)),url('../../nav-bg.png') center/cover no-repeat;border-bottom:1px solid #d7e5ef;box-shadow:0 8px 24px rgba(0,73,110,.08)}
.hdr-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:20px;padding:14px 24px;flex-wrap:wrap}
.logo-wrap{display:flex;align-items:center;text-decoration:none}
.logo-img{height:48px;width:auto;max-width:260px;object-fit:contain}

.topnav{flex:1}
.topnav ul{list-style:none;display:flex;gap:4px;flex-wrap:wrap;justify-content:center}
.topnav a{display:inline-block;padding:8px 14px;border-radius:8px;color:var(--txt);text-decoration:none;font-weight:500;font-size:.88rem;transition:background var(--t),color var(--t);touch-action:manipulation}
.topnav a:hover{background:rgba(0,105,148,.08);color:var(--brand)}
.topnav li.active a{background:var(--brand);color:#fff}
.topnav .ar{font-size:.76rem;opacity:.75;margin-inline-start:4px}

.user-menu{position:relative}
.user-btn{background:#fff;border:1px solid var(--border);border-radius:999px;padding:4px 14px 4px 4px;display:flex;align-items:center;gap:8px;cursor:pointer;font:inherit;color:var(--txt);touch-action:manipulation;user-select:none;-webkit-user-select:none}
.user-btn:hover{border-color:var(--brand2)}
.avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;background:#eee}
.uname{font-weight:600;font-size:.85rem}
.caret{color:var(--muted);font-size:.75rem}
.user-dd{display:none;position:absolute;top:110%;right:0;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);min-width:240px;padding:8px 0;z-index:50}
.user-dd.open{display:block}
.user-dd a{display:block;padding:9px 16px;text-decoration:none;color:var(--txt);font-size:.88rem}
.user-dd a:hover{background:#f0f4f8;color:var(--brand)}
.user-dd-head{padding:10px 16px 8px;border-bottom:1px solid var(--border);margin-bottom:4px}
.user-dd-name{font-weight:600;font-size:.9rem}
.user-dd-meta{font-size:.75rem;color:var(--muted);margin-top:2px}
.user-dd-sep{height:1px;background:var(--border);margin:4px 0}

/* ---------- Container ---------- */
.wrap{max-width:1100px;margin:0 auto;padding:28px 16px 0}
.wrap.narrow{max-width:540px}

/* ---------- Flash ---------- */
.flash{padding:12px 16px;border-radius:10px;margin-bottom:16px;font-size:.9rem}
.flash-ok{background:var(--avail-bg);color:var(--ok);border:1px solid var(--avail-bd)}
.flash-warn{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn-bd)}
.flash-err{background:var(--err-bg);color:var(--err);border:1px solid var(--err-bd)}
.flash-info{background:#eff6ff;color:var(--info);border:1px solid #bfdbfe}

/* ---------- Cards / forms ---------- */
.card{background:var(--card);border-radius:var(--r-card);box-shadow:var(--shadow);border:1px solid var(--border);padding:26px 24px;margin-bottom:22px}
.card h1{font-size:1.4rem;font-weight:700;color:var(--brand);margin-bottom:14px}
.card h2{font-size:1.1rem;font-weight:600;color:var(--txt);margin:18px 0 10px}
.card p{color:var(--muted);line-height:1.6;margin-bottom:10px}

.field{margin-bottom:14px}
.field label{display:block;font-weight:600;font-size:.84rem;margin-bottom:6px}
.input,.select,.textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r-btn);font:inherit;font-size:.95rem;color:var(--txt);background:#f8fafc;outline:none;transition:border-color var(--t),box-shadow var(--t)}
.input:focus,.select:focus,.textarea:focus{border-color:var(--brand2);box-shadow:0 0 0 3px rgba(0,165,207,.15);background:#fff}
.textarea{resize:vertical;min-height:90px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 22px;border-radius:var(--r-btn);font-weight:600;font-size:.9rem;cursor:pointer;border:none;text-decoration:none;transition:background var(--t),color var(--t),transform var(--t);touch-action:manipulation;user-select:none;-webkit-user-select:none}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand2)}
.btn-secondary{background:#f0f4f8;color:var(--txt);border:1px solid var(--border)}
.btn-secondary:hover{background:#e2e8f0}
.btn-danger{background:var(--err);color:#fff}
.btn-danger:hover{background:#b91c1c}
.btn-sm{padding:6px 12px;font-size:.8rem}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:640px){.grid-2{grid-template-columns:1fr}}

/* ---------- Tables ---------- */
.tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}
.tbl th,.tbl td{padding:11px 14px;text-align:left;font-size:.88rem;border-bottom:1px solid var(--border)}
.tbl th{background:#f8fafc;font-weight:600;color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.4px}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:#f8fafc}
.tbl .actions{text-align:right;white-space:nowrap}

/* ---------- Footer (sticky at viewport bottom, brand gradient bg) ---------- */
footer{
  flex-shrink:0;margin-top:auto;
  background:linear-gradient(135deg,#009BA4,var(--brand-dk,#004d6e));
  color:rgba(255,255,255,.92);
  text-align:center;font-size:.85rem;line-height:1.7;
  padding:24px 16px calc(24px + env(safe-area-inset-bottom,0px));
}
footer p{margin:4px 0}
footer a,footer .nmhlink{color:#fff !important;text-decoration:none;font-weight:600}
footer a:hover,footer .nmhlink:hover{text-decoration:underline !important}

/* ---------- Mobile responsiveness — defensive global rules ----------
   Same defence-in-depth as patient portal: prevent any horizontal scroll
   from images, long URLs, code, or wide tables.  Cards clip horizontally;
   tables get their own internal scroll. */
img,video,svg,canvas{max-width:100%;height:auto}
pre,code,kbd,samp{overflow-wrap:anywhere;word-break:break-word;white-space:pre-wrap}
a{overflow-wrap:anywhere;word-break:break-word}
.card{max-width:100%;overflow-wrap:break-word}
.card > *{max-width:100%}
.card table,.tbl{width:100%;max-width:100%}
/* Default: tables render normally on desktop, max-width clamped to parent.
   The mobile stack mode below kicks in at <=640px. */
table{max-width:100%}
table.t-stackable{width:100%}

/* ---------- Mobile stack mode (Filament Group pattern) -----------------
   On phones, tables collapse into stacked label/value cards.  thead is
   visually hidden but still readable by screen readers (left:-9999px).
   tables.js auto-attaches data-label attrs so this works without template
   edits.  Opt out per-table via class="t-no-stack". */
@media(max-width:640px){
  table.t-stackable,
  table.t-stackable thead,
  table.t-stackable tbody,
  table.t-stackable tr,
  table.t-stackable td,
  table.t-stackable th{display:block;width:auto}
  table.t-stackable thead{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
  table.t-stackable tbody tr{border:1px solid var(--border);border-radius:10px;padding:10px 14px;margin-bottom:10px;background:#fff;box-shadow:0 1px 3px rgba(15,23,42,.04)}
  table.t-stackable tbody tr:hover td{background:transparent}
  table.t-stackable tbody td{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:7px 0;border:0;border-bottom:1px dashed #eef2f5;font-size:.88rem;text-align:start}
  table.t-stackable tbody td:last-child{border-bottom:0}
  table.t-stackable tbody td::before{
    content:attr(data-label);
    font-weight:700;color:var(--muted);font-size:.68rem;text-transform:uppercase;
    letter-spacing:.5px;flex-shrink:0;min-width:96px;align-self:center;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:45%;
  }
  /* Cells with no label or empty value gracefully degrade */
  table.t-stackable tbody td:not([data-label])::before{content:""}
  /* Preserve action buttons / form controls in cells */
  table.t-stackable tbody td .actions,
  table.t-stackable tbody td .btn,
  table.t-stackable tbody td input,
  table.t-stackable tbody td select{margin-inline-start:auto}
}
/* Tables that opt OUT of stack mode get the horizontal-scroll fallback */
table.t-no-stack{display:block;overflow-x:auto;max-width:100%}
.wrap>*{max-width:100%}
[class*="-grid"]>*,[class*="-stats"]>*,[class*="-row"]>*{min-width:0;max-width:100%}
input,textarea,select{max-width:100%}
h1,h2,h3,h4{overflow-wrap:break-word}
@media(max-width:480px){
  .wrap{padding:18px 12px 0}
  .card{padding:18px 14px}
}

/* ---------- Misc ---------- */
.badge{display:inline-block;padding:3px 9px;border-radius:999px;font-size:.72rem;font-weight:600;background:#f0f4f8;color:var(--muted)}
.badge.ok{background:var(--avail-bg);color:var(--ok);border:1px solid var(--avail-bd)}
.badge.warn{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn-bd)}
.badge.err{background:var(--err-bg);color:var(--err);border:1px solid var(--err-bd)}

.auth-page{min-height:calc(100vh - 160px);display:flex;align-items:center;justify-content:center}
.auth-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--shadow);border:1px solid var(--border);padding:32px 28px;width:100%;max-width:420px}
.auth-card h1{font-size:1.35rem;color:var(--brand);text-align:center;margin-bottom:6px}
.auth-card .sub{text-align:center;color:var(--muted);font-size:.84rem;margin-bottom:20px}
.auth-card .links{text-align:center;margin-top:14px;font-size:.82rem}
.auth-card .links a{color:var(--brand);text-decoration:none}
.auth-card .links a:hover{text-decoration:underline}

.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:20px}
.stat-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px 16px;text-align:center;box-shadow:var(--shadow)}
.stat-val{font-size:1.7rem;font-weight:700;color:var(--brand)}
.stat-lbl{color:var(--muted);font-size:.8rem;margin-top:4px}

.range-picker{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.range-pill{padding:7px 14px;border:1px solid var(--border);border-radius:999px;background:#fff;cursor:pointer;font-size:.82rem;color:var(--txt);text-decoration:none;touch-action:manipulation;user-select:none;-webkit-user-select:none}
.range-pill:hover{border-color:var(--brand2);color:var(--brand)}
.range-pill.active,
.range-pill:has(input[type=radio]:checked){background:var(--brand);color:#fff;border-color:var(--brand)}

.nmhlink{text-decoration:none !important;color:var(--brand)}
.nmhlink:hover{text-decoration:underline !important}

/* ============================================================
   Mobile burger + offcanvas drawer
   ============================================================ */
.show-mobile{display:none !important}
.hide-mobile{display:flex}

.burger{
  width:44px;height:44px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  cursor:pointer;padding:0;
  margin-inline-start:auto;      /* pushes burger to the far right of the header */
  transition:border-color var(--t),box-shadow var(--t),background var(--t);
  touch-action:manipulation;user-select:none;-webkit-user-select:none;
}
.burger:hover{border-color:var(--brand2);background:#f8fafc}
.burger span{
  display:block;width:20px;height:2px;background:var(--txt);border-radius:2px;
  transition:transform .3s cubic-bezier(.4,0,.2,1), opacity .2s ease, background .2s ease;
  transform-origin:center;
}
.burger.open span{background:var(--brand)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Offcanvas overlay */
/* NOTE: backdrop-filter is ONLY applied when open — if present when closed it creates a GPU
   compositing layer on Android Chrome that intercepts touch events even with pointer-events:none */
.oc-overlay{
  position:fixed;inset:0;
  background:rgba(15,23,42,.45);
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
  z-index:150;
}
.oc-overlay.open{
  opacity:1;pointer-events:auto;
  -webkit-backdrop-filter:blur(2px);
  backdrop-filter:blur(2px);
}

/* Offcanvas panel */
.oc{
  position:fixed;top:0;right:0;bottom:0;
  width:320px;max-width:85%;
  background:#fff;
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1),
             box-shadow .2s ease;
  z-index:200;
  display:flex;flex-direction:column;
  overflow:hidden;
  /* no shadow while closed — otherwise it bleeds in from the right edge
     of the viewport because the drawer is only translated off-screen,
     not actually hidden. */
}
.oc.open{
  transform:translateX(0);
  box-shadow:-12px 0 40px rgba(15,23,42,.18);
}

.oc-head{
  display:flex;align-items:center;gap:12px;
  padding:18px 16px 16px;
  background:linear-gradient(135deg,#006994,#0088b8);
  color:#fff;
  flex-shrink:0;
}
.oc-avatar{
  width:44px;height:44px;border-radius:50%;object-fit:cover;
  border:2px solid rgba(255,255,255,.4);
  background:#fff;flex-shrink:0;
}
.oc-ident{flex:1;min-width:0}
.oc-name{font-weight:700;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.oc-meta{font-size:.75rem;opacity:.85;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.oc-close{
  width:36px;height:36px;border-radius:10px;
  background:rgba(255,255,255,.12);color:#fff;border:none;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background var(--t);flex-shrink:0;
}
.oc-close:hover{background:rgba(255,255,255,.22)}

.oc-body{
  flex:1;overflow-y:auto;
  padding:10px 0 20px;
}

/* The in-oc menu rendered from render_menu() — make it vertical */
.oc .topnav{flex:none;display:block}
.oc .topnav ul{flex-direction:column;gap:0;padding:0;margin:0;list-style:none}
.oc .topnav li{margin:0}
.oc .topnav a{
  display:block;padding:13px 20px;border-radius:0;
  font-size:.95rem;font-weight:500;color:var(--txt);
  border-left:3px solid transparent;
}
.oc .topnav a:hover{background:#f0f4f8;color:var(--brand);border-left-color:var(--brand2)}
.oc .topnav li.active a{background:rgba(0,105,148,.08);color:var(--brand);border-left-color:var(--brand);font-weight:600}
.oc .topnav .ar{display:inline-block;margin-inline-start:6px;font-size:.78rem;opacity:.7}

.oc-label{
  padding:14px 20px 6px;
  font-size:.7rem;text-transform:uppercase;letter-spacing:.8px;
  color:var(--muted);font-weight:700;
}
.oc-link{
  display:flex;align-items:center;gap:12px;
  padding:12px 20px;
  text-decoration:none;color:var(--txt);
  font-size:.92rem;font-weight:500;
  border-left:3px solid transparent;
  transition:background var(--t),color var(--t),border-color var(--t);
  touch-action:manipulation;
}
.oc-link:hover{background:#f0f4f8;color:var(--brand);border-left-color:var(--brand2)}
.oc-link svg{opacity:.6;flex-shrink:0}
.oc-link:hover svg{opacity:1}
.oc-sep{height:1px;background:var(--border);margin:8px 0}
.oc-signout{color:var(--err)}
.oc-signout:hover{background:#fef2f2;color:var(--err);border-left-color:var(--err)}

body.oc-open{overflow:hidden}

/* Responsive break */
@media(max-width:900px){
  .hdr-inner{gap:12px}
  .hdr .topnav{display:none !important}   /* hide the HORIZONTAL nav only;
                                             the offcanvas still shows it */
  .hide-mobile{display:none !important}
  .show-mobile{display:flex !important}
}
@media(max-width:480px){
  .logo-img{height:40px}
  .hdr-inner{padding:12px 16px}
  .oc{width:300px}
}

/* Toggle switch — <label class="switch"><input type="checkbox"><span class="slider"></span></label> */
.switch{position:relative;display:inline-block;width:46px;height:26px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0;position:absolute}
.switch .slider{position:absolute;inset:0;cursor:pointer;background:#cbd5e1;border-radius:999px;transition:background var(--t);touch-action:manipulation}
.switch .slider::before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform var(--t);box-shadow:0 1px 3px rgba(0,0,0,.2)}
.switch input:checked + .slider{background:var(--brand)}
.switch input:checked + .slider::before{transform:translateX(20px)}
.switch input:focus-visible + .slider{box-shadow:0 0 0 3px rgba(0,165,207,.25)}
