@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Playfair+Display:wght@400;500;600;700;800;900&display=swap";:root{--background:#fefcf9;--foreground:#2d1f14;--primary:#8b5e3c;--primary-hover:#6f4a2e;--primary-light:#fbf5ef;--accent:#6b7f3a;--accent-hover:#566832;--muted:#8c7b6b;--border:#e8ddd1;--destructive:#c0392b;--wine:#722f37;--success:#27ae60;--cream:#fbf5ef;--espresso:#2d1f14;--sand:#e8ddd1}*{box-sizing:border-box}body{min-height:100vh;color:var(--foreground);background-color:var(--background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}#root{min-height:100vh}html{scroll-behavior:smooth}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.app-shell{width:min(1160px,92vw);margin:0 auto;padding:2rem 0 3.5rem}.top-bar{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;padding:0 1rem;display:flex}.top-bar h1{letter-spacing:-.02em;color:var(--foreground);margin:0;font-family:Playfair Display,serif;font-size:clamp(2rem,4vw,2.8rem);font-weight:700}.top-bar p{color:var(--muted);margin:.25rem 0 0;font-size:.9rem}.login-container{justify-content:center;align-items:center;min-height:60vh;padding:0 1rem;display:flex}.card{border:1px solid var(--border);background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px #2d1f140f}.card h2{color:var(--foreground);margin:0 0 .5rem;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:600}.card-login{width:100%;max-width:450px}.demo-text{border-top:1px solid var(--border);color:var(--muted);text-align:center;margin-top:1rem;padding-top:1rem;font-size:.85rem}.helper-text{color:var(--muted);margin-bottom:1.2rem;font-size:.9rem}.dashboard-toolbar{gap:.75rem;margin-bottom:1.5rem;padding:0 1rem;display:flex}.tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:1.5rem;padding:0 1rem;display:flex}.tab{cursor:pointer;color:var(--muted);background:0 0;border:none;border-bottom:3px solid #0000;padding:.875rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .24s;position:relative;bottom:-1px}.tab:hover{color:var(--primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.two-column{grid-template-columns:320px 1fr;gap:1.5rem;padding:0 1rem;display:grid}.employee-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.2rem;margin-top:1rem;display:grid}.employee-card{border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:14px;padding:1.2rem;transition:all .24s}.employee-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 16px #2d1f141f}.employee-card.present{border-left:4px solid var(--success)}.employee-card.absent{border-left:4px solid #d9d4cc}.employee-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.8rem;display:flex}.employee-card-header h3{color:var(--foreground);margin:0;font-size:1.1rem;font-weight:600}.employee-card-header p.position{color:var(--muted);margin:.25rem 0 0;font-size:.85rem}.status-badge{text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-radius:8px;padding:.4rem .75rem;font-size:.8rem;font-weight:700;display:inline-block}.status-badge.present{color:#27ae60;background:#e8f5e9}.status-badge.absent{color:#8c7b6b;background:#f5f3f0}.time-info{border-top:1px solid var(--border);gap:1rem;padding-top:.8rem;display:flex}.time-item{flex-direction:column;flex:1;gap:.25rem;display:flex}.time-item .label{text-transform:uppercase;letter-spacing:.03em;color:var(--muted);font-size:.75rem;font-weight:700}.time-item .time{color:var(--primary);font-size:1rem;font-weight:700}.employee-list{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.employee-list-item{border:1px solid var(--border);cursor:pointer;text-align:left;background:#faf8f5;border-radius:12px;justify-content:space-between;align-items:center;padding:.875rem 1rem;font-family:inherit;transition:all .2s;display:flex}.employee-list-item:hover{background:var(--cream);border-color:var(--muted)}.employee-list-item.selected{background:var(--primary-light);border-color:var(--primary)}.employee-list-item strong{color:var(--foreground);margin-bottom:.2rem;display:block}.employee-list-item p{color:var(--muted);margin:0;font-size:.8rem}.employee-header-section{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.employee-header-section h2{margin:0 0 .5rem}.employee-header-section button{flex-shrink:0;margin-top:.25rem}.credentials-layout{grid-template-columns:220px minmax(0,1fr);align-items:start;gap:1.5rem;display:grid}.credentials-summary{border:1px solid var(--border);text-align:center;background:linear-gradient(#fbf5ef 0%,#fff9f3 100%);border-radius:18px;justify-items:center;gap:1rem;padding:1.5rem;display:grid;position:sticky;top:1.5rem}.employee-avatar{background:var(--primary);color:#fff;letter-spacing:.04em;border-radius:50%;place-items:center;width:72px;height:72px;font-size:1.5rem;font-weight:800;display:grid;box-shadow:0 10px 24px #8b5e3c2e}.summary-copy{gap:.35rem;display:grid}.full-name{color:var(--foreground);margin:0;font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700;line-height:1.15}.summary-role{color:var(--muted);margin:0;font-size:.95rem;font-weight:500}.summary-note{color:var(--muted);margin:.2rem 0 0;font-size:.82rem;line-height:1.45}.credentials-sections{flex-direction:column;gap:1.25rem;display:flex}.credentials-section{border:1px solid var(--border);background:#fffaf5;border-radius:16px;padding:1.1rem 1.1rem 1.25rem}.credentials-section .credential-item-full+.credential-item-full{margin-top:.9rem}.section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 .9rem;font-size:.8rem;font-weight:800}.credential-item-full{gap:.35rem;display:grid}.credentials-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;margin-bottom:.9rem;display:grid}.credentials-edit-layout{grid-template-columns:220px minmax(0,1fr);align-items:start;gap:1.5rem;display:grid}.credentials-summary-edit{min-height:100%}.edit-form-grid{flex-direction:column;gap:1rem;display:flex}.credentials-layout,.credentials-edit-layout,.credentials-summary,.credentials-summary-edit,.credentials-sections,.credentials-section,.edit-form-grid,.credential-item-full,.credentials-grid-2{min-width:0}.edit-form-grid .credentials-section{margin:0}.edit-form-grid label{font-size:.9rem}.edit-form-grid input{margin-top:.1rem}input{width:100%;min-width:0}.credential-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:.72rem;font-weight:800}.credential-value{color:var(--foreground);word-break:break-word;font-size:.98rem;font-weight:600}.credential-value-break{overflow-wrap:anywhere}.employee-link{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-weight:600;text-decoration:underline;transition:color .2s}.employee-link:hover{color:var(--primary-hover)}.filter-controls{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:flex-end;gap:1.2rem;margin-top:1rem;padding-bottom:1rem;display:flex}.filter-controls label{color:var(--foreground);gap:.4rem;font-size:.9rem;font-weight:600;display:grid}.filter-controls input[type=date]{border:1px solid var(--border);color:var(--foreground);border-radius:12px;padding:.75rem .875rem;font-family:Inter,inherit;font-size:.95rem}.date-display{color:var(--muted);padding-bottom:.75rem;font-size:.9rem;font-weight:500}.empty-state{text-align:center;color:var(--muted);padding:2rem 1rem;font-style:italic}.form-grid{gap:1rem;display:grid}.modal-body .form-grid{grid-template-columns:1fr 1fr}.modal-body .form-grid button{grid-column:1/-1}.modal-body .credentials-display{grid-template-columns:1fr 1fr}label{color:var(--foreground);gap:.4rem;font-size:.9rem;font-weight:600;display:grid}input{border:1px solid var(--border);color:var(--foreground);background:#fff;border-radius:12px;padding:.75rem .875rem;font-family:Inter,inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}input::placeholder{color:var(--muted)}input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #8b5e3c1a}.primary-btn,.secondary-btn{cursor:pointer;border:0;border-radius:12px;padding:.75rem 1rem;font-family:Inter,inherit;font-size:.95rem;font-weight:600;transition:all .24s}.primary-btn{background:var(--primary);color:#fff}.primary-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b5e3c33}.secondary-btn{background:var(--cream);color:var(--foreground);border:1px solid var(--border)}.secondary-btn:hover{border-color:var(--muted);background:#f5e6d3}.error-text{color:var(--destructive);margin:0;font-size:.85rem;font-weight:500}.table-wrap{margin-top:1rem;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:560px}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.875rem .75rem;font-size:.9rem}th{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;background:#faf8f5;font-size:.8rem;font-weight:700}td{color:var(--foreground)}.thumb{object-fit:cover;border:1px solid var(--border);cursor:pointer;border-radius:10px;width:56px;height:56px;transition:transform .2s}.thumb:hover{transform:scale(1.08)}.thumb-button{cursor:pointer;background:0 0;border:0;padding:0;display:inline-flex}.proof-preview{justify-content:center;align-items:center;padding:.5rem 0 0;display:flex}.proof-preview-image{object-fit:contain;border:1px solid var(--border);border-radius:16px;width:100%;max-width:100%;max-height:72vh;display:block;box-shadow:0 16px 40px #2d1f142e}@media (width<=960px){.two-column,.employee-grid{grid-template-columns:1fr}.tabs{-webkit-overflow-scrolling:touch;padding:0;overflow-x:auto}.modal-body .form-grid,.modal-body .credentials-display,.credentials-layout,.credentials-edit-layout{grid-template-columns:1fr}.credentials-summary{position:static}.credentials-summary-edit{min-height:auto}.credentials-grid-2{grid-template-columns:1fr}.modal-actions{flex-direction:column}}.modal-overlay{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#2d1f147a;animation:.2s fadeIn;position:fixed;inset:0}.modal-dialog{border:1px solid var(--border);z-index:100;background:#fff;border-radius:20px;width:min(980px,96vw);max-width:min(980px,96vw);max-height:90vh;animation:.3s slideUp;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%);box-shadow:0 20px 60px #2d1f1429}.modal-header{border-bottom:1px solid var(--border);z-index:101;background:#fff;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem 2rem;display:flex;position:sticky;top:0}.modal-header h2{color:var(--foreground);margin:0;font-family:Playfair Display,serif;font-size:1.4rem;font-weight:600}.modal-close{background:var(--cream);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--foreground);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:all .2s;display:flex}.modal-close:hover{border-color:var(--muted);background-color:#f5e6d3}.modal-body{padding:1.5rem 2rem}.modal-actions{border-top:1px solid var(--border);gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.modal-actions button{flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}
