@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{--primary:#fefcf9;--secondary:#2d1f14;--accent:#8b5e3c;--foreground:#2d1f14;--border:#e7dbcf;--cream:#faf5ef;--muted:#8c7b6b;--primary-light:#f2e7dc;--primary-hover:#7a4f31;--wine:#5a2a20;--destructive:#c0392b;--text-color:#2d1f14;--text-muted:#8c7b6b;--success:#27ae60;--warning:#f39c12;--error:#c0392b;--info:#3498db}*{box-sizing:border-box}body{min-height:100vh;color:var(--text-color);background:var(--primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}body:has(.login-container){background:var(--primary)}#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:100%;min-height:100vh;display:flex}.app-shell:not(.login-shell){background:var(--primary)}.login-shell{justify-content:center;align-items:center;padding-top:0;display:flex}.sidebar{background:var(--secondary);z-index:100;border-top-right-radius:32px;border-bottom-right-radius:32px;flex-direction:column;width:240px;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-header{flex-shrink:0;justify-content:center;align-items:center;padding:2rem 1.5rem 2.5rem;display:flex}.sidebar-logo{object-fit:cover;border:2px solid #fff3;border-radius:12px;width:56px;height:56px}.sidebar-brand{display:none}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:.5rem 0;display:flex;overflow-y:auto}.nav-section{margin-bottom:2rem}.nav-section-title{letter-spacing:.1em;text-transform:uppercase;color:#fff9;margin-bottom:.5rem;padding:0 1.5rem;font-size:.6875rem;font-weight:700;display:block}.nav-item{color:#ffffffb3;text-align:left;cursor:pointer;z-index:1;background:0 0;border:none;align-items:center;gap:1rem;width:100%;margin:0;padding:1rem 1.5rem;font-family:inherit;font-size:.9375rem;font-weight:500;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.nav-item svg{opacity:.85;stroke-width:2px;flex-shrink:0;transition:opacity .25s}.nav-item:hover:not(.active){color:#fffffff2;background:#ffffff0f}.nav-item:hover:not(.active) svg{opacity:1}.nav-item.active{background:var(--primary);color:var(--accent);z-index:2;border-top-left-radius:24px;border-bottom-left-radius:24px;margin-right:0;padding-right:2rem;font-weight:600}.nav-item.active svg{opacity:1;stroke:var(--accent)}.nav-item.active:before{content:"";background:var(--secondary);width:24px;height:24px;box-shadow:0 12px 0 0 var(--primary);border-bottom-right-radius:24px;position:absolute;top:-24px;right:0}.nav-item.active:after{content:"";background:var(--secondary);width:24px;height:24px;box-shadow:0 -12px 0 0 var(--primary);border-top-right-radius:24px;position:absolute;bottom:-24px;right:0}.main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:240px;display:flex}.top-header{z-index:50;background:#fff;border-bottom:1px solid #8b5e3c1a;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex;position:sticky;top:0}.top-header-actions{align-items:center;gap:.75rem;display:flex}.top-header h1{color:var(--secondary);margin:0;font-family:Playfair Display,serif;font-size:1.75rem;font-weight:700}.logout-btn{color:var(--text-color);cursor:pointer;background:0 0;border:1px solid #8b5e3c33;border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-family:inherit;font-size:.9375rem;font-weight:600;transition:all .2s;display:flex}.logout-btn:hover{border-color:var(--accent);background:#8b5e3c0a}.content-area{flex:1;padding:2rem;overflow-y:auto}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.glass-login-card{-webkit-backdrop-filter:blur(20px);background:#ffffffe6;border:2px solid #8b5e3c26;border-radius:32px;width:min(480px,100%);animation:6s ease-in-out infinite cardFloat;overflow:hidden;box-shadow:0 20px 60px #8b5e3c1f,0 8px 16px #8b5e3c14}@keyframes cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-logo-section{background:#8b5e3c08;border-bottom:1px solid #8b5e3c1a;justify-content:center;align-items:center;padding:3rem 2rem 2rem;display:flex}.login-logo{object-fit:cover;border:3px solid var(--accent);background:#fff;border-radius:50%;width:120px;height:120px;padding:8px;box-shadow:0 8px 24px #8b5e3c26,0 0 0 8px #ffffff80}.login-form-section{padding:2.5rem 2rem 3rem}.glass-form{flex-direction:column;gap:1.25rem;display:flex}.glass-label{display:block;position:relative}.input-icon{color:var(--accent);opacity:.6;pointer-events:none;z-index:1;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.glass-label input{-webkit-backdrop-filter:blur(10px);width:100%;color:var(--text-color);background:#8b5e3c0a;border:1.5px solid #8b5e3c33;border-radius:16px;padding:1rem 1rem 1rem 3rem;font-size:.95rem;font-weight:500;transition:all .3s;box-shadow:inset 0 1px 3px #8b5e3c14}.glass-label input::placeholder{color:#8b5e3c80}.glass-label input:focus{border-color:var(--accent);background:#8b5e3c0f;outline:none;box-shadow:inset 0 1px 3px #8b5e3c14,0 0 0 3px #8b5e3c26}.glass-label input:focus+.input-icon,.glass-label input:not(:placeholder-shown)+.input-icon{color:var(--accent);opacity:1}.glass-label input:-webkit-autofill{-webkit-text-fill-color:var(--text-color);transition:background-color 9999s ease-out;-webkit-box-shadow:inset 0 0 0 1000px #8b5e3c0a}.glass-label input:-webkit-autofill:hover{-webkit-text-fill-color:var(--text-color);transition:background-color 9999s ease-out;-webkit-box-shadow:inset 0 0 0 1000px #8b5e3c0a}.glass-label input:-webkit-autofill:focus{-webkit-text-fill-color:var(--text-color);transition:background-color 9999s ease-out;-webkit-box-shadow:inset 0 0 0 1000px #8b5e3c0a}.login-options{justify-content:space-between;align-items:center;gap:1rem;margin-top:-.25rem;display:flex}.glass-checkbox-label{color:var(--text-color);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;display:flex}.glass-checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--accent)}.glass-forgot-link{color:var(--accent);white-space:nowrap;font-size:.85rem;font-weight:500;text-decoration:none;transition:color .2s}.glass-forgot-link:hover{color:var(--secondary);text-decoration:underline}.glass-error-text{-webkit-backdrop-filter:blur(10px);color:var(--error);text-align:center;background:#c0392b14;border:1px solid #c0392b40;border-radius:12px;margin:0;padding:.75rem 1rem;font-size:.85rem;font-weight:500}.glass-login-btn{background:var(--secondary);-webkit-backdrop-filter:blur(10px);color:#fff;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:none;border-radius:16px;width:100%;margin-top:.5rem;padding:1rem;font-size:.95rem;font-weight:700;transition:all .3s;box-shadow:0 4px 16px #2d1f1440}.glass-login-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--primary-hover) 0%, var(--wine) 100%);transform:translateY(-2px);box-shadow:0 6px 20px #8b5e3c59,inset 0 1px #ffffff4d}.glass-login-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #8b5e3c40,inset 0 1px #fff3}.glass-login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.glass-checkbox-label input[type=checkbox]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.glass-forgot-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.glass-login-btn:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.glass-label input:focus-visible{outline:none}.card{background:#fff;border:1px solid #8b5e3c1f;border-radius:20px;padding:2rem;box-shadow:0 2px 12px #8b5e3c0f}.card h2{color:var(--secondary);margin:0 0 .5rem;font-family:Playfair Display,serif;font-size:1.75rem;font-weight:700}.helper-text{color:var(--text-muted);margin:.5rem 0 1rem;font-size:.875rem}.section-guide{color:var(--text-muted);margin:0 0 1rem;font-size:.875rem;font-weight:500;line-height:1.5}.dashboard-toolbar{gap:.75rem;margin-bottom:1.5rem;display:flex}.navigation-strip{background:#fff;border:1px solid #8b5e3c1f;border-radius:16px;margin-bottom:1.5rem;padding:1.5rem 2rem;box-shadow:0 2px 8px #8b5e3c0a}.tabs{display:none}.two-column{grid-template-columns:320px 1fr;gap:1.5rem;display:grid}.tab-header{justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;display:flex}.tab-header.compact{margin-bottom:1.5rem}.kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;min-width:360px;display:grid}.kpi-card{background:#fff;border:1px solid #8b5e3c1f;border-radius:16px;gap:.5rem;padding:1.25rem 1.5rem;transition:all .2s;display:grid}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5e3c14}.kpi-card span{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.8125rem;font-weight:600}.kpi-card strong{color:var(--secondary);font-size:2rem;font-weight:700;line-height:1}.kpi-card.kpi-good{background:#27ae600a;border-color:#27ae604d}.kpi-card.kpi-good strong{color:var(--success)}.kpi-card.kpi-warn{background:#f39c120a;border-color:#f39c124d}.kpi-card.kpi-warn strong{color:var(--warning)}.next-step-banner{border:1px solid #8b5e3c26;border-left:4px solid var(--accent);color:var(--text-color);background:#8b5e3c08;border-radius:12px;margin-top:1.5rem;margin-bottom:1.5rem;padding:1rem 1.25rem;font-size:.9375rem;line-height:1.5}.next-step-banner strong{color:var(--secondary);font-weight:600}.employee-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.employee-card{cursor:pointer;background:#fff;border:1px solid #8b5e3c1f;border-radius:16px;padding:1.5rem;transition:all .2s}.employee-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 24px #8b5e3c1f}.employee-card.present{border-left:4px solid var(--success);background:#27ae6005}.employee-card.absent{border-left:4px solid var(--text-muted);background:#8c7b6b05}.employee-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.employee-card-header h3{color:var(--secondary);margin:0;font-size:1.125rem;font-weight:700}.employee-card-header p.position{color:var(--text-muted);margin:.375rem 0 0;font-size:.875rem}.status-badge{text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-radius:12px;align-items:center;padding:.5rem 1rem;font-size:.8125rem;font-weight:700;display:inline-flex}.status-badge.present{color:var(--success);background:#27ae601f;border:1px solid #27ae6033}.status-badge.absent{color:var(--text-muted);background:#8c7b6b1f;border:1px solid #8c7b6b33}.time-info{border-top:1px solid #8b5e3c1a;gap:1.5rem;padding-top:1rem;display:flex}.time-item{flex-direction:column;flex:1;gap:.375rem;display:flex}.time-item .label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.75rem;font-weight:600}.time-item .time{color:var(--accent);font-size:1.125rem;font-weight:700}.employee-list{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.search-label{margin-top:.1rem}.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}.employee-actions{align-items:flex-start;gap:.6rem;display:flex}.selection-placeholder{text-align:center;place-content:center;min-height:280px;display:grid}.selection-placeholder h2{margin-bottom:.35rem}.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%}.credentials-edit-content,.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}.credentials-edit-content>.modal-actions{margin-top:.5rem}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}.week-actions{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.week-actions .secondary-btn{padding:.6rem .85rem;font-size:.85rem}.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:none;border-radius:12px;padding:.875rem 1.5rem;font-family:Inter,inherit;font-size:.9375rem;font-weight:600;transition:all .2s}.primary-btn{background:var(--accent);color:#fff;box-shadow:0 2px 8px #2d1f1426}.primary-btn:hover{background:var(--secondary);transform:translateY(-2px);box-shadow:0 4px 16px #2d1f1440}.primary-btn:disabled,.secondary-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.secondary-btn{color:var(--text-color);background:#fff;border:1px solid #8b5e3c33}.secondary-btn:hover{border-color:var(--accent);background:#8b5e3c0a}.error-text{color:var(--destructive);margin:0;font-size:.85rem;font-weight:500}.loading-state{text-align:center;place-items:center;gap:1rem;min-height:240px;display:grid}.loading-state h2{margin:0;font-family:Playfair Display,serif;font-size:1.45rem;font-weight:600}.loading-spinner{border:4px solid #8b5e3c29;border-top-color:var(--primary);border-radius:50%;width:52px;height:52px;animation:.85s linear infinite spin}.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){.sidebar{z-index:60;width:100%;height:auto;position:sticky;top:0}.sidebar-header{padding:1rem}.sidebar-nav{padding:.5rem 0 .85rem}.nav-section{margin-bottom:0}.nav-section-title{display:none}.nav-item{padding:.75rem 1rem}.main-content{min-height:calc(100vh - 168px);margin-left:0}.top-header{padding:1rem}.top-header h1{font-size:1.35rem}.top-header-actions{width:100%;margin-top:.5rem}.top-header{flex-direction:column;align-items:flex-start}.top-header-actions .primary-btn,.top-header-actions .secondary-btn{width:100%}.login-shell{padding-top:1.2rem}.top-bar{padding:0}.brand-logo{border-radius:14px;width:50px;height:50px}.login-container{min-height:100vh;padding:1rem}.glass-login-card{border-radius:28px;width:100%}.login-logo-section{padding:2.5rem 1.5rem 1.5rem}.login-logo{width:100px;height:100px}.login-form-section{padding:2rem 1.5rem 2.5rem}.glass-form{gap:1rem}.login-options{flex-direction:column;align-items:flex-start;gap:.75rem}.glass-forgot-link{align-self:flex-end}.navigation-strip{margin-inline:0}.two-column{grid-template-columns:1fr}.tab-header{flex-direction:column}.kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));width:100%;min-width:0}.employee-actions{flex-direction:column;width:100%}.employee-actions .secondary-btn{width:100%}.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%)}}@keyframes spin{to{transform:rotate(360deg)}}
