  /* =========================================================
     DESIGN TOKENS — Modern SaaS palette
     ========================================================= */
  :root{
    /* Surfaces */
    --bg:            #f8fafc;
    --paper:         #ffffff;
    --paper-2:       #f1f5f9;
    --paper-3:       #e2e8f0;

    /* Text */
    --ink:           #0f172a;
    --muted:         #64748b;
    --muted-2:       #94a3b8;

    /* Borders */
    --border:        #e2e8f0;
    --border-strong: #cbd5e1;

    /* Brand — blue */
    --accent:        #2563eb;
    --accent-hover:  #1d4ed8;
    --accent-soft:   #eff6ff;
    --accent-soft-2: #dbeafe;

    /* Semantic */
    --accent-2:      #10b981;    /* success green */
    --accent-2-soft: #ecfdf5;
    --warn:          #f59e0b;
    --warn-soft:     #fffbeb;
    --danger:        #ef4444;
    --danger-soft:   #fef2f2;
    --info:          #0ea5e9;
    --info-soft:     #f0f9ff;

    /* Shadows — soft, layered */
    --shadow-xs: 0 1px 2px rgba(15,23,42,.05);
    --shadow-sm: 0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);
    --shadow-md: 0 4px 6px -1px rgba(15,23,42,.08), 0 2px 4px -2px rgba(15,23,42,.05);
    --shadow-lg: 0 10px 15px -3px rgba(15,23,42,.08), 0 4px 6px -4px rgba(15,23,42,.05);
    --shadow-xl: 0 20px 25px -5px rgba(15,23,42,.10), 0 8px 10px -6px rgba(15,23,42,.04);

    /* Radius */
    --radius-sm: 6px;
    --radius:    10px;
    --radius-lg: 14px;

    --ease: cubic-bezier(.4,0,.2,1);
  }

  *{ -webkit-tap-highlight-color:transparent; box-sizing:border-box; }
  html,body{ margin:0; padding:0; }
  body{
    background: var(--bg);
    color: var(--ink);
    font-family: 'IBM Plex Sans Arabic', system-ui, -apple-system, sans-serif;
    font-size:15px;
    line-height:1.6;
    min-height:100vh;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,h4,h5,h6{ margin:0; font-weight:700; color:var(--ink); line-height:1.3; }
  p{ margin:0; }
  a{ color:var(--accent); text-decoration:none; }
  a:hover{ color:var(--accent-hover); }

  /* Preserve display-font (used by many headings in old code) */
  .display-font{ font-weight:700; letter-spacing:-0.01em; }

  /* =========================================================
     CARDS
     ========================================================= */
  .card{
    background:var(--paper);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-sm);
    padding:1.25rem;
  }
  .brand-border{ border:1px solid var(--border); border-radius:var(--radius); }

  /* =========================================================
     TABS (top nav, kept for compatibility)
     ========================================================= */
  .tab-btn{
    border:1px solid var(--border-strong);
    background:var(--paper);
    font-weight:600;
    padding:.5rem .9rem;
    cursor:pointer;
    font-family:inherit;
    font-size:.82rem;
    color:var(--muted);
    border-radius:var(--radius-sm);
    transition:all .15s var(--ease);
    box-shadow:var(--shadow-xs);
  }
  .tab-btn:hover{
    background:var(--paper-2);
    color:var(--ink);
    border-color:var(--muted-2);
  }
  .tab-btn.active{
    background:var(--accent);
    color:#fff;
    border-color:var(--accent);
    box-shadow:var(--shadow-sm);
  }

  /* =========================================================
     FORM CONTROLS
     ========================================================= */
  .field{
    background:var(--paper);
    border:1px solid var(--border-strong);
    padding:.6rem .85rem;
    font-family:inherit;
    width:100%;
    font-weight:500;
    font-size:.88rem;
    color:var(--ink);
    border-radius:var(--radius-sm);
    transition:all .15s var(--ease);
    outline:none;
  }
  .field::placeholder{ color:var(--muted-2); }
  .field:hover{ border-color:var(--muted-2); }
  .field:focus{
    border-color:var(--accent);
    box-shadow: 0 0 0 3px rgba(37,99,235,.12);
  }
  .field:disabled{
    background:var(--paper-2);
    color:var(--muted-2);
    cursor:not-allowed;
  }
  textarea.field{ resize:vertical; min-height:72px; }

  label.lbl{
    display:block;
    font-weight:600;
    font-size:.78rem;
    color:var(--muted);
    margin-bottom:.4rem;
  }

  /* =========================================================
     BUTTONS
     ========================================================= */
  .btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.4rem;
    border:1px solid var(--border-strong);
    padding:.55rem 1rem;
    font-weight:600;
    background:var(--paper);
    color:var(--ink);
    font-family:inherit;
    cursor:pointer;
    font-size:.85rem;
    border-radius:var(--radius-sm);
    box-shadow:var(--shadow-xs);
    transition:all .15s var(--ease);
    white-space:nowrap;
  }
  .btn:hover{
    background:var(--paper-2);
    border-color:var(--muted-2);
    box-shadow:var(--shadow-sm);
  }
  .btn:active{ transform:translateY(1px); }
  .btn:disabled{
    opacity:.5;
    cursor:not-allowed;
    box-shadow:none;
  }

  .btn-primary{
    background:var(--accent);
    color:#fff;
    border-color:var(--accent);
  }
  .btn-primary:hover{
    background:var(--accent-hover);
    border-color:var(--accent-hover);
    color:#fff;
  }

  .btn-ok{
    background:var(--accent-2);
    color:#fff;
    border-color:var(--accent-2);
  }
  .btn-ok:hover{
    background:#059669;
    border-color:#059669;
    color:#fff;
  }

  .btn-danger{
    background:var(--danger);
    color:#fff;
    border-color:var(--danger);
  }
  .btn-danger:hover{
    background:#dc2626;
    border-color:#dc2626;
    color:#fff;
  }

  .btn-warn{
    background:var(--warn);
    color:#fff;
    border-color:var(--warn);
  }
  .btn-warn:hover{
    background:#d97706;
    border-color:#d97706;
    color:#fff;
  }

  .btn-sm{ padding:.4rem .7rem; font-size:.77rem; }

  /* =========================================================
     TABLES
     ========================================================= */
  table{
    width:100%;
    border-collapse:collapse;
    font-size:.85rem;
  }
  thead{
    background:var(--paper-2);
  }
  th{
    text-align:right;
    padding:.75rem 1rem;
    font-size:.72rem;
    font-weight:600;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.03em;
    border-bottom:1px solid var(--border);
  }
  td{
    padding:.85rem 1rem;
    border-bottom:1px solid var(--border);
    color:var(--ink);
    vertical-align:middle;
  }
  tbody tr:hover td{ background:var(--paper-2); }
  tr:nth-child(even) td{ background:transparent; }
  tbody tr:last-child td{ border-bottom:none; }

  /* Tables inside cards — remove their border since card has one */
  .card > table,
  .card table{
    border-radius:var(--radius);
    overflow:hidden;
  }

  /* =========================================================
     PILLS / BADGES
     ========================================================= */
  .pill{
    display:inline-flex;
    align-items:center;
    gap:.25rem;
    padding:.2rem .55rem;
    border:1px solid var(--border);
    font-size:.72rem;
    font-weight:600;
    background:var(--paper-2);
    color:var(--muted);
    border-radius:999px;
    line-height:1.4;
  }
  .pill-ok{     background:var(--accent-2-soft); color:var(--accent-2); border-color:#a7f3d0; }
  .pill-low{    background:var(--warn-soft);     color:var(--warn);     border-color:#fde68a; }
  .pill-zero{   background:var(--danger-soft);   color:var(--danger);   border-color:#fecaca; }
  .pill-info{   background:var(--info-soft);     color:var(--info);     border-color:#bae6fd; }
  .pill-danger{ background:var(--danger-soft);   color:var(--danger);   border-color:#fecaca; }

  .badge-pending{  background:var(--warn-soft);      color:var(--warn);     border:1px solid #fde68a; padding:.2rem .55rem; border-radius:999px; font-size:.72rem; font-weight:600; }
  .badge-approved{ background:var(--accent-2-soft); color:var(--accent-2); border:1px solid #a7f3d0; padding:.2rem .55rem; border-radius:999px; font-size:.72rem; font-weight:600; }
  .badge-rejected{ background:var(--danger-soft);   color:var(--danger);   border:1px solid #fecaca; padding:.2rem .55rem; border-radius:999px; font-size:.72rem; font-weight:600; }

  /* =========================================================
     TOASTS
     ========================================================= */
  #toastWrap{
    position:fixed;
    top:1rem;
    left:50%;
    transform:translateX(-50%);
    z-index:9999;
    display:flex;
    flex-direction:column;
    gap:.5rem;
    pointer-events:none;
  }
  .toast{
    background:var(--paper);
    border:1px solid var(--border);
    border-right:3px solid var(--accent);
    padding:.75rem 1.25rem;
    font-weight:500;
    box-shadow:var(--shadow-lg);
    border-radius:var(--radius);
    animation:slide .2s var(--ease);
    min-width:260px;
    max-width:400px;
    text-align:right;
    color:var(--ink);
  }
  .toast.ok{   border-right-color:var(--accent-2); }
  .toast.warn{ border-right-color:var(--warn); }
  .toast.err{  border-right-color:var(--danger); }
  @keyframes slide{ from{transform:translate(-50%,-8px);opacity:0;} to{transform:translate(-50%,0);opacity:1;} }

  /* =========================================================
     DECORATIVE
     ========================================================= */
  .gear-spin{ animation:spin 16s linear infinite; transform-origin:center; }
  @keyframes spin{ to{transform:rotate(360deg);} }
  .strip{
    background:linear-gradient(to left, var(--accent), var(--info), var(--accent));
    height:3px;
  }

  /* =========================================================
     MODAL
     ========================================================= */
  .modal-backdrop{
    position:fixed;
    inset:0;
    background:rgba(15,23,42,.5);
    backdrop-filter:blur(4px);
    z-index:9000;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:1rem;
    overflow:auto;
    animation:fadeIn .15s var(--ease);
  }
  .modal{
    background:var(--paper);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-xl);
    max-width:640px;
    width:100%;
    padding:1.75rem;
    max-height:90vh;
    overflow:auto;
    animation:slideUp .2s var(--ease);
  }
  @keyframes fadeIn{ from{opacity:0;} to{opacity:1;} }
  @keyframes slideUp{ from{opacity:0;transform:translateY(8px);} to{opacity:1;transform:translateY(0);} }

  /* =========================================================
     STAT CARDS
     ========================================================= */
  .stat-card{
    background:var(--paper);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:1.15rem 1.25rem;
    box-shadow:var(--shadow-sm);
    transition:all .2s var(--ease);
  }
  .stat-card:hover{
    box-shadow:var(--shadow-md);
    transform:translateY(-1px);
  }
  .stat-card .num{
    font-size:2rem;
    font-weight:700;
    line-height:1;
    color:var(--accent);
    font-variant-numeric: tabular-nums;
  }
  .stat-card .lbl{
    font-size:.72rem;
    color:var(--muted);
    font-weight:600;
    margin-bottom:.5rem;
    text-transform:uppercase;
    letter-spacing:.03em;
  }

  /* =========================================================
     DETAILS / SUMMARY
     ========================================================= */
  details summary{ cursor:pointer; list-style:none; }
  details summary::-webkit-details-marker{ display:none; }
  details{
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:.85rem 1rem;
    background:var(--paper);
    margin-bottom:.5rem;
  }
  details[open]{ box-shadow:var(--shadow-sm); }

  /* =========================================================
     GRIDS
     ========================================================= */
  .grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
  .grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
  .grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
  @media(max-width:900px){
    .grid-4{ grid-template-columns:repeat(2,1fr); }
    .grid-3{ grid-template-columns:repeat(2,1fr); }
  }
  @media(max-width:640px){
    .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; }
    th,td{ padding:.5rem .55rem; font-size:.78rem; }
  }

  /* =========================================================
     LOGIN
     ========================================================= */
  .login-wrap{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:1rem;
    background:
      radial-gradient(circle at 20% 10%, rgba(37,99,235,.06) 0, transparent 40%),
      radial-gradient(circle at 80% 80%, rgba(14,165,233,.06) 0, transparent 40%),
      var(--bg);
  }
  .login-box{
    background:var(--paper);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-xl);
    padding:2.5rem;
    max-width:440px;
    width:100%;
  }

  .hidden{ display:none !important; }

  /* =========================================================
     APPROVAL CARDS
     ========================================================= */
  .approval-card{
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:1.15rem;
    background:var(--paper);
    margin-bottom:.85rem;
    box-shadow:var(--shadow-sm);
    transition:all .2s var(--ease);
  }
  .approval-card:hover{
    box-shadow:var(--shadow-md);
  }

  /* =========================================================
     SECTION HEADERS
     ========================================================= */
  .section-h{
    font-size:1.2rem;
    font-weight:700;
    margin:0 0 1rem;
    color:var(--ink);
    display:flex;
    align-items:center;
    gap:.5rem;
  }

  /* =========================================================
     UTILITIES
     ========================================================= */
  .row-flex{ display:flex; gap:.6rem; flex-wrap:wrap; align-items:center; }
  .sep{ margin:1.25rem 0; border:none; border-top:1px solid var(--border); }

  /* =========================================================
     HEADER / TOP BAR
     ========================================================= */
  header{
    background:var(--paper);
    border-bottom:1px solid var(--border);
    box-shadow:var(--shadow-xs);
  }

  /* =========================================================
     SCROLLBAR
     ========================================================= */
  ::-webkit-scrollbar{ width:10px; height:10px; }
  ::-webkit-scrollbar-track{ background:var(--paper-2); }
  ::-webkit-scrollbar-thumb{ background:var(--border-strong); border-radius:10px; border:2px solid var(--paper-2); }
  ::-webkit-scrollbar-thumb:hover{ background:var(--muted-2); }

  /* =========================================================
     PRINT
     ========================================================= */
  @media print{
    body{ background:#fff; }
    body *{ visibility:hidden; }
    #printArea, #printArea *{ visibility:visible; }
    #printArea{ position:absolute; inset:0; padding:2rem; }
  }
  #printArea{ display:none; }
