:root{--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #eff6ff;--sidebar-bg: #0c1017;--sidebar-active: #1e293b;--content-bg: #f8fafc;--text-main: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--white: #ffffff;--glass: rgba(255, 255, 255, .85);--shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--transition: all .3s cubic-bezier(.4, 0, .2, 1);--surface-soft: #f8fafc;--surface-muted: #f1f5f9;--surface-info: #eff6ff;--primary-soft: #eff6ff;--secondary-soft: #f5f3ff;--secondary-strong: #7c3aed;--success-soft: #ecfdf5;--success-strong: #059669;--danger-soft: #fef2f2;--danger-strong: #dc2626;--warning-soft: #fffbeb;--warning-strong: #d97706;--info-soft: #f0f9ff;--info-strong: #0369a1;--accent-soft: #fdf2f8;--accent-strong: #db2777}[data-theme=dark]{--primary: #3b82f6;--primary-hover: #2563eb;--primary-light: #0f172a;--primary-soft: #1e293b;--secondary-soft: #2e1065;--secondary-strong: #a78bfa;--sidebar-bg: #020617;--sidebar-active: #1e293b;--content-bg: #020617;--text-main: #e2e8f0;--text-muted: #94a3b8;--border: #1f2a3a;--white: #111827;--glass: rgba(17, 24, 39, .85);--shadow: 0 6px 20px rgba(0, 0, 0, .35);--shadow-lg: 0 16px 40px rgba(0, 0, 0, .45);--surface-soft: #0f172a;--surface-muted: #111827;--surface-info: #0b1a2f;--success-soft: #052e22;--success-strong: #34d399;--danger-soft: #3a1217;--danger-strong: #f87171;--warning-soft: #3a2a09;--warning-strong: #fbbf24;--info-soft: #082f49;--info-strong: #38bdf8;--accent-soft: #3b1230;--accent-strong: #f472b6}[data-theme=dark] input[type=date]{color-scheme:dark}[data-theme=dark] .form-input,[data-theme=dark] select.form-input{background:var(--surface-muted);color:var(--text-main);border-color:var(--border)}[data-theme=dark] select.form-input option{background:var(--white);color:var(--text-main)}[data-theme=light] input[type=date]{color-scheme:light}*{margin:0;padding:0;box-sizing:border-box;font-family:Outfit,sans-serif}body{background-color:var(--content-bg);color:var(--text-main);overflow-x:hidden;-webkit-font-smoothing:antialiased}img,video{max-width:100%;height:auto}input,select,textarea,button{color:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-spin{animation:spin 1s linear infinite}.skeleton{background:var(--surface-muted);background-image:linear-gradient(90deg,#fff0 0,#fff6,#fff0);background-size:200% 100%;animation:skeleton-shimmer 1.8s infinite linear;border-radius:8px}[data-theme=dark] .skeleton{background-image:linear-gradient(90deg,#fff0 0,#ffffff0d,#fff0)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.app-layout{display:flex;height:100vh;width:100vw;overflow:hidden}.main-section{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.content{flex:1;min-height:0;padding:clamp(16px,2.5vw,32px);overflow-y:auto;overflow-x:hidden;background-color:var(--content-bg)}.sidebar{width:260px;flex-shrink:0;min-height:0;background:var(--sidebar-bg);color:#fff;display:flex;flex-direction:column;padding:24px 16px;border-right:1px solid rgba(255,255,255,.05);box-shadow:4px 0 24px #0003;z-index:50;transition:var(--transition)}.sidebar-header{display:flex;align-items:center;gap:12px;padding:0 12px 32px}.sidebar-logo{width:36px;height:36px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb4d}.sidebar-title{font-size:20px;font-weight:700;letter-spacing:-.5px;text-transform:uppercase;color:#fff}.sidebar-nav{flex:1;min-height:0;display:flex;flex-direction:column;gap:4px;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:#94a3b8;text-decoration:none;font-weight:500;font-size:15px;transition:var(--transition)}.sidebar-item svg{width:20px;height:20px}.sidebar-item:hover{background:#ffffff0d;color:#fff}.sidebar-item.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #2563eb40}.sidebar-badge{margin-left:auto;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #ef44444d}.sidebar-item.active .sidebar-badge{background:#fff;color:var(--primary);box-shadow:none}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.05)}.sidebar-logout{width:100%;background:#ffffff0d;color:#fff;display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;cursor:pointer;border:none;font-weight:500;transition:var(--transition)}.sidebar-logout:hover{background:#dc2626;box-shadow:0 4px 12px #dc262633}.navbar{height:72px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 clamp(12px,2vw,24px);z-index:40}.navbar-left-cluster{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.theme-toggle{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:var(--white);color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.theme-toggle:hover{color:var(--primary);border-color:var(--primary)}.navbar-workspace{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.navbar-profile-wrapper{position:relative}.navbar-profile{display:flex;align-items:center;gap:12px;cursor:pointer;background:none;border:none;padding:4px 8px;border-radius:12px;transition:background .2s}.navbar-profile:hover{background:color-mix(in srgb,var(--white) 88%,#94a3b8 12%)}.navbar-profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:170px;background:var(--white);border-radius:12px;border:1px solid var(--border);box-shadow:0 10px 40px #0000001f;z-index:100;padding:8px 0;overflow:hidden}.navbar-profile-dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:11px 14px;font-size:14px;font-weight:500;color:var(--text-main);text-decoration:none;border:none;background:none;cursor:pointer;transition:background .15s;text-align:left}.navbar-profile-dropdown-item:hover{background:color-mix(in srgb,var(--white) 88%,#94a3b8 12%)}.navbar-profile-dropdown-item svg{color:var(--text-muted);flex-shrink:0}.navbar-theme-toggle-item{justify-content:flex-start;gap:12px}.navbar-theme-switch{width:40px;height:22px;border-radius:999px;background:var(--surface-muted);border:1px solid var(--border);display:inline-flex;align-items:center;padding:2px;transition:var(--transition);cursor:pointer}.navbar-theme-switch.on{background:color-mix(in srgb,var(--primary) 22%,var(--white) 78%);border-color:var(--primary)}.navbar-theme-switch-knob{width:18px;height:18px;border-radius:50%;background:var(--white);box-shadow:0 1px 3px #00000026;transform:translate(0);transition:var(--transition)}.navbar-theme-switch.on .navbar-theme-switch-knob{transform:translate(18px)}.navbar-profile-dropdown-divider{height:1px;background:var(--border);margin:4px 0}.navbar-profile-dropdown-logout:hover{background:#fef2f2;color:#dc2626}.navbar-profile-dropdown-logout svg{color:#dc2626}.navbar-user-info{text-align:right}.navbar-username{display:block;font-size:14px;font-weight:600;color:var(--text-main);line-height:1.2}.navbar-role{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.navbar-avatar{width:40px;height:40px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;box-shadow:0 4px 12px #2563eb33}.navbar-notice-trigger{width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--white);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);position:relative}.navbar-notice-trigger:hover{background:color-mix(in srgb,var(--white) 88%,#94a3b8 12%);color:var(--primary);border-color:var(--primary)}.navbar-notice-badge{position:absolute;top:6px;right:6px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.navbar-notice-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:380px;max-width:calc(100vw - 32px);max-height:420px;background:var(--white);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:100;display:flex;flex-direction:column;overflow:hidden}.navbar-notice-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--white) 90%,#94a3b8 10%)}.navbar-notice-title{font-size:16px;font-weight:800;color:var(--text-main);margin:0}.navbar-notice-list{overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;padding:8px;max-height:360px}.navbar-notice-list::-webkit-scrollbar{width:0;height:0}.navbar-notice-item{padding:14px 12px;border-radius:12px;margin-bottom:6px;transition:background .2s;word-break:break-word;overflow-wrap:break-word}.navbar-notice-item:hover{background:color-mix(in srgb,var(--white) 90%,#94a3b8 10%)}.navbar-notice-item.unread{background:color-mix(in srgb,var(--primary) 14%,var(--white) 86%);border-left:3px solid var(--primary)}.card{background:var(--white);border-radius:16px;padding:24px;border:1px solid var(--border);box-shadow:var(--shadow);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.page-header{margin-bottom:clamp(20px,4vw,32px);display:flex;flex-direction:column;gap:8px}.page-category{font-size:12px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;display:block}.page-title{font-size:clamp(1.375rem,3.5vw,2rem);font-weight:800;color:var(--text-main);letter-spacing:-1px;margin-bottom:4px}.page-desc{color:var(--text-muted);font-size:clamp(.875rem,1.5vw,1rem);line-height:1.5}.btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;font-weight:600;font-size:15px;cursor:pointer;border:none;transition:var(--transition)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px #2563eb40}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-success{background:var(--success-strong);color:#fff;border:1px solid transparent;box-shadow:0 4px 10px color-mix(in srgb,var(--success-strong) 35%,transparent)}.btn-success:hover{filter:brightness(.95);transform:translateY(-1px)}.btn-danger{background:var(--danger-strong);color:#fff;border:1px solid transparent;box-shadow:0 4px 10px color-mix(in srgb,var(--danger-strong) 35%,transparent)}.btn-danger:hover{filter:brightness(.95);transform:translateY(-1px)}.btn-secondary{background:var(--surface-muted);color:var(--text-main);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-soft)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;filter:none;box-shadow:none}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--sidebar-bg);padding:24px}.login-form-card{width:100%;max-width:460px;background:var(--white);border-radius:24px;padding:48px;box-shadow:0 20px 50px #0000004d;animation:slideUp .6s cubic-bezier(.2,0,0,1) forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:18px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-main);margin-bottom:6px;opacity:.9}.form-input{width:100%;height:42px;padding:0 14px;background:color-mix(in srgb,var(--white) 85%,#94a3b8 15%);border:1px solid transparent;border-radius:10px;font-size:14px;transition:var(--transition)}.form-input:focus{background:var(--white);border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb14}.data-table-container{background:var(--white);border-radius:16px;border:1px solid var(--border);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow);max-width:100%}.data-table{width:100%;min-width:520px;border-collapse:collapse}.data-table th{background:color-mix(in srgb,var(--white) 90%,#94a3b8 10%);padding:16px 24px;text-align:left;font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.data-table td{padding:18px 24px;font-size:15px;border-bottom:1px solid var(--border);color:var(--text-main)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background:color-mix(in srgb,var(--white) 90%,#94a3b8 10%)}.badge{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:700;text-transform:uppercase}.badge-success{background:#dcfce7;color:#15803d}.badge-warning{background:#fef9c3;color:#a16207}.badge-danger{background:#fee2e2;color:#b91c1c}.badge-info{background:#e0f2fe;color:#0369a1}[data-theme=dark] .badge-success{background:color-mix(in srgb,var(--success-soft) 88%,transparent);color:var(--success-strong)}[data-theme=dark] .badge-warning{background:color-mix(in srgb,var(--warning-soft) 88%,transparent);color:var(--warning-strong)}[data-theme=dark] .badge-danger{background:color-mix(in srgb,var(--danger-soft) 88%,transparent);color:var(--danger-strong)}[data-theme=dark] .badge-info{background:color-mix(in srgb,var(--info-soft) 88%,transparent);color:var(--info-strong)}.modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1200;padding:max(12px,env(safe-area-inset-top,0px)) max(12px,env(safe-area-inset-right,0px)) max(12px,env(safe-area-inset-bottom,0px)) max(12px,env(safe-area-inset-left,0px));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--white);border-radius:20px;padding:clamp(16px,4vw,24px);max-width:min(480px,100%);width:100%;max-height:min(92vh,100dvh - 24px);overflow-y:auto;box-shadow:var(--shadow-lg);position:relative;scrollbar-width:none;-ms-overflow-style:none}.modal-content::-webkit-scrollbar{display:none}.modal-close{position:absolute;top:12px;right:12px;background:transparent;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--text-muted)}.modal-close:hover{color:var(--text-main)}.login-landing-split{display:flex;width:100%;max-width:100vw;min-height:100vh;min-height:100dvh;background:#020617;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative;box-sizing:border-box;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}@media(min-width:1025px){.login-landing-split{position:fixed;inset:0;height:100vh;height:100dvh;overflow:hidden}}.landing-left{flex:1;position:relative;display:flex;flex-direction:column;justify-content:center;padding:80px;color:#fff;background:#020617;overflow:hidden}.landing-left:before{content:"";position:absolute;inset:0;background:radial-gradient(at 0% 0%,rgba(37,99,235,.15) 0px,transparent 50%),radial-gradient(at 100% 0%,rgba(56,189,248,.1) 0px,transparent 50%),radial-gradient(at 100% 100%,rgba(37,99,235,.1) 0px,transparent 50%),radial-gradient(at 0% 100%,rgba(29,78,216,.1) 0px,transparent 50%);z-index:1}.landing-left>*{position:relative;z-index:2}.landing-right{flex:1 1 50%;display:flex;align-items:center;justify-content:center;background:#f8fafc;padding:clamp(20px,4vw,40px);position:relative;border-left:1px solid #e2e8f0;min-width:0;width:100%}.login-form-card--light{width:100%;max-width:min(440px,100%);background:#fff!important;color:#0f172a;box-shadow:0 25px 50px -12px #00000014}.login-form-card--light .form-label{color:#334155}.login-form-card--light .form-input{background:#f8fafc;border:1px solid #e2e8f0;color:#0f172a}.login-form-card--light .form-input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.login-form-card--light .btn-primary{width:100%}.login-form-header{display:flex;flex-direction:column;align-items:center;margin-bottom:clamp(24px,5vw,40px);text-align:center}.login-form-logo{width:56px;height:56px;margin-bottom:20px;border-radius:14px;flex-shrink:0}.login-form-title{font-size:clamp(1.25rem,2vw,1.5rem);font-weight:800;color:#0f172a;margin:0}.login-form-subtitle{font-size:.875rem;color:#64748b;margin:.25rem 0 0;max-width:280px;line-height:1.45}.login-form-footer{margin-top:clamp(1.25rem,4vw,2rem);text-align:center}.login-form-compliance{display:flex;align-items:center;gap:8px;justify-content:center;flex-wrap:wrap;color:#64748b;font-size:clamp(11px,2.5vw,13px);padding:0 4px;line-height:1.4}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:56px;width:100%;max-width:640px}.feature-card{background:#ffffff05;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.05);border-radius:24px;padding:28px;transition:all .5s cubic-bezier(.16,1,.3,1);animation:fadeIn .8s ease-out forwards;opacity:0;box-shadow:0 4px 30px #0000001a}.feature-card:nth-child(1){animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.2s}.feature-card:nth-child(3){animation-delay:.3s}.feature-card:nth-child(4){animation-delay:.4s}.feature-card:hover{background:#ffffff0d;border-color:#ffffff26;transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #0003}.feature-icon-container{width:52px;height:52px;border-radius:14px;background:#2563eb26;display:flex;align-items:center;justify-content:center;color:#60a5fa;margin-bottom:20px;border:1px solid rgba(37,99,235,.2)}.feature-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#2563eb1a;color:#60a5fa;border-radius:100px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:24px;border:1px solid rgba(37,99,235,.2)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.login-landing-split{flex-direction:column}.landing-left{padding:60px 40px;flex:none;min-height:50vh}.landing-right{flex:1;background:#fff}.feature-grid{max-width:none}}@media(max-width:640px){.login-landing-split{min-height:100vh;min-height:100dvh}.landing-left{padding:28px 16px 32px;min-height:auto}.landing-right{padding:20px 16px max(28px,env(safe-area-inset-bottom,16px));border-left:none;border-top:1px solid #e2e8f0}.login-form-card{padding:clamp(20px,5vw,28px) clamp(16px,4vw,20px);border-radius:18px;box-shadow:0 16px 40px #0000001f}.feature-grid{grid-template-columns:1fr}}.responsive-stats-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;margin-bottom:32px}.responsive-stats-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;margin-bottom:32px}.responsive-two-col-wide{display:grid;grid-template-columns:1fr minmax(260px,380px);gap:clamp(20px,3vw,32px);align-items:start}.responsive-doc-layout{display:grid;grid-template-columns:minmax(0,min(100%,400px)) minmax(0,1fr);gap:clamp(16px,2.5vw,28px);align-items:stretch}.document-center-form-column{display:flex;flex-direction:column;gap:0;min-width:0}.document-center-form-card{padding:clamp(18px,2.2vw,22px)}.reports-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.reports-actions-span{grid-column:span 2}@media(max-width:480px){.reports-actions-grid{grid-template-columns:1fr}.reports-actions-span{grid-column:span 1}}.document-center-employee-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-main);margin-bottom:10px}.document-center-section-title{font-size:15px;font-weight:700;color:var(--text-main);margin:0 0 14px;letter-spacing:-.02em}.document-center-divider{height:1px;background:var(--border);margin:4px 0 18px;border:none}.document-center-form-card .form-label{font-size:13px;font-weight:600;color:var(--text-main);margin-bottom:8px}.document-center-form-card .form-input,.document-center-form-card select.form-input{min-height:44px;font-size:15px}.document-center-preview-shell{width:100%;max-width:100%;min-width:0;overflow:hidden;display:flex;justify-content:center;align-items:center;padding:0;background:var(--surface-soft);border-radius:16px;border:1px solid var(--border);box-shadow:inset 0 1px color-mix(in srgb,var(--white) 40%,transparent);height:100%;min-height:85vh;container-type:size}.document-center-a4-viewport{flex-shrink:0;overflow:hidden;border-radius:4px;box-shadow:0 4px 24px #0f172a14}.document-center-preview-paper{flex-shrink:0}@media(max-width:1100px){.document-center-preview-shell{height:70vh;min-height:400px;margin-top:24px;border-radius:12px}}@media(max-width:640px){.document-center-preview-shell{height:60vh;min-height:320px}}.layout-single-column{display:grid;grid-template-columns:minmax(0,1fr);gap:32px;align-items:start}.responsive-checkin-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,260px);gap:clamp(20px,3vw,32px)}.responsive-profile-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,360px);gap:clamp(20px,3vw,28px);align-items:start}.form-responsive-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-responsive-2-lg,.responsive-two-col-equal{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}.responsive-flex-chart{display:flex;align-items:center;justify-content:center;gap:clamp(20px,4vw,48px);flex-wrap:wrap}.responsive-flex-chart>div:first-child{flex:0 0 auto}.navbar-menu-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--surface-soft);color:var(--text-main);cursor:pointer;flex-shrink:0;transition:var(--transition)}.navbar-menu-toggle:hover{background:var(--surface-muted)}.sidebar-backdrop{display:none}.page-tabs-scroll{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid var(--border);padding-bottom:0;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:thin}.page-tabs-scroll>button{flex-shrink:0}.page-header-split{display:flex;flex-direction:column;align-items:stretch;gap:16px}.page-header-split .page-header-cta{width:100%}@media(min-width:640px){.page-header-split{flex-direction:row;justify-content:space-between;align-items:flex-start}.page-header-split .page-header-cta{flex-shrink:0;width:auto}}.page-header-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.page-header-actions .form-input[type=text],.page-header-actions input.form-input{flex:1 1 200px;min-width:0;max-width:100%}.notices-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(20px,4vw,36px);align-items:start}.notices-title-priority{display:grid;grid-template-columns:minmax(0,1fr) minmax(120px,180px);gap:16px}@media(max-width:900px){.notices-form-grid{grid-template-columns:1fr}}@media(max-width:520px){.notices-title-priority{grid-template-columns:1fr}}.notices-recipient-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2px}@media(max-width:480px){.notices-recipient-grid{grid-template-columns:1fr}}.notices-table-desktop{display:block}.notices-cards-mobile{display:none;padding:10px}.notices-mobile-card{border:1px solid var(--border);border-radius:12px;background:var(--white);padding:11px;cursor:pointer}.notices-mobile-card+.notices-mobile-card{margin-top:10px}.notices-mobile-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.notices-mobile-date{font-size:11px;color:var(--text-muted);font-weight:600}.notices-mobile-title{margin-top:6px;font-size:14px;font-weight:700;color:var(--text-main)}.notices-mobile-content{margin-top:4px;font-size:12px;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notices-mobile-meta{margin-top:8px;display:flex;justify-content:space-between;gap:8px;font-size:11px;color:var(--text-muted)}.notices-create-btn{min-height:40px;padding:0 18px;border-radius:10px;font-weight:700;display:inline-flex;align-items:center;gap:6px}.leaves-cta-btn{min-height:40px;white-space:nowrap}.notices-full-overlay{position:fixed;inset:0;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;display:flex;align-items:center;justify-content:center;padding:24px;box-sizing:border-box}.notices-full-overlay-panel{background:var(--white);color:var(--text-main);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow-lg);width:min(1100px,94vw);max-height:min(90dvh,calc(100vh - 24px));overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;padding:28px 28px 24px;box-sizing:border-box;position:relative}.notices-full-overlay-panel::-webkit-scrollbar{width:0;height:0}.notices-modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px}.notices-modal-close-btn{background:none;border:1px solid var(--border);border-radius:8px;width:32px;height:32px;padding:0;cursor:pointer;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.modal-panel-responsive{width:min(540px,calc(100vw - 24px));max-width:100%;max-height:min(90dvh,calc(100vh - 24px));overflow-y:auto;margin:auto}.modal-shell-mobile{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:max(12px,env(safe-area-inset-top,0px)) max(12px,env(safe-area-inset-right,0px)) max(12px,env(safe-area-inset-bottom,0px)) max(12px,env(safe-area-inset-left,0px));background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.employee-table-desktop{display:block}.employee-cards-mobile{display:none}.employee-mobile-card{border:1px solid var(--border);border-radius:14px;padding:14px;background:var(--white)}.employee-mobile-card+.employee-mobile-card{margin-top:10px}.employee-mobile-card-head{display:flex;align-items:center;gap:10px}.employee-mobile-name{font-size:14px;font-weight:700;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-mobile-email{margin-top:2px;display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-mobile-meta{margin-top:12px;display:flex;align-items:center;gap:8px}.employee-mobile-role{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-muted)}.employee-mobile-view-btn{margin-top:12px;width:100%;min-height:40px;border:1px solid var(--border);border-radius:10px;background:var(--surface-soft);color:var(--text-main);font-weight:600;cursor:pointer}.employee-mobile-details-list{display:grid;grid-template-columns:1fr;gap:10px}.employee-mobile-details-list>div{display:flex;justify-content:space-between;align-items:baseline;gap:10px;border-bottom:1px dashed var(--border);padding-bottom:8px}.employee-mobile-details-list span{font-size:12px;color:var(--text-muted)}.employee-mobile-details-list strong{font-size:13px;color:var(--text-main);text-align:right}.analytics-cards-mobile{display:none;padding:10px}.analytics-mobile-card{border:1px solid var(--border);border-radius:14px;background:var(--white);padding:10px 11px;box-shadow:0 4px 14px #0f172a0d}.analytics-mobile-card+.analytics-mobile-card{margin-top:10px}.analytics-mobile-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.analytics-mobile-head-left{display:flex;align-items:center;gap:10px;min-width:0}.analytics-mobile-avatar{width:34px;height:34px;background:var(--surface-muted);border-radius:10px;display:grid;place-items:center;font-size:13px;font-weight:700;color:var(--primary);flex-shrink:0}.analytics-mobile-identity{min-width:0}.analytics-mobile-name{font-weight:700;color:var(--text-main);font-size:13px;line-height:1.2}.analytics-mobile-badges{margin-top:8px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}.analytics-status-badge-corner{margin-left:auto;white-space:nowrap;flex-shrink:0}.analytics-mobile-grid{margin-top:8px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.analytics-mobile-grid>div{border:1px solid var(--border);background:var(--surface-soft);border-radius:8px;padding:6px 7px}.analytics-mobile-grid span{display:block;font-size:10px;color:var(--text-muted);margin-bottom:2px}.analytics-mobile-grid strong{font-size:11.5px;color:var(--text-main);font-weight:700}.attendance-filter-panel-v2{background:var(--white);padding:10px 14px;border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow-lg);width:fit-content;max-width:100%;transition:var(--transition);display:flex;align-items:center;gap:12px}.view-mode-tabs{display:flex;background:var(--surface-muted);padding:4px;border-radius:12px;gap:2px}.view-mode-tab{padding:8px 16px;border-radius:9px;font-size:13px;font-weight:700;color:var(--text-muted);background:transparent;border:none;cursor:pointer;transition:var(--transition)}.view-mode-tab:hover{color:var(--text-main)}.view-mode-tab.active{background:var(--white);color:var(--primary);box-shadow:0 2px 6px #0000000d}.filter-reset-btn{font-size:12px;font-weight:700;color:var(--text-muted);background:transparent;border:none;cursor:pointer;padding:4px 8px}.filter-reset-btn:hover{color:var(--danger-strong)}.view-mode-content{flex:1;min-width:0;animation:filterFadeIn .3s ease}@keyframes filterFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.filter-input-row{display:flex;gap:12px;align-items:center}.input-with-icon{position:relative;flex:1}.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-48%);color:var(--text-muted);pointer-events:none}.input-with-icon .form-input{padding-left:36px;height:44px;background:var(--surface-soft);border:1px solid var(--border);font-size:14px}.input-with-icon .form-input:focus{background:var(--white);border-color:var(--primary)}.range-row{gap:8px}.range-arrow{color:var(--text-muted);font-weight:700}@media(max-width:850px){.attendance-filter-panel-v2{flex-direction:column;align-items:stretch;width:100%}.view-mode-tabs{width:100%}.view-mode-tab{flex:1;text-align:center;padding:8px 2px;font-size:12px}.filter-input-row{flex-direction:column}.input-with-icon{width:100%}.range-row{flex-direction:row;flex-wrap:nowrap}.range-row .input-with-icon{flex:1}}.attendance-filter-clear{border:none;background:var(--primary-light);color:var(--primary);font-size:11px;font-weight:700;cursor:pointer;height:30px;border-radius:10px;padding:0 12px;white-space:nowrap}.leaves-table-desktop{display:block}.leaves-cards-mobile{display:none;padding:12px}.leaves-mobile-card{border:1px solid var(--border);border-radius:14px;background:var(--white);padding:12px;cursor:pointer}.leaves-mobile-card+.leaves-mobile-card{margin-top:10px}.leaves-mobile-head{display:flex;align-items:center;gap:10px}.leaves-mobile-head strong{color:var(--text-main);font-size:14px}.leaves-mobile-row{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:8px}.leaves-mobile-meta{margin-top:8px;font-size:12px;color:var(--text-muted)}.leaves-mobile-reason{margin-top:8px;font-size:13px;color:var(--text-main)}.departments-table-desktop{display:block}.departments-cards-mobile{display:none;padding:12px}.departments-mobile-card{border:1px solid var(--border);border-radius:14px;background:var(--white);padding:12px}.departments-mobile-card+.departments-mobile-card{margin-top:10px}.departments-mobile-head{display:flex;align-items:center;gap:10px}.departments-mobile-head strong{color:var(--text-main);font-size:14px}.departments-mobile-icon{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:var(--primary);background:var(--surface-soft);border:1px solid var(--border)}.departments-mobile-row{margin-top:10px;display:flex;align-items:center;justify-content:space-between}.departments-mobile-delete-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid var(--danger-soft);background:var(--danger-soft);color:var(--danger-strong);cursor:pointer}.leave-governance-stats{gap:14px;margin-bottom:20px}.leave-governance-stat-card{padding:14px 14px 12px;border-radius:12px}.leave-governance-stat-card:hover{transform:none;box-shadow:var(--shadow)}.leave-governance-stat-card>div:first-child{margin-bottom:4px!important;gap:10px!important}.leave-governance-stat-card>div:first-child>div{padding:6px!important;border-radius:7px!important}.leave-governance-stat-card>div:first-child>span{font-size:12px!important}.leave-governance-stat-card>div:nth-child(2){font-size:32px!important;line-height:1!important}.leave-governance-stat-card>p{margin-top:2px!important;font-size:11px!important}.leaves-tabs-scroll{border-bottom:none;padding-bottom:0;gap:8px;overflow-x:visible;flex-wrap:nowrap}.leaves-tab-btn{border:1px solid var(--border);background:var(--surface-soft);color:var(--text-muted);border-radius:10px;padding:8px 11px;font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:5px;max-width:none;flex:1 1 0;min-width:0;justify-content:center}.leaves-tab-btn.is-active{border-color:var(--primary);background:var(--surface-info);color:var(--primary)}[data-theme=dark] .leaves-tab-btn{background:var(--surface-muted);color:var(--text-main)}[data-theme=dark] .leaves-tab-btn.is-active{background:color-mix(in srgb,var(--surface-info) 85%,var(--surface-muted) 15%);border-color:var(--primary)}.leaves-tab-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaves-tab-count{color:#fff;font-size:10px;font-weight:800;padding:2px 7px;border-radius:999px;margin-left:2px}.leaves-tab-count-warning{background:var(--warning)}.leaves-tab-count-primary{background:var(--primary)}.leaves-history-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding:20px 20px 0}.leaves-history-title{display:flex;align-items:center;gap:8px}.leaves-history-filters{display:grid;grid-template-columns:140px 100px 160px;gap:10px}.leaves-history-filter{height:38px;border-radius:10px;font-size:13px;font-weight:600}@media(max-width:1100px){.responsive-two-col-wide,.responsive-doc-layout{grid-template-columns:1fr}}@media(max-width:900px){.responsive-stats-3{grid-template-columns:1fr}.responsive-stats-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:520px){.responsive-stats-4{grid-template-columns:1fr}}@media(max-width:960px){.responsive-checkin-layout,.responsive-profile-body{grid-template-columns:1fr}}@media(max-width:640px){.form-responsive-2,.form-responsive-2-lg,.responsive-two-col-equal{grid-template-columns:1fr}.employee-table-desktop{display:none}.employee-cards-mobile{display:block;padding:10px}.analytics-table-desktop,.leaves-table-desktop,.notices-table-desktop,.departments-table-desktop{display:none}.analytics-cards-mobile,.leaves-cards-mobile,.notices-cards-mobile,.departments-cards-mobile{display:block}.departments-cta-btn{width:auto!important;min-width:150px;align-self:flex-end}.leaves-cta-btn{width:auto!important;min-width:170px;align-self:flex-end}.notices-create-btn{width:auto!important;min-width:132px;align-self:flex-end}.notices-full-overlay{padding:10px;align-items:center}.notices-full-overlay-panel{width:min(520px,calc(100vw - 20px));max-height:min(92dvh,calc(100vh - 20px));padding:16px 14px 14px;border-radius:12px}.notices-modal-header{margin-bottom:14px;gap:8px}.notices-modal-close-btn{width:30px;height:30px}.analytics-mobile-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.attendance-filter-panel{padding:10px}.attendance-filter-label{font-size:11px}.attendance-filter-controls{gap:7px}.attendance-filter-date,.attendance-filter-month,.attendance-filter-year{min-width:0;width:100%}.leaves-tabs-scroll{gap:6px;overflow-x:visible;flex-wrap:nowrap}.leaves-tab-btn{max-width:none;flex:1 1 0;min-width:0;padding:7px 6px;font-size:10px;border-radius:9px;gap:4px}.leaves-tab-count{display:none}.leave-governance-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px}.leave-governance-stat-card{padding:10px 11px 9px;border-radius:10px}.leave-governance-stat-card>div:first-child>span{font-size:11px!important}.leave-governance-stat-card>div:nth-child(2){font-size:24px!important}.leave-governance-stat-card>p{font-size:10px!important}.leaves-history-header{padding:14px 12px 0;gap:10px}.leaves-history-filters{width:100%;display:flex;flex-wrap:nowrap;gap:6px}.leaves-history-filter{flex:1 1 0;width:auto;min-width:0;height:36px;font-size:11px}}@media(max-width:520px){.leave-governance-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:420px){.attendance-filter-row-2{grid-template-columns:1fr}.analytics-mobile-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.leaves-tab-btn{max-width:none;flex:1 1 0;min-width:0;font-size:9.5px;gap:4px;padding:6px 5px}.leaves-tab-btn svg{width:12px;height:12px}.leaves-tab-count{font-size:9px;padding:1px 6px}.leaves-history-filters{display:flex;flex-wrap:nowrap;gap:6px}}.responsive-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,160px),1fr));gap:clamp(16px,3vw,24px);margin-bottom:32px}.responsive-stats-row-lg{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr));gap:clamp(16px,3vw,24px);margin-bottom:32px}.responsive-tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,160px),1fr));gap:16px}.projects-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:32px;flex-wrap:wrap}.projects-search-wrap{position:relative;flex:1 1 220px;min-width:0;max-width:min(100%,400px)}.projects-grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:24px}.reports-actions-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}.reports-actions-grid .reports-actions-span{grid-column:span 2}@media(max-width:1023px){.app-layout{height:100vh;height:100dvh;max-height:100dvh}.content{padding-bottom:max(16px,env(safe-area-inset-bottom,0px))}.sidebar-item{min-height:46px;padding-top:13px;padding-bottom:13px}.navbar-notice-trigger{min-width:44px;min-height:44px}.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(280px,88vw);max-width:100%;z-index:1100;transform:translate(-100%);transition:transform .25s ease;box-shadow:none}.app-layout.sidebar-mobile-open .sidebar{transform:translate(0);box-shadow:8px 0 32px #00000047}.sidebar-backdrop{display:block;position:fixed;inset:0;z-index:1090;background:#0f172a73;border:none;padding:0;margin:0;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s ease}[data-theme=dark] .sidebar-backdrop{background:#0000008c}.app-layout.sidebar-mobile-open .sidebar-backdrop{opacity:1;pointer-events:auto}.navbar-menu-toggle{display:inline-flex}.navbar{height:auto;min-height:56px;padding:10px clamp(10px,2vw,16px);gap:8px;flex-wrap:nowrap}.navbar-workspace{flex:1;min-width:0;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-profile-dropdown{right:0;left:auto;width:min(240px,calc(100vw - 12px));min-width:0;max-width:calc(100vw - 12px);top:calc(100% + 6px);border-radius:10px;padding:6px 0}.navbar-notice-dropdown{right:0;left:auto;width:min(360px,calc(100vw - 16px));max-width:calc(100vw - 16px)}}@media(min-width:1024px){.sidebar-backdrop{display:none!important}}@media(max-width:480px){.navbar-user-info{display:none}.navbar-profile{gap:6px;padding:6px 8px}.navbar-profile-dropdown{width:min(220px,calc(100vw - 10px));max-width:calc(100vw - 10px);right:0;top:calc(100% + 5px)}.navbar-profile-dropdown-item{padding:9px 10px;font-size:12px;gap:9px}.navbar-theme-toggle-item{justify-content:space-between}.navbar-theme-switch{width:52px;height:24px}.navbar-theme-switch-knob{width:18px;height:18px}.navbar-theme-switch.on .navbar-theme-switch-knob{transform:translate(28px)}.data-table{min-width:440px}.data-table th,.data-table td{padding:10px 12px;font-size:13px}.card{padding:clamp(16px,4vw,24px)}.page-tabs-scroll>button{padding:10px 14px;font-size:13px}.reports-actions-grid{grid-template-columns:1fr}.reports-actions-grid .reports-actions-span{grid-column:span 1}.btn{min-height:44px;padding-left:16px;padding-right:16px}}@media(hover:none)and (max-width:1023px){.card:hover{transform:none;box-shadow:var(--shadow)}}.recharts-responsive-container{max-width:100%!important}.attendance-left-stack{display:flex;flex-direction:column;gap:28px}.attendance-hero{display:flex;align-items:center;justify-content:space-between;gap:18px}.attendance-hero-main{display:flex;align-items:center;gap:22px;min-width:0}.attendance-hero-time{min-width:0}.attendance-hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.attendance-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.attendance-history-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:14px;flex-wrap:wrap}.attendance-history-filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.attendance-history-range{display:flex;gap:8px;align-items:center}.attendance-table-desktop{display:block}.attendance-cards-mobile{display:none}.attendance-mobile-card{border:1px solid var(--border);border-radius:12px;background:var(--white);padding:12px}.attendance-mobile-card+.attendance-mobile-card{margin-top:10px}.attendance-mobile-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.attendance-mobile-top strong{color:var(--text-main);font-size:13px}.attendance-mobile-grid{margin-top:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.attendance-mobile-grid span{display:block;font-size:11px;color:var(--text-muted);margin-bottom:3px}.attendance-mobile-grid strong{font-size:12px;color:var(--text-main)}.attendance-mobile-empty{border:1px dashed var(--border);border-radius:12px;padding:14px;color:var(--text-muted);font-size:13px;text-align:center}@media(max-width:640px){.attendance-left-stack{gap:16px}.attendance-hero{padding:14px!important;gap:12px;flex-direction:column;align-items:stretch}.attendance-hero-main{gap:12px}.attendance-hero-main>div:first-child{padding:12px!important;border-radius:14px!important}.attendance-hero-main h2{font-size:30px!important;line-height:1}.attendance-hero-main span{font-size:12px!important}.attendance-hero-actions{width:100%;justify-content:flex-start}.attendance-hero-actions .btn-primary,.attendance-hero-actions button{min-height:40px;padding:10px 14px!important;border-radius:10px!important;font-size:13px!important}.attendance-hero-actions-live{width:100%;justify-content:space-between;flex-wrap:wrap}.attendance-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.attendance-stats-grid .card{padding:10px 10px 9px!important;border-radius:10px}.attendance-stats-grid .card h3{font-size:24px!important}.attendance-history-toolbar{margin-bottom:12px;gap:8px}.attendance-history-toolbar h2{font-size:22px!important}.attendance-history-filters{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}.attendance-history-filters>div,.attendance-history-filters>select{min-width:0!important;width:100%!important}.attendance-history-range{grid-column:1 / -1;display:grid;grid-template-columns:1fr auto 1fr;gap:6px}.attendance-table-desktop{display:none}.attendance-cards-mobile{display:block}.attendance-mobile-grid{grid-template-columns:1fr;gap:6px}}@media(max-width:420px){.attendance-stats-grid{grid-template-columns:1fr 1fr;gap:8px}.attendance-hero-main h2{font-size:31px!important}}@media(max-width:640px){.navbar-notice-dropdown{position:fixed;top:64px;right:8px;left:auto;width:min(340px,calc(100vw - 16px));max-width:calc(100vw - 16px);max-height:min(58dvh,calc(100vh - 120px));border-radius:12px}.navbar-notice-header{padding:12px 14px}.navbar-notice-title{font-size:15px}.navbar-notice-list{padding:8px;max-height:min(48dvh,calc(100vh - 170px))}.navbar-notice-item{padding:11px 10px;border-radius:10px;margin-bottom:5px}}@media(max-width:420px){.navbar-notice-dropdown{top:60px;right:6px;width:min(320px,calc(100vw - 12px));max-width:calc(100vw - 12px);max-height:min(54dvh,calc(100vh - 130px))}}.calendar-layout-wrapper{display:flex;gap:24px;height:calc(100vh - 240px);min-height:600px}.calendar-grid-card{flex:3;display:flex;flex-direction:column;background:var(--white);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.calendar-sidebar-card{flex:1;background:var(--white);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow);display:flex;flex-direction:column;padding:24px}.calendar-header-modern{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.calendar-nav-controls{display:flex;align-items:center;gap:12px}.calendar-grid-header{display:grid;grid-template-columns:repeat(7,1fr);background:var(--surface-muted);border-bottom:1px solid var(--border)}.calendar-weekday{padding:12px 0;text-align:center;font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.calendar-grid-body{flex:1;display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:auto}.calendar-day-cell{min-height:100px;padding:10px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--white);transition:var(--transition);cursor:pointer;display:flex;flex-direction:column;gap:4px}.calendar-day-cell:nth-child(7n){border-right:none}.calendar-day-cell:hover{background:var(--surface-soft)}.calendar-day-cell.is-outside{background:var(--surface-muted);opacity:.5}.calendar-day-cell.is-selected{background:var(--primary-light);box-shadow:inset 0 0 0 2px var(--primary)}.calendar-day-cell.is-today .day-number{background:var(--primary);color:#fff}.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.day-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:14px;font-weight:700;transition:var(--transition)}.cell-event-badge{font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:3px solid transparent}.sidebar-date-hero{margin-bottom:24px}.sidebar-date-hero h3{font-size:24px;font-weight:800;color:var(--text-main);margin-bottom:4px}.sidebar-event-list{display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex:1}.sidebar-event-card{padding:14px;border-radius:12px;border:1px solid var(--border);transition:var(--transition);cursor:pointer}.sidebar-event-card:hover{border-color:var(--primary)}.sidebar-empty{text-align:center;padding-top:40px;color:var(--text-muted)}@media(max-width:1000px){.calendar-layout-wrapper{flex-direction:column;height:auto}}.attendance-filter-panel-v2{display:flex;flex-wrap:wrap;align-items:center;gap:16px;background:var(--white);padding:6px;border:1px solid var(--border);border-radius:12px;min-height:48px;box-shadow:var(--shadow-sm);transition:all .3s ease}.view-mode-tabs{display:flex;background:#f1f5f9;padding:4px;border-radius:8px;gap:4px}.view-mode-tab{padding:6px 14px;font-size:13px;font-weight:700;color:#64748b;border-radius:6px;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);background:transparent}.view-mode-tab.active{background:var(--white);color:var(--primary);box-shadow:0 1px 3px #0000001a}.view-mode-tab:hover:not(.active){color:var(--primary);background:#6366f10d}.view-mode-content{display:flex;align-items:center}.filter-input-row{display:flex;align-items:center;gap:10px}.range-row{gap:6px}.input-with-icon{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:10px;color:var(--primary);pointer-events:none;opacity:.7}.input-with-icon .form-input{padding-left:32px;height:36px!important;font-size:13px;font-weight:600;border-radius:8px;background:#f8fafc;min-width:120px}.single-field .form-input{min-width:160px}.range-arrow{color:#94a3b8;font-weight:700;font-size:14px}.filter-reset-btn{padding:6px 14px;font-size:13px;font-weight:700;color:#ef4444;background:#fef2f2;border:1px solid #fee2e2;border-radius:8px;cursor:pointer;transition:all .2s ease}.filter-reset-btn:hover{background:#fee2e2;transform:translateY(-1px)}.analytics-table-desktop{display:block}.analytics-cards-mobile{display:none;padding:16px}@media(max-width:900px){.analytics-table-desktop{display:none}.analytics-cards-mobile{display:block}}.analytics-mobile-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:16px;margin-bottom:16px;box-shadow:var(--shadow-sm);position:relative;transition:transform .2s ease,box-shadow .2s ease}.analytics-mobile-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.analytics-mobile-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.analytics-mobile-head-left{display:flex;align-items:center;gap:12px}.analytics-mobile-avatar{width:40px;height:40px;background:var(--primary-soft);color:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}.analytics-mobile-identity{display:flex;flex-direction:column}.analytics-mobile-name{font-weight:800;color:var(--text-main);font-size:15px}.analytics-status-badge-corner{font-size:11px;font-weight:800;padding:4px 8px;border-radius:6px}.analytics-mobile-badges{display:flex;gap:6px;margin-bottom:16px}.analytics-mobile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-top:12px;border-top:1px dashed var(--border)}.analytics-mobile-grid div{display:flex;flex-direction:column;gap:4px}.analytics-mobile-grid span{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.02em}.analytics-mobile-grid strong{font-size:14px;color:var(--text-main);font-weight:800}@media(max-width:768px){.attendance-filter-panel-v2{width:100%;border-radius:12px;box-shadow:none}.attendance-filter-panel-v2>div{flex-direction:column!important;align-items:stretch!important;padding:12px!important;gap:12px!important}.attendance-filter-panel-v2 div[style*="flex: 1"]{max-width:100%!important;min-width:0!important}.view-mode-tabs{width:100%;justify-content:space-between!important;margin-left:0!important;background:#f1f5f9}.view-mode-tab{flex:1;text-align:center;padding:8px 4px}.view-mode-content{justify-content:center!important;margin-left:auto!important;width:100%}.filter-input-row{width:100%;justify-content:center}.filter-reset-btn{width:100%;margin-top:4px}}@keyframes zoomIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes checkmarkPulse{0%{transform:scale(1);box-shadow:0 0 #10b98166}70%{transform:scale(1.05);box-shadow:0 0 0 20px #10b98100}to{transform:scale(1);box-shadow:0 0 #10b98100}}.animate-zoom-in{animation:zoomIn .3s cubic-bezier(.34,1.56,.64,1) forwards}.success-checkmark-wrapper{position:relative;width:80px;height:80px}.success-checkmark-circle{width:80px;height:80px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:checkmarkPulse 2s infinite}@layer components{.snackbar-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(100px);z-index:1000;opacity:0;transition:all .4s cubic-bezier(.175,.885,.32,1.275);pointer-events:none;width:max-content;max-width:90vw}.snackbar-container.visible{transform:translate(-50%) translateY(0);opacity:1;pointer-events:all}.snackbar-content{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;min-width:320px}.snackbar-icon-wrapper{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:#ffffff1a}.snackbar-message{flex:1;font-size:14px;font-weight:600;color:var(--text-main)}.snackbar-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.snackbar-close:hover{background:#0000000d;color:var(--text-main)}.snackbar-success .snackbar-icon-wrapper{background:var(--success-soft);color:var(--success-strong)}.snackbar-error .snackbar-icon-wrapper{background:var(--danger-soft);color:var(--danger-strong)}.snackbar-warning .snackbar-icon-wrapper{background:var(--warning-soft);color:var(--warning-strong)}.snackbar-info .snackbar-icon-wrapper{background:var(--info-soft);color:var(--info-strong)}.text-success{color:var(--success-strong)}.text-error{color:var(--danger-strong)}.text-warning{color:var(--warning-strong)}.text-info{color:var(--info-strong)}}@keyframes scaleUp{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-slow{0%,to{opacity:1}50%{opacity:.6}}
