/* HR Kiosk V3 — Serene Professional Light Theme */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700;800&family=Inter:wght@400;500;600&display=swap');

:root {
  --primary:#104356; --primary-container:#2d5a6e; --primary-light:#376478;
  --on-primary:#fff; --on-primary-container:#a3d0e7;
  --tertiary:#004640; --tertiary-container:#006058; --on-tertiary-container:#6fdcce;
  --secondary:#505f76;
  --surface:#f9f9fb; --surface-card:#ffffff; --surface-variant:#e8e8ea;
  --on-surface:#1a1c1d; --on-surface-variant:#41484c;
  --outline:#71787c; --outline-variant:#c1c7cc;
  --error:#ba1a1a; --error-container:#ffdad6;
  --warning-bg:#FFF4E5; --warning-color:#B26B00;
  --success-bg:#E6F4F1; --success-color:#004640;
  --radius-sm:8px; --radius-md:12px; --radius-lg:16px; --radius-xl:20px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 20px rgba(0,0,0,.06);
  --shadow-lg:0 8px 30px rgba(0,0,0,.08);
  --sidebar-w:256px;
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;background:var(--surface);color:var(--on-surface);min-height:100vh;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Manrope',sans-serif}

/* ─── LOGIN ─────────────────────────────────────── */
body.login-body{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f2027,#203a43,#2c5364)}
.login-wrap{width:100%;max-width:440px;padding:1.5rem}
.login-card{background:#fff;border-radius:var(--radius-xl);padding:2.5rem;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.login-card .logo{text-align:center;margin-bottom:2rem}
.login-card .logo img{width:80px;margin-bottom:.75rem}
.login-card .logo h1{font-size:1.5rem;font-weight:800;color:var(--primary);margin-bottom:.25rem}
.login-card .logo p{color:var(--on-surface-variant);font-size:.9rem}
.pin-dots{display:flex;gap:.75rem;justify-content:center;margin-bottom:1.5rem}
.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--outline-variant);background:transparent;transition:.2s}
.pin-dot.filled{background:var(--primary);border-color:var(--primary)}
.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}
.numpad-btn{padding:1rem;border:1px solid var(--outline-variant);border-radius:var(--radius-md);background:#fff;font-size:1.3rem;font-weight:600;color:var(--on-surface);cursor:pointer;transition:.15s;font-family:'Manrope',sans-serif}
.numpad-btn:hover{background:var(--surface);border-color:var(--primary)}
.numpad-btn:active{transform:scale(.96)}
.numpad-btn.danger{color:var(--error)}
.emp-id-field{width:100%;padding:.85rem 1rem;border:1px solid var(--outline-variant);border-radius:var(--radius-md);font-size:1rem;color:var(--on-surface);background:#fff;margin-bottom:1rem;text-align:center;letter-spacing:.1em;font-family:'Inter',sans-serif}
.emp-id-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(16,67,86,.15)}
.btn-login{width:100%;padding:.9rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:.2s}
.btn-login:hover{background:var(--primary-light)}
.login-error{color:var(--error);background:var(--error-container);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.9rem;margin-top:1rem;display:none;text-align:center}

/* ─── APP SHELL ──────────────────────────────────── */
.app-wrap{display:flex;height:100vh;overflow:hidden}

/* Sidebar */
.sidebar{width:var(--sidebar-w);background:#fff;border-right:1px solid var(--outline-variant);display:flex;flex-direction:column;padding:1rem;flex-shrink:0;overflow-y:auto}
.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:.75rem;margin-bottom:1rem}
.sidebar-brand-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--primary-container);display:flex;align-items:center;justify-content:center;color:var(--on-primary-container);font-size:1.2rem}
.sidebar-brand h2{font-size:1rem;font-weight:800;color:var(--primary);line-height:1}
.sidebar-brand p{font-size:.75rem;color:var(--on-surface-variant)}
.sidebar-cta{display:flex;align-items:center;gap:.5rem;background:var(--primary-container);color:var(--on-primary-container);border:none;border-radius:var(--radius-md);padding:.75rem 1rem;width:100%;font-size:.9rem;font-weight:600;cursor:pointer;margin-bottom:1rem;font-family:'Inter',sans-serif;transition:.2s}
.sidebar-cta:hover{background:var(--primary);color:#fff}
.nav-section-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--on-surface-variant);padding:.5rem .75rem;margin-top:.5rem}
.nav-link{display:flex;align-items:center;gap:.75rem;padding:.7rem .75rem;border-radius:var(--radius-md);color:var(--on-surface-variant);text-decoration:none;font-size:.9rem;font-weight:500;transition:.15s;border:none;background:transparent;width:100%;cursor:pointer;font-family:'Inter',sans-serif}
.nav-link i{width:20px;text-align:center;font-size:.95rem}
.nav-link:hover{background:var(--surface);color:var(--on-surface)}
.nav-link.active{background:#fff;color:var(--primary);font-weight:600;box-shadow:var(--shadow-sm);border:1px solid var(--outline-variant)}
.nav-divider{border:none;border-top:1px solid var(--outline-variant);margin:.75rem 0}
.nav-spacer{flex:1}

/* Topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 1.5rem;background:#fff;border-bottom:1px solid var(--outline-variant);box-shadow:var(--shadow-sm);flex-shrink:0}
.topbar-left{display:flex;align-items:center;gap:.75rem}
.topbar-title{font-size:1.1rem;font-weight:700;color:var(--on-surface);font-family:'Manrope',sans-serif}
.topbar-right{display:flex;align-items:center;gap:.5rem}
.icon-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--on-surface-variant);transition:.15s;position:relative}
.icon-btn:hover{background:var(--surface)}
.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--error);border-radius:50%;border:2px solid #fff}
.avatar-chip{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem .25rem .25rem;border-radius:999px;background:var(--surface);border:1px solid var(--outline-variant);cursor:pointer;transition:.15s}
.avatar-chip:hover{background:var(--surface-variant)}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--primary-container);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;font-family:'Manrope',sans-serif}
.avatar-name{font-size:.85rem;font-weight:600;color:var(--on-surface)}

/* Main content */
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}
.main-scroll{flex:1;overflow-y:auto;padding:2rem}

/* ─── COMMON COMPONENTS ──────────────────────────── */
.page-header{margin-bottom:1.75rem}
.page-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);margin-bottom:.4rem}
.page-title{font-size:2rem;font-weight:800;color:var(--on-surface);line-height:1.2}
.page-sub{color:var(--on-surface-variant);font-size:.95rem;margin-top:.35rem}

.card{background:var(--surface-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid #f1f5f9;transition:.3s}
.card:hover{box-shadow:var(--shadow-lg)}
.card-pad{padding:1.5rem}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.bento{display:grid;grid-template-columns:2fr 1fr;gap:1.25rem}
@media(max-width:768px){.grid-2,.grid-3,.grid-4,.bento{grid-template-columns:1fr}}

/* Stats */
.stat-card{background:var(--surface-card);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md);border:1px solid #f1f5f9}
.stat-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--on-surface-variant);margin-bottom:.5rem}
.stat-value{font-size:2rem;font-weight:800;color:var(--on-surface);font-family:'Manrope',sans-serif;line-height:1}
.stat-sub{font-size:.8rem;color:var(--on-surface-variant);margin-top:.4rem}
.stat-up{color:#16a34a} .stat-down{color:var(--error)}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600}
.badge-pending{background:#FFF4E5;color:#B26B00}
.badge-approved{background:var(--success-bg);color:var(--success-color)}
.badge-rejected{background:var(--error-container);color:var(--error)}
.badge-admin{background:var(--primary-container);color:var(--on-primary-container)}
.badge-employee{background:var(--surface-variant);color:var(--on-surface-variant)}
.badge-new{background:var(--success-bg);color:var(--success-color)}
.badge-notice{background:var(--surface-variant);color:var(--on-surface-variant)}
.badge-due-urgent{background:var(--error-container);color:var(--error)}
.badge-due-soon{background:#FFF4E5;color:#B26B00}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:var(--radius-md);border:none;font-size:.875rem;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:.15s;text-decoration:none}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-light)}
.btn-secondary{background:var(--surface);color:var(--on-surface);border:1px solid var(--outline-variant)}
.btn-secondary:hover{background:var(--surface-variant)}
.btn-danger{background:var(--error);color:#fff}
.btn-success{background:var(--tertiary);color:#fff}
.btn-success:hover{background:var(--tertiary-container)}
.btn-ghost{background:transparent;color:var(--primary);border:1px solid var(--primary)}
.btn-ghost:hover{background:var(--primary);color:#fff}
.btn-sm{padding:.4rem .85rem;font-size:.8rem}
.btn-lg{padding:.85rem 1.75rem;font-size:1rem}
.btn-block{width:100%;justify-content:center}
.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm);justify-content:center}

/* Forms */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--on-surface-variant);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.04em}
.form-input,.form-select,.form-textarea{width:100%;padding:.7rem .9rem;border:1px solid var(--outline-variant);border-radius:var(--radius-md);font-size:.95rem;color:var(--on-surface);background:#fff;font-family:'Inter',sans-serif;transition:.15s}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(16,67,86,.12)}
.form-textarea{resize:vertical;min-height:90px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* Tables */
.table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--outline-variant)}
table.data-table{width:100%;border-collapse:collapse;background:#fff}
.data-table th{padding:.75rem 1rem;text-align:left;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--on-surface-variant);background:var(--surface);border-bottom:1px solid var(--outline-variant)}
.data-table td{padding:.85rem 1rem;font-size:.9rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:#f9f9fb}

/* Modals */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .25s}
.modal-overlay.active{opacity:1;pointer-events:all}
.modal-box{background:#fff;border-radius:var(--radius-xl);width:90%;max-width:580px;max-height:90vh;overflow-y:auto;transform:translateY(16px);transition:transform .25s;box-shadow:0 20px 60px rgba(0,0,0,.15)}
.modal-overlay.active .modal-box{transform:translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--outline-variant)}
.modal-title{font-size:1.1rem;font-weight:700;color:var(--on-surface);font-family:'Manrope',sans-serif}
.modal-body{padding:1.5rem}
.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--outline-variant);display:flex;justify-content:flex-end;gap:.75rem}
.btn-close-modal{background:transparent;border:none;cursor:pointer;color:var(--on-surface-variant);font-size:1.25rem;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;transition:.15s}
.btn-close-modal:hover{background:var(--surface)}

/* Alerts / Banners */
.alert{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--radius-md);margin-bottom:1.25rem}
.alert-danger{background:var(--error-container);color:#7f0a10;border:1px solid #ffb4ab}
.alert-warning{background:var(--warning-bg);color:#7a4800;border:1px solid #f5c842}
.alert-success{background:var(--success-bg);color:var(--tertiary);border:1px solid #a8d5ce}
.alert i{margin-top:.15rem;flex-shrink:0}

/* Progress bar */
.progress-track{height:8px;background:var(--surface-variant);border-radius:999px;overflow:hidden;margin-top:.5rem}
.progress-fill{height:100%;border-radius:999px;transition:width .4s ease}
.progress-good{background:#16a34a}
.progress-warn{background:#d97706}
.progress-danger{background:var(--error)}

/* Tabs */
.tabs{display:flex;gap:.25rem;border-bottom:2px solid var(--outline-variant);margin-bottom:1.5rem}
.tab-btn{padding:.6rem 1rem;border:none;background:transparent;font-size:.875rem;font-weight:600;color:var(--on-surface-variant);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;font-family:'Inter',sans-serif;transition:.15s}
.tab-btn:hover{color:var(--on-surface)}
.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}

/* Employee init avatar */
.emp-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-container);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;font-family:'Manrope',sans-serif;flex-shrink:0}

/* Form builder field block */
.fb-field-block{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:1px solid var(--outline-variant);border-radius:var(--radius-md);padding:.9rem 1rem;margin-bottom:.75rem;border-left:3px solid var(--primary)}
.fb-field-block .drag-handle{color:var(--outline);cursor:grab;font-size:1rem}
.fb-field-info{flex:1}
.fb-field-label{font-weight:600;font-size:.9rem;color:var(--on-surface)}
.fb-field-type{font-size:.75rem;color:var(--on-surface-variant)}
.fb-field-actions{display:flex;gap:.5rem}

/* PPE lifecycle card */
.ppe-card{background:#fff;border-radius:var(--radius-lg);border:1px solid #f1f5f9;box-shadow:var(--shadow-sm);padding:1.25rem;transition:.2s}
.ppe-card:hover{box-shadow:var(--shadow-md)}
.ppe-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}
.ppe-card-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:1.1rem}
.ppe-card-name{font-weight:700;font-size:.95rem;color:var(--on-surface);margin-bottom:.15rem}
.ppe-card-meta{font-size:.8rem;color:var(--on-surface-variant)}
.ppe-replacement{font-size:.8rem;font-weight:600;margin-top:.5rem}

/* Quick action tiles */
.quick-tile{background:#fff;border-radius:var(--radius-md);border:1px solid var(--outline-variant);padding:1.25rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:.15s;text-align:center}
.quick-tile:hover{background:var(--surface);border-color:var(--primary)}
.quick-tile i{font-size:1.3rem;color:var(--primary)}
.quick-tile span{font-size:.8rem;font-weight:600;color:var(--on-surface)}

/* Memo card */
.memo-card{background:#fff;border-radius:var(--radius-md);border:1px solid #f1f5f9;padding:1.25rem;box-shadow:var(--shadow-sm)}
.memo-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}
.memo-title{font-weight:700;font-size:.95rem;color:var(--on-surface);margin-bottom:.4rem}
.memo-body{font-size:.875rem;color:var(--on-surface-variant);line-height:1.6}
.memo-read-more{display:inline-flex;align-items:center;gap:.3rem;margin-top:.75rem;font-size:.85rem;font-weight:600;color:var(--primary);background:none;border:none;cursor:pointer;font-family:'Inter',sans-serif;padding:0}

/* Quiz card */
.quiz-card{background:#fff;border-radius:var(--radius-lg);border-left:4px solid var(--primary);border-top:1px solid #f1f5f9;border-right:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;padding:1.25rem;box-shadow:var(--shadow-sm)}
.quiz-card.urgent{border-left-color:var(--error)}
.quiz-card.soon{border-left-color:#d97706}
.quiz-card-title{font-weight:700;font-size:1rem;margin-bottom:.25rem;color:var(--on-surface)}
.quiz-card-meta{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:var(--on-surface-variant);margin-bottom:.75rem}

/* Priority task item */
.priority-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 0;border-bottom:1px solid #f1f5f9}
.priority-item:last-child{border-bottom:none}
.priority-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.priority-icon.orange{background:#FFF4E5;color:#B26B00}
.priority-icon.blue{background:#EFF6FF;color:#1d4ed8}
.priority-icon.green{background:var(--success-bg);color:var(--tertiary)}

/* Animations */
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.view-section{animation:fadeInUp .3s ease forwards}
.spinner{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--on-surface-variant)}
.spinner i{font-size:1.5rem}

/* ─── MOBILE SIDEBAR TOGGLE ─────────────────────── */
.btn-menu-toggle{display:none;width:36px;height:36px;border-radius:50%;border:none;background:transparent;cursor:pointer;align-items:center;justify-content:center;color:var(--on-surface-variant);font-size:1.1rem;transition:.15s;margin-right:.25rem;flex-shrink:0}
.btn-menu-toggle:hover{background:var(--surface)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:99;opacity:0;pointer-events:none;transition:opacity .25s}
.sidebar-overlay.active{opacity:1;pointer-events:all}

@media(max-width:768px){
  .btn-menu-toggle{display:flex}
  .sidebar{position:fixed;top:0;left:0;height:100vh;z-index:100;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay{display:block}
  .topbar{padding:0 1rem}
  .main-scroll{padding:1rem}
  .avatar-name{display:none}
  .form-row{grid-template-columns:1fr}
}

@media(max-width:480px){
  .topbar-title{font-size:.95rem}
  .page-title{font-size:1.5rem}
  .btn-lg{padding:.75rem 1.25rem;font-size:.9rem}
  .main-scroll{padding:.75rem}
}
