/* Copied from original project static/style.css (trimmed start) */
:root {
    --navy: #0f172a;
    --navy-light: #1e293b;
    --blue: #2563eb;
    --blue-dark: #1d4ed8;
    --green: #16a34a;
    --red: #dc2626;
    --yellow-bg: #fef3c7;
    --yellow-text: #92400e;
    --green-bg: #dcfce7;
    --green-text: #166534;
    --blue-bg: #dbeafe;
    --blue-text: #1d4ed8;
    --gray-bg: #e5e7eb;
    --gray-text: #374151;
    --white: #ffffff;
    --muted: #64748b;
    --border: #e2e8f0;
    --background: #f4f6f9;
}

* {box-sizing: border-box; margin:0; padding:0}
body {font-family: "Segoe UI", Arial, sans-serif; background:var(--background); color:#1f2937;overflow-x:hidden}
a {color:var(--blue)}

.auth-body {min-height:100vh; display:flex; background:linear-gradient(135deg,#0f172a,#1e3a8a)}
.auth-left{flex:1;padding:70px;color:white;display:flex;flex-direction:column;justify-content:center}
.auth-left h1{font-size:48px;margin-bottom:18px;line-height:1.1}
.auth-left p{color:#cbd5e1;font-size:18px;max-width:620px;line-height:1.7}
.auth-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.auth-badges span{border:1px solid rgba(255,255,255,0.25);padding:10px 14px;border-radius:999px;color:#e2e8f0}
.auth-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.auth-links a{color:white;text-decoration:none;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.08);padding:10px 12px;border-radius:10px;font-weight:800}
.auth-links a:hover{background:rgba(255,255,255,.15)}
.auth-right{width:480px;display:flex;align-items:center;justify-content:center;padding:35px}
.auth-card{background:#fff;width:100%;padding:35px;border-radius:18px;box-shadow:0 20px 50px rgba(0,0,0,0.25)}
.auth-card h2{font-size:28px;color:var(--navy);margin-bottom:8px}
.auth-card p{color:var(--muted);margin-bottom:25px}

.container{display:flex;min-height:100vh}
.sidebar{width:270px;background:var(--navy);color:white;padding:26px;position:sticky;top:0;height:100vh}
.logo{display:flex;align-items:center;gap:12px;margin-bottom:30px}
.logo-mark{width:42px;height:42px;background:var(--blue);border-radius:12px;display:grid;place-items:center;font-weight:800}
.employee-menu-toggle{display:none}
.user-box{background:rgba(255,255,255,0.07);padding:16px;border-radius:14px;margin-bottom:22px}
.nav-link{display:block;color:#cbd5e1;text-decoration:none;padding:12px 14px;border-radius:10px;margin-bottom:8px;transition:0.15s}
.nav-link:hover{background:var(--navy-light);color:white}
.main{flex:1;padding:30px}
.topbar{background:white;padding:24px 28px;border-radius:16px;margin-bottom:25px;box-shadow:0 4px 16px rgba(15,23,42,0.08);display:flex;align-items:center;justify-content:space-between;gap:20px}
.card{background:white;padding:24px;border-radius:16px;box-shadow:0 4px 16px rgba(15,23,42,0.08);margin-bottom:20px}
.form-group{margin-bottom:18px}
label{display:block;font-weight:700;margin-bottom:7px;color:#334155}
input,textarea,select{width:100%;padding:13px 14px;border:1px solid #cbd5e1;border-radius:10px;font-size:15px;background:white}
textarea{resize:vertical;line-height:1.6}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,0.15)}
.btn{display:inline-block;border:none;padding:11px 18px;border-radius:10px;cursor:pointer;font-weight:700;text-decoration:none;font-size:15px;transition:0.15s}
.btn-primary{background:var(--blue);color:white}
.btn-primary:hover{background:var(--blue-dark)}
.btn-secondary{background:#0f766e;color:white}
.btn-secondary:hover{background:#115e59}
.text-link{font-weight:800;text-decoration:none;color:#0f766e}
.muted-copy{color:var(--muted);line-height:1.6}
.form-message{padding:12px 14px;border-radius:10px;margin-bottom:16px;font-weight:700;font-size:14px}
.form-message.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.form-message.success{background:var(--green-bg);color:var(--green-text);border:1px solid #bbf7d0}
.approval-note{padding:12px 14px;border:1px solid #bfdbfe;background:#eff6ff;border-radius:10px;margin-bottom:18px}
.approval-note strong,.approval-note span{display:block;font-size:13px}
.approval-note strong{color:#1e3a8a}
.approval-note span{color:var(--muted);margin-top:4px}
.credential-box{display:grid;grid-template-columns:1fr 1.4fr;gap:8px 12px;background:#f8fafc;border:1px solid var(--border);padding:14px;border-radius:10px;margin-bottom:16px}
.credential-box span{font-size:12px;color:var(--muted)}
.credential-box strong{font-size:13px;overflow-wrap:anywhere}
.security-note{font-size:12px!important;line-height:1.5;margin-bottom:16px!important}
.table-wrap{overflow-x:auto}
.table{width:100%;border-collapse:collapse;background:white;overflow:hidden;border-radius:12px}
.table th{background:#f1f5f9;text-align:left;padding:14px;color:#334155;font-size:14px}
.table td{padding:14px;border-top:1px solid var(--border);vertical-align:top}
.badge{display:inline-block;padding:6px 10px;border-radius:999px;font-size:13px;font-weight:800}
.badge-pending{background:var(--yellow-bg);color:var(--yellow-text)}
.badge-progress{background:var(--blue-bg);color:var(--blue-text)}
.badge-resolved{background:var(--green-bg);color:var(--green-text)}
.badge-rejected{background:#fee2e2;color:#991b1b}
.badge-warning{background:#ffedd5;color:#9a3412}
.case-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(285px,1fr));gap:18px}
.case-card{background:white;border-left:5px solid var(--blue);padding:20px;border-radius:16px;box-shadow:0 4px 16px rgba(15,23,42,0.08)}

.employee-hero{background:white;border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:22px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:22px;box-shadow:0 4px 16px rgba(15,23,42,0.08)}
.birthday-greeting{background:#fff7ed;border:1px solid #fed7aa;border-left:6px solid #f97316;border-radius:16px;padding:18px 20px;margin-bottom:18px;box-shadow:0 4px 16px rgba(15,23,42,0.06)}
.birthday-greeting strong,.birthday-greeting span{display:block}
.birthday-greeting strong{font-size:22px;color:#9a3412;margin-bottom:4px}
.birthday-greeting span{color:#7c2d12;line-height:1.5}
.birthday-celebrants-card{border-left:5px solid #f97316}
.birthday-celebrants-card .badge-progress{background:#ffedd5;color:#9a3412}
.birthday-celebrant-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.birthday-celebrant-list article{display:grid;grid-template-columns:82px minmax(0,1fr);gap:12px;align-items:center;border:1px solid var(--border);background:#fffaf5;border-radius:14px;padding:12px}
.birthday-celebrant-list article.today{border-color:#fdba74;background:#fff7ed;box-shadow:inset 4px 0 #f97316}
.birthday-celebrant-list article.empty{grid-column:1/-1;background:#f8fafc}
.birthday-celebrant-list strong{display:block;color:#0f172a;overflow-wrap:anywhere}
.birthday-celebrant-list small{display:block;color:var(--muted);margin-top:3px;line-height:1.35}
.birthday-mini-date{border-radius:12px;background:#ffedd5;color:#9a3412;text-align:center;padding:10px 8px}
.birthday-mini-date strong{font-size:14px;color:#9a3412}
.birthday-mini-date span{display:block;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-top:3px}
.birthday-modal{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:rgba(15,23,42,.62);padding:20px;opacity:0;pointer-events:none;transition:opacity .18s ease}
.birthday-modal.open{opacity:1;pointer-events:auto}
.birthday-modal-card{position:relative;width:min(560px,100%);overflow:hidden;text-align:center;background:white;border:1px solid #fed7aa;border-radius:24px;padding:34px;box-shadow:0 28px 70px rgba(15,23,42,.32);transform:translateY(16px) scale(.98);transition:transform .18s ease}
.birthday-modal.open .birthday-modal-card{transform:translateY(0) scale(1)}
.birthday-modal-card small{display:block;color:#c2410c;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.birthday-modal-card h2{font-size:34px;line-height:1.12;color:#9a3412;margin:8px 0 10px}
.birthday-modal-card p{color:#7c2d12;line-height:1.6;font-size:16px}
.birthday-modal-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:22px}
.birthday-confetti span{position:absolute;width:10px;height:20px;border-radius:4px;opacity:.82;animation:birthdayFloat 3.6s ease-in-out infinite}
.birthday-confetti span:nth-child(1){left:8%;top:16%;background:#f97316}
.birthday-confetti span:nth-child(2){left:20%;top:70%;background:#2563eb;animation-delay:.3s}
.birthday-confetti span:nth-child(3){left:76%;top:14%;background:#0f766e;animation-delay:.55s}
.birthday-confetti span:nth-child(4){left:88%;top:62%;background:#facc15;animation-delay:.8s}
.birthday-confetti span:nth-child(5){left:12%;top:44%;background:#dc2626;animation-delay:1.1s}
.birthday-confetti span:nth-child(6){left:82%;top:38%;background:#7c3aed;animation-delay:1.35s}
@keyframes birthdayFloat{
    0%,100%{transform:translateY(0) rotate(0)}
    50%{transform:translateY(-14px) rotate(16deg)}
}
.employee-hero-photo{width:96px;height:96px;border-radius:14px;overflow:hidden;background:#ccfbf1;color:#0f766e;display:grid;place-items:center;font-size:30px;font-weight:900}
.employee-hero-photo img{width:100%;height:100%;object-fit:cover}
.employee-hero-main small,.section-heading small,.dashboard-metrics span,.cash-advance-card small{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.employee-hero-main h1{font-size:30px;line-height:1.15;margin:5px 0}
.employee-hero-main p{color:#475569;margin-bottom:14px}
.employee-hero-actions{display:flex;flex-wrap:wrap;gap:10px}
.employee-status-card{background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:16px;min-width:190px}
.employee-status-card span,.employee-status-card small{display:block;color:var(--muted);font-size:12px}
.employee-status-card strong{display:block;margin:6px 0;color:#166534;text-transform:uppercase}
.dashboard-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:20px}
.dashboard-metrics article{background:white;border:1px solid var(--border);border-left:5px solid #0f766e;border-radius:14px;padding:18px;box-shadow:0 4px 16px rgba(15,23,42,0.06)}
.dashboard-metrics strong{display:block;margin:8px 0 4px;font-size:24px;color:#0f172a}
.dashboard-metrics small{color:var(--muted)}
.section-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}
.section-heading h3{font-size:21px}
.payslip-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.payslip-print-button{border:1px solid var(--border);border-radius:8px;background:#fff;color:#0f766e;padding:10px 12px;font-weight:900;cursor:pointer}
.payslip-print-button:hover{border-color:#0f766e;background:#f0fdfa}
.payslip-print-button-primary{background:#0f766e;border-color:#0f766e;color:#fff}
.payslip-print-button-primary:hover{background:#115e59;color:#fff}
.print-icon-button{width:38px;height:38px;border:1px solid var(--border);border-radius:10px;background:#fff;color:#0f766e;display:inline-grid;place-items:center;cursor:pointer}
.print-icon-button:hover{border-color:#0f766e;background:#f0fdfa}
.print-icon-button svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.detail-grid div{border:1px solid var(--border);background:#f8fafc;border-radius:12px;padding:14px}
.detail-grid .wide{grid-column:1/-1}
.detail-grid span{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;margin-bottom:6px}
.detail-grid strong{display:block;font-size:15px;line-height:1.45;overflow-wrap:anywhere}
.payslip-sheet{border:1px solid var(--border);background:#f8fafc;border-radius:14px;padding:18px;color:#0f172a}
.payslip-copy-company,.payslip-cut-line{display:none}
.payslip-header{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;margin-bottom:16px}
.payslip-title small,.payslip-info span,.payslip-panel-heading span,.payslip-totals span,.payslip-signoff span{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.payslip-title h3{font-size:24px;margin:4px 0;color:#0f172a}
.payslip-title p{color:var(--muted);line-height:1.5}
.payslip-brand{background:#0f766e;color:white;border-radius:14px;padding:16px 18px;min-width:240px;text-align:right}
.payslip-brand span{display:block;font-size:12px;font-weight:800;text-transform:uppercase;color:#ccfbf1}
.payslip-brand strong{display:block;font-size:26px;line-height:1.15;margin:4px 0}
.payslip-brand em{display:block;font-style:normal;font-size:12px;color:#ccfbf1}
.payslip-info{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}
.payslip-info div{background:white;border:1px solid var(--border);border-radius:12px;padding:13px}
.payslip-info strong{display:block;margin-top:6px;line-height:1.35;overflow-wrap:anywhere}
.payslip-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.payslip-panel{background:white;border:1px solid var(--border);border-radius:14px;overflow:hidden}
.payslip-panel-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#f1f5f9;padding:14px 16px;border-bottom:1px solid var(--border)}
.payslip-panel-heading strong{font-size:18px}
.payslip-lines{margin:0}
.payslip-lines div{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 16px;border-bottom:1px solid var(--border)}
.payslip-lines div:last-child{border-bottom:0}
.payslip-lines dt{font-weight:700;color:#334155}
.payslip-lines dd{margin:0;font-weight:800;color:#0f172a;text-align:right}
.deductions-table{border-left:5px solid #d97706}
.deductions-table .payslip-panel-heading{background:#fffbeb}
.deductions-table .payslip-panel-heading strong,.deductions-table .payslip-lines dd{color:#92400e}
.payslip-totals{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:16px}
.payslip-totals div{background:white;border:1px solid var(--border);border-radius:12px;padding:14px}
.payslip-totals strong{display:block;margin-top:6px;font-size:20px}
.payslip-totals .take-home{background:#ecfdf5;border-color:#99f6e4}
.take-home strong{color:#0f766e}
.payslip-signoff{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.payslip-signoff div{background:white;border:1px solid var(--border);border-radius:12px;padding:13px}
.payslip-signoff strong{display:block;margin-top:6px}
.payslip-note{color:var(--muted);font-size:13px;line-height:1.5}
.cash-advance-card{display:flex;align-items:center;justify-content:space-between;gap:24px;border-left:5px solid #d97706}
.cash-advance-card h3{font-size:21px;margin:5px 0 8px}
.cash-advance-card > strong{font-size:30px;color:#92400e;white-space:nowrap}
.message-fab{position:fixed;right:24px;bottom:24px;z-index:45;width:58px;height:58px;border:0;border-radius:18px;background:#0f766e;color:#fff;display:grid;place-items:center;box-shadow:0 18px 36px rgba(15,118,110,.34);cursor:pointer}
.message-fab:hover{background:#115e59}
.message-fab svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.message-fab span{position:absolute;right:-5px;top:-5px;min-width:22px;height:22px;border-radius:999px;background:#dc2626;color:#fff;border:2px solid #fff;font-size:11px;font-weight:900;display:grid;place-items:center}
.message-panel{position:fixed;right:24px;bottom:92px;z-index:44;width:min(450px,calc(100vw - 28px));max-height:min(700px,calc(100vh - 120px));background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 24px 60px rgba(15,23,42,.24);display:grid;grid-template-rows:auto auto minmax(220px,1fr) auto;overflow:hidden;transform:translateY(14px) scale(.98);opacity:0;pointer-events:none;transition:.16s ease}
.message-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
.message-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px 18px 14px;border-bottom:1px solid var(--border);background:#f8fafc}
.message-panel-header small{display:block;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}
.message-panel-header h3{font-size:20px;margin-top:4px}
.message-close{width:34px;height:34px;border:1px solid var(--border);border-radius:10px;background:#fff;color:#0f172a;font-size:24px;line-height:1;cursor:pointer}
.message-recipient-bar{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);background:#fff}
.message-recipient-bar label{font-size:12px;font-weight:900;text-transform:uppercase;color:var(--muted);letter-spacing:.04em}
.message-recipient-bar select{width:100%;min-width:0;border:1px solid var(--border);border-radius:10px;background:#f8fafc;padding:10px 12px;font:inherit;color:#0f172a}
.message-recipient-bar select{grid-column:2}
.message-search-wrap{position:relative;min-width:0}
.message-search-wrap input{width:100%;border:1px solid var(--border);border-radius:10px;background:#fff;padding:10px 12px;font:inherit;color:#0f172a}
.message-search-results{position:absolute;z-index:30;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 18px 45px rgba(15,23,42,.16);overflow:hidden;max-height:250px;overflow-y:auto}
.message-search-results button{width:100%;border:0;background:#fff;padding:11px 12px;text-align:left;display:grid;gap:3px;color:#0f172a;cursor:pointer}
.message-search-results button:hover,.message-search-results button:focus{background:#eef8f7;outline:0}
.message-search-results strong{font-size:13px}
.message-search-results span,.message-search-empty{font-size:12px;color:var(--muted)}
.message-search-empty{padding:12px}
.message-search-empty.error{color:#b42318}
.message-list{padding:16px;overflow:auto;background:#f1f5f9;display:flex;flex-direction:column;gap:12px}
.message-empty{border:1px dashed var(--border);border-radius:12px;background:#fff;color:var(--muted);padding:14px;text-align:center}
.message-empty.error{border-color:#fecaca;color:#991b1b;background:#fef2f2}
.message-item{display:grid;grid-template-columns:38px minmax(0,1fr);gap:10px;align-items:flex-start}
.message-item.mine{grid-template-columns:minmax(0,1fr) 38px}
.message-item.mine .message-avatar{grid-column:2}
.message-item.mine .message-bubble{grid-column:1;grid-row:1;background:#ecfdf5;border-color:#99f6e4}
.message-avatar{width:38px;height:38px;border-radius:14px;background:#ccfbf1;color:#0f766e;display:grid;place-items:center;font-size:13px;font-weight:900}
.message-bubble{background:#fff;border:1px solid var(--border);border-radius:14px;padding:12px;min-width:0}
.message-bubble div{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:3px}
.message-bubble strong{font-size:13px}
.message-bubble time,.message-bubble small{color:var(--muted);font-size:11px}
.message-bubble small{display:block;margin-bottom:8px}
.message-bubble p{font-size:14px;line-height:1.45;overflow-wrap:anywhere}
.message-form{padding:14px;border-top:1px solid var(--border);background:#fff}
.message-form label{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.04em}
.message-form div{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end}
.message-form textarea{min-height:48px;max-height:120px;resize:vertical}
.btn-danger{background:var(--red);color:white}
.btn-danger:hover{background:#b91c1c}
.field-hint{margin-top:7px;color:var(--muted);font-size:13px}
.form-actions,.review-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.case-number{display:block;color:#0f766e;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.case-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.case-form-grid .wide{grid-column:1/-1}
.request-route-card,.request-flow{border:1px solid #bfdbfe;background:#eff6ff;border-radius:14px;padding:14px}
.request-route-card{margin-bottom:0}
.request-route-card strong,.request-flow strong{display:block;color:#1e3a8a;margin-bottom:4px}
.request-route-card span,.request-flow span{display:block;color:#475569;line-height:1.5}
.request-flow{margin-bottom:16px}
.readonly-field{border:1px solid var(--border);background:#f8fafc;border-radius:12px;padding:13px 14px}
.readonly-field strong,.readonly-field span{display:block}
.readonly-field strong{color:#0f766e;margin-bottom:4px}
.readonly-field span{color:var(--muted);line-height:1.45}
.request-type-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:16px}
.request-type-card{display:block;text-decoration:none;color:#0f172a;border:1px solid var(--border);background:#f8fafc;border-radius:14px;padding:15px;min-height:116px}
.request-type-card:hover{border-color:#0f766e;box-shadow:0 8px 22px rgba(15,23,42,.08)}
.request-type-card strong{display:block;margin-bottom:8px;color:#0f766e}
.request-type-card span{display:block;color:var(--muted);font-size:13px;line-height:1.45}
.attendance-access-rule{border-color:#99f6e4;background:#f0fdfa}
.attendance-access-rule strong{color:#0f766e}
.attendance-scan-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.attendance-scan-actions .btn{white-space:nowrap}
.attendance-scan-status{border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a;border-radius:14px;padding:12px 14px;margin:0 0 16px;font-weight:800;line-height:1.45}
.attendance-scan-status.success{border-color:#86efac;background:#dcfce7;color:#166534}
.attendance-scan-status.warning{border-color:#fed7aa;background:#fff7ed;color:#9a3412}
.attendance-scan-status.error{border-color:#fecaca;background:#fef2f2;color:#991b1b}
.attendance-summary-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:0 0 16px}
.attendance-summary-grid article{border:1px solid var(--border);background:#f8fafc;border-radius:12px;padding:12px}
.attendance-summary-grid span{display:block;color:var(--muted);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}
.attendance-summary-grid strong{display:block;margin-top:5px;font-size:18px;color:#0f172a}
.employee-attendance-table td strong,.employee-attendance-table td small{display:block}
.employee-attendance-table td small{color:var(--muted);margin-top:4px;line-height:1.35}
.employee-attendance-table .badge{margin:0 6px 6px 0;text-decoration:none}
.request-status-list{margin-top:10px}
.case-request-list{display:grid;gap:12px}
.case-request-row{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;border:1px solid var(--border);border-radius:14px;background:#f8fafc;padding:15px}
.case-request-row strong{display:block;font-size:17px;color:#0f172a;margin-bottom:3px}
.case-request-row small{display:block;color:var(--muted);line-height:1.4}
.case-row-actions{display:flex;gap:12px;justify-content:flex-end}
.case-empty-state{border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc;padding:18px}
.case-empty-state strong{display:block;margin-bottom:6px;color:#0f172a}
.case-detail-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(300px,.7fr);gap:20px;align-items:start}
.case-side-card{position:sticky;top:24px}
.case-proof-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}
.case-proof-grid a{display:block;text-decoration:none;color:#0f172a;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#f8fafc}
.case-proof-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:#e2e8f0}
.case-proof-grid span{display:block;padding:9px;font-size:12px;font-weight:700;overflow-wrap:anywhere}
.case-proof-grid a > small{display:block;padding:0 9px 10px;color:var(--muted);font-size:11px;line-height:1.35}
.case-proof-document{aspect-ratio:4/3;background:#eff6ff;display:grid;place-content:center;text-align:center;padding:12px}
.case-proof-document strong{font-size:24px;color:#1d4ed8;line-height:1}
.case-proof-document small{display:block;margin-top:7px;color:#475569;font-size:11px}
.proof-section-heading{margin-top:20px;padding-top:18px;border-top:1px solid var(--border)}
.proof-upload-form{margin-top:18px;padding-top:16px;border-top:1px dashed #cbd5e1}
.review-form,.reply-form{margin-top:4px}
.reply-list{display:grid;gap:12px;margin-bottom:18px}
.reply-item{border:1px solid var(--border);border-left:5px solid #0f766e;border-radius:14px;background:#f8fafc;padding:15px}
.reply-item.hr-reply{border-left-color:var(--blue);background:#eff6ff}
.reply-item strong{display:block;color:#0f172a}
.reply-item small{display:block;color:var(--muted);margin-top:2px}
.reply-item p{margin-top:10px;line-height:1.6;color:#334155}
.attendance-scan-modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(15,23,42,.62)}
.attendance-scan-modal.open{display:flex}
.attendance-scan-dialog{width:min(620px,100%);max-height:calc(100vh - 40px);overflow:auto;background:#fff;border:1px solid var(--border);border-radius:18px;padding:20px;box-shadow:0 24px 70px rgba(15,23,42,.28)}
.attendance-camera-frame{display:grid;place-items:center;aspect-ratio:4/3;border:1px solid var(--border);border-radius:16px;background:#0f172a;overflow:hidden;margin:14px 0}
.attendance-camera-frame video,.attendance-camera-frame img{width:100%;height:100%;object-fit:cover}
.attendance-scan-modal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:14px}

@media(max-width:900px){
    .auth-body{display:block;min-height:100vh}
    .auth-left{padding:34px 22px 18px}
    .auth-left h1{font-size:34px;line-height:1.08;margin-bottom:12px}
    .auth-left p{font-size:15px;line-height:1.55}
    .auth-badges{gap:8px;margin-top:18px}
    .auth-badges span{border-radius:10px;padding:8px 10px;font-size:13px}
    .auth-links{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:18px}
    .auth-links a{text-align:center;padding:10px 8px;font-size:13px}
    .auth-right{width:100%;padding:16px 16px 28px;align-items:flex-start}
    .auth-card{padding:22px;border-radius:14px}
    .auth-card h2{font-size:24px}
    .auth-card p{margin-bottom:18px}
    .container{display:block}
    .sidebar{width:100%;height:auto;position:sticky;top:0;z-index:20;padding:14px 16px;box-shadow:0 8px 24px rgba(15,23,42,0.18);overflow:visible}
    .logo{margin-bottom:0;padding-right:58px}
    .logo-mark{width:38px;height:38px;border-radius:10px}
    .logo h2{font-size:22px;line-height:1.1}
    .logo small{display:none}
    .employee-menu-toggle{position:absolute;right:16px;top:15px;width:42px;height:42px;border:1px solid rgba(255,255,255,.18);border-radius:12px;background:rgba(255,255,255,.08);color:white;display:grid;place-items:center;cursor:pointer}
    .employee-menu-toggle svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round}
    .employee-menu-toggle:hover{background:rgba(255,255,255,.14)}
    .user-box{padding:10px 12px;margin-bottom:10px;border-radius:12px}
    .user-box strong{display:inline;font-size:14px}
    .user-box small{display:block;margin-top:3px;font-size:12px;line-height:1.35}
    .nav-link{display:inline-flex;align-items:center;min-height:40px;padding:9px 12px;margin:0 6px 8px 0;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);white-space:nowrap}
    .sidebar:not(.menu-open) .user-box,.sidebar:not(.menu-open) .nav-link{display:none}
    .sidebar.menu-open{max-height:calc(100vh - 8px);overflow:auto}
    .sidebar.menu-open .user-box{display:block;margin-top:12px}
    .sidebar.menu-open .nav-link{display:inline-flex}
    .main{padding:18px}
    .employee-hero{grid-template-columns:1fr;text-align:left}
    .employee-status-card{min-width:0}
    .dashboard-metrics{grid-template-columns:1fr}
    .birthday-celebrant-list{grid-template-columns:1fr}
    .detail-grid{grid-template-columns:1fr}
    .detail-grid .wide{grid-column:auto}
    .request-type-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .attendance-scan-actions{justify-content:flex-start}
    .attendance-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .payslip-header,.payslip-info,.payslip-columns,.payslip-totals,.payslip-signoff{grid-template-columns:1fr}
    .payslip-brand{text-align:left;min-width:0}
    .cash-advance-card{align-items:flex-start;flex-direction:column}
    .cash-advance-card > strong{white-space:normal}
    .message-panel{right:12px;bottom:82px;max-height:calc(100vh - 96px)}
    .case-form-grid,.case-detail-grid,.case-request-row{grid-template-columns:1fr}
    .case-form-grid .wide{grid-column:auto}
    .case-side-card{position:static}
    .case-row-actions{justify-content:flex-start}
}

@media(max-width:640px){
    body{font-size:15px}
    .sidebar{max-height:none;overflow:visible}
    .sidebar.menu-open{max-height:calc(100vh - 8px);overflow:auto}
    .main{padding:12px}
    .card,.topbar,.employee-hero{border-radius:14px;padding:16px;margin-bottom:14px}
    .employee-hero{gap:14px;box-shadow:0 2px 12px rgba(15,23,42,.06)}
    .birthday-greeting{padding:15px;margin-bottom:14px;border-radius:14px}
    .birthday-greeting strong{font-size:19px}
    .birthday-celebrant-list article{grid-template-columns:74px minmax(0,1fr);padding:10px}
    .birthday-mini-date{padding:9px 7px}
    .birthday-modal{padding:14px}
    .birthday-modal-card{border-radius:18px;padding:26px 18px}
    .birthday-modal-card h2{font-size:26px}
    .birthday-modal-actions{display:grid;grid-template-columns:1fr;gap:8px}
    .employee-hero-photo{width:74px;height:74px;border-radius:14px;font-size:24px}
    .employee-hero-main h1{font-size:25px;line-height:1.1;overflow-wrap:anywhere}
    .employee-hero-main p{font-size:15px;line-height:1.35;margin-bottom:12px}
    .employee-hero-actions{display:grid;grid-template-columns:1fr;gap:8px}
    .btn{width:100%;text-align:center;padding:12px 14px}
    .employee-status-card{padding:12px}
    .dashboard-metrics{gap:12px;margin-bottom:14px}
    .dashboard-metrics article{padding:14px;border-radius:12px}
    .dashboard-metrics strong{font-size:22px}
    .section-heading{display:grid;grid-template-columns:1fr;align-items:start;gap:10px}
    .section-heading h3{font-size:20px;line-height:1.2}
    .section-heading .btn,.section-heading .text-link{width:100%;text-align:center}
    .payslip-actions{display:grid;grid-template-columns:1fr;width:100%;justify-content:stretch}
    .payslip-print-button{width:100%}
    .case-request-row{gap:10px;padding:13px;border-radius:12px}
    .request-type-grid{grid-template-columns:1fr;gap:10px}
    .request-type-card{min-height:0;padding:13px;border-radius:12px}
    .request-flow,.request-route-card{border-radius:12px;padding:12px}
    .case-row-actions{display:grid;grid-template-columns:1fr 1fr;width:100%;gap:8px}
    .case-row-actions .text-link{text-align:center;background:#eef7f6;border-radius:10px;padding:10px}
    .attendance-scan-actions{display:grid;grid-template-columns:1fr 1fr;width:100%;gap:8px}
    .attendance-scan-actions .btn{width:100%;justify-content:center}
    .attendance-scan-modal{padding:12px}
    .attendance-scan-dialog{border-radius:14px;padding:16px;max-height:calc(100vh - 24px)}
    .attendance-scan-modal-actions{display:grid;grid-template-columns:1fr;gap:8px}
    .attendance-summary-grid{grid-template-columns:1fr;gap:8px}
    .detail-grid{gap:10px}
    .detail-grid div{border-radius:10px;padding:12px}
    .payslip-sheet{padding:12px;border-radius:12px;overflow:hidden}
    .payslip-title h3{font-size:20px}
    .payslip-brand{padding:14px;text-align:left;border-radius:12px}
    .payslip-brand strong{font-size:23px;overflow-wrap:anywhere}
    .payslip-info,.payslip-columns,.payslip-totals,.payslip-signoff{gap:10px}
    .payslip-panel-heading{display:grid;grid-template-columns:1fr;gap:4px;padding:12px}
    .payslip-lines div{align-items:flex-start;padding:11px 12px}
    .payslip-lines dt{min-width:0;padding-right:8px}
    .payslip-lines dd{max-width:48%;overflow-wrap:anywhere}
    .payslip-totals strong{font-size:18px;overflow-wrap:anywhere}
    .cash-advance-card h3{font-size:20px}
    .cash-advance-card > strong{font-size:24px;overflow-wrap:anywhere}
    .table th,.table td{padding:10px;min-width:120px}
}

@media(max-width:420px){
    .main{padding:10px}
    .auth-left{padding:28px 16px 14px}
    .auth-left h1{font-size:28px}
    .auth-links{grid-template-columns:1fr}
    .auth-right{padding:12px 12px 24px}
    .auth-card{padding:18px}
    .sidebar{padding:12px 12px 8px}
    .logo h2{font-size:20px}
    .nav-link{font-size:14px;padding:8px 10px;min-height:38px}
    .employee-hero-main h1{font-size:22px}
    .dashboard-metrics strong,.cash-advance-card > strong{font-size:22px}
    .payslip-lines div{display:grid;grid-template-columns:1fr;gap:4px}
    .payslip-lines dd{max-width:none;text-align:left}
    .message-fab{right:14px;bottom:14px;width:52px;height:52px;border-radius:16px}
    .message-panel{right:8px;bottom:72px;width:calc(100vw - 16px);border-radius:16px}
    .message-recipient-bar{grid-template-columns:1fr;gap:6px;padding:10px 12px}
    .message-recipient-bar select{grid-column:auto}
    .message-form div{grid-template-columns:1fr}
    .attendance-scan-actions{grid-template-columns:1fr}
}

@media print{
    @page{size:8.5in 11in;margin:.25in}
    html{background:#fff!important}
    body.print-payslip{width:8.5in;min-height:11in;background:#fff!important;color:#000!important}
    body.print-payslip .sidebar,
    body.print-payslip .employee-mobile-header,
    body.print-payslip .message-fab,
    body.print-payslip .message-panel,
    body.print-payslip .attendance-scan-modal,
    body.print-payslip .birthday-modal,
    body.print-payslip .main > :not(#payslip),
    body.print-payslip #payslip > .section-heading{display:none!important}
    body.print-payslip .container{display:block;min-height:0;background:#fff!important}
    body.print-payslip .main{display:block;padding:0!important;margin:0!important;background:#fff!important}
    body.print-payslip #payslip{display:block!important;margin:0!important;padding:0!important;border:0!important;box-shadow:none!important;background:#fff!important}
    body.print-payslip .payslip-sheet{border:0!important;background:#fff!important;border-radius:0!important;padding:0!important;color:#000!important}
    body.print-payslip .payslip-print-stack{display:block;width:100%;height:10.5in;overflow:hidden;background:#fff}
    body.print-payslip .payslip-copy{display:block!important;border:1px solid #111;background:#fff!important;border-radius:0!important;color:#000!important;padding:.12in;height:5.1in;overflow:hidden;break-inside:avoid;page-break-inside:avoid}
    body.print-payslip .payslip-copy-company,
    body.print-payslip .payslip-cut-line{display:none!important}
    body.print-payslip-company .payslip-copy-employee{display:none!important}
    body.print-payslip-company .payslip-copy-company,
    body.print-payslip-both .payslip-copy-company,
    body.print-payslip-pdf .payslip-copy-company{display:block!important}
    body.print-payslip-both .payslip-cut-line,
    body.print-payslip-pdf .payslip-cut-line{display:flex!important;align-items:center;justify-content:center;height:.2in;border:0;border-top:1px dashed #111;color:#111;font-size:8px;text-transform:uppercase;letter-spacing:0;background:#fff}
    body.print-payslip .payslip-header{grid-template-columns:1fr auto;gap:8px;align-items:start;margin-bottom:5px}
    body.print-payslip .payslip-title small,
    body.print-payslip .payslip-info span,
    body.print-payslip .payslip-panel-heading span,
    body.print-payslip .payslip-totals span,
    body.print-payslip .payslip-signoff span{color:#111!important;font-size:7.5px;letter-spacing:0}
    body.print-payslip .payslip-title h3{font-size:15px;margin:1px 0;color:#000!important}
    body.print-payslip .payslip-title p{font-size:8.5px;line-height:1.2;color:#111!important;margin:0}
    body.print-payslip .payslip-brand{border:1px solid #111;background:#fff!important;color:#000!important;border-radius:0;padding:5px 7px;min-width:1.8in;text-align:right}
    body.print-payslip .payslip-brand span,
    body.print-payslip .payslip-brand em{color:#111!important;font-size:7.5px}
    body.print-payslip .payslip-brand strong{font-size:14px;margin:1px 0;color:#000!important}
    body.print-payslip .payslip-info{grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;margin-bottom:5px}
    body.print-payslip .payslip-info div{border:1px solid #999;background:#fff!important;border-radius:0;padding:3px 5px}
    body.print-payslip .payslip-info strong{font-size:8.5px;margin-top:1px;color:#000!important;line-height:1.2}
    body.print-payslip .payslip-columns{grid-template-columns:1fr 1fr;gap:5px;margin-bottom:5px}
    body.print-payslip .payslip-panel{border:1px solid #111;background:#fff!important;border-radius:0}
    body.print-payslip .deductions-table{border-left:1px solid #111}
    body.print-payslip .payslip-panel-heading{background:#eee!important;border-bottom:1px solid #111;padding:3px 5px}
    body.print-payslip .payslip-panel-heading strong{font-size:9px;color:#000!important}
    body.print-payslip .payslip-lines div{padding:2px 5px;gap:5px;border-bottom:1px solid #bbb}
    body.print-payslip .payslip-lines dt,
    body.print-payslip .payslip-lines dd{font-size:8px;color:#000!important;line-height:1.15}
    body.print-payslip .payslip-lines dt{font-weight:700}
    body.print-payslip .payslip-lines dd{font-weight:800;text-align:right}
    body.print-payslip .payslip-totals{grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;margin-bottom:5px}
    body.print-payslip .payslip-totals div{border:1px solid #111;background:#fff!important;border-radius:0;padding:3px 5px}
    body.print-payslip .payslip-totals .take-home{background:#ffff66!important;border-color:#111!important}
    body.print-payslip .payslip-totals strong{font-size:9.5px;margin-top:1px;color:#000!important}
    body.print-payslip .payslip-signoff{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:3px}
    body.print-payslip .payslip-signoff div{border:0;border-bottom:1px solid #111;background:#fff!important;border-radius:0;padding:2px 0 1px}
    body.print-payslip .payslip-signoff strong{font-size:8px;margin-top:7px;color:#000!important}
    body.print-payslip .payslip-note{font-size:7px;line-height:1.15;color:#000!important;margin:0;text-align:center}
}
