/* App-wide layout and dashboard styles extracted from dashboard.php */
/* Global box sizing to prevent overflow caused by padding */
*, *::before, *::after{ box-sizing:border-box }

:root{
  --bg-app:#eef4f7;
  --bg-surface:#ffffff;
  --bg-surface-soft:#f6f9fc;
  --bg-surface-muted:#eaf1f7;
  --bg-hero-start:#ffffff;
  --bg-hero-end:#f3f8fb;
  --text-strong:#1a202c;
  --text-body:#4a5568;
  --text-muted:#8a9bb0;
  --text-soft:#a0aec0;
  --brand:#3d8b37;
  --brand-strong:#2e7d32;
  --brand-soft:#e8f5e9;
  --brand-soft-2:#dcedd8;
  --accent-blue:#2563eb;
  --accent-blue-strong:#1d4ed8;
  --accent-blue-soft:#e8f0ff;
  --accent-blue-soft-2:#dbe8ff;
  --accent-blue-border:#cfe0ff;
  --accent-blue-ink:#274690;
  --surface-cool:#f4f8ff;
  --surface-cool-strong:#edf4ff;
  --focus-ring:rgba(37,99,235,.16);
  --border:#e5e9ef;
  --border-soft:#edf1f5;
  --shadow-lg:0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:0 8px 24px rgba(28,35,51,0.08);
  --shadow-sm:0 1px 2px rgba(0,0,0,0.05);
  --sidebar-bg:linear-gradient(180deg,#e8f4ea 0%,#e7f0fb 100%);
  --sidebar-text:#4c6177;
  --sidebar-active:#204a8a;
  --sidebar-active-bg:rgba(37,99,235,0.12);
  --row-hover:#f3f7fd;
  --row-stripe:#f8fbfe;
  --status-on-time:#2e7d32;
  --status-late:#c62828;
  --status-absent:#e53e3e;
  --status-remote:var(--accent-blue-strong);
  --stat-total:#e8f5e9;
  --stat-absent:#ffebee;
  --stat-ontime:#e8f1ff;
  --stat-late:#fff3e0;
  --appbar-h:76px;
}

html, body.app-web{
  padding:0;
}

body.app-web{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:
    radial-gradient(circle at top right, rgba(59,130,246,.08), transparent 26%),
    radial-gradient(circle at top left, rgba(61,139,55,.07), transparent 24%),
    var(--bg-app);
  color:var(--text-strong);
}
.dashboard-app{min-height:100vh;display:flex;flex-direction:column;margin:0;padding:0}
.app-bar{display:flex;align-items:center;justify-content:space-between;gap:24px;margin:0;padding:16px 28px;background:linear-gradient(180deg,rgba(242,247,250,.97) 0%,rgba(236,244,249,.95) 100%);backdrop-filter:blur(12px);box-shadow:none;position:fixed;top:0;left:var(--sidebar-w);right:0;z-index:10;border-bottom:1px solid var(--border);min-height:var(--appbar-h)}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:18px}
.topbar-left{min-width:0}
.topbar-copy{display:flex;flex-direction:column;gap:2px}
.page-title{margin:0;font-size:22px;line-height:1.1;font-weight:700;color:var(--text-strong)}
.page-subtitle{margin:0;font-size:12px;color:var(--text-muted)}
.brand{display:flex;align-items:center;gap:12px;font-weight:600;font-size:18px;color:var(--text-strong)}
.brand .logo{width:36px;height:36px;border-radius:14px;background:linear-gradient(135deg,var(--accent-blue) 0%,var(--brand) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;box-shadow:0 12px 22px rgba(37,99,235,0.22);overflow:hidden}
.brand .logo img{width:100%;height:100%;object-fit:cover;display:block}
.app-nav{display:flex;gap:24px;flex:1;max-width:800px}
.app-nav a{text-decoration:none;color:var(--text-body);font-weight:500;padding-bottom:6px;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease}
.app-nav a:hover{color:var(--accent-blue-strong)}
.app-nav a.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}
.user-meta{display:flex;align-items:center;gap:14px}
.icon-button{width:40px;height:40px;border:none;border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-body);box-shadow:none;cursor:pointer;border:1px solid var(--border)}
.icon-button:hover{background:var(--surface-cool);color:var(--accent-blue-strong)}
.notif-toggle{position:relative}
.notif-dot{position:absolute;top:8px;right:8px;width:10px;height:10px;border-radius:999px;background:#ef4444;border:2px solid #fff;box-shadow:0 2px 8px rgba(239,68,68,.35)}
.search-wrap{position:relative;display:flex;align-items:center;min-width:220px}
.search-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none}
.search-input{border:1px solid var(--border);border-radius:8px;padding:9px 12px 9px 36px;font-size:13.5px;background:#fff;width:260px;color:var(--text-strong);outline:none;transition:border-color .15s,box-shadow .15s}
.search-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--focus-ring)}
.user-info{display:flex;align-items:center;gap:12px}
.user-info img{width:38px;height:38px;border-radius:50%;object-fit:cover}
.user-info div{display:flex;flex-direction:column;gap:2px}
.user-info strong{font-size:14px;color:var(--text-strong)}
.user-info span{font-size:12px;color:var(--text-muted)}
.logout-link{text-decoration:none;font-size:13px;color:var(--text-body);padding:8px 14px;border-radius:10px;border:1px solid var(--border);transition:background .2s ease,color .2s ease,border-color .2s ease;background:#fff}
.logout-link:hover{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}
.dashboard-main{flex:1;display:flex;justify-content:center;padding:calc(28px + var(--appbar-h)) 28px 48px}
.dashboard-container{width:100%;max-width:1280px;display:flex;flex-direction:column;gap:24px}
.dashboard-shell{display:flex;flex-direction:column;gap:20px}
.dashboard-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px}
.dashboard-head-copy{display:flex;flex-direction:column;gap:6px}
.dashboard-kicker{text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:700;color:var(--text-muted);margin:0}
.dashboard-head-copy h2{margin:0;font-size:32px;line-height:1.05;font-weight:700;color:var(--text-strong)}
.dashboard-head-subtitle{margin:0;font-size:14px;color:var(--text-body)}
.dashboard-head-actions{display:flex;gap:12px;align-items:center}
.hero-banner{position:relative;display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.95fr);gap:22px;padding:24px 26px;border-radius:22px;border:1px solid #d9e4ef;background:
  radial-gradient(circle at top right, rgba(59,130,246,.18), transparent 32%),
  radial-gradient(circle at 75% 100%, rgba(111,155,110,.16), transparent 26%),
  linear-gradient(135deg,rgba(255,255,255,.98) 0%,rgba(245,249,253,.97) 100%);
  box-shadow:0 22px 48px rgba(49,73,111,.09);overflow:hidden}
.hero-banner::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--accent-blue) 0%,var(--brand) 100%)}
.hero-banner::after{content:'';position:absolute;right:-78px;top:-88px;width:220px;height:220px;border-radius:999px;background:radial-gradient(circle, rgba(210,228,255,.58) 0%, rgba(210,228,255,0) 72%);pointer-events:none}
.hero-copy{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px;min-width:0}
.heading-eyebrow{margin:0;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:#5d78a8}
.hero-copy h1{margin:0;font-size:clamp(34px,4.2vw,56px);line-height:1.02;letter-spacing:-.05em;color:#183024}
.hero-copy p{margin:0;max-width:62ch;color:#617389;font-size:15px;line-height:1.6}
.hero-meta-row{display:flex;gap:8px;flex-wrap:wrap}
.hero-meta-chip{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:6px 11px;border-radius:999px;border:1px solid #d5e0ef;background:linear-gradient(180deg,rgba(255,255,255,.88) 0%,rgba(241,247,255,.9) 100%);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#4c6d99}
.hero-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.hero-side{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px;align-items:stretch;justify-content:space-between;min-width:0}
.hero-actions-cluster{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.hero-stat-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.hero-stat{display:flex;flex-direction:column;gap:6px;padding:14px 15px;border-radius:16px;border:1px solid #d7e3f1;background:linear-gradient(180deg,rgba(255,255,255,.92) 0%,rgba(243,248,255,.92) 100%);box-shadow:0 10px 20px rgba(49,73,111,.05);min-width:0}
.hero-stat-kicker{font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:800;color:#6c84b1}
.hero-stat-value{font-size:22px;line-height:1;font-weight:800;color:#183024;letter-spacing:-.04em}
.hero-stat-note{font-size:12px;color:#667b96;line-height:1.45}
.hero-stat-list{display:flex;flex-wrap:wrap;gap:8px}
.hero-stat-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:var(--accent-blue-soft);color:var(--accent-blue-ink);font-size:12px;font-weight:700}
.hero-banner.hero-banner--compact{grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);padding:22px 24px}
.hero-banner.hero-banner--single{grid-template-columns:1fr}
.hero-banner.hero-banner--single .hero-side{justify-content:flex-start}
.hero-banner.hero-banner--single .hero-actions-cluster{justify-content:flex-start}
.date-range-btn,.primary-btn{border:none;border-radius:8px;padding:11px 18px;font-weight:600;cursor:pointer;font-size:13.5px;transition:background .15s ease,color .15s ease,border-color .15s ease,transform .15s ease}
.date-range-btn{background:#fff;color:var(--text-body);border:1px solid var(--border)}
.date-range-btn:hover{transform:translateY(-1px);background:var(--surface-cool);border-color:var(--accent-blue-border);color:var(--accent-blue-strong)}
.date-range-btn.is-active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}
.primary-btn{background:var(--brand);color:#fff;box-shadow:none}
.primary-btn:hover{transform:translateY(-1px);background:var(--brand-strong)}
.attendance-month-export{width:150px;min-height:43px;padding:10px 12px}
.dashboard-quote-card{display:flex;justify-content:space-between;gap:20px;align-items:flex-end;background:linear-gradient(180deg,#ffffff 0%,#f6faff 100%);border:1px solid #dce6f3;border-radius:12px;padding:20px 22px;box-shadow:var(--shadow-lg)}
.quote-copy{display:flex;flex-direction:column;gap:8px}
.quote-copy h3{margin:0;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}
.quote-copy p{margin:0;font-size:16px;line-height:1.6;color:var(--text-strong)}
.quote-author{margin:0;font-size:13px;color:var(--text-muted);text-align:right}
.summary-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}
.summary-row--dense{gap:16px}
.summary-card{background:#fff;border-radius:10px;padding:18px 20px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.summary-card--banner{position:relative;overflow:hidden}
.summary-card--banner::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent-blue)}
.summary-card--ontime{background:var(--stat-ontime)}
.summary-card--neutral{background:var(--surface-cool)}
.summary-card--late{background:var(--stat-late)}
.summary-card--total{background:var(--stat-total)}
.summary-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--text-muted)}
.summary-header{display:flex;align-items:center;gap:14px}
.summary-icon{width:46px;height:46px;border-radius:16px;background:var(--accent-blue-soft);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--accent-blue-strong)}
.summary-meta h3{margin:0;font-size:14px;color:var(--text-muted);font-weight:500}
.summary-value{font-size:28px;font-weight:700;color:var(--text-strong);font-variant-numeric:tabular-nums}
.summary-note{font-size:12px;color:var(--text-body)}
.leave-balance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.leave-balance-grid .summary-card{--leave-accent:#2563eb;position:relative;overflow:hidden;min-height:166px;padding:18px 20px;border-radius:16px;border-color:#dce6f3;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);box-shadow:0 12px 24px rgba(31,55,92,.07)}
.leave-balance-grid .summary-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--leave-accent)}
.leave-balance-grid .summary-card:nth-child(2){--leave-accent:#0f766e}
.leave-balance-grid .summary-card:nth-child(3){--leave-accent:#b45309}
.leave-balance-grid .summary-card:nth-child(4){--leave-accent:#7c3aed}
.leave-balance-grid .summary-card:nth-child(5){--leave-accent:#be185d}
.leave-balance-grid .summary-card:nth-child(6){--leave-accent:#047857}
.leave-balance-grid .summary-card:nth-child(7){--leave-accent:#dc2626}
.leave-balance-grid .summary-card:nth-child(8){--leave-accent:#475569}
.leave-balance-grid .summary-header{align-items:flex-start;gap:12px}
.leave-balance-grid .summary-icon{width:42px;height:42px;border-radius:12px;background:color-mix(in srgb,var(--leave-accent) 12%,#fff);color:var(--leave-accent);font-size:0;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--leave-accent) 18%,transparent)}
.leave-balance-grid .summary-icon::before{content:'LV';font-size:11px;font-weight:800;letter-spacing:.08em}
.leave-balance-grid .summary-card:nth-child(1) .summary-icon::before{content:'AL'}
.leave-balance-grid .summary-card:nth-child(2) .summary-icon::before{content:'ML'}
.leave-balance-grid .summary-card:nth-child(3) .summary-icon::before{content:'UL'}
.leave-balance-grid .summary-card:nth-child(4) .summary-icon::before{content:'CL'}
.leave-balance-grid .summary-card:nth-child(5) .summary-icon::before{content:'MR'}
.leave-balance-grid .summary-card:nth-child(6) .summary-icon::before{content:'PT'}
.leave-balance-grid .summary-card:nth-child(7) .summary-icon::before{content:'HL'}
.leave-balance-grid .summary-card:nth-child(8) .summary-icon::before{content:'OT'}
.leave-balance-grid .summary-meta h3{font-size:15px;font-weight:800;color:#183153;line-height:1.25}
.leave-balance-grid .summary-meta .summary-note{margin-top:3px;color:#6d7f9e}
.leave-balance-grid .summary-value{margin-top:4px;font-size:26px;line-height:1.1;letter-spacing:0;color:#07152c}
.leave-balance-grid .summary-card > .summary-note{margin-top:auto;color:#405573;font-weight:600}
.leave-balance-grid .summary-card > div:last-child{height:9px!important;background:#edf3fb!important;border-radius:999px!important;overflow:hidden!important}
.leave-balance-grid .summary-card > div:last-child > div{border-radius:999px!important;background:linear-gradient(90deg,var(--leave-accent) 0%,color-mix(in srgb,var(--leave-accent) 58%,#ffffff) 100%)!important}
.content-layout{display:grid;grid-template-columns:minmax(0,1.9fr) minmax(320px,1fr);gap:20px}
.content-layout--dashboard{align-items:start}
.dashboard-side-stack{display:flex;flex-direction:column;gap:20px}
/* .content-layout.equal{grid-template-columns:1fr 1fr} */
.form-grid.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.control{padding:12px 14px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text-strong)}
.control:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--focus-ring)}
.check{display:flex;align-items:center;gap:12px}

.panel{background:#fff;border-radius:12px;padding:22px 24px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:20px;width:100%;max-width:100%;border:1px solid var(--border)}
.panel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}
.panel-header h2,.panel-header h3{margin:0;font-size:18px;color:var(--text-strong)}
.panel-header--compact{align-items:center}
.panel-subtitle{margin:6px 0 0;font-size:13px;color:var(--text-muted)}
.secondary-link{border:none;background:transparent;color:var(--accent-blue-strong);font-weight:600;font-size:13px;cursor:pointer;padding:6px 0}
.panel--date-strip{position:relative;overflow:hidden;border-radius:20px;padding:20px 22px;background:
  radial-gradient(circle at top right, rgba(59,130,246,.18), transparent 34%),
  linear-gradient(180deg,#ffffff 0%,#f5f9ff 100%);
  border-color:#dbe6f4}
.panel--date-strip::after{content:'';position:absolute;left:22px;right:22px;bottom:0;height:1px;background:linear-gradient(90deg,rgba(37,99,235,0), rgba(37,99,235,.16), rgba(111,155,110,.12), rgba(37,99,235,0));pointer-events:none}
.calendar-row{display:flex;gap:10px;flex-wrap:wrap}
.calendar-row--strip{flex-wrap:nowrap;overflow-x:auto;padding:4px 2px 6px;scrollbar-width:none;scroll-snap-type:x proximity}
.calendar-row--strip::-webkit-scrollbar{display:none}
.calendar-pill{position:relative;min-width:94px;padding:12px 14px;border-radius:14px;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);border:1px solid #d7e2f0;color:#35506c;font-size:12.5px;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease;box-shadow:0 8px 18px rgba(49,73,111,.05);scroll-snap-align:start}
.calendar-pill:hover{transform:translateY(-2px);background:linear-gradient(180deg,#ffffff 0%,#eef5ff 100%);border-color:#bfd2f0;box-shadow:0 12px 24px rgba(49,73,111,.09)}
.calendar-pill.active{background:linear-gradient(135deg,#edf4ff 0%,#dde9ff 100%);border-color:#c7d8fb;color:#1f4070;box-shadow:0 14px 28px rgba(37,99,235,.16)}
.calendar-pill.active::after{content:'';position:absolute;left:16px;right:16px;bottom:8px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--accent-blue) 0%,var(--brand) 100%)}
.timeline{position:relative;padding-left:24px;display:flex;flex-direction:column;gap:18px}
.timeline::before{content:'';position:absolute;top:4px;bottom:4px;left:8px;width:2px;background:#d7e3f4}
.timeline-item{display:flex;gap:18px;align-items:center}
.timeline-icon{width:36px;height:36px;border-radius:10px;background:var(--accent-blue-soft);color:var(--accent-blue-strong);display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:none;border:1px solid rgba(37,99,235,.12)}
.timeline-content{display:flex;justify-content:space-between;align-items:center;flex:1;gap:16px}
.timeline-content .info{display:flex;flex-direction:column;gap:6px}
.timeline-content .info strong{font-size:15px;color:var(--text-strong)}
.timeline-content .info span{font-size:12px;color:var(--text-muted)}
.timeline-content .time{text-align:right}
.timeline-content .time strong{display:block;font-size:16px;color:var(--text-strong);font-variant-numeric:tabular-nums}
.timeline-content .time span{font-size:12px;color:var(--accent-blue-strong)}
.timeline-empty{padding:18px 0 4px;color:var(--text-muted);font-size:13px}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.dashboard-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.stat-card{background:var(--bg-surface-soft);border-radius:10px;padding:16px 18px;display:flex;flex-direction:column;gap:6px;color:var(--text-body);border:1px solid var(--border)}
.stat-card strong{font-size:20px;color:var(--text-strong)}
.stat-card--expected{background:#f4f8ff}
.stat-card--actual{background:#edf7ee}
.stat-card--overtime{background:#fff7ec}
.activity-log{display:flex;flex-direction:column;gap:16px}
.activity-log--dense{gap:12px}
.activity-item{border-radius:10px;padding:16px 18px;background:#fff;display:flex;justify-content:space-between;align-items:center;gap:16px;border:1px solid var(--border)}
.activity-item:hover{background:var(--row-hover)}
.activity-item .details{display:flex;align-items:center;gap:14px}
.activity-item .symbol{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--accent-blue-strong);background:var(--accent-blue-soft);box-shadow:none}
.activity-item .details div{display:flex;flex-direction:column;gap:4px}
.activity-item .details strong{font-size:14px;color:var(--text-strong)}
.activity-item .details span{font-size:12px;color:var(--text-muted)}
.activity-item .status{text-align:right;display: flex;flex-direction: column;}
.activity-item .status strong{font-size:15px;color:var(--text-strong)}
.activity-item .status span{font-size:12px;color:#59b483}
.activity-item--empty{background:var(--bg-surface-soft)}

.leave-item{position:relative;align-items:center;display:grid;grid-template-columns:minmax(240px,1.45fr) minmax(140px,.86fr) minmax(120px,.64fr) minmax(170px,.92fr) minmax(220px,1.18fr) minmax(118px,.58fr);gap:20px;padding:18px 20px 18px 22px;border-radius:16px;border-color:#dce7f5;background:linear-gradient(180deg,#ffffff 0%,#f9fbff 100%);box-shadow:0 10px 22px rgba(31,55,92,.055);overflow:hidden}
.leave-item::before{content:'';position:absolute;left:0;top:14px;bottom:14px;width:4px;border-radius:0 999px 999px 0;background:#d1ddec}
.leave-item:has(.pill.pending)::before{background:#f59e0b}
.leave-item:has(.pill.approved)::before{background:#0f766e}
.leave-item:has(.pill.declined)::before{background:#dc2626}
.leave-item:has(.pill.cancelled)::before{background:#64748b}
.leave-item:hover{background:linear-gradient(180deg,#ffffff 0%,#f5f9ff 100%);border-color:#cddcf0;box-shadow:0 14px 28px rgba(31,55,92,.085)}
.leave-col{display:flex;flex-direction:column;gap:7px;min-width:0}
.leave-col .muted{font-size:10px;line-height:1;letter-spacing:.08em;text-transform:uppercase;color:#7487a8;font-weight:800}
.leave-col strong{font-size:13px;line-height:1.35;color:#15233c;white-space:normal;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.leave-period strong{font-size:14px;font-weight:800;color:#07152c;letter-spacing:.01em}
.leave-period .muted{display:inline-flex;align-items:center;width:max-content;max-width:100%;padding:5px 9px;border-radius:999px;background:#eef5ff;color:#315a92;text-transform:none;letter-spacing:0;font-size:12px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.leave-status .pill{align-self:flex-start;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:800}
.leave-form{align-items:stretch}
.leave-form .muted{text-align:center}
.leave-print{width:100%;min-width:0;justify-content:center;padding:9px 12px;font-size:12px;font-weight:800;text-decoration:none;display:inline-flex;align-items:center;border-radius:12px;background:#fff;transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease}
.leave-print:hover{transform:translateY(-1px);background:#eef5ff;border-color:#bfd2f0;color:#1f4f8f}
.assets-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
/* Approvals page layout */
.approvals-controls{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:end}
.approvals-controls .field{display:flex;flex-direction:column;gap:6px;min-width:160px}
@media (max-width:900px){ .approvals-controls{grid-template-columns:1fr; } .approvals-controls .field{min-width:0} .attendance-admin-stats{grid-template-columns:repeat(2,minmax(0,1fr));} }
.attendance-admin-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.attendance-admin-toolbar-wrap{justify-content:flex-end}
.attendance-admin-head{padding-bottom:4px;border-bottom:1px solid rgba(205,220,243,0.88)}
.attendance-admin-panel{gap:18px}
.attendance-admin-stats{display:grid;grid-template-columns:repeat(4,minmax(200px,1fr));gap:14px;margin:0 0 6px}
.attendance-admin-stats--monthly{margin-top:0}
.attendance-admin-stat-card{background:linear-gradient(180deg,#ffffff 0%,#f3f8ff 100%);border:1px solid #d8e3f2;border-radius:18px;padding:16px 18px;display:flex;flex-direction:column;gap:8px;min-height:98px;box-shadow:0 10px 24px rgba(49,73,111,.06)}
.attendance-admin-stat-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#6f85ae;font-weight:700}
.attendance-admin-stat-value{font-size:30px;line-height:1.05;font-weight:700;color:var(--text-strong);word-break:break-word}
.attendance-admin-table-wrap{overflow:auto;border:1px solid #d8e3f2;border-radius:22px;background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);padding:6px 10px 10px}
.attendance-admin-table thead th{font-size:12px;color:#6f85ae;font-weight:700;letter-spacing:.02em}
.attendance-admin-table tbody tr{background:#fff;box-shadow:0 10px 24px rgba(49,73,111,.05);border-radius:16px}
.attendance-admin-table tbody td{border-top:1px solid transparent;border-bottom:1px solid transparent}
.attendance-admin-table .btn-light{min-width:88px}
.status-chip{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:capitalize}
.status-chip--success{background:#eaf8f0;color:#1c8c54}
.status-chip--warning{background:#fff3e7;color:#cb6d1d}
.status-chip--danger{background:#ffe9e9;color:#cf4040}
.status-chip--neutral{background:var(--accent-blue-soft);color:var(--accent-blue-ink)}
.asset-status{color:var(--text-muted);font-size:13px}
.asset-status--unavailable{color:#dc2626;font-weight:600}
.asset-admin-status{gap:10px;align-items:flex-end}
.asset-admin-status .asset-admin-actions{display:flex;flex-direction:column;gap:8px;min-width:220px}
.asset-admin-status .asset-admin-actions .control{height:36px}
.asset-admin-status .asset-admin-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.booking-admin-row,.asset-admin-row{align-items:center}
.booking-admin-copy,.asset-admin-copy{min-width:0}
.booking-admin-copy strong,.asset-admin-copy strong{font-size:15px}
.booking-admin-copy span,.asset-admin-copy span{display:block}
.booking-admin-user{font-weight:600;color:var(--accent-blue-ink)}
.booking-admin-time,.asset-admin-meta{font-size:12px;color:var(--text-muted)}
.asset-admin-note{margin-top:4px;font-size:12px;color:#7b4f0e;line-height:1.45}
.booking-admin-status,.asset-admin-status{min-width:280px}
.booking-admin-badge,.asset-admin-badge{display:flex;justify-content:flex-end}
.booking-admin-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.booking-admin-actions .btn-light,.asset-admin-buttons .btn-light{min-width:124px}
.asset-admin-actions .control{min-width:240px}
/* Expandable member details */
.member-extra{display:none;margin-top:8px;color:var(--text-muted)}
.activity-item.open{flex-direction:column;align-items:stretch}
.activity-item.open .member-extra{display:block}
.team-card{border-radius:20px;background:linear-gradient(135deg,var(--accent-blue-strong) 0%,var(--brand) 100%);color:#fff;padding:22px 24px;display:flex;flex-direction:column;gap:16px;box-shadow:0 18px 44px rgba(37,99,235,.18)}
.team-card h3{margin:0;font-size:18px}
.team-progress{display:flex;align-items:center;gap:16px}
.team-progress meter{flex:1;height:12px;border-radius:8px;overflow:hidden;background:var(--accent-blue-strong)}
meter::-webkit-meter-bar{background:var(--accent-blue-strong);border:none}
meter::-webkit-meter-optimum-value{background:#8fd6b1}
.team-card footer{font-size:13px;color:rgba(255,255,255,0.86)}
.team-card--flat{border-radius:10px;background:#f8fafc;color:var(--text-strong);padding:8px 0 0;box-shadow:none}
.team-card--flat .team-progress meter{background:#dfe6ee}
.team-card--flat meter::-webkit-meter-bar{background:#dfe6ee}
.team-card--flat meter::-webkit-meter-optimum-value{background:var(--brand)}
.team-card--flat footer{font-size:13px;color:var(--text-body)}
.cta-bar{margin-top:4px;border-radius:10px;background:var(--bg-surface);padding:18px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.cta-bar p{margin:0;font-size:15px;color:var(--text-body)}
.cta-bar strong{display:block;margin-bottom:4px;font-size:15px;color:var(--text-strong)}
.cta-bar button{border:none;background:var(--accent-blue);color:#fff;border-radius:8px;padding:12px 18px;font-weight:600;cursor:pointer;box-shadow:none}
footer.app-footer{padding:24px 0 40px;text-align:center;font-size:12px;color:var(--text-soft)}
@media (max-width:1140px){.summary-row{grid-template-columns:repeat(2,minmax(0,1fr))}.content-layout{grid-template-columns:1fr}}
@media (max-width:860px){
  .app-bar{flex-wrap:wrap;align-items:stretch;padding:18px 20px;gap:16px}
  .topbar-left,
  .topbar-right{width:100%}
  .topbar-left{justify-content:flex-start;gap:14px}
  .topbar-copy{min-width:0}
  .topbar-right{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;align-items:start}
  .search-wrap{min-width:0;width:100%}
  .search-input{width:100%;min-height:46px}
  .user-meta{width:100%;justify-content:space-between;gap:12px;flex-wrap:nowrap}
  .dashboard-main{padding:28px 18px 44px}
  .dashboard-container{gap:20px}
  .dashboard-shell{gap:22px}
  .dashboard-head{flex-direction:column;align-items:flex-start;gap:16px}
  .dashboard-head-actions{width:100%;flex-wrap:wrap;gap:12px}
  .dashboard-head-actions .date-range-btn,
  .dashboard-head-actions .primary-btn{flex:1 1 220px;min-height:48px}
}
@media (max-width:640px){
  .summary-row{grid-template-columns:1fr;gap:18px}
  .dashboard-head-copy{gap:8px}
  .dashboard-head-actions{gap:14px}
  .dashboard-head-actions button{width:100%}
  .dashboard-quote-card{flex-direction:column;align-items:flex-start;gap:14px}
}

/* Responsive polish */
@media (max-width:1024px){
  .dashboard-stats-grid{grid-template-columns:1fr}
  .panel{padding:20px 20px}
}
@media (max-width:768px){
  .dashboard-container{gap:22px}
  .dashboard-shell{gap:24px}
  .dashboard-head-copy h2{font-size:clamp(24px,6vw,32px)}
  .summary-value{font-size:clamp(18px,4.5vw,24px)}
  .timeline-content{flex-direction:column;align-items:flex-start;gap:8px}
  .activity-item{flex-direction:column;align-items:flex-start}
  .cta-bar{flex-direction:column;gap:14px;align-items:flex-start;padding:20px 20px}
  .panel{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .booking-admin-status,.asset-admin-status{width:100%;min-width:0;align-items:flex-start}
  .booking-admin-badge,.asset-admin-badge{justify-content:flex-start}
  .booking-admin-actions,.asset-admin-status .asset-admin-buttons{justify-content:flex-start}
  .asset-admin-status .asset-admin-actions{width:100%;min-width:0}
  .asset-admin-actions .control{min-width:0;width:100%}
  .hero-banner{gap:18px;padding:22px 22px}
  .hero-stat-strip{grid-template-columns:1fr}
  .hero-actions-cluster{justify-content:flex-start}
  .panel{padding:22px}
  .panel-header{gap:12px}
}
@media (max-width:560px){
  .app-bar{padding:18px 16px;gap:14px}
  .topbar-left{align-items:flex-start}
  .topbar-copy{gap:4px}
  .page-title{font-size:19px;line-height:1.15}
  .page-subtitle{font-size:11px}
  .topbar-right{gap:14px}
  .user-meta{align-items:center;gap:10px}
  .user-info{min-width:0;gap:10px}
  .user-info div{min-width:0}
  .user-info strong{font-size:13px;line-height:1.3}
  .logout-link{padding:9px 12px;border-radius:12px}
  .dashboard-main{padding:20px 14px 32px}
  .dashboard-container{gap:18px}
  .dashboard-shell{gap:20px}
  .dashboard-head{gap:14px}
  .dashboard-head-actions .date-range-btn,
  .dashboard-head-actions .primary-btn{min-height:50px}
  .dashboard-quote-card{padding:22px 20px;border-radius:18px}
  .summary-row{gap:16px}
  .summary-card{padding:20px 18px;border-radius:18px}
  .summary-value{font-size:clamp(24px,8vw,30px)}
  .panel{border-radius:20px;padding:20px}
  .panel--date-strip{padding:22px 18px}
  .calendar-row{flex-wrap:nowrap;overflow-x:auto;padding:6px 2px 8px;-webkit-overflow-scrolling:touch}
  .calendar-row::-webkit-scrollbar{display:none}
  .calendar-pill{flex:0 0 auto;min-width:102px;padding:13px 14px}
  .user-info span{display:none}
  .timeline{gap:16px}
  .activity-log{gap:14px}
  .activity-item{padding:18px 16px;border-radius:16px}
  .cta-bar{padding:20px 18px;border-radius:18px}
}

/* Lightweight modal for filters */
.wp-modal{position:fixed;inset:0;background:rgba(17,31,61,.14);display:none;align-items:center;justify-content:center;z-index:2000;padding:24px}
.wp-modal.show{display:flex}
.wp-modal-card{background:var(--bg-surface);border-radius:20px;box-shadow:0 30px 60px rgba(17,31,61,.22);width:min(92vw,640px);padding:22px 24px;display:flex;flex-direction:column;gap:16px;max-width:1100px;border:1px solid var(--border-soft)}
.wp-modal-card h3{margin:0 0 8px 0;color:var(--text-strong)}
.wp-modal-actions{display:flex;gap:10px;justify-content:flex-end}
.btn-light{border:1px solid var(--border);background:#fff;color:var(--text-strong);border-radius:12px;padding:10px 16px;cursor:pointer}
.admin-leave-panel{gap:22px}
.admin-leave-toolbar{display:flex;align-items:center;justify-content:flex-end}
.admin-leave-tabs{display:flex;gap:8px;flex-wrap:wrap}
.admin-leave-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:8px}
.admin-leave-stat{padding:14px 16px;border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,0.82)}
.admin-leave-stat-label{display:block;margin-bottom:8px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-weight:700}
.admin-leave-stat strong{font-size:16px;color:var(--text-strong)}
.admin-leave-table-wrap{overflow:auto;border:1px solid var(--border);border-radius:22px;background:rgba(255,255,255,0.78)}
.admin-leave-table{width:100%;border-collapse:separate;border-spacing:0}
.admin-leave-table thead th{padding:16px 14px;border-bottom:1px solid var(--border);color:#667fa8;font-size:12px;text-align:left;letter-spacing:.04em;text-transform:uppercase}
.admin-leave-row td{padding:18px 14px;vertical-align:top;border-bottom:1px solid rgba(210,223,243,0.8)}
.admin-leave-row:last-child td{border-bottom:none}
.admin-leave-user{display:flex;align-items:flex-start;gap:12px;min-width:190px}
.admin-leave-avatar{width:42px;height:42px;border-radius:14px;background:linear-gradient(180deg,#edf4ff,#dce9ff);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--accent-blue-strong)}
.admin-leave-user-name{font-weight:800;color:var(--text-strong);line-height:1.35}
.admin-leave-user-meta{margin-top:4px;font-size:12px;color:var(--text-muted);line-height:1.45}
.admin-leave-period,.admin-leave-type,.admin-leave-reason,.admin-leave-submitted,.admin-leave-decision{color:var(--text-strong);line-height:1.45}
.admin-leave-reason{max-width:250px;white-space:normal;word-break:break-word}
.admin-leave-status{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;font-size:12px;font-weight:800}
.admin-leave-status.status-pending{background:#fff7ed;color:#c2410c}
.admin-leave-status.status-approved{background:#ecfdf3;color:#15803d}
.admin-leave-status.status-rejected{background:#fef2f2;color:#dc2626}
.admin-leave-actions{display:flex;flex-direction:column;gap:8px;min-width:108px}
.admin-leave-actions .primary-btn,.admin-leave-actions .btn-light,.admin-leave-print{width:100%;justify-content:center;text-align:center}
.admin-leave-print{text-decoration:none;display:inline-flex;align-items:center}
.admin-leave-empty{padding:32px 18px !important;text-align:center;color:var(--text-muted)}

/* Modal form look & feel */
.wp-modal-card .form-grid.two{grid-template-columns:1fr 1fr;gap:16px}
.wp-modal-card label{font-size:13px;color:#49628f;margin-bottom:6px;display:block}
.wp-modal-card .control{background:#fff;border:1px solid var(--border);border-radius:14px;padding:12px 14px;width: 100%;}
.wp-modal-card .control:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--focus-ring)}

/* Sidebar navigation */
:root{ --sidebar-w: 240px; --sidebar-w-collapsed: 88px; }
.side-nav{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:
  var(--sidebar-bg);
  box-shadow:2px 0 10px rgba(49,73,111,0.10);padding:0 0 16px;display:flex;flex-direction:column;gap:10px;z-index:1000;overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;border-right:1px solid rgba(87,124,176,0.14);transition:width .22s ease, box-shadow .22s ease}
.side-brand{display:flex;align-items:center;gap:10px;min-height:var(--appbar-h);padding:0 20px;color:var(--sidebar-active);font-weight:700;font-size:17px;border-bottom:1px solid var(--border);flex:0 0 var(--appbar-h)}
.side-brand .logo{width:34px;height:34px;border-radius:12px;background:rgba(37,99,235,0.12);display:flex;align-items:center;justify-content:center;color:var(--sidebar-active);font-size:18px;overflow:hidden}
.side-brand .logo img{width:100%;height:100%;object-fit:cover;display:block}
.side-brand-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-collapse-toggle{margin-left:auto;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.7);color:var(--sidebar-active);flex:0 0 34px}
.sidebar-collapse-toggle svg{transition:transform .22s ease}
.side-menu{display:flex;flex-direction:column;gap:6px;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}
.side-menu::-webkit-scrollbar{width:0;height:0}
.side-link{display:flex;align-items:center;gap:10px;padding:9px 20px;border-radius:0;color:var(--sidebar-text);text-decoration:none;font-weight:600;font-size:13.5px;white-space:nowrap}
.side-link-short{display:none;width:34px;height:34px;border-radius:12px;background:rgba(37,99,235,0.10);align-items:center;justify-content:center;font-size:11px;font-weight:800;letter-spacing:.08em;color:var(--sidebar-active);flex:0 0 34px}
.side-link-label{overflow:hidden;text-overflow:ellipsis}
.side-link-badge{transition:opacity .2s ease}
.side-link:hover{background:var(--sidebar-active-bg);color:var(--sidebar-active)}
.side-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active);box-shadow:none}
.side-section{display:block;margin:14px 20px 6px;padding:7px 10px;border-radius:10px;background:linear-gradient(135deg, rgba(37,99,235,.22), rgba(22,163,74,.14));color:#334a6c;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.1em;line-height:1.2}
.side-subsection{display:block;margin:10px 20px 4px;padding:6px 10px;border-radius:9px;background:linear-gradient(135deg, rgba(148,163,184,.2), rgba(59,130,246,.12));color:#64748b;font-size:10px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;line-height:1.2}

/* Shift app content to accommodate sidebar on desktop */
.app-nav{display:none}
.app-bar{margin-left:0}
.dashboard-main{margin-left:var(--sidebar-w)}
.app-footer{margin-left:var(--sidebar-w)}
body.sidebar-collapsed .side-nav{width:var(--sidebar-w-collapsed)}
body.sidebar-collapsed .app-bar{left:var(--sidebar-w-collapsed)}
body.sidebar-collapsed .dashboard-main,
body.sidebar-collapsed .app-footer{margin-left:var(--sidebar-w-collapsed)}
body.sidebar-collapsed .side-brand{padding:0 12px;justify-content:space-between}
body.sidebar-collapsed .side-brand-text,
body.sidebar-collapsed .side-section,
body.sidebar-collapsed .side-subsection,
body.sidebar-collapsed .side-link-label,
body.sidebar-collapsed .side-link-badge{display:none}
body.sidebar-collapsed .side-menu{gap:8px;padding-top:8px}
body.sidebar-collapsed .side-link{justify-content:center;padding:8px 0;margin:0 12px;border-radius:14px;min-height:46px}
body.sidebar-collapsed .side-link-short{display:inline-flex}
body.sidebar-collapsed .side-link.active .side-link-short{background:rgba(37,99,235,0.18)}
body.sidebar-collapsed .sidebar-collapse-toggle{margin-left:0;width:32px;height:32px}
body.sidebar-collapsed .sidebar-collapse-toggle svg{transform:rotate(180deg)}

/* Mobile nav toggle */
.menu-toggle{display:none}
@media (max-width:860px){
  body.sidebar-collapsed .side-nav{width:var(--sidebar-w)}
  body.sidebar-collapsed .app-bar{left:0}
  body.sidebar-collapsed .dashboard-main,
  body.sidebar-collapsed .app-footer{margin-left:0}
  body.sidebar-collapsed .side-brand{padding:0 20px;justify-content:flex-start}
  body.sidebar-collapsed .side-brand-text,
  body.sidebar-collapsed .side-section,
  body.sidebar-collapsed .side-subsection,
  body.sidebar-collapsed .side-link-label,
  body.sidebar-collapsed .side-link-badge{display:initial}
  body.sidebar-collapsed .side-link-short{display:none}
  body.sidebar-collapsed .side-link{justify-content:flex-start;padding:9px 20px}
  body.sidebar-collapsed .sidebar-collapse-toggle{margin-left:auto}
  body.sidebar-collapsed .sidebar-collapse-toggle svg{transform:none}
  .menu-toggle{display:inline-flex}
  .sidebar-collapse-toggle{display:none}
  .app-nav{display:none !important}
  /* Sidebar becomes overlay */
  .side-nav{transform:translateX(-100%);transition:transform .2s ease;box-shadow:0 12px 40px rgba(49,73,111,0.14)}
  body.nav-open .side-nav{transform:translateX(0)}
  /* Content not shifted on mobile */
  .app-bar{left:0;right:0;padding:18px 20px; padding-top:calc(18px + env(safe-area-inset-top))}
  .dashboard-main{margin-left:0}
  .app-footer{margin-left:0}
}

/* Backdrop for mobile sidebar */
.nav-backdrop{position:fixed;inset:0;background:rgba(17,31,61,.14);opacity:0;pointer-events:none;z-index:90;transition:opacity .2s ease}
body.nav-open .nav-backdrop{opacity:1;pointer-events:auto}
.notif-panel{position:fixed;top:92px;right:32px;width:min(420px,calc(100vw - 24px));max-height:min(72vh,680px);background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 24px 60px rgba(17,31,61,.18);display:none;flex-direction:column;z-index:1200;overflow:hidden}
.notif-panel.show{display:flex}
.notif-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 18px 14px;border-bottom:1px solid var(--border);background:#fff}
.notif-panel-title{display:flex;flex-direction:column;gap:4px}
.notif-panel-title strong{font-size:18px;color:var(--text-strong)}
.notif-panel-title span{font-size:12px;color:var(--text-muted)}
.notif-panel-body{padding:14px;overflow:auto;display:flex;flex-direction:column;gap:10px}
.notif-group-label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);padding:4px 2px}
.notif-item{display:flex;gap:12px;align-items:flex-start;padding:14px;border:1px solid var(--border-soft);border-radius:18px;background:linear-gradient(180deg,#fff 0%,#f6faff 100%);cursor:pointer}
.notif-item:hover{background:#f2f7ff}
.notif-item.is-unread{border-color:#dbe6f6;box-shadow:0 10px 20px rgba(49,73,111,.06)}
.notif-item-icon{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;letter-spacing:.06em;line-height:1;flex:0 0 42px}
.notif-item-body{display:flex;flex-direction:column;gap:5px;min-width:0;flex:1}
.notif-item-title{font-size:14px;font-weight:700;color:var(--text-strong)}
.notif-item-sub{font-size:12px;color:var(--text-muted);line-height:1.45}
.notif-item-meta{display:flex;justify-content:space-between;gap:10px;align-items:center;font-size:11px;color:var(--text-soft)}
.notif-item-dot{width:8px;height:8px;border-radius:999px;background:#ef4444;flex:0 0 8px}
.notif-empty{padding:22px 14px;text-align:center;color:var(--text-muted)}
@media (max-width:860px){.notif-panel{top:84px;right:12px;left:12px;width:auto;max-height:70vh}}

/* Responsive grids and panels */
@media (max-width: 980px){
  .summary-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .content-layout{grid-template-columns:1fr}
  .hero-banner{flex-direction:column;align-items:stretch;gap:16px}
  .panel-header{flex-direction:column;align-items:flex-start;gap:10px}
  .admin-leave-toolbar{width:100%;justify-content:flex-start}
  .admin-leave-stats{grid-template-columns:1fr}
  .admin-leave-table thead{display:none}
  .admin-leave-table,.admin-leave-table tbody,.admin-leave-table tr,.admin-leave-table td{display:block;width:100%}
  .admin-leave-row{display:block;padding:14px;border-bottom:1px solid rgba(210,223,243,0.8)}
  .admin-leave-row td{display:block;padding:8px 0;border-bottom:none}
  .admin-leave-actions{min-width:0}
  .admin-leave-print{width:auto}
  .assets-grid{grid-template-columns:1fr}
  .leave-item{grid-template-columns:1fr;gap:10px}
}
@media (max-width: 640px){
  .attendance-admin-stats{grid-template-columns:1fr}
  .summary-row{grid-template-columns:1fr}
  .form-grid.two{grid-template-columns:1fr}
  .panel{padding:20px;border-radius:20px}
  .user-info img{width:36px;height:36px}
  .activity-log .activity-item{flex-direction:column;align-items:stretch;gap:8px}
  .activity-log .activity-item .status{align-self:flex-end}
}

/* Leave allocation grid (admin): responsive columns */
.alloc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:end}
@media (max-width:560px){ .alloc-grid{grid-template-columns:1fr} }

/* Kanban board */
.kanban{display:grid;grid-template-columns:repeat(4, minmax(0,1fr));gap:14px}
.column{background:var(--bg-surface-soft);border:1px solid var(--border-soft);border-radius:16px;padding:12px;display:flex;flex-direction:column;min-height:340px}
.kanban-header{font-weight:700;margin:2px 0 8px;border-radius:12px;padding:8px 10px;color:#fff;display:inline-block}
.kanban-header.todo{background:var(--accent-blue-strong)}
.kanban-header.progress{background:#F59E0B}
.kanban-header.review{background:#4f7dcf}
.kanban-header.done{background:#10B981}
.column-list{display:flex;flex-direction:column;gap:10px;min-height:280px;height: 100%;}
.task-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:10px 12px;box-shadow:0 8px 20px rgba(17,31,61,.06);cursor:grab}
.task-card:active{cursor:grabbing}
.task-title{font-weight:600;color:var(--text-strong);margin:0 0 6px}
.task-desc{color:var(--text-muted);font-size:13px;line-height:1.45;margin:0 0 8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}
.task-meta{display:flex;gap:8px;align-items:center;color:var(--text-muted);font-size:12px}
.pill{display:inline-block;border-radius:10px;padding:3px 8px;font-size:11px;font-weight:700}
.pill.high{background:#fee2e2;color:#b91c1c}
.pill.medium{background:var(--accent-blue-soft);color:var(--accent-blue-ink)}
.pill.low{background:#dcfce7;color:#065f46}
.pill.pending{background:#fff7ed;color:#c2410c}
.pill.approved{background:#ecfeff;color:#155e75}
.pill.declined{background:#fee2e2;color:#b91c1c}
.pill.cancelled{background:#fef2f2;color:#dc2626}
@media (max-width:1100px){ .kanban{grid-template-columns:repeat(2, minmax(0,1fr));} }
@media (max-width:720px){ .kanban{grid-template-columns:1fr;} }

/* Resume editor helpers */
.list-plain{display:flex;gap:8px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:8px;background:var(--bg-surface-soft);border:1px solid var(--border);border-radius:999px;padding:6px 10px}
.chip button{border:none;background:transparent;color:var(--text-muted);cursor:pointer}
.list-cards{display:grid;grid-template-columns:1fr;gap:12px}
