@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap";*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:DM Sans,sans-serif;background:#f8fafc;color:#0f172a;line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:Bricolage Grotesque,sans-serif;font-weight:700;line-height:1.25;letter-spacing:-.02em}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none}button,input,select,textarea{font-family:DM Sans,sans-serif}img{max-width:100%;display:block}ol,ul{list-style:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app-shell{display:flex;min-height:100vh}.page-body{flex:1 1;padding:32px;max-width:1440px;width:100%;margin:0 auto}@media(max-width:1024px){.page-body{padding:24px}}@media(max-width:640px){.page-body{padding:16px}}.grid-2{grid-template-columns:repeat(2,1fr);grid-gap:24px}.grid-2,.grid-3{display:grid;gap:24px}.grid-3{grid-template-columns:repeat(3,1fr);grid-gap:24px}.grid-4{grid-template-columns:repeat(4,1fr);grid-gap:24px}.grid-4,.grid-auto{display:grid;gap:24px}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:24px}@media(max-width:1280px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@media(max-width:640px){.grid-auto{grid-template-columns:1fr}}.card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);padding:24px;transition:all .22s ease}.card:hover{box-shadow:0 4px 12px rgba(15,23,42,.08),0 2px 4px rgba(15,23,42,.04)}@media(max-width:640px){.card{padding:16px;border-radius:12px}}.btn{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;padding:9px 18px;border-radius:12px;font-size:14px;font-weight:600;transition:all .13s ease;white-space:nowrap;outline:none;font-family:DM Sans,sans-serif;letter-spacing:-.01em}.btn--primary{background:#2563eb;color:#fff;box-shadow:0 4px 16px rgba(37,99,235,.24)}.btn--primary:hover{background:#1d4ed8}.btn--secondary{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.btn--secondary:hover{background:#dbeafe}.btn--ghost{background:transparent;color:#475569;border:1px solid #e2e8f0}.btn--ghost:hover{background:#f1f5f9;border-color:#cbd5e1;color:#0f172a}.btn--danger{background:#fef2f2;color:#ef4444;border:1px solid #fecaca}.btn--danger:hover{background:#fee2e2}.btn--success{background:#10b981;color:#fff}.btn--success:hover{background:#0e9d6d}.btn--sm{padding:6px 13px;font-size:13px;border-radius:8px}.btn--lg{padding:12px 24px;font-size:15px}.btn--icon{padding:8px;border-radius:12px}.btn--icon-sm{padding:6px;border-radius:8px;font-size:15px}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}@media(max-width:640px){.btn--mobile-full{width:100%;justify-content:center}}.badge{display:inline-flex;align-items:center;gap:5px;border-radius:9999px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.02em;white-space:nowrap;border:1px solid transparent}.badge:before{content:"";width:6px;height:6px;border-radius:9999px;background:currentColor;opacity:.7;flex-shrink:0}.badge--accepted,.badge--active,.badge--approved,.badge--completed,.badge--counter_accepted,.badge--paid{background:#ecfdf5;color:#0d9367;border-color:#a7f3d0}.badge--pending,.badge--processing{background:#fffbeb;color:#bb7808;border-color:#fde68a}.badge--scheduled{background:#f0f9ff;color:#0b83b9;border-color:#bae6fd}.badge--counter_offered,.badge--in_progress{background:#f5f3ff;color:#6c23eb;border-color:#ddd6fe}.badge--cancelled,.badge--expired,.badge--inactive,.badge--terminated,.badge--unpaid{background:#f1f5f9;color:#94a3b8;border-color:#e2e8f0}.badge--counter_declined,.badge--declined,.badge--no_show,.badge--rejected{background:#fef2f2;color:#ef4444;border-color:#fecaca}.badge--on_leave{background:#f0f9ff;color:#0b83b9;border-color:#bae6fd}.badge--draft{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.badge--info{background:#f0f9ff;color:#0b83b9;border-color:#bae6fd}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border-radius:12px;border:1.5px solid #e2e8f0;background:#fff;color:#0f172a;font-size:14px;font-family:DM Sans,sans-serif;outline:none;transition:all .13s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.2)}.form-group input::placeholder,.form-group select::placeholder,.form-group textarea::placeholder{color:#94a3b8}@media(max-width:640px){.form-group input,.form-group select,.form-group textarea{padding:12px 14px;font-size:16px}}.form-group textarea{resize:vertical;min-height:88px}.form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath fill='%2394A3B8' d='M5 6L0 0h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:36px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:16px;gap:16px}@media(max-width:768px){.form-row{grid-template-columns:1fr}}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap::-webkit-scrollbar{width:5px;height:5px}.table-wrap::-webkit-scrollbar-track{background:transparent}.table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}.table-wrap::-webkit-scrollbar-thumb:hover{background:#94a3b8}.data-table{width:100%;border-collapse:collapse;min-width:500px}.data-table thead tr th{padding:10px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;text-align:left;white-space:nowrap;background:#f1f5f9;border-bottom:1px solid #e2e8f0}.data-table thead tr th:first-child{border-radius:8px 0 0 8px}.data-table thead tr th:last-child{border-radius:0 8px 8px 0}.data-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background all .13s ease}.data-table tbody tr:hover{background:#eff6ff}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr td{padding:13px 16px;font-size:14px;vertical-align:middle}.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.48);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;flex-direction:row;align-items:center;justify-content:center;animation:fadeIn .16s ease;padding:16px}@media(max-width:640px){.modal-overlay{padding:0;align-items:flex-end}}.modal-overlay .modal{background:#fff;border-radius:20px;box-shadow:0 8px 24px rgba(15,23,42,.1),0 4px 8px rgba(15,23,42,.05),0 0 0 1px #e2e8f0;width:100%;max-width:560px;max-height:92vh;overflow-y:auto}.modal-overlay .modal::-webkit-scrollbar{width:5px;height:5px}.modal-overlay .modal::-webkit-scrollbar-track{background:transparent}.modal-overlay .modal::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}.modal-overlay .modal::-webkit-scrollbar-thumb:hover{background:#94a3b8}.modal-overlay .modal{animation:slideUp .2s ease}.modal-overlay .modal--lg{max-width:740px}.modal-overlay .modal--sm{max-width:400px}@media(max-width:640px){.modal-overlay .modal{border-radius:20px 20px 0 0;max-height:95vh;max-width:100%;animation:sheetUp .22s ease}}.modal-overlay .modal__header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:16px;padding:24px 32px;border-bottom:1px solid #e2e8f0}.modal-overlay .modal__header h2{font-size:18px;font-weight:700}@media(max-width:640px){.modal-overlay .modal__header{padding:16px 24px}.modal-overlay .modal__header h2{font-size:16px}}.modal-overlay .modal__body{padding:32px}@media(max-width:640px){.modal-overlay .modal__body{padding:24px}}.modal-overlay .modal__footer{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:8px;padding:16px 32px 32px;border-top:1px solid #e2e8f0}@media(max-width:640px){.modal-overlay .modal__footer{padding:16px 24px;flex-wrap:wrap}.modal-overlay .modal__footer button{flex:1 1;justify-content:center}}.av{display:flex;flex-direction:row;align-items:center;justify-content:center;border-radius:12px;font-family:Bricolage Grotesque,sans-serif;font-weight:700;color:#fff;flex-shrink:0}.av--xs{width:28px;height:28px;font-size:10px}.av--sm{width:32px;height:32px;font-size:12px}.av--md{width:40px;height:40px;font-size:14px}.av--lg{width:52px;height:52px;font-size:18px}.av--xl{width:72px;height:72px;font-size:24px}.search-bar{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:8px;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;padding:8px 13px;transition:all .13s ease}.search-bar:focus-within{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.2)}.search-bar .si{color:#94a3b8;font-size:17px;flex-shrink:0}.search-bar input{border:none;background:none;outline:none;font-size:14px;color:#0f172a;width:100%}.search-bar input::placeholder{color:#94a3b8}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 32px;text-align:center}.empty-state .ei{font-size:44px;color:#94a3b8;opacity:.35}.empty-state h3{font-size:16px;font-weight:700;color:#475569}.empty-state p{font-size:14px;color:#94a3b8;max-width:280px}.spinner{width:20px;height:20px;border:2px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100vh}.page-loading .spinner{width:36px;height:36px;border-width:3px}.page-loading p{font-size:14px;color:#94a3b8}.flex-between{justify-content:space-between}.flex-between,.flex-center{display:flex;flex-direction:row;align-items:center}.flex-center{justify-content:center}.font-mono{font-family:JetBrains Mono,monospace!important}.text-blue{color:#2563eb!important}.text-success{color:#10b981!important}.text-danger{color:#ef4444!important}.text-warning{color:#f59e0b!important}.text-muted{color:#94a3b8!important}.divider{height:1px;background:#e2e8f0;margin:24px 0}.gap-sm{gap:8px}.gap-md{gap:16px}.mt-md{margin-top:16px}.mt-lg{margin-top:24px}.mb-lg{margin-bottom:24px}.full-w{width:100%}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}