:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}#root{width:100%;min-height:100vh}body{margin:0;min-width:320px;min-height:100vh;width:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;position:relative;overflow:hidden;background:linear-gradient(180deg,#e0f2fe,#f1f5f9,#e2e8f0)}.login-bg{position:absolute;inset:-20px;background-image:url(https://images.unsplash.com/photo-1497366811353-6870744d04b2?w=1920&q=85);background-size:cover;background-position:center;filter:blur(6px);transform:scale(1.04);z-index:0}.login-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#ffffff1f,#ffffff0f,#ffffff14);z-index:1}.login-page:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 30% 20%,rgba(255,255,255,.12) 0%,transparent 45%),radial-gradient(circle at 70% 80%,rgba(255,255,255,.08) 0%,transparent 45%);pointer-events:none;z-index:2}.login-page:after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle 1px at 15% 25%,rgba(255,255,255,.5) 0%,transparent 100%),radial-gradient(circle 1px at 85% 75%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(circle 1px at 50% 50%,rgba(255,255,255,.3) 0%,transparent 100%);background-size:200% 200%,180% 180%,220% 220%;background-position:0 0,40px 60px,80px 40px;pointer-events:none;z-index:2;opacity:.7}.login-card{position:relative;z-index:10;background:#ffffffb8;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:2.5rem 2.25rem;border-radius:24px;border:1px solid rgba(255,255,255,.6);box-shadow:0 4px 6px -1px #0000000a,0 20px 50px -12px #0000001f;width:100%;max-width:400px;text-align:center}.login-card-icon-wrap{width:72px;height:72px;margin:0 auto 1.25rem;border-radius:50%;background:#fff;border:2px solid #93c5fd;color:#1d4ed8;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb26}.login-title{margin:0 0 .35rem;font-size:1.6rem;font-weight:700;color:#1e3a8a;letter-spacing:-.02em}.login-subtitle{margin:0 0 1.75rem;font-size:.95rem;color:#64748b}.login-form{text-align:left}.login-label{display:block;margin-bottom:1rem;font-weight:500;color:#475569;font-size:.9rem}.login-input-wrap{position:relative;margin-top:.4rem}.login-input-wrap input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #e2e8f0;border-radius:12px;font-size:1rem;background:#fff;color:#1e293b;box-sizing:border-box;box-shadow:inset 0 1px 2px #0000000a;transition:border-color .2s,box-shadow .2s}.login-input-wrap input::placeholder{color:#94a3b8}.login-input-wrap input:hover{border-color:#cbd5e1}.login-input-wrap input:focus{outline:none;border-color:#2563eb;box-shadow:inset 0 1px 2px #0000000a,0 0 0 3px #2563eb26}.login-input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#2563eb;display:flex;align-items:center;justify-content:center;pointer-events:none}.login-error{color:#dc2626;font-size:.9rem;margin:0 0 .75rem}.login-btn{width:100%;padding:.9rem 1rem;margin-top:.75rem;background:#2563eb;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 4px 14px #2563eb66;transition:background .2s,box-shadow .2s,transform .1s}.login-btn:hover:not(:disabled){background:#1d4ed8;box-shadow:0 6px 20px #2563eb73}.login-btn:active:not(:disabled){transform:scale(.99)}.login-btn:disabled{opacity:.8;cursor:not-allowed}.app-sidebar{position:fixed;top:0;left:0;height:100vh;width:56px;min-width:56px;background:#1e293b;color:#fff;padding:.75rem 0;display:flex;flex-direction:column;gap:.25rem;box-shadow:2px 0 8px #0000001a;transition:width .2s ease,min-width .2s ease;overflow:hidden;z-index:100}.app-sidebar:hover{width:220px;min-width:220px}.app-sidebar-brand{padding:.5rem .75rem;margin-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.12);min-height:2.5rem;display:flex;align-items:center;justify-content:center}.app-sidebar:hover .app-sidebar-brand{justify-content:flex-start}.app-sidebar-brand-text{font-size:1.25rem;font-weight:700;color:#fff;white-space:nowrap;opacity:0;transform:translate(-8px);transition:opacity .2s ease,transform .2s ease}.app-sidebar:hover .app-sidebar-brand-text{opacity:1;transform:translate(0)}.app-sidebar .app-sidebar-brand-text{overflow:hidden}.app-sidebar:not(:hover) .app-sidebar-brand-text{opacity:1;font-size:1.35rem;font-weight:700;letter-spacing:.02em;width:1.1rem;display:inline-block;text-align:center;transform:none;overflow:hidden}.app-sidebar:hover .app-sidebar-brand-text{width:auto;font-size:1.25rem}.app-sidebar-icon{width:22px;height:22px;flex-shrink:0}.app-sidebar-link{display:flex;align-items:center;justify-content:flex-start;gap:.75rem;padding:.6rem .75rem;color:#ffffffd9;text-decoration:none;font-weight:500;font-size:.95rem;transition:background .15s,color .15s;border-left:3px solid transparent;min-height:44px;box-sizing:border-box}.app-sidebar:not(:hover) .app-sidebar-link{justify-content:center;padding-left:.5rem;padding-right:.5rem}.app-sidebar-link:hover{background:#ffffff14;color:#fff}.app-sidebar-link.active{background:#0ea5e940;color:#fff;border-left-color:#0ea5e9}.app-sidebar-link-text{white-space:nowrap;opacity:0;transform:translate(-8px);transition:opacity .2s ease,transform .2s ease;overflow:hidden}.app-sidebar:hover .app-sidebar-link-text{opacity:1;transform:translate(0)}.dashboard{min-height:100vh;width:100%;max-width:100%;background:#f1f5f9}.dashboard-page{min-height:calc(100vh - 76px);margin:-1rem -1.5rem -1.5rem;padding:1rem 1.5rem 1.5rem;background-image:linear-gradient(180deg,#f8fafcb8,#f8fafcd1),url(https://images.unsplash.com/photo-1497366754035-f200968a6e72?w=1920&q=80);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed}.attendance-page-bg{min-height:calc(100vh - 76px);margin:-1rem -1.5rem -1.5rem;padding:1rem 1.5rem 1.5rem;background-image:linear-gradient(160deg,#eff6ffeb,#dbeafee0,#e0f2fee6 70%,#f0f9fff0),url(https://images.unsplash.com/photo-1497366754035-f200968a6e72?w=1920&q=80);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed}.dashboard-main{width:100%;max-width:1600px;margin:0 auto;padding:4.5rem 1.5rem 0}.dashboard-header{position:fixed;top:0;left:0;right:0;z-index:100;background:#0f172ac7;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);color:#fff;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;border-bottom:1px solid rgba(255,255,255,.12);box-shadow:0 10px 24px #0f172a38}.dashboard-header h1{margin:0;font-size:1.35rem;font-weight:800;letter-spacing:-.02em}.header-actions{display:flex;align-items:center;gap:.75rem}.user-name{font-size:.9rem;opacity:.95;color:#ffffffeb}.btn{padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;border:none}.btn-primary{background:#0f3460;color:#fff}.btn-secondary{background:#0ea5e9;color:#fff}.btn-outline{background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.22)}.btn-outline:hover{background:#ffffff24;border-color:#ffffff52}.btn-approve{background:#16a34a;color:#fff}.btn-reject{background:#dc2626;color:#fff}.btn:disabled{opacity:.6;cursor:not-allowed}.dashboard-loading,.dashboard-error{padding:4.5rem 1.5rem 3rem;text-align:center}.dashboard-error .btn{margin-top:1rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;padding:0 0 1.5rem}@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.stat-card{padding:1.15rem 1.25rem;border-radius:16px;text-align:left;position:relative;overflow:hidden;border:none;box-shadow:0 2px 8px #0000000f;display:flex;align-items:center;gap:.85rem}.stat-card-total{background:linear-gradient(145deg,#eff6ff,#dbeafe);color:#1d4ed8}.stat-card-present{background:linear-gradient(145deg,#f0fdf4,#dcfce7);color:#15803d}.stat-card-absent{background:linear-gradient(145deg,#fef2f2,#fecaca);color:#b91c1c}.stat-card-pending{background:linear-gradient(145deg,#fefce8,#fef9c3);color:#a16207}.stat-card-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-icon svg{opacity:1;width:24px;height:24px}.stat-card-total .stat-card-icon svg,.stat-card-total .stat-value,.stat-card-total .stat-card-text,.stat-card-total .stat-label{color:#1d4ed8}.stat-card-present .stat-card-icon svg,.stat-card-present .stat-value,.stat-card-present .stat-card-text,.stat-card-present .stat-label{color:#15803d}.stat-card-absent .stat-card-icon svg,.stat-card-absent .stat-value,.stat-card-absent .stat-card-text,.stat-card-absent .stat-label{color:#b91c1c}.stat-card-pending .stat-card-icon svg,.stat-card-pending .stat-value,.stat-card-pending .stat-card-text,.stat-card-pending .stat-label{color:#a16207}.stat-card-link{text-decoration:none;display:flex;align-items:center;gap:.85rem;width:100%;cursor:pointer;transition:box-shadow .2s,transform .15s}.stat-card-link.stat-card-total,.stat-card-link.stat-card-total:link,.stat-card-link.stat-card-total:visited,.stat-card-link.stat-card-total:hover,.stat-card-link.stat-card-total:focus{color:#1d4ed8}.stat-card-link.stat-card-present,.stat-card-link.stat-card-present:link,.stat-card-link.stat-card-present:visited,.stat-card-link.stat-card-present:hover,.stat-card-link.stat-card-present:focus{color:#15803d}.stat-card-link.stat-card-absent,.stat-card-link.stat-card-absent:link,.stat-card-link.stat-card-absent:visited,.stat-card-link.stat-card-absent:hover,.stat-card-link.stat-card-absent:focus{color:#b91c1c}.stat-card-link.stat-card-pending,.stat-card-link.stat-card-pending:link,.stat-card-link.stat-card-pending:visited,.stat-card-link.stat-card-pending:hover,.stat-card-link.stat-card-pending:focus{color:#a16207}.stat-card-link:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.stat-value{display:block;margin-left:auto;font-size:1.9rem;font-weight:800;color:inherit;line-height:1.2;white-space:nowrap}.stat-card-text{font-size:.95rem;font-weight:700;color:inherit;line-height:1.2}.stat-label{font-size:.9rem;font-weight:600;margin-top:.35rem;display:block;opacity:.95}.dashboard-section{padding:0 0 1.5rem}.dashboard-section-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000f,0 1px 2px #0000000a;padding:1.5rem 1.75rem;margin-bottom:1.5rem}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}.section-title-with-bar{margin:0;font-size:1.2rem;font-weight:700;color:#1e293b;padding-left:1rem;border-left:4px solid #0ea5e9}.section-desc{margin:0 0 1rem;color:#64748b;font-size:.9rem}.dashboard-section-card .section-desc,.section-actions{margin-bottom:1rem}.btn-approve-bulk{flex-shrink:0}.btn-view-all{flex-shrink:0;padding:.5rem 1rem;font-size:.9rem}.section-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}.section-header-row .section-desc{margin-bottom:0}.filter-checkbox{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#475569;flex-shrink:0}.filter-checkbox input{width:1.1rem;height:1.1rem;cursor:pointer}.section h2{margin:0 0 .35rem;font-size:1.2rem;color:#1e293b}.pending-list{display:flex;flex-wrap:wrap;gap:1rem}.pending-card{display:flex;flex-direction:column;gap:.9rem;background:#f8fafc;padding:1rem 1.25rem;border-radius:12px;border:1px solid #e2e8f0;min-width:280px;flex:1 1 300px}.pending-card-top{display:flex;align-items:center;justify-content:space-between;gap:1rem}.pending-card-bottom{display:grid;grid-template-columns:80px minmax(0,1fr);align-items:center;gap:1rem}.pending-photo{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;flex-shrink:0;background:#e2e8f0}.pending-photo-clickable{cursor:pointer;transition:box-shadow .2s ease,transform .15s ease}.pending-photo-clickable:hover{box-shadow:0 2px 8px #0003;transform:scale(1.02)}.pending-photo-placeholder{position:absolute;inset:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#e2e8f0;font-size:2rem;color:#94a3b8}.pending-photo-img,.pending-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.pending-info{min-width:0;display:flex;flex-direction:column;gap:.45rem}.pending-info strong{font-size:1.1rem;display:block;margin-bottom:2px}.pending-staff-name{font-size:1rem;font-weight:700;color:#1e293b;display:block}.emp-id{font-size:.85rem;color:#64748b;display:block}.pending-meta{font-size:.9rem;color:#475569;display:block;line-height:1.45}.pending-actions{display:flex;gap:.5rem;align-items:center;justify-content:flex-end;flex-wrap:wrap}@media(max-width:640px){.pending-card-top{flex-direction:column;align-items:flex-start}.pending-card-bottom{grid-template-columns:1fr}.pending-actions{justify-content:flex-start}}.dashboard-empty-state{text-align:center;padding:1.5rem 1.25rem}.dashboard-empty-illustration{max-width:140px;margin:0 auto 1rem}.dashboard-empty-illustration svg{width:100%;height:auto}.dashboard-empty-title{margin:0 0 .25rem;font-size:1rem;font-weight:700;color:#1e293b}.dashboard-empty-desc{margin:0;font-size:.85rem;color:#64748b}.table-wrap{overflow-x:auto;background:#fafbfc;border-radius:12px;border:1px solid #e2e8f0}.dashboard-section-card .table-wrap{background:#f8fafc}.staff-grid-wrap{background:transparent;border:none;overflow:visible}.attendance-table{width:100%;border-collapse:collapse;font-size:.9rem}.attendance-table th,.attendance-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e2e8f0;color:#1e293b}.attendance-table td{vertical-align:middle}.attendance-table th{background:#f8fafc;font-weight:600;color:#475569}.attendance-table tbody tr:hover{background:#f8fafc}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:6px;font-size:.8rem;font-weight:600}.status-approved{background:#dcfce7;color:#166534}.status-pending{background:#fef3c7;color:#92400e}.status-rejected{background:#fee2e2;color:#991b1b}.status-present{background:#dcfce7;color:#166534}.status-absent{background:#fee2e2;color:#991b1b}.attendance-table-staff .th-photo,.attendance-table-staff .td-photo{width:52px;padding-right:.5rem;vertical-align:middle}.staff-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;background:#e0f2fe;color:#0369a1;font-weight:700;flex-shrink:0;font-size:.9rem}.staff-avatar-sm{width:36px;height:36px;font-size:.95rem}.staff-avatar-md{width:48px;height:48px;font-size:1.1rem}.staff-avatar-img{width:100%;height:100%;object-fit:cover}.attendance-rejection-reason{margin-top:4px;font-size:12px;color:#b91c1c;line-height:1.4;max-width:240px}.staff-avatar-initial{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.staff-avatar-initial.visible{display:flex!important}.staff-avatar-clickable{cursor:pointer;transition:box-shadow .2s ease,transform .15s ease}.staff-avatar-clickable:hover{box-shadow:0 2px 8px #0003;transform:scale(1.08)}.staff-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem 1.2rem}@media(max-width:900px){.staff-grid{grid-template-columns:1fr}}.staff-card{display:flex;align-items:center;gap:.85rem;width:100%;padding:1.15rem 1.25rem;border:1px solid rgba(255,255,255,.35);border-radius:18px;background:#ffffff5c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 28px #0f172a14;cursor:pointer;text-align:left;transition:box-shadow .18s ease,transform .12s ease}.staff-card:hover{box-shadow:0 14px 30px #0f172a1f;transform:translateY(-3px)}.staff-card:focus-visible{outline:2px solid #38bdf8;outline-offset:2px}.staff-card-body{display:flex;flex-direction:column;gap:.1rem}.staff-card-line{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;color:#0f172a}.staff-card-name{font-weight:700;color:#0f172a;font-size:1rem}.staff-card-meta-inline{color:#475569;font-size:.93rem}.staff-card-sep{color:#94a3b8;font-weight:700}.empty-state{padding:1rem;color:#475569}.attendance-table-today .th-photo,.attendance-table-today .td-photo{width:52px;padding-right:.5rem;vertical-align:middle}.pending-detail-overlay{position:fixed;inset:0;z-index:1000;background:radial-gradient(circle at 20% 20%,rgba(59,130,246,.12),transparent 32%),#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease;overflow:auto;overscroll-behavior:contain}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pending-detail-modal{background:#fff;border-radius:24px;box-shadow:0 28px 80px #0f172a38;max-width:960px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pending-detail-header{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.6rem;border-bottom:1px solid #e2e8f0}.pending-detail-header h3{margin:0;font-size:1.15rem;font-weight:800;color:#1e293b;text-transform:capitalize}.pending-detail-close{width:32px;height:32px;border:none;background:#f1f5f9;border-radius:8px;font-size:1.5rem;line-height:1;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,color .15s}.pending-detail-close:hover{background:#e2e8f0;color:#1e293b}.pending-detail-body{padding:1.35rem 1.6rem 1.15rem}.pending-detail-photo-wrap{width:100%;aspect-ratio:1.45;max-width:none;margin:0 0 1.25rem;border-radius:18px;overflow:hidden;background:#e2e8f0}.pending-detail-photo{width:100%;height:100%;object-fit:cover}.pending-detail-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#94a3b8}.pending-detail-summary{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid #e2e8f0}.pending-detail-person{min-width:0}.pending-detail-name{margin:0;font-size:1.15rem;font-weight:800;color:#1e293b}.pending-detail-employee-id{margin:.25rem 0 0;font-size:.92rem;color:#64748b;font-weight:600}.pending-detail-status{flex-shrink:0;padding:.45rem .8rem;border-radius:999px;font-size:.9rem;font-weight:700}.pending-detail-meta-list{display:flex;flex-direction:column;gap:.95rem}.pending-detail-meta-row{display:flex;align-items:flex-start;gap:.85rem;color:#1e293b;font-size:.98rem;line-height:1.5}.pending-detail-meta-row-location{padding-bottom:.15rem}.pending-detail-meta-icon{display:inline-flex;align-items:center;justify-content:center;color:#475569;flex-shrink:0;margin-top:.05rem}.pending-detail-action-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-top:1.2rem;padding-top:1.15rem;border-top:1px solid #e2e8f0}.pending-detail-action-btn{justify-content:center;gap:.55rem;min-height:48px;border-radius:12px;font-size:1rem;font-weight:700;box-shadow:0 6px 14px #0f172a14}.pending-detail-footer{padding:1rem 1.6rem 1.35rem;border-top:1px solid #e2e8f0}.pending-detail-btn-close{color:#475569!important;border-color:#cbd5e1!important;background:#fff!important;border-radius:12px!important;padding:.7rem 1.2rem!important}.pending-detail-btn-close:hover{background:#f1f5f9!important}@media(max-width:560px){.pending-detail-summary{flex-direction:column}.pending-detail-action-row{grid-template-columns:1fr}}.dashboard-sidebar{position:fixed;left:0;top:0;bottom:0;z-index:99;width:52px;background:#1e293b;color:#fff;transition:width .25s ease;overflow:hidden;display:flex;flex-direction:column}.dashboard-sidebar.sidebar-open{width:320px;max-width:90vw;box-shadow:4px 0 20px #00000026}.sidebar-tab{padding:1rem;font-size:1.25rem;cursor:default;flex-shrink:0;min-width:52px}.sidebar-content{flex:1;overflow-y:auto;padding:0 1rem 1rem;opacity:0;transition:opacity .2s ease}.dashboard-sidebar.sidebar-open .sidebar-content{opacity:1}.sidebar-title{margin:1rem 0 .5rem;font-size:.95rem;font-weight:600;color:#fffffff2}.sidebar-desc{font-size:.8rem;color:#ffffffb3;margin:0 0 .5rem}.sidebar-stats{display:flex;flex-direction:column;gap:.5rem}.sidebar-stat{font-size:.85rem;color:#ffffffe6}.sidebar-stat .sidebar-stat-value{font-weight:700;margin-right:.35rem}.sidebar-stat.present .sidebar-stat-value{color:#86efac}.sidebar-stat.absent .sidebar-stat-value{color:#fca5a5}.sidebar-staff-list{display:flex;flex-direction:column;gap:.25rem;max-height:180px;overflow-y:auto}.sidebar-staff-item{background:#ffffff1a;border:none;color:#fff;padding:.4rem .6rem;border-radius:6px;font-size:.85rem;text-align:left;cursor:pointer;transition:background .15s}.sidebar-staff-item:hover{background:#fff3}.sidebar-staff-item.selected{background:#0ea5e9;color:#fff}.sidebar-calendar-panel{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2)}.sidebar-month-nav{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem;font-size:.9rem}.sidebar-month-nav button{background:#fff3;border:none;color:#fff;padding:.35rem .6rem;border-radius:6px;cursor:pointer;font-size:1rem}.sidebar-month-nav button:hover{background:#ffffff4d}.sidebar-present-days,.sidebar-loading,.sidebar-no-days{font-size:.85rem;color:#ffffffd9;margin:0 0 .5rem}.sidebar-days-list{max-height:200px;overflow-y:auto;font-size:.8rem}.sidebar-day-row{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;padding:.35rem 0;border-bottom:1px solid rgba(255,255,255,.1);color:#ffffffe6}.logout-modal-overlay{z-index:1001}.logout-modal{background:#fff;border-radius:12px;padding:1.5rem;max-width:360px;width:100%;box-shadow:0 20px 60px #00000040}.logout-modal h3{margin:0 0 .75rem;font-size:1.2rem;color:#1e293b}.logout-modal p{margin:0 0 1.25rem;color:#64748b;font-size:.95rem}.logout-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.logout-modal-btn-cancel{color:#475569!important;border-color:#cbd5e1!important}.logout-modal-btn-cancel:hover{background:#f1f5f9!important}.logout-modal-btn-confirm{background:#dc2626;color:#fff;border:none}.logout-modal-btn-confirm:hover{background:#b91c1c}.staff-name-link{background:none;border:none;padding:0;font:inherit;color:#0ea5e9;cursor:pointer;text-decoration:underline;text-align:left}.staff-name-link:hover{color:#0284c7}.staff-attendance-modal.attendance-modal{max-width:1080px;overflow:hidden}.attendance-modal-header{background:#1e293b;color:#fff;padding:1.1rem 1.3rem;border-radius:18px 18px 0 0;background:linear-gradient(135deg,#12233d,#1f3458)}.attendance-modal-header-actions{display:inline-flex;align-items:center;gap:.65rem}.attendance-modal-header h3{color:#fff;font-size:1.1rem;font-weight:700}.attendance-header-icon-btn{height:40px;border:1px solid rgba(255,255,255,.22);background:#ffffff1f;color:#fff;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;flex-direction:row;gap:8px;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .12s ease;overflow:hidden;padding:8px 12px}.attendance-header-avatar{width:28px;height:28px;border-radius:8px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center}.attendance-header-avatar-img{display:block;object-fit:cover;width:100%;height:100%;border-radius:inherit;flex-shrink:0}.attendance-header-avatar-fallback{display:none;align-items:center;justify-content:center;color:#fff;font-size:.9rem;font-weight:700;line-height:1;width:100%;height:100%;border-radius:inherit}.attendance-header-avatar-fallback.visible{display:inline-flex}.attendance-header-label{color:#e2e8f0;font-size:.72rem;font-weight:600;line-height:1;letter-spacing:.01em}.attendance-header-avatar-fallback svg{width:16px;height:16px}.attendance-hero{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#f7f9fc,#eef2f8);border:1px solid #e5eaf2;border-radius:12px;padding:.9rem 1rem;box-shadow:inset 0 1px #fffc;margin-bottom:.75rem}.attendance-hero-left{display:flex;align-items:center;gap:.85rem}.attendance-hero-avatar{width:54px;height:54px;border-radius:16px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:#1e293b;box-shadow:0 8px 18px #0f172a14}.attendance-hero-meta h4{margin:0;font-size:1.05rem;color:#0f172a;font-weight:800}.attendance-hero-row{display:inline-flex;align-items:center;gap:.85rem;flex-wrap:wrap}.attendance-hero-contact-inline{display:inline-flex;align-items:center;gap:.45rem;color:#2563eb;font-weight:700;font-size:.95rem}.attendance-hero-contact-inline svg{width:16px;height:16px}.attendance-hero-role,.attendance-hero-meta p{margin:4px 0 0;color:#475569;font-weight:600}.attendance-hero-contact{display:inline-flex;align-items:center;gap:6px;color:#2563eb;font-weight:700;font-size:.95rem}.attendance-hero-profile-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;background:#f8fafc;color:#1e293b;border:1px solid #e2e8f0;box-shadow:0 6px 14px #0f172a0f;font-weight:700;cursor:pointer;transition:all .15s ease}.attendance-hero-profile-btn svg{width:18px;height:18px}.attendance-hero-profile-btn:hover{transform:translateY(-1px);border-color:#cbd5e1}.attendance-hero-profile-btn.active{background:#2563eb;color:#fff;border-color:#1d4ed8;box-shadow:0 10px 20px #2563eb40}.attendance-tabs{display:inline-flex;gap:12px;border-bottom:1px solid #e2e8f0;margin-bottom:.6rem}.attendance-tabs button{border:none;background:none;padding:.65rem .9rem;font-weight:700;color:#475569;position:relative;cursor:pointer;transition:color .15s ease}.attendance-tabs button.active{color:#2563eb}.attendance-tabs button.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;background:#2563eb;border-radius:999px}.attendance-summary-row{display:flex;justify-content:center;align-items:center;gap:1.2rem;margin-bottom:.65rem;padding:.7rem .5rem .6rem}.attendance-summary-card{display:inline-flex;align-items:center;gap:8px;padding:.35rem .65rem;border-radius:999px;font-weight:700;border:1px solid transparent}.attendance-summary-card .dot{width:14px;height:14px;border-radius:999px;display:inline-block}.attendance-summary-card .label{color:#334155}.attendance-summary-card .value{font-weight:800}.attendance-summary-card.present{background:#e7f6ef;border-color:#c8ebd6}.attendance-summary-card.present .dot{background:#16a34a}.attendance-summary-card.absent{background:#fdecec;border-color:#f7caca}.attendance-summary-card.absent .dot{background:#ef4444}.attendance-summary-card.leaves{background:#fff3df;border-color:#f9dfb5}.attendance-summary-card.leaves .dot{background:#d97706}.attendance-summary-inline .summary-sep{color:#cbd5e1}.staff-modal-month-nav{display:flex;align-items:center;justify-content:center;gap:.9rem;margin:0 0 .3rem;background:#f8fafc;border:1px solid #e2e8f0;padding:.55rem .8rem;border-radius:10px;width:100%}.staff-modal-month-label{text-align:center;font-weight:800;color:#0f172a;letter-spacing:.01em}.attendance-nav-btn{background:none;border:none;color:#2563eb;font-weight:700;cursor:pointer;text-align:center}.staff-modal-month-nav.inline .attendance-nav-btn{width:34px;height:34px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;display:inline-flex;align-items:center;justify-content:center;color:#1f2937}.attendance-header-icon-btn:hover{background:#fff3;border-color:#ffffff59;transform:translateY(-1px)}.attendance-header-icon-btn.active{background:#0ea5e9;border-color:#38bdf8}.attendance-modal-header .pending-detail-close{background:#ffffff26;color:#fff}.attendance-modal-header .pending-detail-close:hover{background:#ffffff40;color:#fff}.attendance-modal{background:#fdfefe}.attendance-modal-body{display:flex;flex-direction:column;min-height:0;padding:1.5rem 1.25rem;background:#f9fbff;max-height:calc(90vh - 140px);flex:1 1 auto;overflow:hidden}.staff-profile-view{display:flex;flex-direction:column;gap:1.25rem;flex:1 1 auto;overflow-y:auto;min-height:0}.staff-attendance-view{display:flex;flex-direction:column;gap:.75rem;flex:1 1 auto;overflow:hidden;min-height:0}.staff-profile-actions{display:flex;justify-content:flex-end}.profile-edit-actions{display:inline-flex;gap:.5rem}.profile-input{width:100%;padding:.6rem .75rem;border-radius:10px;border:1px solid #d8e0eb;background:#fff;font-size:.95rem;color:#0f172a}.profile-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.staff-profile-card textarea.profile-input{resize:vertical}.staff-profile-hero{display:flex;align-items:center;gap:1rem;padding:1rem 1.1rem;background:linear-gradient(135deg,#f8fbff,#eef6ff);border:1px solid #dbeafe;border-radius:18px}.staff-profile-avatar{width:72px;height:72px;font-size:1.45rem;flex-shrink:0}.staff-profile-hero-copy{min-width:0}.staff-profile-hero-copy h4{margin:0;font-size:1.2rem;font-weight:800;color:#0f172a}.staff-profile-hero-copy p{margin:.35rem 0 0;color:#475569;font-size:.95rem}.staff-profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.staff-profile-card{display:flex;flex-direction:column;gap:.35rem;padding:1.05rem 1.15rem;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 10px 24px #0f172a14}.staff-profile-card-wide{grid-column:1 / -1}.staff-profile-label{font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#64748b}.staff-profile-value{color:#0f172a;font-size:.98rem;font-weight:600;line-height:1.5;word-break:break-word}.staff-profile-card-head{display:inline-flex;align-items:center;gap:.55rem;margin-bottom:.35rem}.profile-card-icon{width:26px;height:26px;border-radius:8px;background:#eef2ff;display:inline-flex;align-items:center;justify-content:center;color:#2563eb;box-shadow:inset 0 1px #ffffffe6}.profile-card-icon svg{width:16px;height:16px}.attendance-modal-summary{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1.25rem;padding:.75rem 1rem;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.attendance-summary-label{font-size:.9rem;color:#64748b}.attendance-summary-value{font-size:1.25rem;font-weight:700;color:#16a34a}.staff-modal-month-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.attendance-nav-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;color:#475569;transition:background .15s,color .15s}.attendance-nav-btn:hover{background:#e2e8f0;color:#1e293b}.staff-modal-month-label{font-weight:600;font-size:1rem;color:#1e293b}.staff-modal-present-days{margin:0 0 .75rem;font-size:.95rem;color:#475569}.staff-modal-loading{margin:0;color:#64748b}.attendance-table-wrap.staff-modal-table-wrap{max-height:360px;overflow-y:auto;overflow-x:hidden;border:1px solid #e2e8f0;border-radius:10px;background:#fff}.attendance-modal-table.staff-attendance-table{font-size:.9rem;border-collapse:collapse;width:100%}.attendance-modal-table th{background:#eef2f6;font-size:.82rem}.attendance-modal-table tr:last-child td{border-bottom:none}.attendance-modal-table thead{position:sticky;top:0;z-index:1;background:#f1f5f9;box-shadow:0 1px #e2e8f0}.attendance-modal-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:#475569}.attendance-modal-table td{padding:.75rem 1rem;vertical-align:middle;border-top:1px solid #f1f5f9}.attendance-row:hover td{background:#fafafa}.attendance-row-editing td{background:#f1f5ff;position:relative}.attendance-row-editing td:first-child:before{content:"";position:absolute;inset:0;width:4px;background:#2563eb;border-radius:999px}.attendance-row-absent td{background:#fff6f6}.attendance-table .attendance-btn-edit{background:#1d9bf0;color:#fff;box-shadow:0 8px 18px #1d9bf040}.attendance-table .attendance-btn-edit:hover:not(:disabled){transform:translateY(-1px)}.attendance-time-field{display:flex;flex-direction:column;gap:.25rem}.attendance-time-field label{font-size:.75rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.attendance-time-input{padding:.5rem .65rem;border:1px solid #cbd5e1;border-radius:10px;font-size:.9rem;min-width:7rem;color:#1e293b;background:#fff;transition:border-color .15s,box-shadow .15s}.attendance-time-input:hover{border-color:#94a3b8}.attendance-time-input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e926}.attendance-time-picker{display:inline-flex;align-items:center;gap:.25rem;flex-wrap:nowrap}.attendance-time-select{padding:.45rem .5rem;border:1px solid #cbd5e1;border-radius:10px;font-size:.92rem;min-width:3.8rem;color:#1e293b;background:#fff;transition:border-color .15s,box-shadow .15s}.attendance-time-meridiem{min-width:4.8rem;border-radius:10px}.attendance-time-select:hover{border-color:#94a3b8}.attendance-time-select:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e926}.attendance-row-editing .attendance-time-field label{display:none}.attendance-quick-hours{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;margin-top:.35rem}.attendance-quick-label{font-size:.8rem;color:#475569;margin-right:.15rem}.attendance-quick-btn{padding:.35rem .65rem;font-size:.8rem;font-weight:600;border-radius:10px;border:1px solid #dbeafe;background:#f8fafc;color:#0f172a;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.attendance-quick-btn:hover:not(:disabled){background:#e2e8f0;color:#0f172a;box-shadow:0 4px 12px #0f172a14}.attendance-quick-btn.active{background:#2563eb;border-color:#2563eb;color:#fff;box-shadow:0 6px 18px #2563eb38}.attendance-legend{display:inline-flex;align-items:center;gap:.35rem;margin-left:.75rem}.attendance-legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.attendance-legend-dot.success{background:#16a34a}.attendance-legend-text{font-size:.82rem;color:#475569}.attendance-time-separator{font-weight:700;color:#475569}.attendance-time-display{font-weight:500;color:#1e293b}.attendance-inline-form{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1rem 1.25rem}.attendance-form-actions{display:inline-flex;flex-wrap:wrap;align-items:center;gap:.5rem}.attendance-btn-edit{padding:.45rem .9rem;font-size:.85rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:opacity .15s,transform .1s;display:inline-flex;align-items:center;gap:.4rem}.attendance-btn-icon{width:1rem;height:1rem;flex-shrink:0}.attendance-btn-edit:hover:not(:disabled){opacity:.92}.attendance-btn-save{padding:.45rem 1rem;font-size:.85rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;background:#16a34a;color:#fff;transition:opacity .15s,background .15s}.attendance-btn-save:hover:not(:disabled){background:#15803d;opacity:1}.attendance-btn-cancel{padding:.45rem .9rem;font-size:.85rem;font-weight:500;border-radius:8px;background:#fff;color:#475569;border:1px solid #cbd5e1;cursor:pointer;transition:background .15s,color .15s}.attendance-btn-cancel:hover:not(:disabled){background:#f1f5f9;color:#1e293b}.attendance-btn-absent{padding:.45rem .9rem;font-size:.85rem;font-weight:600;border-radius:8px;background:#dc2626;color:#fff;border:none;cursor:pointer;transition:opacity .15s,background .15s}.attendance-btn-absent:hover:not(:disabled){background:#b91c1c;opacity:1}.attendance-actions-cell{white-space:nowrap}.attendance-modal-footer{padding:1rem 1.25rem;border-top:1px solid #e2e8f0;background:#fafafa;border-radius:0 0 16px 16px}.attendance-btn-close{padding:.5rem 1.25rem;font-size:.9rem;font-weight:500;border-radius:8px;background:#fff;color:#475569;border:1px solid #cbd5e1;cursor:pointer;transition:background .15s,color .15s}.attendance-btn-close:hover{background:#f1f5f9;color:#1e293b}.btn-sm{padding:.35rem .6rem;font-size:.8rem}@media(max-width:680px){.staff-profile-grid{grid-template-columns:1fr}.staff-profile-card-wide{grid-column:auto}.staff-profile-hero{align-items:flex-start}}.app-layout{display:flex;min-height:100vh;width:100%;background:#f1f5f9}.app-layout-main{flex:1;min-width:0;margin-left:56px;display:flex;flex-direction:column}.app-layout-header{position:sticky;top:0;z-index:50}.app-layout-content{flex:1;padding:1rem 1.5rem 1.5rem}.addstaff-page,.addstaff-embed-modal,.addstaff-card-embedded{--addstaff-primary: #2563eb;--addstaff-primary-dark: #1d4ed8;--addstaff-primary-light: #dbeafe;--addstaff-accent: #3b82f6;--addstaff-accent-light: #eff6ff;--addstaff-surface: #ffffff;--addstaff-text: #1e293b;--addstaff-text-muted: #64748b;--addstaff-border: #e2e8f0;--addstaff-success: #059669;--addstaff-success-bg: #d1fae5;--addstaff-error: #dc2626;--addstaff-error-bg: #fee2e2}.addstaff-page{min-height:100%;background-image:linear-gradient(160deg,#eff6ffeb,#dbeafee0,#e0f2fee6 70%,#f0f9fff0),url(https://images.unsplash.com/photo-1497366754035-f200968a6e72?w=1920&q=80);background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;overflow:hidden}.addstaff-page:before{content:"";position:absolute;top:-20%;right:-10%;width:50%;height:60%;background:radial-gradient(ellipse at center,rgba(37,99,235,.08) 0%,transparent 70%);pointer-events:none}.addstaff-page:after{content:"";position:absolute;bottom:-15%;left:-5%;width:45%;height:50%;background:radial-gradient(ellipse at center,rgba(59,130,246,.06) 0%,transparent 70%);pointer-events:none}.addstaff-content{position:relative;z-index:1;padding:1.5rem;max-width:960px;margin:0 auto}.addstaff-card{background:var(--addstaff-surface);border-radius:20px;box-shadow:0 4px 6px -1px #0000000d,0 10px 25px -5px #0000000f,0 0 0 1px #2563eb14;overflow:hidden;border:1px solid rgba(37,99,235,.12)}.addstaff-card-header{display:flex;align-items:center;gap:1.25rem;padding:2rem 3.5rem 2rem 2rem;background:linear-gradient(135deg,#2563eb0f,#3b82f60a);border-bottom:1px solid var(--addstaff-border);position:relative;overflow:visible}.addstaff-card-header-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--addstaff-primary) 0%,var(--addstaff-primary-dark) 100%);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px #2563eb66}.addstaff-card-header-icon svg{width:26px;height:26px}.addstaff-card-title{margin:0 0 .3em;font-size:1.6rem;font-weight:800;color:var(--addstaff-text);letter-spacing:-.02em}.addstaff-card-subtitle{margin:0;font-size:.95rem;color:var(--addstaff-text-muted);line-height:1.45}.addstaff-header-close{position:absolute;top:1.25rem;right:1.75rem;width:36px;height:36px;border-radius:50%;border:1px solid rgba(15,23,42,.15);background:#e2e8f0;box-shadow:0 2px 8px #0f172a1a;display:inline-flex;align-items:center;justify-content:center;color:#334155;cursor:pointer;z-index:10;flex-shrink:0;transition:background .18s ease,color .18s ease,transform .15s ease,box-shadow .18s ease;font-size:1.25rem;line-height:1}.addstaff-header-close:hover{background:var(--addstaff-primary);color:#fff;border-color:var(--addstaff-primary);transform:translateY(-1px);box-shadow:0 6px 16px #2563eb66}.addstaff-header-close:focus-visible{outline:2px solid rgba(37,99,235,.5);outline-offset:2px}.addstaff-header-close-icon{display:block;font-size:1.75rem;font-weight:300;line-height:1;color:inherit}.addstaff-form-body{display:grid;grid-template-columns:220px 1fr;gap:2rem;padding:2rem;background:linear-gradient(180deg,#fffeff,#fefefe)}@media(max-width:768px){.addstaff-form-body{grid-template-columns:1fr}}.addstaff-sidebar{display:flex;flex-direction:column;gap:1.5rem}.addstaff-photo-wrap{display:flex;flex-direction:column;align-items:center;gap:.75rem}.addstaff-photo-circle{width:120px;height:120px;border-radius:50%;background:linear-gradient(145deg,var(--addstaff-primary-light) 0%,#e0f2fe 100%);border:2px dashed var(--addstaff-primary);display:flex;align-items:center;justify-content:center;color:var(--addstaff-primary);overflow:hidden;opacity:.9;transition:border-color .2s,box-shadow .2s}.addstaff-photo-circle:hover{border-color:var(--addstaff-primary-dark);box-shadow:0 0 0 4px #2563eb26}.addstaff-photo-preview{width:100%;height:100%;object-fit:cover}.addstaff-photo-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.addstaff-upload-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.1rem;font-size:.875rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--addstaff-primary) 0%,var(--addstaff-primary-dark) 100%);border:none;border-radius:10px;cursor:pointer;font-family:inherit;transition:transform .15s,box-shadow .2s;box-shadow:0 2px 8px #2563eb59}.addstaff-upload-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb73}.addstaff-upload-hint{margin:0;font-size:.75rem;color:var(--addstaff-text-muted)}.addstaff-section-nav{display:flex;flex-direction:column;gap:.3rem}.addstaff-section-nav-item{display:flex;align-items:center;gap:.65rem;padding:.6rem .85rem;font-size:.82rem;color:var(--addstaff-text-muted);border-radius:10px;border:none;background:none;cursor:pointer;font-family:inherit;text-align:left;width:100%;transition:background .2s,color .2s}.addstaff-section-nav-item svg{flex-shrink:0;color:var(--addstaff-primary);opacity:.85}.addstaff-section-nav-item:hover{background:var(--addstaff-primary-light);color:var(--addstaff-primary-dark)}.addstaff-section-nav-item:hover svg{opacity:1}.addstaff-fields{min-width:0}.addstaff-block{margin-bottom:1.75rem}.addstaff-block:last-child{margin-bottom:0}.addstaff-block-title{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:700;color:var(--addstaff-text)}.addstaff-block-title svg{color:var(--addstaff-primary);flex-shrink:0}.addstaff-block-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.25rem}.addstaff-field-full{grid-column:1 / -1}@media(max-width:560px){.addstaff-block-grid{grid-template-columns:1fr}}.addstaff-field{display:flex;flex-direction:column;gap:.4rem}.addstaff-field label{font-size:.82rem;font-weight:600;color:var(--addstaff-text)}.addstaff-field-hint{margin:.3rem 0 0;font-size:.75rem;color:var(--addstaff-text-muted)}.addstaff-form input,.addstaff-form select{width:100%;padding:.65rem .95rem;border:1px solid var(--addstaff-border);border-radius:10px;font-size:.9rem;font-family:inherit;color:var(--addstaff-text);background:#fff;transition:border-color .2s,box-shadow .2s,background .2s;box-sizing:border-box}.addstaff-form input::placeholder{color:#94a3b8}.addstaff-form input:hover,.addstaff-form select:hover{border-color:#cbd5e1;background:#fafafa}.addstaff-form input:focus,.addstaff-form select:focus{outline:none;border-color:var(--addstaff-primary);box-shadow:0 0 0 3px #2563eb2e;background:#fff}.addstaff-input-wrap{position:relative;display:block}.addstaff-input-wrap input{padding-right:2.5rem}.addstaff-input-wrap .addstaff-input-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:var(--addstaff-primary);opacity:.7;pointer-events:none;display:flex;align-items:center;justify-content:center}.addstaff-input-icon-btn{position:absolute;right:.55rem;top:50%;transform:translateY(-50%);width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--addstaff-primary);opacity:.8;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.addstaff-input-icon-btn:hover{background:#2563eb14;opacity:1}.addstaff-input-icon-btn:focus-visible{outline:2px solid rgba(37,99,235,.25);outline-offset:1px}.addstaff-input-wrap .addstaff-input-icon-left{left:.75rem;right:auto}.addstaff-input-wrap .addstaff-input-icon-left+input{padding-left:2.5rem;padding-right:.9rem}.addstaff-select-wrap{display:flex;align-items:center;gap:0;padding:0;border:none;background:transparent}.addstaff-select-wrap>svg{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--addstaff-primary);opacity:.7;pointer-events:none;width:18px;height:18px}.addstaff-select-wrap select{padding-left:2.5rem;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%232563eb' stroke-width='2'%3E%3Cpath d='M2 4 L6 8 L10 4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.addstaff-message{margin:0 2rem 1rem;padding:.85rem 1.1rem;border-radius:12px;font-size:.875rem;line-height:1.45;font-weight:500}.addstaff-message-error{background:var(--addstaff-error-bg);color:#b91c1c;border:1px solid #fecaca}.addstaff-message-success{background:var(--addstaff-success-bg);color:var(--addstaff-success);border:1px solid #a7f3d0}.addstaff-actions{display:flex;justify-content:flex-end;gap:.85rem;padding:1.5rem 2rem;border-top:1px solid var(--addstaff-border);background:linear-gradient(180deg,#f8fafc,#f1f5f9)}@media(max-width:560px){.addstaff-actions{flex-direction:column}}.addstaff-btn{padding:.7rem 1.35rem;font-size:.9rem;font-weight:600;border-radius:10px;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s;border:none}.addstaff-btn-cancel{background:#fff;color:var(--addstaff-primary-dark);border:1px solid var(--addstaff-border)}.addstaff-btn-cancel:hover{background:var(--addstaff-primary-light);border-color:var(--addstaff-primary);color:var(--addstaff-primary-dark)}.addstaff-btn-submit{min-width:150px;background:linear-gradient(135deg,var(--addstaff-primary) 0%,var(--addstaff-primary-dark) 100%)!important;color:#fff!important;box-shadow:0 4px 14px #2563eb66}.addstaff-btn-submit:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 6px 20px #2563eb80!important}.addstaff-btn-submit:disabled{cursor:not-allowed;opacity:.8;transform:none}.addstaff-embed-modal{max-width:1080px;background:transparent;box-shadow:none;border-radius:0;padding:0;overflow:visible}.addstaff-card-embedded{max-height:90vh;overflow:auto}.addstaff-spinner{width:1em;height:1em;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:addstaff-spin .7s linear infinite}@keyframes addstaff-spin{to{transform:rotate(360deg)}}*{box-sizing:border-box}html,body{margin:0;width:100%;min-height:100vh;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f1f5f9;color:#64748b}
