@import"https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;500;600;700&family=Poppins:wght@400;500;600;700&display=swap";:root{--color-primary: #2563EB;--color-primary-light: #3B82F6;--color-primary-dark: #1D4ED8;--color-cta: #F97316;--color-cta-light: #FB923C;--color-success: #22C55E;--color-danger: #EF4444;--color-warning: #EAB308;--bg-base: #0F172A;--bg-surface: #1E293B;--bg-elevated: #334155;--bg-glass: rgba(255, 255, 255, .05);--bg-glass-hover: rgba(255, 255, 255, .08);--border-glass: rgba(255, 255, 255, .1);--border-glass-hover: rgba(255, 255, 255, .2);--text-primary: #F1F5F9;--text-secondary: #CBD5E1;--text-muted: #94A3B8;--text-dark: #0F172A;--font-heading: "Poppins", sans-serif;--font-body: "Open Sans", sans-serif;--sidebar-width: 260px;--blur: blur(12px);--transition: all .2s ease;--shadow-glow: 0 0 20px rgba(37, 99, 235, .3);--shadow-card: 0 4px 24px rgba(0, 0, 0, .3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.3}a{color:var(--color-primary-light);text-decoration:none;transition:var(--transition)}a:hover{color:var(--color-primary)}.glass-card{background:var(--bg-glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border:1px solid var(--border-glass);border-radius:16px;transition:var(--transition)}.glass-card:hover{background:var(--bg-glass-hover);border-color:var(--border-glass-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:12px;font-family:var(--font-heading);font-weight:600;font-size:.95rem;cursor:pointer;transition:var(--transition);outline:none}.btn:focus-visible{outline:2px solid var(--color-primary-light);outline-offset:2px}.btn-primary{background:linear-gradient(135deg,var(--color-cta),var(--color-cta-light));color:#fff;box-shadow:0 4px 14px #f9731666}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #f9731680}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-glass);border:1px solid var(--border-glass);color:var(--text-primary);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur)}.btn-secondary:hover{background:var(--bg-glass-hover);border-color:var(--border-glass-hover)}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper>svg{position:absolute;left:14px;color:var(--text-muted);width:18px;height:18px;pointer-events:none}.input-wrapper input,.input-wrapper select{width:100%;padding:12px 14px 12px 44px;background:var(--bg-surface);border:1px solid var(--border-glass);border-radius:12px;color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;transition:var(--transition);outline:none}.input-wrapper input:focus,.input-wrapper select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb33}.input-wrapper input::placeholder{color:var(--text-muted)}.input-wrapper .input-action{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;pointer-events:auto;border-radius:8px;transition:var(--transition)}.input-wrapper .input-action:hover{color:var(--text-primary);background:#ffffff14}.input-wrapper select option{background:var(--bg-surface);color:var(--text-primary)}.metric-card{padding:24px;display:flex;flex-direction:column;gap:8px}.metric-card .metric-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.metric-card .metric-value{font-family:var(--font-heading);font-size:1.8rem;font-weight:700}.metric-card .metric-label{font-size:.85rem;color:var(--text-muted)}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table th{text-align:left;padding:14px 16px;font-family:var(--font-heading);font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-glass)}.data-table td{padding:14px 16px;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.04)}.data-table tbody tr{transition:var(--transition)}.data-table tbody tr:hover{background:var(--bg-glass-hover)}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:9999px;font-size:.75rem;font-weight:600}.badge-blue{background:#2563eb26;color:#60a5fa}.badge-green{background:#22c55e26;color:#4ade80}.badge-orange{background:#f9731626;color:#fb923c}.badge-purple{background:#a855f726;color:#c084fc}.badge-teal{background:#14b8a626;color:#2dd4bf}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;animation:fadeIn .2s ease}.modal-content{width:100%;max-width:500px;max-height:90vh;overflow-y:auto;padding:32px;margin:16px;animation:slideUp .3s ease}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.toast{position:fixed;top:24px;right:24px;padding:14px 20px;border-radius:12px;font-size:.9rem;font-weight:500;z-index:100;animation:slideIn .3s ease}.toast-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.toast-success{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#86efac}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:768px){:root{--sidebar-width: 0px}.modal-content{max-width:100%;margin:8px;padding:24px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden}.login-bg{position:fixed;inset:0;z-index:0;overflow:hidden}.bg-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4}.bg-orb-1{width:400px;height:400px;background:var(--color-primary);top:-100px;right:-100px;animation:float 8s ease-in-out infinite}.bg-orb-2{width:300px;height:300px;background:var(--color-cta);bottom:-80px;left:-80px;animation:float 10s ease-in-out infinite reverse}.bg-orb-3{width:250px;height:250px;background:#8b5cf6;top:50%;left:50%;transform:translate(-50%,-50%);animation:float 12s ease-in-out infinite}.login-card{width:100%;max-width:440px;padding:40px;position:relative;z-index:1;animation:slideUp .5s ease}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 8px 24px #2563eb66}.login-header h1{font-size:1.6rem;margin-bottom:6px}.login-header p{color:var(--text-muted);font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:20px}.login-btn{width:100%;padding:14px;font-size:1rem;margin-top:4px}.login-hint{text-align:center;margin-top:20px;font-size:.8rem;color:var(--text-muted)}.login-hint strong{color:var(--color-cta-light)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:#0f172af2;-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-right:1px solid var(--border-glass);display:flex;flex-direction:column;z-index:40;transition:var(--transition)}.sidebar-header{padding:24px 20px;border-bottom:1px solid var(--border-glass)}.sidebar-logo{display:flex;align-items:center;gap:12px;font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--text-primary)}.sidebar-logo svg{color:var(--color-primary-light)}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;color:var(--text-muted);font-size:.9rem;font-weight:500;transition:var(--transition);cursor:pointer;text-decoration:none}.nav-item:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.nav-item.active{background:#2563eb26;color:var(--color-primary-light)}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border-glass);display:flex;align-items:center;gap:8px}.sidebar-user{flex:1;display:flex;align-items:center;gap:10px;min-width:0}.user-avatar{width:36px;height:36px;border-radius:10px;background:#2563eb26;color:var(--color-primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-info{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--text-muted)}.btn-logout{width:36px;height:36px;border:none;border-radius:10px;background:#ef44441a;color:#ef4444;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);flex-shrink:0}.btn-logout:hover{background:#ef444433}.mobile-menu-btn{display:none;position:fixed;top:16px;left:16px;z-index:50;width:44px;height:44px;border:none;border-radius:12px;background:#0f172ae6;-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--border-glass);color:var(--text-primary);align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.mobile-menu-btn:hover{background:var(--bg-glass-hover)}.mobile-close-btn{display:none;width:36px;height:36px;border:none;border-radius:10px;background:var(--bg-glass);color:var(--text-muted);align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.mobile-close-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.sidebar-overlay{display:none}@media(max-width:768px){.mobile-menu-btn,.mobile-close-btn{display:flex}.sidebar-header{display:flex;align-items:center;justify-content:space-between}.sidebar{transform:translate(-100%);width:280px}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:39;animation:fadeIn .2s ease}}.layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:32px;max-width:100%;overflow-x:hidden}.page-header{margin-bottom:32px}.page-header h1{font-size:1.6rem;margin-bottom:4px}.page-subtitle{color:var(--text-muted);font-size:.9rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:32px}.profile-section{padding:28px}.profile-section h2{font-size:1.1rem;margin-bottom:20px;color:var(--text-primary)}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.profile-item{display:flex;align-items:flex-start;gap:14px}.profile-item svg{color:var(--color-primary-light);margin-top:2px;flex-shrink:0}.profile-label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:2px}.profile-value{display:block;font-weight:500;color:var(--text-primary)}.report-status-section{margin-bottom:24px}.report-status-card{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;text-decoration:none;cursor:pointer;transition:var(--transition)}.report-status-card:hover{border-color:var(--color-primary);box-shadow:0 0 20px #2563eb26}.report-status-left{display:flex;align-items:center;gap:16px}.report-status-title{display:flex;align-items:center;font-family:var(--font-heading);font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.report-status-text{font-size:.85rem;color:var(--text-muted)}.report-status-action{display:flex;align-items:center;gap:8px;color:var(--color-primary-light);font-size:.85rem;font-weight:500}@media(max-width:768px){.main-content{margin-left:0;padding:72px 16px 20px}.stats-grid{grid-template-columns:1fr 1fr}.page-header h1{font-size:1.3rem}.report-status-card{flex-direction:column;align-items:flex-start;gap:12px}.profile-grid{grid-template-columns:1fr}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.admin-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.table-section{padding:0;overflow:hidden}.table-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-glass);flex-wrap:wrap;gap:12px}.table-header h2{font-size:1.05rem}.search-bar{display:flex;align-items:center;gap:8px;background:var(--bg-surface);border:1px solid var(--border-glass);border-radius:10px;padding:8px 14px;min-width:260px;transition:var(--transition)}.search-bar:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb33}.search-bar svg{color:var(--text-muted);flex-shrink:0}.search-bar input{border:none;background:none;color:var(--text-primary);outline:none;font-size:.9rem;width:100%}.search-bar input::placeholder{color:var(--text-muted)}.table-wrapper{overflow-x:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-header h2{font-size:1.15rem}.btn-close{width:36px;height:36px;border:none;border-radius:10px;background:var(--bg-glass);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.btn-close:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.modal-form{display:flex;flex-direction:column;gap:16px}.modal-hint{font-size:.8rem;color:var(--text-muted);text-align:center}.modal-hint strong{color:var(--color-cta-light)}.import-modal{max-width:680px}.import-body{display:flex;flex-direction:column;gap:20px}.import-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px 20px;border:2px dashed var(--border-glass);border-radius:14px;background:var(--bg-surface);cursor:pointer;transition:var(--transition);text-align:center}.import-dropzone:hover{border-color:var(--color-primary);background:#2563eb0d}.import-dropzone.has-file{border-color:var(--color-primary);border-style:solid;background:#2563eb14}.dropzone-icon{color:var(--text-muted);margin-bottom:4px}.has-file .dropzone-icon{color:var(--color-primary)}.dropzone-text{font-size:.95rem;color:var(--text-secondary);font-weight:500}.dropzone-filename{font-size:.95rem;color:var(--text-primary);font-weight:600}.dropzone-hint{font-size:.8rem;color:var(--text-muted)}.import-preview h3,.import-result h3{font-size:.95rem;margin-bottom:12px;color:var(--text-secondary)}.import-preview .table-wrapper{max-height:200px;overflow:auto;border-radius:10px;border:1px solid var(--border-glass)}.import-preview .data-table{font-size:.82rem}.import-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.import-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;border-radius:12px;background:var(--bg-surface);border:1px solid var(--border-glass)}.import-stat-success{color:#22c55e;border-color:#22c55e40;background:#22c55e14}.import-stat-skip{color:#f97316;border-color:#f9731640;background:#f9731614}.import-stat-error{color:#ef4444;border-color:#ef444440;background:#ef444414}.stat-number{font-size:1.5rem;font-weight:700}.stat-label{font-size:.8rem;opacity:.85}.import-errors{margin-top:12px;padding:14px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:10px}.import-errors h4{font-size:.85rem;color:#ef4444;margin-bottom:8px}.import-errors ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.import-errors li{font-size:.82rem;color:var(--text-secondary);padding-left:12px;position:relative}.import-errors li:before{content:"•";position:absolute;left:0;color:#ef4444}.import-actions{margin-top:4px}.btn-download-sample{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--color-primary);font-size:.85rem;cursor:pointer;padding:4px 0;opacity:.85;transition:var(--transition)}.btn-download-sample:hover{opacity:1;text-decoration:underline}@media(max-width:768px){.admin-header{flex-direction:column;align-items:flex-start}.search-bar{min-width:100%}.table-header{flex-direction:column;align-items:flex-start}.import-stats{grid-template-columns:1fr}}.report-status-banner{display:flex;align-items:center;gap:16px;padding:18px 24px;margin-bottom:20px;border-left:4px solid transparent;animation:slideUp .3s ease}.report-status-banner.status-submitted{border-left-color:#22c55e}.report-status-banner.status-pending{border-left-color:#f97316}.status-icon-wrap{display:flex;flex-shrink:0}.status-submitted .status-icon-wrap{color:#22c55e}.status-pending .status-icon-wrap{color:#f97316}.status-info{display:flex;flex-direction:column;gap:2px}.status-title{font-family:var(--font-heading);font-weight:600;font-size:.95rem;color:var(--text-primary)}.status-detail{display:flex;align-items:center;font-size:.82rem;color:var(--text-muted)}.report-form{display:flex;flex-direction:column;gap:16px}.report-question{padding:20px 24px}.report-question label{display:flex;align-items:center;gap:10px;font-family:var(--font-heading);font-weight:600;font-size:.9rem;color:var(--text-primary);margin-bottom:12px}.question-icon{color:var(--color-primary-light);display:flex;flex-shrink:0}.report-question textarea{width:100%;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border-glass);border-radius:12px;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;line-height:1.6;resize:vertical;outline:none;transition:var(--transition);min-height:80px}.report-question textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb33}.report-question textarea::placeholder{color:var(--text-muted)}.report-submit{align-self:flex-end;padding:14px 32px;font-size:1rem;margin-top:8px}@media(max-width:768px){.report-submit{width:100%;align-self:stretch}}.congrats-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .3s ease;cursor:pointer}.congrats-content{text-align:center;padding:48px 40px;background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:24px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);max-width:420px;width:90%;animation:congratsSlideUp .5s cubic-bezier(.34,1.56,.64,1);cursor:default}.congrats-icon{display:inline-flex;align-items:center;justify-content:center;width:100px;height:100px;border-radius:50%;background:#22c55e26;color:#22c55e;margin-bottom:24px;animation:congratsPulse 1.5s ease-in-out infinite}.congrats-title{font-family:var(--font-heading);font-size:1.8rem;font-weight:700;color:var(--text-primary);margin-bottom:12px}.congrats-message{font-size:1.05rem;color:var(--text-secondary);margin-bottom:8px;line-height:1.5}.congrats-sub{font-size:.85rem;color:var(--text-muted);margin-bottom:28px}.congrats-btn{padding:14px 40px;font-size:1rem;border-radius:14px}.confetti-container{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:201}.confetti-piece{position:absolute;top:-20px;left:var(--x);width:var(--size);height:var(--size);background:var(--color);border-radius:2px;animation:confettiFall var(--duration) var(--delay) ease-in forwards;transform:rotate(var(--rotation))}@keyframes confettiFall{0%{top:-20px;opacity:1;transform:rotate(0) scale(1)}to{top:110vh;opacity:0;transform:rotate(720deg) scale(.5)}}@keyframes congratsSlideUp{0%{opacity:0;transform:translateY(40px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes congratsPulse{0%,to{transform:scale(1);box-shadow:0 0 #22c55e4d}50%{transform:scale(1.05);box-shadow:0 0 0 16px #22c55e00}}.month-nav{display:flex;align-items:center;gap:12px;padding:14px 20px;margin-bottom:20px}.month-label{font-family:var(--font-heading);font-weight:600;font-size:1.05rem;color:var(--text-primary);text-transform:capitalize;min-width:160px;text-align:center}.btn-icon{background:var(--bg-surface);border:1px solid var(--border-glass);border-radius:10px;color:var(--text-secondary);padding:8px;cursor:pointer;display:flex;align-items:center;transition:var(--transition)}.btn-icon:hover{background:#2563eb26;color:var(--color-primary-light);border-color:var(--color-primary)}.btn-sm{font-size:.8rem;padding:6px 14px;border-radius:8px;background:#2563eb1f;border:1px solid rgba(37,99,235,.3);color:var(--color-primary-light);cursor:pointer;transition:var(--transition)}.btn-sm:hover{background:#2563eb40}.calendar-wrapper{padding:0;overflow:hidden}.calendar-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.calendar-scroll::-webkit-scrollbar{height:6px}.calendar-scroll::-webkit-scrollbar-track{background:transparent}.calendar-scroll::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.dept-chart-scroll{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}.dept-chart-scroll::-webkit-scrollbar{width:4px}.dept-chart-scroll::-webkit-scrollbar-track{background:transparent}.dept-chart-scroll::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:4px;transition:background .2s}.dept-chart-scroll::-webkit-scrollbar-thumb:hover{background:#ffffff40}.calendar-table{width:100%;border-collapse:collapse;min-width:1200px}.calendar-table th,.calendar-table td{text-align:center;padding:8px 4px;border-bottom:1px solid var(--border-glass);font-size:.78rem;white-space:nowrap}.calendar-table thead th{background:var(--bg-surface);color:var(--text-muted);font-weight:600;font-family:var(--font-heading);font-size:.72rem;position:sticky;top:0;z-index:2}.day-name{display:block;text-transform:uppercase;font-size:.6rem;letter-spacing:.5px;color:var(--text-muted)}.day-num{display:block;font-size:.82rem;font-weight:700;color:var(--text-secondary);margin-top:1px}.sticky-col{position:-webkit-sticky;position:sticky;left:0;background:var(--bg-surface);z-index:10;min-width:150px;text-align:left;padding-left:12px;box-shadow:2px 0 8px #0000004d}thead .sticky-col{z-index:12;background:var(--bg-surface)}.col-role{position:-webkit-sticky;position:sticky;left:150px;min-width:50px;text-align:center;padding-left:0;box-shadow:2px 0 8px #0000004d}.total-col{position:-webkit-sticky;position:sticky;right:0;background:var(--bg-surface);z-index:10;min-width:70px;font-family:var(--font-heading);box-shadow:-2px 0 8px #0000004d}thead .total-col{z-index:5;background:var(--bg-surface)}.emp-cell{overflow:hidden}.emp-name{display:block;font-weight:600;color:var(--text-primary);font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.emp-code{display:block;color:var(--text-muted);font-size:.68rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell{transition:var(--transition)}.cell.done{color:#22c55e}.cell.miss{color:#ef4444}.cell.future{color:var(--text-muted);opacity:.4}.cell-dot{width:8px;height:8px;border-radius:50%;background:var(--border-glass)}.future-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--border-glass)}.today-col{background:#2563eb14!important;border-left:2px solid rgba(37,99,235,.3);border-right:2px solid rgba(37,99,235,.3)}thead .today-col .day-num{color:var(--color-primary-light)}.weekend-col{background:#ffffff05}.weekend-col .day-name,.weekend-col .day-num{opacity:.5}.count-done{color:#22c55e;font-weight:700}.count-sep{color:var(--text-muted);margin:0 2px}.count-miss{color:#ef4444;font-weight:700}.admin-toggle{background:#ffffff0d;border:1px solid var(--border-glass);border-radius:8px;padding:6px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;transition:var(--transition)}.admin-toggle:hover{border-color:var(--color-primary)}.admin-toggle.is-admin{color:#22c55e;background:#22c55e1f;border-color:#22c55e4d}.calendar-legend{display:flex;gap:24px;padding:12px 0;justify-content:center}.legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted)}.legend-done{color:#22c55e}.legend-miss{color:#ef4444}.cell.clickable{cursor:pointer;transition:var(--transition)}.cell.clickable:hover{transform:scale(1.3);filter:brightness(1.3)}.report-detail-modal{max-width:560px}.report-detail-modal .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.report-detail-modal .modal-header h2{font-size:1.15rem;display:flex;align-items:center}.report-detail-modal .btn-close{width:36px;height:36px;border:none;border-radius:10px;background:var(--bg-glass);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.report-detail-modal .btn-close:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.report-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-glass)}.report-detail-name{font-family:var(--font-heading);font-weight:600;font-size:1.05rem;color:var(--text-primary)}.report-detail-date{font-size:.85rem;color:var(--text-muted)}.report-detail-time{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--text-muted);margin-left:auto}.report-detail-sections{display:flex;flex-direction:column;gap:16px}.report-section{padding:16px;background:#ffffff08;border:1px solid var(--border-glass);border-radius:12px}.report-section h3{font-size:.85rem;font-weight:600;margin-bottom:8px;color:var(--text-secondary)}.report-section p{font-size:.9rem;color:var(--text-primary);line-height:1.6;white-space:pre-wrap}@media(max-width:1024px){.calendar-table{min-width:1000px}.calendar-table th,.calendar-table td{padding:6px 3px;font-size:.72rem}.sticky-col{min-width:150px;width:150px;max-width:150px;padding-left:10px}.col-role{display:none}.emp-name{font-size:.78rem}.day-name{font-size:.55rem}.day-num{font-size:.75rem}}@media(max-width:768px){.calendar-table{min-width:900px}.sticky-col{min-width:130px;width:130px;max-width:130px;padding-left:8px}.col-role{display:none}.calendar-table th,.calendar-table td{padding:6px 2px;font-size:.7rem}.emp-name{font-size:.75rem}.emp-code,.day-name{display:none}.day-num{font-size:.72rem}.total-col{min-width:55px}.calendar-legend{gap:12px;font-size:.72rem}.report-detail-modal{max-width:100%}.report-detail-meta{flex-direction:column;align-items:flex-start}.report-detail-time{margin-left:0}}@media(max-width:480px){.calendar-table{min-width:800px}.sticky-col{min-width:120px;width:120px;max-width:120px}.col-role{display:none}.admin-toggle{padding:4px}.month-nav{padding:10px 12px;gap:8px}.month-label{font-size:.9rem;min-width:120px}}.date-picker-wrapper{display:flex;align-items:center;gap:8px;background:var(--bg-surface);border:1px solid var(--border-glass);border-radius:10px;padding:8px 14px}.date-picker-wrapper svg{color:var(--text-muted);flex-shrink:0}.date-picker{border:none;background:none;color:var(--text-primary);font-size:.9rem;font-family:var(--font-body);outline:none;cursor:pointer;color-scheme:dark}.qr-section{padding:28px;margin-bottom:24px;animation:slideUp .3s ease}.qr-content{display:flex;align-items:center;gap:32px}.qr-code-wrapper{padding:20px;background:var(--bg-surface);border-radius:16px;border:1px solid var(--border-glass);flex-shrink:0}.qr-info h3{font-size:1.1rem;margin-bottom:8px}.qr-info p{color:var(--text-muted);font-size:.9rem;margin-bottom:12px}.qr-url{background:var(--bg-surface);border:1px solid var(--border-glass);border-radius:8px;padding:10px 14px;margin-bottom:12px}.qr-url code{font-size:.85rem;color:var(--color-primary-light);word-break:break-all}.qr-hint{font-size:.8rem!important;color:var(--text-muted)!important;opacity:.7}.report-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.reports-list{display:flex;flex-direction:column;gap:12px}.report-card{padding:16px 20px;cursor:pointer}.report-card-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.report-employee{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.report-employee strong{font-size:.95rem}.report-time{font-size:.8rem;color:var(--text-muted)}.report-detail{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-glass);display:flex;flex-direction:column;gap:14px;animation:slideUp .2s ease}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-family:var(--font-heading);font-size:.8rem;font-weight:600;color:var(--color-primary-light)}.detail-item p{font-size:.9rem;color:var(--text-secondary);white-space:pre-wrap;line-height:1.5}@media(max-width:768px){.qr-content{flex-direction:column;text-align:center}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-icon{animation:spin 1s linear infinite}.link-loading-hint{font-size:.75rem;color:#3b82f6;font-weight:400;margin-left:8px}.group-name-cell{display:flex;flex-direction:column;gap:2px}.group-name-cell strong{color:var(--text-primary)}.group-desc{font-size:.8rem;color:var(--text-muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-id-code{background:#ffffff0f;padding:3px 8px;border-radius:4px;font-size:.78rem;color:var(--primary);font-family:Courier New,monospace;letter-spacing:.3px}.action-btns{display:flex;gap:6px}.btn-icon-danger{color:#ef4444!important}.btn-icon-danger:hover{background:#ef444426!important}.badge-red{background:#ef444426;color:#ef4444}.toggle-row{display:flex;gap:24px;margin:8px 0 16px;flex-wrap:wrap}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;color:var(--text-secondary);font-size:.9rem;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{display:none}.toggle-switch{width:40px;height:22px;background:#ffffff1a;border-radius:11px;position:relative;transition:background .25s;flex-shrink:0}.toggle-switch:after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:var(--text-muted);top:2px;left:2px;transition:all .25s}.toggle-label input:checked+.toggle-switch{background:#22c55e4d}.toggle-label input:checked+.toggle-switch:after{background:#22c55e;left:20px}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:10px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-danger:hover{filter:brightness(1.1);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--text-secondary);border:1px solid rgba(255,255,255,.12);padding:10px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-outline:hover{background:#ffffff0d;border-color:#fff3}.modal-sm{max-width:400px!important}
