/* ============================================
   Gobotix PMS - Style (Repairslab Design)
   ============================================ */

/* ===== Theme Colors ===== */
:root{
  --bg:#e0e7ff;
  --card:#ffffff;
  --card2:#f8fafc;
  --border:#c7d2fe;
  --text:#1e293b;
  --muted:#64748b;
  --primary:#667eea;
  --primary-hover:#5568d3;
  --success:#10b981;
  --warning:#f59e0b;
  --danger:#ef4444;
  /* PMS status aliases */
  --status-active:#667eea;
  --status-completed:#10b981;
  --status-pending:#f59e0b;
  --status-cancelled:#ef4444;
  --bamboo-green:#10b981;
  --wood-accent:#667eea;
  --shadow:0 4px 6px -1px rgba(102,126,234,.12), 0 2px 4px -1px rgba(102,126,234,.08);
  --shadow-lg:0 10px 15px -3px rgba(102,126,234,.15), 0 4px 6px -2px rgba(102,126,234,.08);
  --shadow-xl:0 20px 25px -5px rgba(102,126,234,.18), 0 10px 10px -5px rgba(102,126,234,.08);
  --gradient-primary:linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  --gradient-success:linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%);
  --gradient-warm:linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
  --gradient-bg:linear-gradient(135deg, #e0e7ff 0%, #f5f3ff 50%, #ddd6fe 100%);
}

/* ===== Animations ===== */
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes slideInLeft { from{opacity:0;transform:translateX(-40px)} to{opacity:1;transform:translateX(0)} }
@keyframes slideInRight { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
@keyframes slideDown { from{opacity:0;transform:translateY(-30px)} to{opacity:1;transform:translateY(0)} }
@keyframes scaleIn { from{opacity:0;transform:scale(0.98)} to{opacity:1;transform:scale(1)} }
@keyframes shimmer { 0%{background-position:-1000px 0} 100%{background-position:1000px 0} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.1)} }
@keyframes pageLoad { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes bellRing { 0%,100%{transform:rotate(0deg)} 25%{transform:rotate(15deg)} 75%{transform:rotate(-15deg)} }

/* ===== Base ===== */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background:var(--gradient-bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  min-height:100vh;
  animation:pageLoad 0.6s cubic-bezier(0.4,0,0.2,1);
}
a{ color:inherit; text-decoration:none; transition:all 0.3s ease; }
.wrap{ max-width:1200px; margin:0 auto; }
.muted{ color:var(--muted); font-size:13px; }

/* ===== Layout ===== */
.layout{
  display:flex;
  min-height:100vh;
  align-items:stretch;
  background:var(--bg);
}
/* PMS alias */
.layout-container{ display:flex; min-height:100vh; align-items:stretch; background:var(--bg); }

.sidebar{
  width:240px;
  min-width:240px;
  flex:0 0 240px;
  background:linear-gradient(180deg,#ffffff 0%,#faf8ff 100%);
  border-right:1px solid var(--border);
  padding:16px 12px;
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  animation:slideInLeft 0.8s ease;
  display:flex;
  flex-direction:column;
}

.main{
  flex:1;
  padding:24px;
  min-width:0;
  animation:fadeIn 0.8s ease;
  background:transparent;
}
/* PMS alias */
.main-content{ flex:1; padding:24px; min-width:0; animation:fadeIn 0.8s ease; }

/* ===== Sidebar Logo ===== */
.logo{
  background:var(--gradient-primary);
  border:0;
  border-radius:12px;
  padding:14px 16px;
  margin-bottom:16px;
  box-shadow:var(--shadow-lg);
  position:relative;
  overflow:hidden;
}
.logo::before{
  content:'';
  position:absolute;
  top:-50%; right:-50%;
  width:200%; height:200%;
  background:radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%);
}
.logo b{ display:block; font-size:15px; line-height:1.2; color:#fff; font-weight:700; position:relative; z-index:1; }
.logo .muted{ font-size:11px; margin-top:4px; color:rgba(255,255,255,0.85); position:relative; z-index:1; }

/* PMS sidebar-header alias */
.sidebar-header{ background:var(--gradient-primary); border-radius:12px; padding:14px 16px; margin-bottom:16px; }
.sidebar-logo{ height:32px; width:auto; display:block; margin-bottom:6px; filter:brightness(0) invert(1); }
.sidebar-title{ font-size:14px; font-weight:700; color:#fff; }

/* ===== Sidebar Nav ===== */
.nav{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin-top:8px;
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  min-height:0;
  scrollbar-width:none;
  -ms-overflow-style:none;
  padding-left:2px;
}
.nav::-webkit-scrollbar{ display:none; }
.nav a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:8px 10px;
  border:1px solid var(--border);
  border-left:3px solid transparent;
  border-radius:8px;
  background:var(--card);
  transition:all 0.2s ease;
  color:var(--text);
}
.nav a:hover{
  border-color:var(--primary);
  border-left-color:var(--primary);
  box-shadow:var(--shadow);
  background:color-mix(in srgb, var(--primary) 5%, var(--card) 95%);
}
.nav a.active{
  border-color:var(--primary);
  border-left:3px solid var(--primary);
  box-shadow:var(--shadow-lg);
  background:linear-gradient(135deg, color-mix(in srgb, var(--primary) 10%, transparent 90%), color-mix(in srgb, var(--primary) 5%, transparent 95%));
}
.nav .left{ display:flex; align-items:center; gap:10px; }
.nav .icon{ width:20px; text-align:center; font-size:16px; }
.nav .title{ font-weight:500; font-size:13px; }
.nav a.active .title{ font-weight:700; }
.nav .desc{ font-size:11px; color:var(--muted); margin-top:1px; }
.nav .chev{ color:var(--muted); font-size:14px; }

/* Pemisah sidebar: ringkasan vs operasi; & modul Jadual vs menu utama */
hr.nav-module-break{
  margin:16px 2px 12px;
  border:none;
  border-top:1px solid color-mix(in srgb, var(--muted) 45%, var(--border));
  opacity:0.95;
}

/* Sidebar: Projek flyout submenu (admin) */
.nav-flyout{ position:relative; width:100%; }
.nav-flyout__trigger{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:8px 10px;
  border:1px solid var(--border);
  border-left:3px solid transparent;
  border-radius:8px;
  background:var(--card);
  transition:all 0.2s ease;
  color:var(--text);
  cursor:pointer;
  font:inherit;
  text-align:left;
  box-sizing:border-box;
}
.nav-flyout__trigger:focus{ outline:none; }
.nav-flyout__trigger:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
.nav-flyout__trigger:hover{
  border-color:var(--primary);
  border-left-color:var(--primary);
  box-shadow:var(--shadow);
  background:color-mix(in srgb, var(--primary) 5%, var(--card) 95%);
}
.nav-flyout--active-parent .nav-flyout__trigger,
.nav-flyout__trigger.nav-flyout__trigger--active{
  border-color:var(--primary);
  border-left:3px solid var(--primary);
  box-shadow:var(--shadow-lg);
  background:linear-gradient(135deg, color-mix(in srgb, var(--primary) 10%, transparent 90%), color-mix(in srgb, var(--primary) 5%, transparent 95%));
}
.nav-flyout--active-parent .nav-flyout__trigger .title,
.nav-flyout__trigger.nav-flyout__trigger--active .title{ font-weight:700; }
.nav-flyout.is-open .nav-flyout__chev{ transform:rotate(90deg); }
.nav-flyout__chev{ transition:transform 0.28s cubic-bezier(0.34, 1.2, 0.64, 1); display:inline-block; }
.nav-flyout__panel{
  padding:0;
  overflow:hidden;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  box-shadow:var(--shadow-xl);
  opacity:0;
  transform:translate3d(-14px, -4px, 0) scale(0.97);
  transform-origin:left top;
  pointer-events:none;
  transition:
    opacity 0.26s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.28s cubic-bezier(0.34, 1.2, 0.64, 1),
    box-shadow 0.26s ease;
  will-change:opacity, transform;
}
.nav-flyout__panel-hd{
  padding:10px 14px 8px;
  font-size:10px;
  font-weight:700;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--muted);
  background:linear-gradient(
    180deg,
    color-mix(in srgb, var(--primary) 7%, var(--card)) 0%,
    color-mix(in srgb, var(--primary) 3%, var(--card)) 100%
  );
  border-bottom:1px solid color-mix(in srgb, var(--border) 85%, var(--primary) 15%);
}
.nav-flyout__panel-body{
  padding:6px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.nav-flyout.is-open .nav-flyout__panel{
  opacity:1;
  transform:translate3d(0, 0, 0) scale(1);
  pointer-events:auto;
  box-shadow:0 12px 40px -8px rgba(102, 126, 234, 0.28), 0 4px 14px rgba(30, 41, 59, 0.12);
}
@keyframes navFlyoutLinkIn{
  from{ opacity:0; transform:translateY(-6px); }
  to{ opacity:1; transform:translateY(0); }
}
.nav-flyout.is-open .nav-flyout__panel-body .nav-flyout__link{
  animation:navFlyoutLinkIn 0.28s cubic-bezier(0.34, 1.15, 0.64, 1) backwards;
}
.nav-flyout.is-open .nav-flyout__panel-body .nav-flyout__link:nth-child(1){ animation-delay:0.05s; }
.nav-flyout.is-open .nav-flyout__panel-body .nav-flyout__link:nth-child(2){ animation-delay:0.1s; }
.nav-flyout.is-open .nav-flyout__panel-body .nav-flyout__link:nth-child(3){ animation-delay:0.15s; }
.nav-flyout.is-open .nav-flyout__panel-body .nav-flyout__link:nth-child(4){ animation-delay:0.2s; }
.nav-flyout__link{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  min-height:48px;
  text-decoration:none;
  color:var(--text);
  border:1px solid transparent;
  border-radius:10px;
  transition:background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.nav-flyout__link:hover{
  background:color-mix(in srgb, var(--primary) 5%, var(--card2));
  border-color:var(--border);
}
.nav-flyout__link:focus{ outline:none; }
.nav-flyout__panel-body .nav-flyout__link:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:-2px;
  z-index:1;
  position:relative;
}
.nav-flyout__link.active{
  background:color-mix(in srgb, var(--primary) 9%, var(--card));
  border-color:color-mix(in srgb, var(--primary) 22%, var(--border));
  box-shadow:inset 3px 0 0 var(--primary);
}
.nav-flyout__link-icon{
  flex-shrink:0;
  width:30px;
  height:30px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:9px;
  background:color-mix(in srgb, var(--primary) 14%, transparent);
  color:var(--primary);
  font-size:14px;
}
.nav-flyout__link.active .nav-flyout__link-icon{
  background:color-mix(in srgb, var(--primary) 24%, transparent);
  color:var(--primary);
}
.nav-flyout__link-main{
  flex:1;
  min-width:0;
}
.nav-flyout__link-title{
  display:block;
  font-weight:600;
  font-size:13px;
  line-height:1.25;
}
.nav-flyout__link-title--row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.nav-flyout__link-badge{
  font-size:10px;
  padding:2px 6px;
  line-height:1.2;
}
.nav-flyout__link-desc{
  display:block;
  font-size:11px;
  color:var(--muted);
  margin-top:3px;
  line-height:1.35;
}

/* Kos perbelanjaan: kumpulan accordion (selaras gaya jadual kos barang) */
tbody.cost-group{
  border-bottom:1px solid var(--border);
}
tbody.cost-group:last-of-type{ border-bottom:0; }
tr.cost-group-hdr{ background:color-mix(in srgb,var(--primary) 6%,white); }
tr.cost-group-hdr .cost-group-hdr__toggle{
  cursor:pointer;
  user-select:none;
  padding:10px 14px;
  transition:background .2s ease;
}
tr.cost-group-hdr .cost-group-hdr__toggle:hover{
  background:color-mix(in srgb,var(--primary) 10%,white);
}
.cost-group-chev{
  display:inline-block;
  margin-right:4px;
  color:var(--muted);
  transition:transform .28s cubic-bezier(0.34, 1.2, 0.64, 1);
  vertical-align:middle;
}
tbody.cost-group.is-collapsed .cost-group-chev{
  transform:rotate(-90deg);
}
tbody.cost-group.is-collapsed tr.cost-group-item{
  display:none;
}

/* Kos perbelanjaan (admin): PV per baris — input sebaris + bayar */
tr.cost-group-hdr .perb-group-sum{
  padding:10px 10px 10px 6px;
  vertical-align:middle;
}
.perb-group-sum__hint{
  display:flex;
  align-items:flex-start;
  gap:6px;
  font-size:11px;
  color:var(--muted);
  line-height:1.4;
  max-width:240px;
}
.perb-group-sum__hint i{
  margin-top:2px;
  color:var(--primary);
  flex-shrink:0;
}
.perb-pv-stack{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
  padding:2px 0;
}
.perb-pv-form{ margin:0; }
.perb-pv-inline{
  display:flex;
  gap:6px;
  align-items:stretch;
}
.perb-pv-input{
  flex:1;
  min-width:0;
  width:100%;
  box-sizing:border-box;
  font-size:12px;
  padding:7px 10px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--card);
}
.perb-pv-input:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 2px color-mix(in srgb, var(--primary) 22%, transparent);
}
.perb-pv-save{
  flex:0 0 auto;
  padding:7px 12px !important;
  font-size:11px !important;
  white-space:nowrap;
}
.perb-pv-pay{
  width:100%;
  font-size:11px !important;
  padding:7px 10px !important;
}
.perb-pv-paid{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
}
.perb-pv-code{
  font-size:11px;
  font-weight:700;
  word-break:break-word;
  padding:5px 9px;
  border-radius:6px;
  background:color-mix(in srgb, var(--primary) 9%, var(--card));
  color:var(--primary);
  border:1px solid color-mix(in srgb, var(--primary) 20%, transparent);
  line-height:1.3;
}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* PMS sidebar-menu alias */
.sidebar-menu{ list-style:none; display:flex; flex-direction:column; gap:4px; flex:1; overflow-y:auto; scrollbar-width:none; padding-left:2px; }
.sidebar-menu::-webkit-scrollbar{ display:none; }
.sidebar-menu li a{
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 12px; border:1px solid var(--border); border-left:3px solid transparent;
  border-radius:8px; background:var(--card); transition:all 0.2s ease; color:var(--text);
  gap:10px; font-weight:500; font-size:13px; text-decoration:none;
}
.sidebar-menu li a:hover{ border-color:var(--primary); border-left-color:var(--primary); box-shadow:var(--shadow); background:color-mix(in srgb, var(--primary) 5%, var(--card) 95%); }
.sidebar-menu li a.active{ border-color:var(--primary); border-left:3px solid var(--primary); box-shadow:var(--shadow-lg); font-weight:700; background:linear-gradient(135deg, color-mix(in srgb, var(--primary) 10%, transparent 90%), color-mix(in srgb, var(--primary) 5%, transparent 95%)); }
.sidebar-menu li a i{ width:18px; text-align:center; font-size:14px; color:var(--primary); }

/* ===== Sidebar Footer ===== */
.sideFooter{
  flex-shrink:0;
  margin-top:8px;
  font-size:11px;
  color:var(--muted);
  border-top:1px solid var(--border);
  padding-top:10px;
}
/* PMS sidebar-footer alias */
.sidebar-footer{ flex-shrink:0; margin-top:8px; border-top:1px solid var(--border); padding-top:12px; display:flex; flex-direction:column; gap:8px; }
.user-info{ display:flex; align-items:center; gap:10px; padding:8px; background:var(--card2); border-radius:8px; border:1px solid var(--border); }
.user-info i{ font-size:24px; color:var(--primary); }
.user-details .user-name{ font-weight:700; font-size:13px; color:var(--text); }
.user-details .user-role{ font-size:11px; color:var(--muted); }
.lang-toggle{ display:flex; align-items:center; gap:8px; padding:6px 8px; }
.lang-toggle a{ font-size:12px; font-weight:600; padding:4px 10px; border-radius:6px; border:1px solid var(--border); color:var(--text); background:var(--card); }
.lang-toggle a.active{ background:var(--gradient-primary); color:#fff; border-color:transparent; }
.sidebar-actions .btn{ width:100%; justify-content:center; }

/* Repairslab-style: tindakan akaun di footer sidebar */
.sideFooter{
  flex-shrink:0;
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid var(--border);
  font-size:11px;
  color:var(--muted);
  animation:fadeIn 1s ease-out 0.5s both;
}
.sideFooter-userCard{
  margin-bottom:10px;
  padding:8px 10px;
  background:var(--card2);
  border-radius:8px;
  border:1px solid var(--border);
}
.sideFooter-userRole{ font-size:11px; color:var(--muted); }
.sideFooter-userName{
  font-weight:600;
  font-size:13px;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sideFooter-btn{
  width:100%;
  display:block;
  text-align:left;
  margin-bottom:6px;
  padding:7px 10px;
  font-size:13px;
  box-sizing:border-box;
}
.sideFooter-btn--last{ margin-bottom:0; }

/* ===== Top Bar ===== */
.top{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:16px;
  margin-bottom:24px;
  animation:fadeIn 0.6s ease-out 0.2s both;
  flex-wrap:wrap;
}
.top-actions{ display:flex; align-items:center; gap:16px; margin-left:auto; }

/* ===== Cards ===== */
.card{
  background:linear-gradient(135deg,#ffffff 0%,#fefbff 100%);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  margin-bottom:16px;
  box-shadow:var(--shadow-lg);
  transition:all 0.3s ease;
  animation:fadeIn 0.8s ease;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:2px;
  background:var(--gradient-primary);
  transform:scaleX(0);
  transition:transform 0.4s ease;
}
/* No translateY on hover — moving the card breaks hover hit-testing at bottom/inner edges (table flicker). */
.card:hover{
  box-shadow:0 8px 24px rgba(102,126,234,0.18);
  border-color:color-mix(in srgb, var(--primary) 30%, var(--border) 70%);
}
.card:hover::before{ transform:scaleX(1); }

/* Senarai projek PM: elak jadual kelihatan “hilang” jika overflow dipotong */
.card--projects-list{
  overflow:visible;
}
.projects-sort-hint .sort-sep{
  margin:0 6px;
  user-select:none;
}
/* Jadual senarai projek PM: elak animasi opacity sesetengah pelayar “zaman animasi” */
.card--projects-list .pm-projects-table{
  animation:none;
  opacity:1;
}

/* PMS card-header alias */
.card-header{
  font-size:15px; font-weight:700; color:var(--text);
  border-bottom:2px solid var(--border);
  padding-bottom:12px; margin-bottom:16px;
  display:flex; align-items:center; gap:8px;
}
.card-header i{ color:var(--primary); }

/* PMS mb-4 utility */
.mb-4{ margin-bottom:24px; }
.mt-3{ margin-top:16px; }

/* ===== Grid ===== */
.grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:16px; animation:fadeIn 0.6s ease-out 0.3s both; }
.kpi{ grid-column:span 3; }
.wide{ grid-column:span 12; }
/* PMS grid aliases */
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.dashboard-summary-grid-5{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(168px, 1fr));
  gap:16px;
}
.gap-2{ gap:16px; }

/* ===== Typography ===== */
h2{
  margin:0 0 14px;
  font-size:16px; font-weight:700; color:var(--text);
  position:relative; padding-bottom:12px;
}
h2::after{
  content:''; position:absolute; left:0; bottom:0;
  width:40px; height:3px;
  background:var(--gradient-primary); border-radius:2px;
}
.num{
  font-size:36px; font-weight:800; margin-top:8px;
  background:var(--gradient-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ===== Stat Cards (PMS) ===== */
.stat-card{ text-align:center; }
.stat-card-value{
  font-size:36px; font-weight:800;
  background:var(--gradient-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-card-label{ font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:0.5px; margin-top:4px; }
.stat-card-icon{ font-size:28px; margin-bottom:8px; opacity:0.7; }
.kpi .card{ text-align:center; }
.kpi .card:nth-child(4n+1){ border-top:3px solid var(--primary); }
.kpi .card:nth-child(4n+2){ border-top:3px solid var(--success); }
.kpi .card:nth-child(4n+3){ border-top:3px solid var(--warning); }
.kpi .card:nth-child(4n+4){ border-top:3px solid var(--danger); }

/* ===== Forms ===== */
label{ display:block; font-size:13px; font-weight:600; color:var(--text); margin:12px 0 6px; }
/* PMS form-label alias */
.form-label{ display:block; font-size:13px; font-weight:600; color:var(--text); margin:0 0 6px; }
.form-label.required::after{ content:' *'; color:var(--danger); }
/* PMS form-group alias */
.form-group{ margin-bottom:16px; }
.form-control{
  display:block; width:100%; padding:10px 12px; font-size:14px;
  line-height:1.4; border:1px solid var(--border); border-radius:10px; background:#fff; color:var(--text);
  box-sizing:border-box; transition:border-color 0.2s, box-shadow 0.2s;
}
.form-control:focus{
  outline:none; border-color:var(--primary);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 22%, transparent);
}

input,select,textarea,
.form-input,.form-select,.form-textarea{
  width:100%; padding:10px 14px;
  border:2px solid var(--border); border-radius:10px;
  font-size:14px; background:var(--card); color:var(--text);
  transition:all 0.2s ease; font-family:inherit;
}
input:focus,select:focus,textarea:focus,
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 12%, transparent 88%);
}
input:hover,select:hover,textarea:hover,
.form-input:hover,.form-select:hover,.form-textarea:hover{
  border-color:color-mix(in srgb, var(--primary) 40%, var(--border) 60%);
}
input[type="checkbox"],input[type="radio"]{ width:auto; }
textarea,.form-textarea{ min-height:100px; resize:vertical; line-height:1.6; }
::placeholder{ color:var(--muted); opacity:0.7; }

.row{ display:grid; grid-template-columns:repeat(12,1fr); gap:14px; width:100%; }
.col6{ grid-column:span 6; min-width:0; }
.col12{ grid-column:span 12; min-width:0; }
.actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:20px; align-items:center; }

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:10px 18px; border-radius:10px; text-decoration:none; border:0;
  cursor:pointer; font-size:14px; font-weight:600;
  transition:all 0.25s ease; position:relative; overflow:hidden;
  box-shadow:var(--shadow);
}
.btn:hover{ transform:translateY(-1px); box-shadow:0 4px 12px rgba(102,126,234,0.25); }
.btn:active{ transform:translateY(0); }

/* Primary (purple gradient) */
.btn-primary,.btnPrimary{
  background:var(--gradient-primary); color:#fff; box-shadow:var(--shadow-lg);
}
.btn-primary:hover,.btnPrimary:hover{ box-shadow:0 6px 16px rgba(102,126,234,0.3); transform:translateY(-1px); color:#fff; }

/* Secondary (ghost) */
.btn-secondary,.btnGhost{
  background:var(--card); color:var(--text); border:2px solid var(--border);
}
.btn-secondary:hover,.btnGhost:hover{ border-color:var(--primary); background:color-mix(in srgb, var(--primary) 8%, var(--card) 92%); transform:translateY(-2px); }

/* Success */
.btn-success{
  background:linear-gradient(135deg, #10b981 0%, #0ca678 100%); color:#fff;
  box-shadow:0 4px 12px rgba(16,185,129,0.3);
}
.btn-success:hover{ box-shadow:0 6px 20px rgba(16,185,129,0.4); transform:translateY(-2px); color:#fff; }

/* Danger */
.btn-danger,.btnDanger{
  background:linear-gradient(135deg, var(--danger) 0%, color-mix(in srgb, var(--danger) 85%, #000 15%) 100%);
  color:#fff; box-shadow:0 4px 12px rgba(239,68,68,0.3);
}
.btn-danger:hover,.btnDanger:hover{ box-shadow:0 6px 20px rgba(239,68,68,0.4); transform:translateY(-2px); color:#fff; }

/* Info */
.btn-info{
  background:linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%); color:#fff;
  box-shadow:0 4px 12px rgba(14,165,233,0.3);
}
.btn-info:hover{ box-shadow:0 6px 20px rgba(14,165,233,0.4); transform:translateY(-2px); color:#fff; }

/* Warning */
.btn-warning{
  background:linear-gradient(135deg, var(--warning) 0%, #d97706 100%); color:#fff;
  box-shadow:0 4px 12px rgba(245,158,11,0.3);
}
.btn-warning:hover{ box-shadow:0 6px 20px rgba(245,158,11,0.4); transform:translateY(-2px); color:#fff; }

/* Small */
.btn-sm{ padding:6px 14px; font-size:12px; }

/* ===== Alerts / Messages ===== */
.alert,.success,.error{
  padding:14px 18px; border-radius:12px; margin:12px 0;
  font-weight:500; display:flex; align-items:flex-start; gap:12px; line-height:1.5;
}
.alert-success,.success{
  background:linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
  border:2px solid var(--success); color:#065f46;
  animation:slideInRight 0.5s ease-out;
  box-shadow:0 4px 12px rgba(16,185,129,0.2);
}
.alert-error,.error{
  background:linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
  border:2px solid var(--danger); color:#991b1b;
  animation:slideInRight 0.5s ease-out;
  box-shadow:0 4px 12px rgba(239,68,68,0.2);
}
.alert-info{
  background:linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
  border:2px solid #3b82f6; color:#1e40af;
}
.alert-warning{
  background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  border:2px solid var(--warning); color:#92400e;
}

/* ===== Tables ===== */
table{
  width:100%; border-collapse:separate; border-spacing:0;
  animation:fadeIn 0.6s ease-out;
}
.table{ width:100%; border-collapse:separate; border-spacing:0; }
thead{ background:var(--gradient-primary); color:#fff !important; box-shadow:0 4px 12px rgba(102,126,234,0.25); }
th{
  padding:12px 14px; text-align:left;
  font-size:12px; font-weight:700; text-transform:uppercase;
  letter-spacing:0.4px; border-bottom:2px solid var(--primary);
  color:#fff !important; background:transparent;
}
th:first-child{ border-top-left-radius:10px; }
th:last-child{ border-top-right-radius:10px; }

/* Kalendar mingguan jadual (admin/PM): elak th global (warna putih) pada latar cerah */
table.schedule-week-calendar thead{
  background:transparent !important;
  box-shadow:none !important;
  color:#1e1b3a !important;
}
table.schedule-week-calendar thead th{
  color:#1e1b3a !important;
  background:linear-gradient(180deg, #cfc6e8 0%, #c2b6e0 100%) !important;
  border-bottom:2px solid color-mix(in srgb, var(--primary) 45%, #9b8bc4);
  text-shadow:none;
}
/* Petak hari (admin/PM): klik → tambah jadual ikut tarikh */
table.schedule-week-calendar .schedule-cal-day-cell{
  transition:filter 0.15s ease;
}
table.schedule-week-calendar .schedule-cal-day-cell:hover{
  filter:brightness(0.97);
}
tbody tr{
  border-bottom:1px solid var(--border);
  /* Avoid transform on row hover — scale() shifts layout/hit-testing and causes cursor flicker. */
  transition:background 0.2s ease;
  background:#ffffff;
}
tbody tr:hover{
  background:linear-gradient(135deg, #f0f4ff 0%, #faf6ff 100%);
}
td{ padding:11px 14px; font-size:13px; color:var(--text); }
td:last-child{ white-space:nowrap; }
tbody tr:last-child{ border-bottom:0; }
tbody tr:last-child td:first-child{ border-bottom-left-radius:12px; }
tbody tr:last-child td:last-child{ border-bottom-right-radius:12px; }

/* PMS table-sm alias */
.table-sm th,.table-sm td{ padding:8px 12px; font-size:12px; }

/* ===== Table Wrapper ===== */
.table-wrapper{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:12px;
  margin-bottom:16px;
}
/* Row action buttons: disable lift — transform fights table row hover hit-testing */
.table-wrapper .btn:hover{
  transform:none;
}
th.table-cell--currency,
td.table-cell--currency{
  text-align:right;
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
td.table-cell--currency{
  font-weight:700;
  color:var(--primary);
}
.table-row-actions{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  align-items:center;
}

/* Admin — Jadual Kerja: readable title stack + action spacing */
.admin-schedules-table tbody tr.admin-schedule-row td{
  vertical-align:top;
  padding-top:13px;
  padding-bottom:12px;
}
.admin-schedules-table tbody tr.admin-schedule-row td.col-num{
  text-align:center;
  color:var(--muted);
  font-weight:700;
  font-size:12px;
  width:40px;
}
.admin-schedules-table tbody tr.admin-schedule-row td.col-status{
  white-space:nowrap;
}
.admin-schedules-table tbody tr.admin-schedule-row td.col-done,
.admin-schedules-table tbody tr.admin-schedule-row td.col-actions{
  padding-top:16px;
}
/* Telah lepas / ditanda selesai — kelabu sederhana, masih jelas */
.admin-schedules-table tbody tr.admin-schedule-row--past{
  background:color-mix(in srgb, var(--muted) 10%, var(--card));
  box-shadow:inset 3px 0 0 color-mix(in srgb, var(--muted) 38%, transparent);
}
.admin-schedules-table tbody tr.admin-schedule-row--past .schedule-title-text{
  color:color-mix(in srgb, var(--text) 72%, var(--muted));
}
.admin-schedules-table tbody tr.admin-schedule-row--past td.col-num{
  color:color-mix(in srgb, var(--muted) 85%, var(--text));
}
.admin-schedules-table tbody tr.admin-schedule-row--past .badge{
  opacity:0.93;
  filter:saturate(0.9);
}
.admin-schedules-table tbody tr.admin-schedule-row--past .table-row-actions .btn{
  opacity:0.95;
}
/* PM — senarai jadual: baris lepas / selesai (selaras admin) */
tbody tr.pm-schedule-row--past{
  background:color-mix(in srgb, var(--muted) 10%, var(--card));
  box-shadow:inset 3px 0 0 color-mix(in srgb, var(--muted) 38%, transparent);
}
tbody tr.pm-schedule-row--past td{
  color:color-mix(in srgb, var(--text) 78%, var(--muted));
}
tbody tr.pm-schedule-row--past strong{
  color:color-mix(in srgb, var(--text) 70%, var(--muted));
}
tbody tr.pm-schedule-row--past .badge{
  opacity:0.93;
  filter:saturate(0.9);
}
tbody tr.pm-schedule-row--past .btn{
  opacity:0.95;
}
.admin-schedules-table td.schedule-cell-title{
  white-space:normal;
  max-width:min(400px,42vw);
  vertical-align:top;
  line-height:1.45;
}
.admin-schedules-table .schedule-title-badges{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px;
  margin:0 0 8px 0;
}
.admin-schedules-table .schedule-title-badges .badge{
  flex-shrink:0;
  white-space:nowrap;
  font-size:10px !important;
  padding:4px 9px;
  line-height:1.2;
  border-radius:6px;
}
.admin-schedules-table .schedule-title-text{
  font-size:14px;
  font-weight:600;
  line-height:1.35;
  color:var(--text);
  word-break:break-word;
}
.admin-schedules-table .schedule-title-meta{
  display:flex;
  align-items:flex-start;
  gap:7px;
  font-size:12px;
  color:var(--muted);
  margin-top:8px;
  line-height:1.45;
}
.admin-schedules-table .schedule-title-meta i{
  margin-top:3px;
  flex-shrink:0;
  opacity:0.88;
  width:14px;
  text-align:center;
}
.admin-schedules-table .schedule-title-notes{
  margin-top:6px;
}
.admin-schedules-table th.col-done,
.admin-schedules-table td.col-done{
  width:56px;
  min-width:56px;
  text-align:center;
  vertical-align:top;
  padding-left:10px;
  padding-right:10px;
}
.admin-schedules-table th.col-actions,
.admin-schedules-table td.col-actions{
  min-width:172px;
  vertical-align:top;
}
.admin-schedules-table th.col-status{
  white-space:nowrap;
}
.admin-schedules-table .table-row-actions{
  gap:10px;
  justify-content:flex-start;
}
.admin-schedules-table .table-row-actions .btn{
  min-width:40px;
  min-height:36px;
  padding:7px 11px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
}
.admin-schedules-table td.col-requester{
  max-width:170px;
  white-space:normal;
  word-break:break-word;
  vertical-align:top;
  font-size:12px;
  line-height:1.4;
}
.admin-schedules-table td.col-project{
  max-width:150px;
  white-space:normal;
  word-break:break-word;
  vertical-align:top;
  font-size:12px;
  line-height:1.4;
}
.admin-schedules-table td.col-date{
  vertical-align:top;
}

/* Admin projects: search toolbar */
.projects-toolbar{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.projects-search-wrap{ position:relative; }
.projects-search-input{
  padding:8px 36px 8px 14px;
  border:2px solid var(--border);
  border-radius:10px;
  font-size:13px;
  width:min(260px,100%);
  background:#fff;
}
.projects-search-input:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 12%, transparent 88%);
}
.projects-search-icon{
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  color:var(--muted);
  pointer-events:none;
}
.projects-sort-hint a{
  color:var(--primary);
  text-decoration:none;
  font-weight:600;
}
.projects-sort-hint a:hover{ text-decoration:underline; }
.projects-sort-hint a.projects-sort--active{
  color:var(--text);
  text-decoration:underline;
  font-weight:700;
}

/* Delete project modal */
.modal-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.6);
  z-index:9999;
  align-items:center;
  justify-content:center;
}
.modal-overlay.is-open,
.modal-overlay.active{ display:flex; }
.modal-dialog{
  background:#fff;
  border-radius:16px;
  padding:32px;
  max-width:440px;
  width:90%;
  box-shadow:0 20px 60px rgba(0,0,0,0.3);
}
.modal-dialog--narrow{ max-width:400px; padding:24px 26px 28px; }
.modal-dialog__hdr{
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
  margin-bottom:16px;
}
.modal-dialog__title{ font-size:18px; font-weight:700; color:var(--text); margin:0; line-height:1.25; flex:1; }
.modal-dialog__close{
  flex-shrink:0; width:36px; height:36px; border:none; border-radius:10px;
  background:color-mix(in srgb, var(--muted) 12%, transparent); color:var(--text);
  font-size:22px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center;
}
.modal-dialog__close:hover{ background:color-mix(in srgb, var(--muted) 22%, transparent); }
.modal-dialog__footer{ display:flex; gap:12px; margin-top:8px; }
.modal-dialog__footer .btn{ flex:1; }

/* Modal tukar kata laluan (footer global) */
.changePw-field{ position:relative; }
.changePw-field .form-control{ padding-right:44px; }
.changePw-toggle{
  position:absolute; right:6px; top:50%; transform:translateY(-50%);
  border:none; background:transparent; cursor:pointer; color:var(--muted);
  padding:8px; font-size:15px; line-height:1; border-radius:8px;
}
.changePw-toggle:hover{ color:var(--text); background:color-mix(in srgb, var(--primary) 8%, transparent); }
.changePw-match{ font-size:12px; margin-top:6px; min-height:1.25em; }
.changePw-match--ok{ color:var(--success, #16a34a); font-weight:600; }
.changePw-match--bad{ color:var(--danger, #dc2626); font-weight:600; }

mark.search-highlight{
  background:#fef08a;
  border-radius:3px;
  padding:0 2px;
}
.po-chip{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:12px;
  background:color-mix(in srgb,var(--success) 10%,white);
  color:var(--success);
  padding:3px 8px;
  border-radius:6px;
  border:1px solid color-mix(in srgb,var(--success) 25%,white);
}

/* Admin projects list: kunci suntingan (lihat di senarai) */
.project-editing-lock{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-left:6px;
  font-size:12px;
  vertical-align:middle;
  opacity:0.9;
}
.project-editing-lock--completed{
  color:var(--warning, #ca8a04);
}
.project-editing-lock--pm{
  color:color-mix(in srgb, var(--primary) 85%, var(--muted));
}

/* Admin project view: baris butang tukar status (rapat & sebaris rata) */
.project-status-quick-form{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(118px, 1fr));
  gap:10px;
  align-items:stretch;
}
.project-status-quick-form .project-status-quick-btn{
  white-space:normal;
  line-height:1.28;
  padding:10px 10px;
  min-height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  box-sizing:border-box;
}
@media (max-width:560px){
  .project-status-quick-form{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

/* ===== Badges ===== */
.badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:999px;
  font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:0.4px;
  white-space:nowrap;
  transition:all 0.3s ease;
}
.badge::before{ content:''; width:7px; height:7px; border-radius:50%; animation:pulse 2s ease-in-out infinite; }

.badge-success,.badge-completed{
  background:color-mix(in srgb, var(--success) 15%, transparent 85%);
  color:var(--success); border:1px solid var(--success);
}
.badge-success::before,.badge-completed::before{ background:var(--success); }

.badge-warning,.badge-pending{
  background:color-mix(in srgb, var(--warning) 15%, transparent 85%);
  color:var(--warning); border:1px solid var(--warning);
}
.badge-warning::before,.badge-pending::before{ background:var(--warning); }

.badge-danger,.badge-cancelled{
  background:color-mix(in srgb, var(--danger) 15%, transparent 85%);
  color:var(--danger); border:1px solid var(--danger);
}
.badge-danger::before,.badge-cancelled::before{ background:var(--danger); }

.badge-primary,.badge-active{
  background:color-mix(in srgb, var(--primary) 15%, transparent 85%);
  color:var(--primary); border:1px solid var(--primary);
}
.badge-primary::before,.badge-active::before{ background:var(--primary); }

.badge-secondary{
  background:color-mix(in srgb, var(--muted) 15%, transparent 85%);
  color:var(--muted); border:1px solid var(--muted);
}
.badge-secondary::before{ background:var(--muted); }

.badge-info{
  background:color-mix(in srgb, #0ea5e9 15%, transparent 85%);
  color:#0ea5e9; border:1px solid #0ea5e9;
}
.badge-info::before{ background:#0ea5e9; }

.badge-awaiting_dept_payment{
  background:color-mix(in srgb, #0ea5e9 15%, transparent 85%);
  color:#0369a1; border:1px solid #0ea5e9;
}
.badge-awaiting_dept_payment::before{ background:#0ea5e9; }

/* ===== Page Header ===== */
.page-header,.content-header{
  background:var(--gradient-primary);
  border-radius:16px; padding:22px 28px; margin-bottom:24px;
  color:#fff; box-shadow:var(--shadow-xl);
  position:relative; overflow:hidden;
  animation:slideDown 0.8s ease;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:12px;
}
.page-header::before{
  content:''; position:absolute; top:-50%; right:-20%;
  width:300px; height:300px;
  background:radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%);
  border-radius:50%;
}
.page-header-title,.content-title{
  font-size:22px; font-weight:700; margin:0;
  display:flex; align-items:center; gap:10px;
  text-shadow:0 2px 10px rgba(0,0,0,0.2); color:#fff;
}
.content-header-lead{ flex:1; min-width:200px; position:relative; z-index:2; }
.content-header-sub{
  margin:10px 0 0;
  font-size:13px;
  font-weight:500;
  opacity:0.92;
  line-height:1.45;
  color:rgba(255,255,255,0.95);
}
.content-title--compact{
  font-size:clamp(16px, 2.5vw, 20px);
  flex-wrap:wrap;
}
/* Paparan projek: syarikat dalam subtitle (bold) + kad konteks putih */
.project-view-company-inline{
  font-weight:800;
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-color:rgba(255,255,255,0.45);
}
.project-view-context-card{
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.project-view-context-card__body{
  padding:16px 18px !important;
}
.project-view-context-card__grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:14px 24px;
  align-items:start;
}
.project-view-context-card__label{
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:var(--muted);
  margin-bottom:4px;
}
.project-view-context-card__value{
  font-size:15px;
  font-weight:700;
  color:var(--text);
  line-height:1.35;
  word-break:break-word;
}
.project-view-context-card__value--money{
  font-size:17px;
  color:var(--primary);
  font-variant-numeric:tabular-nums;
}
/* Paparan projek — jadual kos barang ikut kumpulan (spacing sahaja; markup: project_view_barang_grouped.php) */
.project-view-barang-grouped{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  margin:0;
}
.project-view-barang-grouped thead th{
  padding:12px 14px;
  vertical-align:middle;
}
.project-view-barang-grouped tbody td{
  padding:12px 14px;
  vertical-align:middle;
  border-bottom:1px solid color-mix(in srgb,var(--border) 88%,transparent);
  font-size:13px;
}
.project-view-barang-grouped__head td{
  padding:11px 14px;
  vertical-align:middle;
  border-bottom:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));
  background:color-mix(in srgb,var(--primary) 6%,#f8f9fc);
}
.project-view-barang-grouped__head-line{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px 14px;
  line-height:1.45;
}
.project-view-barang-grouped__supplier{
  font-size:13px;
  font-weight:700;
}
.project-view-barang-grouped__inv-badge{
  font-size:11px;
}
.project-view-barang-grouped__head-sum{
  font-size:12px;
}
.project-view-barang-grouped__head-sum strong{
  font-variant-numeric:tabular-nums;
}
.project-view-barang-grouped__head-pv{
  vertical-align:middle !important;
  padding:11px 14px !important;
}
.project-view-barang-grouped__cell-num{
  text-align:center;
  font-weight:600;
}
.project-view-barang-grouped__cell-item--indented{
  padding-left:20px !important;
}
@media (max-width:720px){
  .project-view-barang-grouped thead th,
  .project-view-barang-grouped tbody td{
    padding:10px 10px;
    font-size:12px;
  }
  .project-view-barang-grouped__head td,
  .project-view-barang-grouped__head-pv{
    padding:10px 10px !important;
  }
  .project-view-barang-grouped__head-line{
    gap:6px 10px;
  }
  .project-view-barang-grouped__cell-item--indented{
    padding-left:14px !important;
  }
}
.page-header-subtitle{ font-size:14px; margin-top:8px; opacity:0.9; }
.page-header-actions,.content-actions{
  display:flex; gap:10px; flex-wrap:wrap; align-items:center;
  position:relative; z-index:2;
}
.page-header-actions .btn,.content-actions .btn{
  background:rgba(255,255,255,0.2); color:#fff;
  border:2px solid rgba(255,255,255,0.4);
  backdrop-filter:blur(10px);
}
.page-header-actions .btn:hover,.content-actions .btn:hover{
  background:rgba(255,255,255,0.3);
  border-color:rgba(255,255,255,0.6);
  transform:translateY(-2px);
}
.content-actions .btn-primary{ background:#fff; color:var(--primary); border:2px solid #fff; }
.content-actions .btn-primary:hover{ background:rgba(255,255,255,0.95); transform:translateY(-2px); }

/* ===== Login Page ===== */
.login-container{
  display:flex; justify-content:center; align-items:center;
  min-height:100vh; padding:20px;
  background:var(--gradient-bg);
}
.login-card{
  background:#fff; border-radius:20px;
  padding:40px; max-width:420px; width:100%;
  box-shadow:var(--shadow-xl); text-align:center;
  animation:scaleIn 0.5s ease-out;
  border:1px solid var(--border);
  position:relative; overflow:hidden;
}
.login-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:var(--gradient-primary);
}
.login-logo{ max-width:120px; margin:0 auto 16px; display:block; }
.login-title{ font-size:22px; font-weight:700; color:var(--text); margin-bottom:4px; }
.login-subtitle{ font-size:14px; color:var(--muted); margin-bottom:28px; }

/* ===== Status Color Utilities ===== */
.text-success{ color:var(--success); }
.text-danger{ color:var(--danger); }
.text-warning{ color:var(--warning); }
.text-primary{ color:var(--primary); }
.text-muted{ color:var(--muted); }

/* ===== Loading ===== */
.loading{
  display:inline-block; width:20px; height:20px;
  border:3px solid var(--border); border-top-color:var(--primary);
  border-radius:50%; animation:spin 0.6s linear infinite;
}

/* ===== Scrollbar ===== */
::-webkit-scrollbar{ width:8px; height:8px; }
::-webkit-scrollbar-track{ background:var(--card2); border-radius:10px; }
::-webkit-scrollbar-thumb{ background:var(--gradient-primary); border-radius:10px; }

/* ===== Divider ===== */
.divider{ height:1px; background:linear-gradient(90deg, transparent 0%, var(--border) 50%, transparent 100%); margin:20px 0; }

/* ===== Empty State ===== */
.empty-state{ text-align:center; padding:60px 20px; color:var(--muted); }
.empty-state i,.empty-state-icon{ font-size:56px; opacity:0.3; margin-bottom:16px; display:block; }
.empty-state p{ font-size:16px; font-weight:600; margin-bottom:8px; }

/* ===== Focus Visible ===== */
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--primary); outline-offset:2px;
}

/* ===== Reduce Motion ===== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:0.01ms !important; transition-duration:0.01ms !important; }
}

/* ===== Print ===== */
@media print{
  .sidebar,#menuBtn,.sideOverlay,.sidebar-toggle,.sidebar-overlay,.btn,.actions,.page-header-actions,.content-actions{ display:none !important; }
  .main,.main-content{ padding:0; }
  .card{ box-shadow:none; border:1px solid #ddd; }
}

/* ===== Mobile Button ===== */
#menuBtn{
  display:none; align-items:center; justify-content:center; gap:8px;
  padding:10px 16px; background:var(--card); border:2px solid var(--border);
  border-radius:12px; cursor:pointer; font-weight:600; font-size:14px; color:var(--text);
  transition:all 0.3s ease;
}
#menuBtn:hover{ border-color:var(--primary); background:color-mix(in srgb, var(--primary) 8%, var(--card) 92%); }

/* ===== Side Overlay (Mobile) ===== */
.sideOverlay,.sidebar-overlay{
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,0.55); backdrop-filter:blur(4px);
  z-index:999; animation:fadeIn 0.3s ease;
}
.sideOverlay.show,.sidebar-overlay.show,.sidebar-overlay.active{ display:block; }

/* ===== Responsive ===== */
@media (max-width:980px){
  #menuBtn{ display:inline-flex; }
  .kpi{ grid-column:span 6; }
  .col6{ grid-column:span 12 !important; }
}

@media (max-width:720px){
  #menuBtn{ display:inline-flex; }
  .sidebar{
    position:fixed; top:0; left:-100%;
    width:280px; min-width:280px; height:100vh;
    z-index:1000; transition:left 0.3s cubic-bezier(0.4,0,0.2,1);
    box-shadow:var(--shadow-xl);
  }
  .sidebar.open,.sidebar.active{ left:0; }
  .main,.main-content{ padding:16px 12px; }
  .kpi{ grid-column:span 12; }
  .grid-2,.grid-3,.grid-4,.dashboard-summary-grid-5{ grid-template-columns:1fr; }
  .col6{ grid-column:span 12 !important; }
  .card{ padding:16px; border-radius:12px; }
  .top{ position:sticky; top:0; background:var(--bg); z-index:998; padding:10px 0; margin-bottom:16px; }
  .page-header,.content-header{ padding:18px 16px; border-radius:12px; }
  .page-header-title,.content-title{ font-size:18px; }
  h2{ font-size:15px; }
  .num,.stat-card-value{ font-size:26px; }
  input,select,textarea,.form-input,.form-select,.form-textarea{ font-size:16px; }
  .btn-sm{ min-height:36px; }
  .table{ display:block; overflow-x:auto; white-space:nowrap; }
  table{ display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; white-space:nowrap; }
  thead{ display:table; width:100%; table-layout:auto; }
  tbody{ display:table; width:100%; table-layout:auto; }
  th,td{ padding:9px 8px; font-size:12px; min-width:80px; }
  .table-wrapper{ margin:0 -16px 16px; border-radius:0; }
  .actions{ flex-direction:column; }
  .actions .btn{ width:100%; justify-content:center; }
  table .btn,td .btn{ width:auto !important; min-width:auto; font-size:12px; padding:7px 10px; }
  /* Jadual admin: jangan paksa nowrap — tajuk & nota perlu wrap */
  table.admin-schedules-table,
  table.admin-schedules-table td{
    white-space:normal;
  }
  table.admin-schedules-table td.col-date{
    white-space:nowrap;
  }
  table.admin-schedules-table td.col-actions{
    white-space:nowrap;
  }
  /* Senarai projek admin — benarkan wrap, elak baris “hilang” pada skrin kecil */
  table.admin-projects-table,
  table.admin-projects-table td{
    white-space:normal;
  }
  table.admin-projects-table td.table-cell--currency,
  table.admin-projects-table td:last-child{
    white-space:nowrap;
  }
  table.admin-schedules-table td.col-actions .table-row-actions .btn{
    min-width:40px !important;
  }
}

@media (max-width:480px){
  .main,.main-content{ padding:10px 8px; }
  .card{ padding:12px; }
  .page-header,.content-header{ padding:14px 12px; }
  h2{ font-size:14px; }
  .num,.stat-card-value{ font-size:22px; }
}

@media (hover:none) and (pointer:coarse){
  .btn{ min-height:46px; padding:12px 20px; }
  input,select,textarea,.form-input,.form-select,.form-textarea{ min-height:46px; font-size:16px; }
  .nav a,.sidebar-menu li a{ min-height:50px; }
}

/* ===== Tabs ===== */
.tabs{
  display:flex;
  gap:4px;
  margin-bottom:24px;
  border-bottom:2px solid var(--border);
  overflow-x:auto;
}
.tab{
  padding:10px 20px;
  background:transparent;
  border:none;
  border-bottom:3px solid transparent;
  margin-bottom:-2px;
  cursor:pointer;
  font-size:14px;
  font-weight:600;
  color:var(--muted);
  transition:all 0.2s ease;
  white-space:nowrap;
  border-radius:8px 8px 0 0;
}
.tab:hover{
  color:var(--primary);
  background:color-mix(in srgb,var(--primary) 6%,white);
}
.tab.active{
  color:var(--primary);
  border-bottom-color:var(--primary);
  background:color-mix(in srgb,var(--primary) 5%,white);
}
.tab-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:20px;
  height:20px;
  padding:0 6px;
  background:var(--danger);
  color:#fff;
  border-radius:99px;
  font-size:11px;
  font-weight:700;
  margin-left:6px;
}
.tab-content{ display:none; }
.tab-content.active{ display:block; }
.card-body{ padding:20px; }
.flex-between{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.ml-2{ margin-left:8px; }
.mr-2{ margin-right:8px; }
.mb-3{ margin-bottom:16px; }
.mb-4{ margin-bottom:24px; }
.mt-3{ margin-top:16px; }
.mt-4{ margin-top:24px; }
.text-center{ text-align:center; }
.text-right{ text-align:right; }
.w-100{ width:100%; }
.gap-2{ gap:16px; }

/* Impersonate PM (pentadbir → paparan PM) */
.impersonation-banner{
  background:linear-gradient(135deg, color-mix(in srgb, var(--warning) 24%, var(--card)), color-mix(in srgb, var(--warning) 10%, var(--card)));
  border:1px solid color-mix(in srgb, var(--warning) 40%, var(--border));
  border-radius:12px;
  padding:10px 14px;
  margin-bottom:16px;
  box-shadow:var(--shadow);
}
.impersonation-banner__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
}
.impersonation-banner__text{
  font-size:13px;
  font-weight:600;
  color:var(--text);
  display:flex;
  align-items:center;
  gap:8px;
  max-width:100%;
}
.table-actions-flex{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
}
.form-inline-impersonate{
  display:inline;
  margin:0;
}

/* ===== Stat Cards - Proper Card Style ===== */
.stat-card{
  background:linear-gradient(135deg,#ffffff 0%,#fefbff 100%);
  border:1px solid var(--border);
  border-radius:14px;
  padding:20px 16px;
  text-align:center;
  box-shadow:var(--shadow-lg);
  transition:all 0.3s ease;
  animation:fadeIn 0.8s ease;
  position:relative;
  overflow:hidden;
}
.stat-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--gradient-primary); transform:scaleX(0); transition:transform 0.4s ease;
}
.stat-card:hover{ box-shadow:0 8px 24px rgba(102,126,234,0.18); transform:translateY(-3px); }
.stat-card:hover::before{ transform:scaleX(1); }
.stat-card-value{
  font-size:38px; font-weight:800; margin:8px 0 4px;
  background:var(--gradient-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1.1;
}
.stat-card-label{
  font-size:11px; color:var(--muted); text-transform:uppercase;
  letter-spacing:0.6px; font-weight:600; margin-top:4px;
}
.stat-card-icon{ font-size:24px; margin-bottom:6px; opacity:0.6; }

/* Stat card color variants */
.stat-card.active .stat-card-value{ background:var(--primary); -webkit-background-clip:text; background-clip:text; }
.stat-card.completed .stat-card-value{ background:var(--success); -webkit-background-clip:text; background-clip:text; }
.stat-card.pending .stat-card-value{ background:var(--warning); -webkit-background-clip:text; background-clip:text; }
.stat-card.cancelled .stat-card-value{ background:var(--danger); -webkit-background-clip:text; background-clip:text; }
.stat-card.awaiting-dept .stat-card-value{
  background:linear-gradient(135deg,#0ea5e9 0%,#0369a1 100%);
  -webkit-background-clip:text;
  background-clip:text;
}
.stat-card.active{ border-top:3px solid var(--primary); }
.stat-card.completed{ border-top:3px solid var(--success); }
.stat-card.pending{ border-top:3px solid var(--warning); }
.stat-card.cancelled{ border-top:3px solid var(--danger); }
.stat-card.awaiting-dept{ border-top:3px solid #0ea5e9; }

/* ===== Dashboard ===== */
.dashboard-notice.alert{
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
}
.dashboard-notice .dashboard-notice__text{
  display:flex;
  align-items:flex-start;
  gap:10px;
  flex:1;
  min-width:200px;
}
.dashboard-notice .dashboard-notice__text i{
  margin-top:2px;
  opacity:0.85;
}
.stat-card-value--currency{
  font-size:clamp(20px, 2.6vw, 32px);
  line-height:1.15;
}
.dashboard-section-title{
  font-size:12px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.08em;
  margin:0 0 14px;
}
h2.dashboard-section-title{
  font-size:12px;
  color:var(--muted);
  padding-bottom:0;
  margin:0 0 14px;
}
h2.dashboard-section-title::after{ display:none; content:none; }

/* ===== Dashboard layout ===== */
.page-shell{
  max-width:1120px;
  margin:0 auto;
  width:100%;
}
.page-shell > .login-container{
  min-height:calc(100vh - 140px);
  padding:24px 12px;
}
.request-tabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.dashboard-section{
  margin-bottom:28px;
}
.dashboard-section:last-child{
  margin-bottom:0;
}
.dashboard .stat-card .stat-card-icon{
  width:48px;
  height:48px;
  margin:0 auto 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  background:color-mix(in srgb,var(--primary) 14%,white);
  font-size:18px;
  opacity:1;
}
.dashboard .stat-card.active .stat-card-icon{
  background:color-mix(in srgb,var(--primary) 18%,white);
}
.dashboard .stat-card.completed .stat-card-icon{
  background:color-mix(in srgb,var(--success) 18%,white);
}
.dashboard .stat-card.pending .stat-card-icon{
  background:color-mix(in srgb,var(--warning) 22%,white);
}
.dashboard .stat-card.cancelled .stat-card-icon{
  background:color-mix(in srgb,var(--danger) 16%,white);
}
.dashboard .stat-card.awaiting-dept .stat-card-icon{
  background:color-mix(in srgb,#0ea5e9 18%,white);
}
.dashboard-recent-card{
  box-shadow:var(--shadow-lg);
}

/* Dashboard admin — susun atur panel */
.dashboard-dual-grid{
  display:grid;
  gap:20px;
  margin-bottom:24px;
  grid-template-columns:1fr;
}
.dashboard-panel{
  background:linear-gradient(165deg,color-mix(in srgb,var(--primary) 5%,var(--card)) 0%,var(--card) 48%);
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px 18px 20px;
  box-shadow:var(--shadow-lg);
}
.dashboard-panel__title{
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--text);
  margin:0 0 6px;
}
.dashboard-panel__hint{
  font-size:12px;
  color:var(--muted);
  margin:0 0 16px;
  line-height:1.45;
}
.dashboard-kpi-grid{
  display:grid;
  gap:14px;
  grid-template-columns:repeat(auto-fit,minmax(148px,1fr));
}
/* Admin: grid KPI — elak lajur terlalu sempit (nilai RM terpotong) */
.dashboard--admin .dashboard-kpi-grid--5{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,180px),1fr));
}
@media (min-width:1200px){
  .dashboard--admin .dashboard-kpi-grid--5{
    grid-template-columns:repeat(5,minmax(0,1fr));
  }
}
.dashboard--admin .dashboard-panel .stat-card.stat-card--admin-kpi{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:12px;
  text-align:left;
  overflow:visible;
}
.dashboard--admin .dashboard-panel .stat-card.stat-card--admin-kpi .stat-card-icon{
  margin:0;
  flex-shrink:0;
}
.dashboard--admin .dashboard-panel .stat-card.stat-card--admin-kpi .stat-card-body{
  min-width:0;
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:2px;
  overflow:visible;
}
.dashboard--admin .dashboard-panel .stat-card.stat-card--admin-kpi .stat-card-value{
  margin:0;
  max-width:100%;
  width:100%;
  overflow:visible;
}
.dashboard--admin .dashboard-panel .stat-card.stat-card--admin-kpi .stat-card-label{
  margin:0;
  line-height:1.25;
  text-align:left;
  white-space:normal;
}

.dashboard--admin .dashboard-panel .stat-card{
  box-shadow:0 2px 10px rgba(0,0,0,.06);
  overflow:visible;
  min-width:0;
  padding:16px 12px;
}
.dashboard--admin .dashboard-panel .stat-card-value{
  margin-left:auto;
  margin-right:auto;
  max-width:100%;
}
.dashboard--admin .dashboard-panel .stat-card.stat-card--admin-kpi .stat-card-value{
  margin-left:0;
  margin-right:0;
}
/* Mata wang: jangan nowrap (boleh 2 baris) + skala ikut lebar — elak "RM 36,7…" terpotong */
.dashboard--admin .dashboard-panel .stat-card-value--currency{
  font-size:clamp(11px, 0.35rem + 1.55vw, 22px);
  line-height:1.2;
  white-space:normal;
  overflow:visible;
  overflow-wrap:anywhere;
  word-break:break-word;
  hyphens:manual;
  font-variant-numeric:tabular-nums;
}
.dashboard--admin .dashboard-panel .stat-card-label{
  line-height:1.35;
  max-width:100%;
}
.dashboard--admin .dashboard-panel .stat-card:hover{
  transform:translateY(-2px);
}
.dashboard-recent-tidy .dashboard-recent-tidy__header{
  border-bottom:1px solid var(--border);
  padding-bottom:12px;
  margin-bottom:0;
}
.dashboard-recent-tidy .dashboard-recent-tidy__title{
  font-weight:800;
  font-size:15px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.dashboard-recent-tidy .dashboard-recent-tidy__title i{
  color:var(--primary);
}
.dashboard-table-wrap table{
  width:100%;
}
.dashboard-table-wrap th:first-child,
.dashboard-table-wrap td:first-child{
  padding-left:16px;
}
.dashboard-table-wrap th:last-child,
.dashboard-table-wrap td:last-child{
  padding-right:16px;
}

@media (max-width:980px) and (min-width:721px){
  .grid-4{ grid-template-columns:repeat(2,1fr); }
}
@media (min-width:981px){
  .dashboard-status-grid .stat-card{
    min-height:148px;
    display:flex;
    flex-direction:column;
    justify-content:center;
  }
}
.content-title-badge{
  display:inline-flex;
  align-items:center;
  padding:4px 10px;
  margin-left:10px;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.04em;
  text-transform:uppercase;
  vertical-align:middle;
  border-radius:999px;
  background:rgba(255,255,255,0.22);
  border:1px solid rgba(255,255,255,0.45);
  text-shadow:none;
}
.card-body--flush{ padding:0 0 4px; }
.card-body--table{ padding:0; }

/* Senarai projek: asing aktif vs selesai (admin & PM) */
.projects-list-section{
  margin-bottom:1.5rem;
}
.projects-list-section:last-child{
  margin-bottom:0;
}
.projects-list-section__title{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  font-size:1rem;
  font-weight:700;
  margin:0 0 12px;
  padding:10px 14px;
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:10px;
  color:var(--text);
}
.projects-list-section__title .fa-briefcase,
.projects-list-section__title .fa-check-circle{
  opacity:0.85;
}
.projects-list-section__count{
  font-weight:600;
  font-size:12px;
}
.projects-list-section--completed .projects-list-section__title{
  background:rgba(100,116,139,0.08);
  border-style:dashed;
}
.projects-list-section--completed .table-wrapper{
  opacity:0.92;
}

/* Admin projects: "Lagi" dropdown (Permintaan / Bayar PM / bulk) */
.project-actions-dropdown{
  position:relative;
  display:inline-block;
}
.project-actions-dropdown__toggle{
  white-space:nowrap;
}
/* Panel position is set via JS (fixed) so it is not clipped by .table-wrapper overflow */
.project-actions-dropdown__panel{
  display:none;
  min-width:240px;
  max-width:min(280px,calc(100vw - 16px));
  max-height:min(70vh, calc(100vh - 24px));
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow:var(--shadow-lg);
  z-index:10000;
  padding:6px 0;
}
.project-actions-dropdown.is-open .project-actions-dropdown__panel{
  display:block;
}
.project-actions-dropdown__panel a,
.project-actions-dropdown__panel button{
  display:flex;
  align-items:center;
  gap:8px;
  width:100%;
  text-align:left;
  padding:10px 14px;
  font-size:13px;
  color:var(--text);
  text-decoration:none;
  border:none;
  background:none;
  cursor:pointer;
  font-family:inherit;
}
.project-actions-dropdown__panel a:hover,
.project-actions-dropdown__panel button:hover{
  background:var(--card2);
}
.project-actions-dropdown__sep{
  height:1px;
  background:var(--border);
  margin:6px 0;
}
.project-actions-dropdown__status-wrap{
  padding:10px 14px 8px;
}
.project-actions-dropdown__status-label{
  display:block;
  font-size:11px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.04em;
  margin-bottom:6px;
}
.project-actions-dropdown__panel .project-list-status-select{
  width:100%;
  max-width:none;
  box-sizing:border-box;
  font-size:13px;
  padding:8px 10px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
  font-family:inherit;
}
.project-actions-dropdown__danger{
  color:var(--danger)!important;
}

/* —— Jadual: kalendar admin / PM & legenda —— */
.schedule-page-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.schedule-page-filters{
  display:flex;
  gap:6px;
  margin-bottom:14px;
  flex-wrap:wrap;
  align-items:center;
}
.schedule-cal-card .schedule-cal-nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}
.schedule-cal-nav__link{
  text-decoration:none;
  font-weight:700;
  color:var(--primary);
  font-size:14px;
  padding:4px 8px;
  border-radius:8px;
  transition:background .15s ease,color .15s ease;
}
.schedule-cal-nav__link:hover{
  background:color-mix(in srgb,var(--primary) 12%,transparent);
  color:var(--primary-hover);
}
.schedule-cal-nav__title{
  font-weight:700;
  font-size:15px;
  color:var(--text);
}
.schedule-cal-table-wrap{
  padding:0;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.schedule-cal-legend{
  padding:10px 14px;
  font-size:11px;
  line-height:1.5;
  color:var(--muted);
  border-bottom:1px solid var(--border);
  background:color-mix(in srgb,var(--primary) 3%,var(--card));
}
.schedule-cal-legend__badges{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px 14px;
  margin-bottom:8px;
}
.schedule-cal-legend__chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-weight:600;
  color:var(--text);
  font-size:11px;
}
.schedule-cal-legend__swatch{
  display:inline-block;
  width:10px;
  height:10px;
  border-radius:2px;
  flex-shrink:0;
}
.schedule-cal-legend__swatch--onsite{
  background:linear-gradient(135deg,#ef4444,#b91c1c);
}
.schedule-cal-legend__swatch--onsite-van{
  background:linear-gradient(135deg,#2dd4bf,#0f766e);
}
.schedule-cal-legend__swatch--task{
  background:linear-gradient(135deg,#f59e0b,#d97706);
}
.schedule-cal-legend__swatch--event{
  background:linear-gradient(135deg,#0ea5e9,#0369a1);
}
.schedule-cal-legend__list{
  margin:0;
  padding-left:1.15rem;
  color:var(--muted);
}
.schedule-cal-legend__list li{
  margin:4px 0;
}
.schedule-cal-legend__tip{
  color:var(--muted);
}
