*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{background:#0b1120;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.bg-slate-100{background-color:#f1f5f9}.overflow-auto{overflow:auto}aside.w-64{color:#e5e7eb}aside.w-64 h1{margin:0}.sidebar-link{display:block;padding:8px 10px;border-radius:6px;font-size:.85rem;color:#f9fafb;opacity:1;transition:background-color .18s ease,color .18s ease}.sidebar-link:hover{background-color:#1e293b}.sidebar-link-active{background-color:#1d4ed8;color:#fff;opacity:1}aside button:hover{cursor:pointer}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.space-y-1>*+*{margin-top:.25rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.grid{display:grid}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-white{color:#fff}.text-gray-200{color:#e5e7eb}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}main{background:#f1f5f9;color:#111827}main h1{margin:0 0 .75rem;font-size:1.35rem;font-weight:700;color:#0f172a}main h2{margin-top:0;font-size:1.1rem;font-weight:600;color:#111827}.text-[11px]{font-size:.6875rem}.border{border:1px solid #e5e7eb}.border-b{border-bottom:1px solid #e5e7eb}.border-blue-900{border-color:#1e3a8a}.rounded,.rounded-md{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.shadow{box-shadow:0 4px 12px #0f172a1f}.bg-white{background-color:#fff}.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-blue-700{background-color:#1d4ed8}.bg-blue-800{background-color:#1e40af}.card{background:#fff;border-radius:.5rem;border:1px solid #e5e7eb;padding:1rem;box-shadow:0 4px 10px #0f172a0f}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.card-title{font-size:.95rem;font-weight:600}.table{width:100%;border-collapse:collapse;font-size:.85rem}.table thead{background:#f3f4f6}.table th,.table td{padding:.5rem .65rem;text-align:left;border-bottom:1px solid #e5e7eb}.table th{font-weight:600;font-size:.8rem;color:#4b5563}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.4rem .75rem;font-size:.8rem;border-radius:.375rem;border:1px solid transparent;background:#e5e7eb;color:#111827;cursor:pointer;transition:background-color .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease}.btn:hover{background:#d1d5db}.btn-primary{background:#2563eb;color:#fff;border-color:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-danger{background:#dc2626;color:#fff;border-color:#b91c1c}.btn-danger:hover{background:#b91c1c}.btn-soft{background:#e5f0ff;color:#1d4ed8;border-color:transparent}.btn-soft:hover{background:#d0e2ff}input[type=text],input[type=number],input[type=password],input[type=date],select,textarea{font-size:.85rem;padding:.4rem .5rem;border-radius:.375rem;border:1px solid #d1d5db;outline:none;transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus,textarea:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.schedule-grid-container{background:#fff;border-radius:.5rem;border:1px solid #e5e7eb;overflow:hidden}.schedule-grid-header{background:#0f172a;color:#fff}.schedule-row{font-size:.75rem}.pending-card,.approved-card{background:#fff;border-radius:.75rem;border:1px solid #e5e7eb;box-shadow:0 6px 16px #0f172a1f;overflow:hidden}.text-muted{color:#6b7280;font-size:.8rem}.section{margin-bottom:1.5rem}@media (max-width: 1024px){aside.w-64{width:220px}}@media (max-width: 768px){aside.w-64{display:none}main{padding:1rem}}.excel-header{text-align:center;margin-bottom:10px}.excel-logo{height:70px;-o-object-fit:contain;object-fit:contain;margin-bottom:6px}.excel-title{font-size:30px;font-weight:800;margin:0;text-transform:uppercase}.excel-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:14px;font-family:Arial,sans-serif}.excel-table th,.excel-table td{border:2px solid #000;padding:3px 2px;text-align:center;vertical-align:middle;line-height:1.1}.excel-table thead th{background:#d9d9d9;color:#111;font-weight:700}.excel-header-employee,.excel-employee-cell{background:#cfcfcf;font-weight:700;text-align:left;padding-left:8px;width:150px}.excel-employee-cell{background:#e5e7eb}.excel-table tbody tr:nth-child(odd) td{background-color:#f7f7f7}.excel-table tbody tr:nth-child(2n) td{background-color:#fff}.excel-cell-off{background-color:#fff}.excel-cell-work{background-color:#eef0ff}.excel-table td,.excel-cell,.excel-cell-work,.excel-cell-off{color:#111827;opacity:1;font-weight:600}@media print{.excel-table{font-size:13px}.excel-table th,.excel-table td{padding:2px 1px;border:2px solid #000}}aside.w-64 *{color:#fff!important;opacity:1!important}.sidebar-link{color:#fff!important;opacity:1!important}.sidebar-link:hover{background:#1e293b!important;color:#fff!important}.sidebar-link-active{background:#1d4ed8!important;color:#fff!important;opacity:1!important}aside.w-64 p{color:#fff!important;opacity:1!important}.login-page{min-height:100vh;width:100%;background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;display:flex;align-items:center;justify-content:center}.login-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 0%,rgba(0,0,0,.35),transparent),radial-gradient(circle at 80% 100%,rgba(0,0,0,.4),transparent),#00000059}.login-content{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{width:320px;max-width:90vw;background:#0f172ae6;border-radius:1rem;padding:1.75rem 1.5rem;border:1px solid rgba(148,163,184,.5);box-shadow:0 18px 45px #0f172ae6;color:#e5e7eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-title{margin:0 0 .25rem;font-size:1.3rem;font-weight:700;letter-spacing:.08em;text-align:center;text-transform:uppercase}.login-subtitle{margin:0 0 1.25rem;font-size:.75rem;text-align:center;color:#9ca3af}.login-field{margin-bottom:.75rem}.login-label{display:block;margin-bottom:.25rem;font-size:.8rem;font-weight:500;color:#e5e7eb}.login-input{width:100%;border-radius:.5rem;border:1px solid rgba(148,163,184,.7);padding:.45rem .6rem;font-size:.8rem;background:#0f172ad9;color:#f9fafb;outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.login-input::-moz-placeholder{color:#6b7280}.login-input::placeholder{color:#6b7280}.login-input:focus{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6b3;background:#0f172af2}.login-button{width:100%;margin-top:.5rem;border-radius:999px;border:none;padding:.5rem .75rem;font-size:.8rem;font-weight:600;background:linear-gradient(135deg,#2563eb,#4f46e5);color:#f9fafb;cursor:pointer;box-shadow:0 10px 25px #2563eb8c;transition:transform .1s ease,box-shadow .1s ease,filter .15s ease}.login-button:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 14px 30px #2563eba6}.login-button:active{transform:translateY(0);box-shadow:0 8px 18px #2563eb80}.login-footer{margin-top:.75rem;font-size:.7rem;text-align:center;color:#9ca3af}.sch-cell-blocked{box-shadow:inset 0 0 0 1px #fecaca;position:relative}.sch-blocked-tag{position:absolute;top:2px;right:4px;font-size:9px;letter-spacing:.08em;font-weight:700;color:#b91c1c;background:#fee2e2f5;padding:1px 4px;border-radius:999px;text-transform:uppercase;pointer-events:none}@media (max-width: 768px){body{font-size:14px}main{padding:.75rem}.card{padding:.75rem}h1.text-lg,main h1{font-size:1.05rem}main h2{font-size:.95rem}.btn-block-mobile{width:100%}}.table-wrapper,.sch-table-container,.excel-table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrapper table,.sch-table-container table,.excel-table-wrapper table{width:100%}.sch-table-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.sch-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:.8rem}.sch-table th,.sch-table td{padding:3px 2px}@media (max-width: 768px){.sch-table{min-width:720px}}.excel-schedule-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.excel-table{min-width:720px}.sch-cell-blocked{background-color:#fee2e2!important;color:#b91c1c!important;font-weight:700!important}.app-sidebar{position:static}.app-mobile-header{display:none}.app-mobile-menu-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;border-radius:.5rem;border:1px solid #cbd5f5;background:#e5edff;font-size:.8rem;font-weight:500;color:#0f172a;cursor:pointer}.app-mobile-menu-icon{display:inline-flex;flex-direction:column;gap:2px}.app-mobile-menu-icon span{width:16px;height:2px;background:#0f172a;display:block}.app-mobile-header-right{text-align:right}.app-mobile-header-title{margin:0;font-size:.75rem;color:#6b7280}.app-mobile-header-user{margin:0;font-size:.7rem;color:#111827}@media (max-width: 768px){.app-sidebar{position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);transition:transform .2s ease-out;z-index:40}.app-sidebar.app-sidebar-open{transform:translate(0)}.app-mobile-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;background:#fff;box-shadow:0 1px 3px #0f172a1a}}.fixed{position:fixed}.inset-0{top:0;right:0;bottom:0;left:0}.inset-y-0{top:0;bottom:0}.left-0{left:0}.z-30{z-index:30}.z-40{z-index:40}.transform,.translate-x-0{transform:translate(0)}.-translate-x-full{transform:translate(-100%)}.transition-transform{transition:transform .2s ease-in-out}.duration-200{transition-duration:.2s}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;background:#fff;box-shadow:0 2px 6px #0f172a0f}.mobile-menu-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.8rem;border-radius:.5rem;border:1px solid #cbd5f5;background:#e5edff;color:#1d4ed8}.mobile-menu-icon{display:flex;flex-direction:column;justify-content:center;gap:2px}.mobile-menu-icon span{width:14px;height:2px;background:#1f2937;border-radius:999px}.mobile-header-right{text-align:right}.mobile-header-title{font-size:.7rem;color:#6b7280;margin:0}.mobile-header-user{font-size:.7rem;color:#111827;margin:0}.sidebar-close{border:none;background:transparent;color:#e5e7eb;font-size:1.2rem;line-height:1;cursor:pointer}@media (min-width: 768px){.md\:hidden{display:none!important}.md\:static{position:static!important}.md\:translate-x-0{transform:translate(0)!important}}.mobile-header-user-row{display:flex;align-items:center;gap:.35rem;justify-content:flex-end}.mobile-logout-btn{border:none;border-radius:999px;padding:.15rem .6rem;font-size:.7rem;font-weight:500;background:#fee2e2;color:#b91c1c;cursor:pointer}.mobile-logout-btn:hover{background:#fecaca}
