@import"https://fonts.googleapis.com/css2?family=General+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--bg: #FAFAF9;--surface: #FFFFFF;--border: #E7E5E4;--sidebar: #1A1A1D;--sidebar-hover: #252528;--sidebar-active: #303034;--accent: #2563EB;--accent-hover: #1D4ED8;--text-primary: #1C1917;--text-secondary: #57534E;--text-tertiary: #78716C;--red: #F43F5E;--green: #10B981;--yellow: #F59E0B}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{overflow:hidden;overscroll-behavior:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation;height:100%}body{font-family:General Sans,system-ui,sans-serif;background:var(--bg);color:var(--text-primary);height:100%;overflow:hidden}#root{height:100%;display:flex;flex-direction:column}@keyframes screen-enter{0%{opacity:0;transform:scale(1.015)}to{opacity:1;transform:scale(1)}}@keyframes screen-exit{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.97)}}@keyframes welcome-rise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.screen{display:flex;height:100%;overflow:hidden}.screen--enter{animation:screen-enter .35s ease both}.screen--exit{animation:screen-exit .35s ease both;pointer-events:none}.welcome__heading--animate{animation:welcome-rise .4s ease both .05s}.welcome__instruction--animate{animation:welcome-rise .4s ease both .12s}.search-wrap--animate{animation:welcome-rise .4s ease both .2s}.side-panel{width:240px;flex-shrink:0;position:relative;overflow:hidden;background:linear-gradient(180deg,#16161a,#111114 60%,#0e0e11);display:flex;flex-direction:column;height:100%}.side-panel__runway-lights{display:none}.side-panel__content{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:space-between;padding:28px 20px;height:100%}.side-panel__clock{display:flex;flex-direction:column;gap:6px}.side-panel__date{font-size:16px;font-weight:500;color:#ffffff8c}.side-panel__time{font-family:JetBrains Mono,monospace;font-size:52px;font-weight:700;color:#fff;line-height:1;letter-spacing:-.02em}.side-panel__logo{display:flex;align-items:center;gap:7px;font-size:15px;font-weight:700;color:#ffffff59;letter-spacing:.1em;text-transform:uppercase;background:none;border:none;cursor:pointer;font-family:inherit;padding:6px 8px;border-radius:8px;align-self:flex-start;margin:-6px -8px;transition:color .15s,background .15s}.side-panel__logo:hover{color:#ffffffb3;background:#ffffff12}.main-panel{flex:1;background:var(--surface);overflow-y:auto;display:flex;flex-direction:column;min-height:0}.main-panel--centered{position:relative;align-items:center;justify-content:center;padding:24px;gap:20px}.main-panel--dashboard{padding:0;display:flex;flex-direction:column}.welcome{padding:32px 24px 24px;display:flex;flex-direction:column;gap:12px}.welcome__heading{font-size:36px;font-weight:700;color:var(--accent);letter-spacing:.04em}.welcome__instruction{font-size:18px;color:var(--text-secondary)}.search-wrap{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;padding:14px 16px 14px 44px;border:1px solid var(--border);border-radius:8px;font-size:18px;font-family:inherit;color:var(--text-primary);background:var(--bg);outline:none;transition:border-color .15s,box-shadow .15s;user-select:text;-webkit-user-select:text}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.employee-list{list-style:none;border:1px solid var(--border);border-radius:12px;overflow:hidden}.employee-list__row{display:flex;align-items:center;gap:16px;padding:16px 20px;min-height:64px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}.employee-list__row:last-child{border-bottom:none}.employee-list__row:hover,.employee-list__row:active{background:var(--bg)}.employee-list__name{font-size:20px;font-weight:500;color:var(--text-primary)}.employee-list__empty{padding:16px;font-size:14px;color:var(--text-tertiary)}.back-link{font-size:14px;font-weight:500;color:var(--accent);text-decoration:none}.pin-back-link{position:absolute;top:24px;left:24px}.pin-greeting{font-size:36px;font-weight:700;color:var(--accent);text-align:center}.pin-instruction{font-size:20px;color:var(--text-secondary);text-align:center}.pinpad{display:flex;flex-direction:column;align-items:center;gap:32px;width:100%;max-width:360px}.pinpad__dots{display:flex;gap:24px;align-items:center}@keyframes dot-pop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.25)}to{transform:scale(1.15);opacity:1}}.pinpad__dot{width:22px;height:22px;border-radius:999px;border:2px solid var(--border);background:transparent;transition:background .12s,border-color .12s,transform .15s}.pinpad__dot--filled{background:var(--accent);border-color:var(--accent);animation:dot-pop .22s cubic-bezier(.34,1.56,.64,1) both}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.pinpad__dots--shake{animation:shake .45s ease}.pinpad__grid{display:grid;grid-template-columns:repeat(3,90px);gap:18px}.pinpad__btn{width:90px;height:90px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-primary);font-size:30px;font-family:JetBrains Mono,monospace;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,transform .1s,box-shadow .1s;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 6px #0000000f}.pinpad__btn:active{background:#f5f5f4;transform:scale(.93);box-shadow:none}.pinpad__btn--text{font-size:16px;font-weight:500;font-family:inherit;color:var(--text-secondary);border-color:transparent;box-shadow:none}.db-header{display:flex;align-items:center;gap:20px;padding:28px 28px 24px;border-bottom:1px solid var(--border)}.db-header__info{display:flex;flex-direction:column;gap:6px;min-width:0}.db-header__name{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1}.db-status{font-size:14px;font-weight:500}.db-status--in{color:var(--green)}.db-status--out{color:var(--text-tertiary)}.db-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 28px 28px;gap:8px;border-bottom:1px solid var(--border)}.db-hero__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-tertiary)}.db-hero__value{font-family:JetBrains Mono,monospace;font-size:64px;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-.02em}.db-stats{display:flex;align-items:stretch;padding:0 28px;border-bottom:1px solid var(--border)}.db-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;padding:22px 8px}.db-stat-divider{width:1px;background:var(--border);margin:16px 0}.db-stat__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary)}.db-stat__value{font-family:JetBrains Mono,monospace;font-size:26px;font-weight:700;color:var(--text-primary);line-height:1}.db-notes{display:flex;flex-direction:column;gap:10px;padding:24px 28px 20px}.db-notes__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary)}.notes-textarea{border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:15px;font-family:inherit;color:var(--text-primary);background:var(--bg);resize:none;outline:none;user-select:text;-webkit-user-select:text;transition:border-color .15s,box-shadow .15s}.db-notes__textarea{flex:1;height:60px}.notes-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.db-toast{margin:0 28px;padding:12px 20px;background:#1c1917;color:#fff;font-size:15px;font-weight:600;border-radius:10px;text-align:center;animation:toast-in .2s ease both}.db-clock-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 28px}.btn--clock-hero{flex-direction:column;gap:12px;font-size:20px;font-weight:700;border-radius:50%;width:200px;min-width:200px;max-width:200px;height:200px;min-height:200px;max-height:200px;padding:0;flex-shrink:0;align-self:center;display:flex;align-items:center;justify-content:center}.btn--clock-hero svg{width:40px;height:40px}.btn--clockin.btn--clock-hero{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 20px #10b98166}.btn--clockout.btn--clock-hero{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 20px #ef444466}.field-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.dashboard__bar{display:none}.btn--signout-full{width:100%;height:50px;flex:0 0 50px;border-radius:0!important;font-size:14px;letter-spacing:.04em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:500;font-size:14px;border:none;border-radius:8px;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s;-webkit-tap-highlight-color:transparent}.btn--secondary{background:var(--bg);color:var(--text-secondary);border:1px solid var(--border);padding:8px 14px;font-size:13px}.btn--secondary:hover{background:var(--border)}.btn--save-note{align-self:flex-end;background:var(--bg);color:var(--accent);border:1px solid var(--accent);padding:9px 20px;font-size:14px;font-weight:600;border-radius:8px}.btn--save-note:hover{background:#2563eb0f}.btn--signout{background:var(--accent);color:#fff;font-size:14px;font-weight:600;border-radius:0;letter-spacing:.03em}.btn--signout:hover{background:var(--accent-hover)}.btn--signout:active{background:#1e40af}@keyframes pulse-green{0%,to{box-shadow:0 0 #10b98180}50%{box-shadow:0 0 0 8px #10b98100}}@keyframes pulse-red{0%,to{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 0 8px #ef444400}}.btn--clockin{flex:2;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:22px;font-weight:700;border-radius:0;letter-spacing:.04em;text-transform:uppercase;animation:pulse-green 2.5s ease-in-out infinite}.btn--clockin:active{transform:scale(.98);background:linear-gradient(135deg,#059669,#047857)}.btn--clockout{flex:2;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:22px;font-weight:700;border-radius:0;letter-spacing:.04em;text-transform:uppercase;animation:pulse-red 2.5s ease-in-out infinite}.btn--clockout:active{transform:scale(.98);background:linear-gradient(135deg,#dc2626,#b91c1c)}@keyframes confirm-pop{0%{transform:scale(.5) rotate(-15deg);opacity:0}60%{transform:scale(1.15) rotate(4deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}@keyframes confirm-rise{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes confirm-close{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.06)}}.confirmation--closing{animation:confirm-close .35s ease forwards;pointer-events:none}.confirmation{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;height:100%;padding:32px}.confirmation--in{background:linear-gradient(160deg,#059669,#10b981 60%,#34d399)}.confirmation--out{background:linear-gradient(160deg,#b91c1c,#ef4444 60%,#f87171)}.confirmation__check{width:88px;height:88px;border-radius:999px;background:#ffffff40;display:flex;align-items:center;justify-content:center;color:#fff}.confirmation__check--animate{animation:confirm-pop .5s cubic-bezier(.34,1.56,.64,1) both}.confirmation__heading{font-size:26px;font-weight:700;color:#fff;text-align:center}.confirmation__heading--animate{animation:confirm-rise .4s ease both .15s}.confirmation__sub{font-size:17px;color:#ffffffe0;text-align:center}.confirmation__sub--animate{animation:confirm-rise .4s ease both .25s}.confirmation__actions{display:flex;gap:12px;margin-top:8px}.confirmation__btn{font-family:inherit;font-size:16px;font-weight:600;padding:14px 32px;border-radius:10px;cursor:pointer;border:none;transition:opacity .15s,transform .1s;-webkit-tap-highlight-color:transparent}.confirmation__btn:active{transform:scale(.97)}.confirmation__btn--secondary{background:#ffffff2e;color:#fff;border:2px solid rgba(255,255,255,.35)}.confirmation__btn--secondary:hover{background:#ffffff40}.confirmation__btn--primary{background:#fff;color:#1c1917}.confirmation__btn--primary:hover{opacity:.9}.confirmation__goback--animate{animation:confirm-rise .4s ease both .35s}.admin{display:flex;flex-direction:column;height:100%;min-height:100vh;background:var(--bg);font-family:General Sans,system-ui,sans-serif}.admin-header{display:flex;align-items:center;gap:16px;padding:14px 24px;background:var(--sidebar);border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.admin-header__back{font-size:14px;font-weight:500;color:#fff9;background:none;border:none;cursor:pointer;font-family:inherit;padding:6px 10px;border-radius:6px;transition:background .15s,color .15s;white-space:nowrap}.admin-header__back:hover{background:#ffffff14;color:#fff}.admin-header__title{font-size:17px;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px}.admin-header__logo{font-size:20px}.admin-body{display:flex;flex:1;overflow:hidden}.admin-nav{width:210px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 10px;gap:4px}.admin-nav__btn{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;transition:background .15s,color .15s}.admin-nav__btn:hover{background:var(--bg);color:var(--text-primary)}.admin-nav__btn--active{background:#2563eb14;color:var(--accent);font-weight:600}.admin-main{flex:1;overflow-y:auto;padding:28px 32px}.admin-panel{max-width:1100px}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.panel-title{font-size:22px;font-weight:700;color:var(--text-primary)}.panel-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:20px}.filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.seg-ctrl{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg)}.seg-btn{padding:8px 14px;font-size:13px;font-weight:500;font-family:inherit;background:none;border:none;border-right:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.seg-btn:last-child{border-right:none}.seg-btn:hover{background:var(--surface);color:var(--text-primary)}.seg-btn--active{background:var(--accent);color:#fff;font-weight:600}.period-nav{display:flex;align-items:center;gap:6px}.period-nav__btn{width:32px;height:32px;border-radius:7px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s;font-family:inherit}.period-nav__btn:hover{background:var(--bg)}.period-nav__label{font-size:14px;font-weight:600;color:var(--text-primary);min-width:200px;text-align:center}.filter-select{padding:9px 36px 9px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;font-weight:500;color:var(--text-primary);background-color:var(--surface);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;cursor:pointer;transition:border-color .15s,box-shadow .15s}.filter-select:hover{border-color:#9ca3af}.filter-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table th{text-align:left;padding:10px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tfoot td{border-top:2px solid var(--border);background:var(--bg);padding:12px 16px}.th-sort{display:inline-flex;align-items:center;gap:5px;background:none;border:none;padding:0;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary);cursor:pointer;font-family:inherit;transition:color .15s}.th-sort:hover{color:var(--text-primary)}.th-sort__icon{font-size:12px;opacity:.7}.thead-filters th{padding:6px 10px;background:var(--surface);border-bottom:2px solid var(--border)}.th-filter{width:100%;padding:6px 10px;background:var(--bg);border:1.5px solid var(--border);border-radius:6px;font-size:12px;font-family:inherit;font-weight:400;color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s;text-transform:none;letter-spacing:0}.th-filter::placeholder{color:var(--text-tertiary)}.th-filter:focus{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb1a}.th-filter--select{padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.th-clear{font-size:11px;font-family:inherit;font-weight:600;padding:5px 10px;background:transparent;border:1.5px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s}.th-clear:hover{border-color:#dc2626;color:#dc2626}.admin-table tbody tr:hover td{background:#fafaf9}.tr--active td{background:#10b9810a}.mono{font-family:JetBrains Mono,monospace;font-size:13px}.td-notes{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:var(--text-secondary)}.badge-active{display:inline-block;padding:2px 8px;border-radius:999px;background:#10b9811a;color:var(--green);font-size:11px;font-weight:600}.empty-state{padding:40px;text-align:center;color:var(--text-tertiary);font-size:15px}.initials-badge{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;background:#9ca3af;color:#fff;font-size:12px;font-weight:600}.pin-badge{font-family:JetBrains Mono,monospace;font-size:14px;letter-spacing:.1em;color:var(--text-secondary)}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:inherit;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;padding:9px 18px;transition:background .15s,opacity .15s;white-space:nowrap}.admin-btn--primary{background:var(--accent);color:#fff}.admin-btn--primary:hover{background:var(--accent-hover)}.admin-btn--ghost{background:var(--bg);color:var(--text-secondary);border:1px solid var(--border)}.admin-btn--ghost:hover{background:var(--border);color:var(--text-primary)}.admin-btn--danger{background:#ef444414;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.admin-btn--danger:hover{background:#ef444424}.admin-btn--sm{padding:5px 12px;font-size:13px}.emp-form{display:flex;flex-direction:column;gap:16px}.form-row{display:flex;gap:16px;flex-wrap:wrap}.form-field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:140px}.form-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary)}.form-hint{text-transform:none;letter-spacing:0;font-weight:400;color:var(--text-tertiary)}.form-input{padding:10px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit;color:var(--text-primary);background:var(--bg);outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:hover{border-color:#9ca3af}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}select.form-input{padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-color:var(--bg);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-input--pin{max-width:120px;font-family:JetBrains Mono,monospace;letter-spacing:.2em}.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:4px}.form-error{color:#dc2626;font-size:13px}.form-msg{font-size:13px;color:var(--text-secondary);margin-right:auto}.form-msg--ok{color:var(--green)}.form-msg--err{color:#dc2626}.settings-section{padding:24px}.settings-section__title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:18px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal{background:var(--surface);border-radius:16px;width:100%;max-width:520px;box-shadow:0 24px 64px #00000040;animation:confirm-pop .2s cubic-bezier(.34,1.56,.64,1) both}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-title{font-size:17px;font-weight:700;color:var(--text-primary)}.modal-close{width:30px;height:30px;border-radius:7px;border:none;background:var(--bg);color:var(--text-secondary);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;font-family:inherit}.modal-close:hover{background:var(--border)}.modal-body{padding:20px 24px 24px}.admin-login{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px}.admin-login__card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px 36px;width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 8px 32px #00000014}.admin-login__icon{width:64px;height:64px;border-radius:16px;background:#2563eb1a;color:var(--accent);display:flex;align-items:center;justify-content:center}.admin-login__title{font-size:26px;font-weight:700;color:var(--text-primary)}.admin-login__sub{font-size:15px;color:var(--text-secondary)}@media (max-width: 860px){.admin-body{flex-direction:column}.admin-nav{width:100%;flex-direction:row;border-right:none;border-bottom:1px solid var(--border);padding:0;gap:0;overflow-x:auto}.admin-nav__btn{flex:1;justify-content:center;border-radius:0;padding:14px 8px;font-size:13px;border-bottom:3px solid transparent;min-width:80px}.admin-nav__btn--active{background:none;border-bottom-color:var(--accent)}.admin-main{padding:20px 16px}.period-nav__label{min-width:140px;font-size:13px}.filter-bar{gap:8px}}@media (max-width: 520px){.admin-header{padding:12px 16px}.panel-title{font-size:18px}}@keyframes transition-in{0%{opacity:0}to{opacity:1}}@keyframes circle-pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.15);opacity:1}to{transform:scale(1);opacity:1}}@keyframes check-draw{0%{stroke-dashoffset:40;opacity:0}30%{opacity:1}to{stroke-dashoffset:0;opacity:1}}.pin-transition{position:fixed;top:0;right:0;bottom:0;left:0;background:#10b981eb;display:flex;align-items:center;justify-content:center;z-index:999;animation:transition-in .2s ease both}.pin-transition--admin{background:#2563ebeb}.pin-transition__circle{width:110px;height:110px;border-radius:50%;background:#fff3;border:3px solid rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;color:#fff;animation:circle-pop .4s cubic-bezier(.34,1.56,.64,1) both .1s}.pin-transition__circle svg polyline{stroke-dasharray:40;stroke-dashoffset:40;animation:check-draw .35s ease both .3s}.seg-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent}.seg-btn--active,.seg-btn--active:hover,.seg-btn--active:focus,.seg-btn--active:active{background:var(--accent)!important;color:#fff!important;font-weight:600!important}.pp-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pp-type-btn{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 16px;background:var(--surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.pp-type-btn:hover{border-color:var(--accent);background:#2563eb0a}.pp-type-btn--active,.pp-type-btn--active:hover,.pp-type-btn--active:focus,.pp-type-btn--active:active{border-color:var(--accent)!important;background:#2563eb14!important}.pp-type-btn__label{font-size:14px;font-weight:600;color:var(--text-primary)}.pp-type-btn--active .pp-type-btn__label{color:var(--accent)}.pp-type-btn__desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.btn-change-pin{margin-left:auto;padding:8px 14px;font-size:12px;font-weight:600;font-family:inherit;color:var(--text-secondary);background:var(--surface);border:1.5px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color .15s,color .15s;-webkit-tap-highlight-color:transparent;white-space:nowrap}.btn-change-pin:hover{border-color:var(--accent);color:var(--accent)}.pin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:24px}.pin-modal{background:var(--surface);border-radius:20px;padding:28px 24px 32px;width:100%;max-width:340px;display:flex;flex-direction:column;align-items:center;animation:confirm-rise .25s ease both}.pin-modal__header{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:8px}.pin-modal__title{font-size:18px;font-weight:700;color:var(--text-primary)}.pin-modal__close{background:none;border:none;font-size:16px;color:var(--text-tertiary);cursor:pointer;padding:4px 8px;-webkit-tap-highlight-color:transparent}.pin-modal__step{font-size:14px;color:var(--text-secondary);margin-bottom:6px;text-align:center}.pin-modal__error{font-size:13px;color:#dc2626;margin-bottom:4px;text-align:center}.pin-modal__steps{display:flex;gap:8px;margin-bottom:20px}.pin-modal__dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.pin-modal__dot--active{background:var(--accent)}.pin-modal__dot--done{background:var(--green)}.pin-modal__success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 0}.pin-modal__success-icon{width:56px;height:56px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;animation:confirm-pop .4s cubic-bezier(.34,1.56,.64,1) both}.pin-modal__success p{font-size:16px;font-weight:600;color:var(--text-primary)}.csel{position:relative}.csel__trigger{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--surface);border:1.5px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;font-weight:500;color:var(--text-primary);cursor:pointer;white-space:nowrap;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.csel__trigger:hover{border-color:#9ca3af}.csel--open .csel__trigger{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}.csel__chevron{opacity:.5;flex-shrink:0;transition:transform .2s ease}.csel--open .csel__chevron{transform:rotate(180deg)}@keyframes csel-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.csel__menu{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:#1c1c1e;border-radius:12px;padding:5px;box-shadow:0 8px 32px #00000047,0 2px 8px #00000029;z-index:200;animation:csel-in .15s ease both;overflow:hidden}.csel__option{display:flex;align-items:center;gap:0;width:100%;padding:9px 12px 9px 8px;background:transparent;border:none;border-radius:7px;font-size:14px;font-family:inherit;font-weight:500;color:#ffffffe6;cursor:pointer;text-align:left;transition:background .1s;-webkit-tap-highlight-color:transparent}.csel__option:hover{background:#ffffff14}.csel__option--active{background:#2563eb!important;color:#fff}.csel__option--active:hover{background:#1d4ed8!important}.csel__check{width:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:24px}.login-card{display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px 40px;width:100%;max-width:420px;gap:0}.login-logo{width:72px;height:72px;background:var(--accent);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:24px}.login-title{font-size:28px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:8px}.login-subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:32px}.login-error{background:#dc262614;border:1px solid rgba(220,38,38,.2);border-radius:10px;padding:12px 16px;font-size:13px;color:#dc2626;margin-bottom:20px;width:100%}.login-google-btn{display:flex;align-items:center;gap:12px;padding:14px 24px;background:#fff;border:1.5px solid var(--border);border-radius:12px;font-size:15px;font-weight:600;font-family:inherit;color:var(--text-primary);text-decoration:none;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s;width:100%;justify-content:center;margin-bottom:20px}.login-google-btn:hover{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a;background:#2563eb05}.login-note{font-size:12px;color:var(--text-tertiary);line-height:1.6}@keyframes spin{to{transform:rotate(360deg)}}.app-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.setup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.setup-modal{background:var(--surface);border-radius:20px;padding:48px 40px 36px;max-width:460px;width:100%;display:flex;flex-direction:column;align-items:center;text-align:center;animation:confirm-rise .3s ease both}.setup-icon{font-size:48px;margin-bottom:20px;line-height:1}.setup-title{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:14px;letter-spacing:-.01em}.setup-body{font-size:15px;color:var(--text-secondary);line-height:1.65;margin-bottom:32px}.setup-dots{display:flex;gap:8px;margin-bottom:28px}.setup-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.setup-dot--active{background:var(--accent)}.setup-actions{display:flex;gap:10px;width:100%;align-items:center}@keyframes row-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.employee-list__row{animation:row-in .2s ease both}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:300;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade-in .15s ease}.confirm-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 32px;width:100%;max-width:400px;animation:slide-up .18s ease}.confirm-modal__title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 10px}.confirm-modal__message{font-size:14px;color:var(--text-secondary);margin:0 0 24px;line-height:1.5}.confirm-modal__actions{display:flex;gap:10px;justify-content:flex-end}.confirm-modal__btn{padding:9px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:opacity .15s}.confirm-modal__btn:hover{opacity:.85}.confirm-modal__btn--cancel{background:var(--surface-2);color:var(--text-primary)}.confirm-modal__btn--danger{background:#e53935;color:#fff}.confirm-modal__btn--confirm{background:var(--accent);color:#fff}
