/* Contact HRIS — light navy theme (matches the old HR-v4 palette)
   White sidebar · navy ink · orange accents · navy→blue greeting.
   Typography & components from the PDF_STUDIO brand (IBM Plex Sans EN/AR). */

@font-face{font-family:"IBM Plex Sans";src:url("../fonts/IBMPlexSans-300.ttf") format("truetype");font-weight:300;font-display:swap}
@font-face{font-family:"IBM Plex Sans";src:url("../fonts/IBMPlexSans-400.ttf") format("truetype");font-weight:400;font-display:swap}
@font-face{font-family:"IBM Plex Sans";src:url("../fonts/IBMPlexSans-500.ttf") format("truetype");font-weight:500;font-display:swap}
@font-face{font-family:"IBM Plex Sans";src:url("../fonts/IBMPlexSans-600.ttf") format("truetype");font-weight:600;font-display:swap}
@font-face{font-family:"IBM Plex Sans";src:url("../fonts/IBMPlexSans-700.ttf") format("truetype");font-weight:700;font-display:swap}
@font-face{font-family:"IBM Plex Sans Arabic";src:url("../fonts/IBMPlexSansArabic-400.ttf") format("truetype");font-weight:400;font-display:swap}
@font-face{font-family:"IBM Plex Sans Arabic";src:url("../fonts/IBMPlexSansArabic-500.ttf") format("truetype");font-weight:500;font-display:swap}
@font-face{font-family:"IBM Plex Sans Arabic";src:url("../fonts/IBMPlexSansArabic-600.ttf") format("truetype");font-weight:600;font-display:swap}
@font-face{font-family:"IBM Plex Sans Arabic";src:url("../fonts/IBMPlexSansArabic-700.ttf") format("truetype");font-weight:700;font-display:swap}

:root{
  --navy:#0B2545; --navy-2:#13315C; --blue:#1D4ED8; --blue-d:#1E40AF;
  --orange:#F38222; --orange-d:#DC6F18; --gold:#F9BC40;
  --mint:#14B8A6; --rose:#F43F5E;
  --ink:#0B1B33; --ink-soft:#243B53; --muted:#5A6B85;
  --line:#E5E9F0; --line-soft:#F1F4F9; --surface:#fff; --surface-alt:#FAFBFE; --tint:#F7F9FC;
  --green:#0F766E; --green-bg:#E6FBF6; --red:#9F1239; --red-bg:#FEE2E2;
  --amber:#92400E; --amber-bg:#FEF3C7; --info:#1D4ED8; --info-bg:#E5EDFE;
  --r:12px; --r-sm:9px; --r-lg:16px;
  --shadow:0 1px 2px rgba(11,27,51,.04),0 6px 20px rgba(11,27,51,.06);
  --font:"IBM Plex Sans","IBM Plex Sans Arabic","DejaVu Sans",sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--tint);font-size:14.5px;line-height:1.55;
  -webkit-font-smoothing:antialiased}
a{text-decoration:none;color:var(--blue)}
bdi{font-family:"IBM Plex Sans Arabic","IBM Plex Sans",sans-serif}
.app{display:flex;min-height:100vh}

/* ---- Sidebar (white, navy text, orange active) ---- */
.sidebar{width:252px;flex:0 0 252px;background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{padding:20px 20px 18px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;border-bottom:1px solid var(--line)}
.brand-logo{height:76px;width:auto;max-width:100%;display:block}
.brand-sub{font-weight:600;color:var(--navy);font-size:1rem;letter-spacing:.16em;text-transform:uppercase;
  padding-left:13px;border-left:2px solid var(--line)}
.nav-list{padding:16px 12px;display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}
.nav-list a{color:var(--ink-soft);padding:10px 13px;border-radius:var(--r-sm);display:flex;align-items:center;
  gap:12px;font-weight:500;font-size:.93rem;transition:.12s;border-left:3px solid transparent}
.nav-list a .bi{font-size:1.08rem;color:var(--muted);width:20px;text-align:center}
.nav-list a:hover{background:var(--line-soft);color:var(--ink)}
.nav-list a.active{background:rgba(243,130,34,.10);color:var(--orange-d);font-weight:600;border-left-color:var(--orange)}
.nav-list a.active .bi{color:var(--orange)}
.nav-sep{color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.13em;
  padding:16px 14px 6px;font-weight:600}
.side-foot{padding:14px;border-top:1px solid var(--line);font-size:.88rem}
.side-foot .who{display:flex;align-items:center;gap:10px;color:var(--ink);margin-bottom:10px}
.side-foot .who .bi{font-size:1.7rem;background:linear-gradient(135deg,var(--navy),var(--blue));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.side-foot .role{display:block;font-size:.66rem;color:var(--orange-d);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.side-foot .logout{color:var(--muted);display:flex;align-items:center;gap:8px}
.side-foot .logout:hover{color:var(--orange-d)}

/* ---- Main + topbar ---- */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:62px;background:var(--surface);border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:10}
.topbar h1{font-size:1.15rem;font-weight:600;margin:0;color:var(--navy);letter-spacing:-.01em}
.top-actions{display:flex;align-items:center;gap:10px}
.bell,.chip{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  color:var(--ink-soft);position:relative;border:1px solid var(--line);background:#fff}
.bell:hover,.chip:hover{background:var(--tint);color:var(--blue)}
.badge-dot{position:absolute;top:-5px;right:-5px;background:var(--orange);color:#fff;font-size:.66rem;
  font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;
  justify-content:center;padding:0 4px}
/* topbar check-in/out toggle */
.ci-top{display:flex;flex-direction:column;align-items:stretch;gap:2px;margin-right:6px}
.ci-toggle{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 16px;
  font-weight:600;border-radius:9px;border:0;color:#fff;cursor:pointer;font-size:.85rem;line-height:1;white-space:nowrap}
.ci-toggle.is-in{background:linear-gradient(135deg,#16A34A,#15803D)}
.ci-toggle.is-out{background:linear-gradient(135deg,#EF4444,#B91C1C)}
.ci-toggle:hover{filter:brightness(.95)}
.ci-last{font-size:.66rem;color:var(--muted);text-align:center;text-transform:capitalize;letter-spacing:.02em}

.content{padding:26px 28px;max-width:1200px;width:100%}

/* ---- Flash ---- */
.flash{padding:11px 15px;border-radius:var(--r);margin-bottom:14px;font-weight:500;
  display:flex;align-items:center;gap:9px;border:1px solid}
.flash-success{background:var(--green-bg);color:var(--green);border-color:#a7f3e4}
.flash-error,.flash-danger{background:var(--red-bg);color:var(--red);border-color:#fecaca}
.flash-warning,.flash-warn{background:var(--amber-bg);color:var(--amber);border-color:#fde68a}
.flash-info{background:var(--info-bg);color:var(--blue-d);border-color:#c7d7fb}

/* ---- Grid / cards ---- */
.grid{display:grid;gap:18px;align-items:start}
.stack{display:flex;flex-direction:column;gap:18px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.card2{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden}
.card2 .hd{padding:15px 18px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card2 .hd h2{font-size:1rem;font-weight:600;margin:0;display:flex;align-items:center;gap:9px;color:var(--navy)}
.card2 .hd h2::before{content:"";width:4px;height:18px;border-radius:2px;background:linear-gradient(180deg,var(--orange),var(--gold))}
.card2 .hd h2 .bi{color:var(--orange)}
.card2 .bd{padding:18px}
.muted{color:var(--muted)}
.empty{color:var(--muted);text-align:center;padding:26px 10px;font-size:.92rem}

/* ---- KPIs ---- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.kpi{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:17px 18px 15px;box-shadow:var(--shadow);overflow:hidden}
.kpi::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--blue))}
.kpi:nth-child(2)::before{background:linear-gradient(90deg,var(--orange),var(--gold))}
.kpi:nth-child(3)::before{background:linear-gradient(90deg,var(--mint),#5EEAD4)}
.kpi:nth-child(4)::before{background:linear-gradient(90deg,var(--rose),#FB7185)}
.kpi .v{font-size:1.8rem;font-weight:600;color:var(--navy);line-height:1.1;font-variant-numeric:tabular-nums}
.kpi .l{color:var(--muted);font-size:.74rem;margin-top:4px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* ---- Greeting (navy → blue, old-version style) ---- */
.greet{background:linear-gradient(135deg,#0B2545 0%,#1D4ED8 100%);color:#fff;border-radius:var(--r-lg);
  padding:28px 30px;margin-bottom:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.greet::after{content:"";position:absolute;right:-50px;top:-60px;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(243,130,34,.32),transparent 70%)}
.greet h2{margin:0 0 5px;font-size:1.6rem;font-weight:600;position:relative}
.greet p{margin:0;opacity:.82;position:relative}

/* ---- Home dashboard: quick actions, clickable KPIs, table density ---- */
.quick-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(148px,1fr));gap:12px;margin-bottom:20px}
.quick{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;padding:15px 12px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);color:var(--ink-soft);
  text-align:center;box-shadow:var(--shadow);transition:transform .15s,border-color .15s,color .15s}
.quick:hover{border-color:var(--orange);color:var(--orange-d);transform:translateY(-2px)}
.quick .bi{font-size:1.35rem;color:var(--orange)}
.quick span{font-size:.82rem;font-weight:600;line-height:1.2}
a.kpi{text-decoration:none;transition:border-color .15s,box-shadow .15s}
a.kpi:hover{border-color:var(--orange)}
.card2 .bd.flush{padding:0}
.card2 .bd.flush .tbl,.card2 .bd.flush .tbl thead th{border-radius:0}
.tbl.compact th,.tbl.compact td{padding:9px 15px;font-size:.88rem}
.tbl.compact th{font-size:.72rem;letter-spacing:.04em;text-transform:uppercase}
.tbl a{color:var(--navy);font-weight:600}
.tbl a:hover{color:var(--orange-d)}
.ndot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--orange);margin-right:7px;vertical-align:middle}
/* hero enrichment */
.greet.hero{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.hero-id{display:flex;align-items:center;gap:16px;position:relative}
.hero-avatar{width:62px;height:62px;border-radius:50%;background:rgba(255,255,255,.16);border:2px solid rgba(255,255,255,.38);
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex:0 0 62px;text-transform:uppercase}
.hero-ci{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  border-radius:14px;padding:12px 18px;position:relative}
.hero-ci .lbl{font-size:.64rem;text-transform:uppercase;letter-spacing:.1em;opacity:.75}
.hero-ci .val{font-size:1.05rem;font-weight:700}
.hero-btn{background:#fff;color:var(--navy);border:0;border-radius:10px;padding:10px 18px;font-weight:700;font-size:.88rem;
  display:inline-flex;align-items:center;gap:7px;cursor:pointer;transition:filter .15s}
.hero-btn:hover{filter:brightness(.94)}
.hero-btn.out{background:var(--orange);color:#fff}
/* avatars in lists */
.avatar{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-size:.76rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--navy),var(--blue));flex:0 0 34px;text-transform:uppercase}
.avatar.sm{width:28px;height:28px;font-size:.68rem;flex-basis:28px}
.uline{display:inline-flex;align-items:center;gap:10px}
/* leave progress bar */
.bar{height:9px;border-radius:999px;background:var(--line);overflow:hidden;margin:8px 0 6px}
.bar > i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--orange),var(--gold))}
/* kpi corner icon */
.kpi .ico{position:absolute;top:13px;right:14px;font-size:1.05rem;opacity:.26;color:var(--navy)}
/* scrollable card body with sticky table header */
.scroll-y{max-height:300px;overflow:auto}
.scroll-y .tbl thead th{position:sticky;top:0;z-index:1}

/* ---- Tables (navy gradient header + zebra) ---- */
table.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:.92rem;
  border:1px solid var(--line);border-radius:10px;overflow:hidden}
table.tbl th{text-align:left;color:#fff;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;
  padding:11px 13px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%)}
table.tbl td{padding:11px 13px;border-top:1px solid var(--line-soft);color:var(--ink-soft)}
table.tbl tbody tr:nth-child(even) td{background:var(--surface-alt)}
table.tbl tbody tr:hover td{background:#EEF3FB}

/* ---- Pills ---- */
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;
  font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.pill-green,.pill.good{background:var(--green-bg);color:var(--green)}
.pill-red,.pill.bad{background:var(--red-bg);color:var(--red)}
.pill-amber,.pill.warn{background:var(--amber-bg);color:var(--amber)}
.pill-blue{background:var(--info-bg);color:var(--blue-d)}
.pill-grey{background:#EEF1F6;color:var(--muted)}

/* ---- Buttons ---- */
.btn{border-radius:9px;font-weight:600}
.btn-accent{background:linear-gradient(135deg,var(--orange),var(--orange-d));border:0;color:#fff}
.btn-accent:hover{filter:brightness(.96);color:#fff}
.btn-navy{background:var(--navy);border-color:var(--navy);color:#fff}
.btn-navy:hover{background:var(--blue);border-color:var(--blue);color:#fff}

/* ---- Check-in widget ---- */
.checkin{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.checkin .status{flex:1;min-width:180px}
.checkin .status b{font-size:1.05rem;color:var(--navy)}
.ci-btns{display:flex;gap:10px}
.ci-btns button{padding:12px 22px;font-weight:600;border-radius:10px;border:0;color:#fff;cursor:pointer}
.ci-in{background:linear-gradient(135deg,var(--mint),#0F766E)} .ci-out{background:linear-gradient(135deg,var(--orange),var(--orange-d))}

/* ---- Announcement / notifications ---- */
.ann{padding:14px 0;border-bottom:1px solid var(--line-soft)}
.ann:last-child{border-bottom:0}
.ann h3{font-size:1rem;margin:0 0 3px;font-weight:600;color:var(--navy)}
.ann .meta{color:var(--muted);font-size:.8rem;margin-bottom:5px}
.ann.important h3::before{content:"\F33A";font-family:bootstrap-icons;color:var(--orange);margin-right:6px}
.notif{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.notif.unread{background:linear-gradient(90deg,rgba(243,130,34,.07),transparent);margin:0 -12px;padding:13px 12px;border-radius:8px}
.notif .dot{width:9px;height:9px;border-radius:50%;background:var(--orange);margin-top:6px;flex:0 0 9px}
.notif.read .dot{background:var(--line)}

/* ---- Auth (copied from HR-v4 login) ---- */
.auth-page{min-height:100vh;
  background:
    radial-gradient(circle at 18% 12%, rgba(250,225,41,.22) 0%, transparent 38%),
    radial-gradient(circle at 88% 78%, rgba(243,130,34,.32) 0%, transparent 48%),
    radial-gradient(circle at 50% 50%, rgba(91,90,176,.30) 0%, transparent 70%),
    linear-gradient(140deg,#0A0930 0%,#1B1A4E 30%,#31307D 60%,#5B5AB0 100%);
  display:grid;place-items:center;padding:2rem 1rem}
.auth-card{position:relative;overflow:hidden;background:rgba(255,255,255,.97);
  border-radius:var(--r-lg);box-shadow:0 20px 60px rgba(10,9,48,.45);
  padding:2.25rem 2rem 1.85rem;max-width:420px;width:100%}
.auth-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--orange),var(--gold),#5B5AB0)}
.auth-card .brand{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.7rem;margin-bottom:1.3rem;border-bottom:0;padding:0}
.auth-card .brand img{height:160px;max-width:100%;width:auto}
.auth-card .brand-name{font-size:1.2rem;font-weight:700;letter-spacing:.34em;color:var(--navy);text-transform:uppercase}
.auth-card h2{color:var(--navy);font-size:1.2rem;text-align:center;margin:0 0 1.2rem;font-weight:600;letter-spacing:-.01em}
.input-group-text{background:var(--surface-alt);border:1px solid var(--line);color:var(--muted);border-right:0}
.input-group .form-control{border-left:0}
.login-aside{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.6);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600}

@media(max-width:900px){
  .sidebar{position:fixed;left:-252px;z-index:50;transition:.2s}
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
}
