*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{background:#f0f4f8;color:#111827;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app,body{min-height:100vh}.app{background:#fff;display:flex;flex-direction:column;margin:0 auto;max-width:480px}@media(min-width:481px){.app{box-shadow:0 0 24px #00000014}}.container{flex:1 1;padding:16px 16px calc(88px + env(safe-area-inset-bottom, 0px))}.section-title{color:#374151;font-size:15px;font-weight:700;margin-bottom:12px}.header{align-items:center;background:#12b7ad;box-shadow:0 2px 6px #0000001f;color:#fff;display:flex;justify-content:space-between;padding:14px 16px;position:sticky;top:0;z-index:10}.header__name{font-size:15px;font-weight:800;letter-spacing:-.2px}.header__email{font-size:11px;margin-top:2px;opacity:.5}.header__clock{text-align:right}.header__clock-time{font-size:15px;font-weight:700;letter-spacing:.5px}.header__clock-date{font-size:10px;margin-top:2px;opacity:.7}.footer{background:#fff;border-top:1px solid #e5e7eb;bottom:0;box-shadow:0 -2px 10px #00000012;display:flex;left:50%;max-width:480px;padding-bottom:env(safe-area-inset-bottom,0);position:fixed;transform:translateX(-50%);width:100%;z-index:20}.footer__item{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:3px;justify-content:center;padding:10px 0;transition:color .18s}.footer__item--active{color:#12b7ad}.footer__icon{font-size:20px;line-height:1}.footer__label{font-size:11px;font-weight:600}.btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 16px;text-align:center;transition:opacity .18s}.btn:disabled{cursor:not-allowed;filter:grayscale(.3);opacity:.25}.btn-primary:not(:disabled):hover{opacity:.88}.btn-secondary{background:#3b82f6;color:#fff}.btn-secondary:not(:disabled):hover{opacity:.88}.btn-danger{background:#ef4444}.btn-danger:not(:disabled):hover{opacity:.88}.btn-outline{background:#0000;border:1.5px solid #12b7ad;color:#12b7ad}.btn-outline:hover{background:#f0fdfb}.btn-sm{font-size:13px;padding:6px 12px}.btn-locked{background:#0000;border:1.5px solid #e5e7eb;color:#9ca3af;cursor:pointer}.btn-locked:hover{background:#fafafa}.action-bar{display:flex;gap:10px;margin-bottom:20px}.action-bar .btn{flex:1 1}.input-btn-wrap{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:4px}.input-btn-wrap .btn{width:100%}.input-btn-hint{color:#9ca3af;font-size:11px;font-style:italic}.month-card{align-items:center;border:1px solid #e5e7eb;border-left-width:4px;border-radius:10px;box-shadow:0 2px 8px #00000014;cursor:pointer;display:flex;gap:12px;margin-bottom:10px;padding:14px 16px;transition:box-shadow .18s,background .18s,border-left-color .18s}.month-card:hover{background:#f9fafb;box-shadow:0 6px 18px #0000001f}.month-card--current{background:#f0fdfb;border-left-color:#12b7ad}.month-card--current:hover{background:#e6faf8}.month-card__left{flex:1 1;min-width:0}.month-card__name{color:#111827;font-size:15px;font-weight:600;margin-bottom:4px}.month-card__badge{background:#ccfbf1;border-radius:99px;color:#0f766e;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px}.month-card__right{flex-shrink:0;text-align:right}.month-card__qty{color:#111827;font-size:22px;font-weight:800;line-height:1}.month-card__unit{color:#9ca3af;font-size:11px;font-weight:500;margin-top:2px}.month-card__arrow{color:#12b7ad;flex-shrink:0;font-size:26px;font-weight:700;line-height:1;opacity:.85;padding-left:4px}.empty-state{padding:48px 24px}.empty-state__icon{font-size:48px}.empty-state__title{font-size:16px;font-weight:700;margin-bottom:6px}.empty-state__desc{line-height:1.5}.modal-overlay{align-items:flex-end;background:#0000007a;inset:0;z-index:100}.modal{background:#fff;border-radius:16px 16px 0 0;max-height:92vh;max-width:480px;overflow-y:auto;width:100%}.modal__header{align-items:center;background:#fff;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:16px 16px 12px;position:sticky;top:0;z-index:1}.modal__header h2{font-size:17px;font-weight:700}.modal__close{background:none;border:none;color:#6b7280;cursor:pointer;font-size:20px;line-height:1;padding:2px 6px}.modal__body{padding:16px}.modal__subtitle{color:#6b7280;font-size:13px;margin-bottom:14px}.modal__actions{display:flex;gap:10px;margin-top:20px;padding-bottom:4px}.modal__actions .btn{flex:1 1}.detail-summary{background:#f0fdfb;border-radius:8px;color:#374151;font-size:14px;margin-bottom:14px;padding:10px 12px}.detail-list{display:flex;flex-direction:column;gap:10px}.detail-item{align-items:center;border:1px solid #e5e7eb;border-radius:10px;display:flex;gap:12px;padding:12px}.detail-item__img{border-radius:8px;flex-shrink:0;height:54px;object-fit:cover;width:54px}.detail-item__img--clickable{cursor:zoom-in;transition:transform .15s,box-shadow .15s}.detail-item__img--clickable:hover{box-shadow:0 4px 12px #0000002e;transform:scale(1.06)}.detail-item__img-placeholder{background:#f3f4f6;border-radius:8px;flex-shrink:0;height:54px;width:54px}.detail-item__info{flex:1 1;min-width:0}.detail-item__jenis{color:#111827;font-size:14px;font-weight:600}.detail-item__qty{color:#6b7280;font-size:13px;margin-top:3px}.form-group{margin-bottom:16px}.form-group label{color:#374151;display:block;font-size:13px;margin-bottom:6px}.form-group input[type=number],.form-group input[type=tel],.form-group input[type=text],.form-group input[type=url],.form-group select,.form-group textarea{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;outline:none;padding:10px 12px;transition:border-color .18s;width:100%}.form-group input[type=number]:focus,.form-group input[type=tel]:focus,.form-group input[type=text]:focus,.form-group input[type=url]:focus,.form-group select:focus,.form-group textarea:focus{border-color:#12b7ad}.form-group input[type=number].error,.form-group input[type=tel].error,.form-group input[type=text].error,.form-group input[type=url].error,.form-group select.error,.form-group textarea.error{border-color:#ef4444}.form-group input[type=number]:disabled,.form-group input[type=tel]:disabled,.form-group input[type=text]:disabled,.form-group input[type=url]:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.form-group textarea{line-height:1.5;min-height:80px}.form-group input[type=file]{color:#6b7280;font-size:13px;margin-top:2px}.form-group .form-optional{color:#9ca3af;font-size:12px;font-weight:400}.error-msg{color:#ef4444;display:block;font-size:12px;margin-top:4px}.img-preview{border:1px solid #e5e7eb;border-radius:8px;margin-top:10px;max-height:180px;object-fit:cover;width:100%}.photo-picker{align-items:center;background:#f3f4f6;border:2px dashed #e5e7eb;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:20px 16px;transition:border-color .18s,background .18s;width:100%}.photo-picker:active,.photo-picker:hover{background:#f0fdfb;border-color:#12b7ad}.photo-picker__icon{font-size:32px;line-height:1}.photo-picker__label{color:#374151;font-size:14px;font-weight:600}.photo-picker__sub{color:#9ca3af;font-size:11px}.photo-picker__preview-wrap{border-radius:10px;overflow:hidden;position:relative;width:100%}.photo-picker__preview{border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:block;max-height:200px;object-fit:cover;width:100%}.photo-picker__remove{align-items:center;background:#0000008c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:13px;height:28px;justify-content:center;position:absolute;right:8px;top:8px;transition:background .15s;width:28px}.photo-picker__remove:hover{background:#000000bf}.photo-picker__change{background:#f0fdfb;border:1.5px solid #12b7ad;border-radius:8px;color:#12b7ad;cursor:pointer;display:block;font-size:13px;font-weight:600;margin-top:6px;padding:8px;text-align:center;transition:background .18s;width:100%}.photo-picker__change:hover{background:#e6faf8}.img-lightbox{animation:fadeIn .18s ease;background:#000000e0;inset:0;padding:24px;position:fixed;z-index:300}.img-lightbox,.img-lightbox__close{align-items:center;display:flex;justify-content:center}.img-lightbox__close{background:#ffffff1f;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:20px;height:40px;position:absolute;right:16px;top:16px;transition:background .15s;width:40px}.img-lightbox__close:hover{background:#ffffff38}.img-lightbox__img{animation:zoomIn .2s ease;border-radius:10px;box-shadow:0 8px 40px #00000080;max-height:80vh;max-width:100%;object-fit:contain}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.lp{background:#0ea59c;display:flex;flex-direction:column;margin:0 auto;max-width:480px;min-height:100vh;overflow:hidden;position:relative}.lp__circle{background:#ffffff14;border-radius:50%;pointer-events:none;position:absolute}.lp__circle--1{height:260px;right:-80px;top:-80px;width:260px}.lp__circle--2{height:180px;left:-60px;top:120px;width:180px}.lp__hero{flex:0 0 auto;flex-direction:column;padding:40px 24px 28px;position:relative;text-align:center;z-index:1}.lp__hero,.lp__logo-wrap{align-items:center;display:flex;justify-content:center}.lp__logo-wrap{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff2e;border-radius:24px;box-shadow:0 8px 24px #0000001f;height:88px;margin-bottom:18px;width:88px}.lp__logo{font-size:44px;line-height:1}.lp__title{color:#fff;font-size:28px;font-weight:800;letter-spacing:-.3px;margin-bottom:6px}.lp__subtitle{color:#ffffffc7;font-size:14px;letter-spacing:.2px}.lp__sheet{background:#fff;border-radius:28px 28px 0 0;box-shadow:0 -8px 32px #0000001a;padding:30px 24px 36px;position:relative;z-index:1}.lp__heading{color:#111827;font-size:20px;font-weight:700;margin-bottom:4px}.lp__desc{color:#9ca3af;font-size:13px;margin-bottom:24px}.lp__error{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#dc2626;font-size:13px;font-weight:500;gap:8px;margin-bottom:16px;padding:10px 14px}.lp__error,.lp__field{align-items:center;display:flex}.lp__field{background:#f9fafb;border:2px solid #d1d5db;border-radius:12px;margin-bottom:14px;padding:0 14px;transition:border-color .18s,box-shadow .18s,background .18s}.lp__field:focus-within{background:#fff;border-color:#12b7ad;box-shadow:0 0 0 4px #12b7ad26}.lp__field-icon{flex-shrink:0;font-size:18px;margin-right:10px;opacity:.85}.lp__input{background:#0000;border:none;color:#111827;flex:1 1;font-size:14px;outline:none;padding:14px 0}.lp__input::placeholder{color:#9ca3af}.lp__eye{background:none;flex-shrink:0;font-size:16px;opacity:.6;padding:4px}.lp__btn,.lp__eye{border:none;cursor:pointer}.lp__btn{align-items:center;background:linear-gradient(135deg,#0ea59c,#0a7c75);border-radius:12px;box-shadow:0 6px 20px #0a7c7573;color:#fff;display:flex;font-size:15px;font-weight:700;justify-content:center;letter-spacing:.5px;margin-top:8px;min-height:52px;padding:15px;transition:opacity .18s,transform .12s,box-shadow .12s;width:100%}.lp__btn:not(:disabled):hover{box-shadow:0 8px 24px #0a7c7580;opacity:.95;transform:translateY(-2px)}.lp__btn:not(:disabled):active{box-shadow:0 3px 10px #0a7c7559;transform:translateY(0)}.lp__btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.45}.lp__spinner{animation:spin .7s linear infinite;border:2.5px solid #ffffff59;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.lp__hint{color:#9ca3af;font-size:12px;line-height:1.6;margin-top:18px;text-align:center}.lp__mock-section{margin-top:20px}.lp__mock-divider{align-items:center;color:#9ca3af;display:flex;font-size:12px;gap:10px;margin-bottom:14px}.lp__mock-divider:after,.lp__mock-divider:before{background:#e5e7eb;content:"";flex:1 1;height:1px}.lp__mock-btn{align-items:center;background:#f0fdfb;border:2px dashed #12b7ad;border-radius:12px;color:#0d9488;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:13px;transition:background .18s,border-color .18s;width:100%}.lp__mock-btn:hover{background:#e6faf8;border-color:#0d9488}.lp__mock-hint{margin-top:8px;text-align:center}.lp__mock-hint code{background:#f3f4f6;border-radius:99px;color:#9ca3af;font-family:monospace;font-size:11px;padding:3px 10px}.profile-view{flex-direction:column;gap:0;padding:28px 0 0}.profile-avatar,.profile-view{align-items:center;display:flex}.profile-avatar{background:linear-gradient(135deg,#12b7ad,#0d9488);border-radius:50%;box-shadow:0 0 0 4px #12b7ad2e,0 8px 24px #12b7ad40;color:#fff;font-size:36px;font-weight:800;height:84px;justify-content:center;margin-bottom:12px;width:84px}.profile-name{color:#111827;font-size:20px;font-weight:700;margin-bottom:4px}.profile-email{color:#9ca3af;font-size:13px;margin-bottom:24px}.profile-section-label{color:#9ca3af;font-size:11px;font-weight:700;letter-spacing:.8px;padding:0 4px 8px;text-transform:uppercase;width:100%}.profile-card{border:1px solid #e5e7eb;border-radius:10px;margin-bottom:20px;overflow:hidden;width:100%}.profile-card__row{align-items:center;background:#fff;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:14px 16px}.profile-card__row:last-child{border-bottom:none}.profile-card__row--action{cursor:pointer;transition:background .18s}.profile-card__row--action:hover{background:#f0fdfb}.profile-card__label{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:500;gap:8px}.profile-card__value{color:#6b7280;font-size:13px;max-width:60%;text-align:right;word-break:break-all}.profile-card__chevron{color:#9ca3af;font-size:22px;line-height:1}.profile-logout{align-items:center;background:#fff5f5;border:1.5px solid #fca5a5;border-radius:10px;color:#dc2626;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;margin-bottom:8px;padding:14px;transition:background .18s,border-color .18s;width:100%}.profile-logout:hover{background:#fee2e2;border-color:#f87171}.profile-footer-space{height:16px}.profile-edit-btn,.profile-edit-form{margin-bottom:16px;width:100%}.profile-edit-form{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px}.profile-edit-form .form-group{margin-bottom:14px}.profile-edit-form .form-group label{color:#374151;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.profile-edit-form .form-group input[type=tel],.profile-edit-form .form-group input[type=text]{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;outline:none;padding:10px 12px;transition:border-color .18s;width:100%}.profile-edit-form .form-group input[type=tel]:focus,.profile-edit-form .form-group input[type=text]:focus{border-color:#12b7ad}.profile-edit-form .form-group input[type=tel].error,.profile-edit-form .form-group input[type=text].error{border-color:#ef4444}.profile-edit-actions{display:flex;gap:10px;margin-top:14px}.profile-edit-actions .btn{flex:1 1}@keyframes fadeInUp{0%{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.toast{animation:fadeInUp .25s ease;background:#1f2937;border-radius:99px;bottom:calc(88px + env(safe-area-inset-bottom, 0px));box-shadow:0 4px 16px #0003;color:#fff;font-size:13px;font-weight:500;left:50%;padding:11px 20px;position:fixed;transform:translateX(-50%);white-space:nowrap;z-index:200}.badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:700;letter-spacing:.4px;padding:4px 11px;text-transform:uppercase}.badge--draft{background:#fef3c7;color:#92400e}.badge--submitted{background:#dbeafe;color:#1d4ed8}.badge--approved{background:#d1fae5;color:#065f46}.badge--rejected{background:#fee2e2;color:#991b1b}.badge--active{background:#d1fae5;color:#065f46}.badge--inactive{background:#f1f5f9;color:#475569}.loading-state{align-items:center;color:#64748b;display:flex;flex-direction:column;font-size:14px;gap:14px;justify-content:center;padding:60px 20px}.loading-state__spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{padding:48px 20px;text-align:center}.empty-state__icon{font-size:40px;margin-bottom:12px}.empty-state__title{color:#374151;font-size:15px;font-weight:600;margin-bottom:4px}.empty-state__desc{color:#9ca3af;font-size:13px}.breadcrumb{align-items:center;color:#64748b;display:flex;font-size:13px;gap:6px;margin-bottom:20px}.breadcrumb__item--link{color:#6366f1;cursor:pointer}.breadcrumb__item--link:hover{text-decoration:underline}.breadcrumb__item--current{color:#374151;font-weight:500}.breadcrumb__sep{color:#cbd5e1}.tabs{border-bottom:2px solid #e5e7eb;display:flex;margin-bottom:16px}.tab-btn{background:none;border:none;border-bottom:2px solid #0000;color:#9ca3af;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;margin-bottom:-2px;padding:10px 12px;transition:color .18s,border-color .18s}.tab-btn--active{border-bottom-color:#12b7ad;color:#12b7ad}.tab-btn:hover:not(.tab-btn--active){color:#374151}.pagination{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-top:16px;padding:8px 0}.pagination__info{color:#9ca3af;flex-shrink:0;font-size:13px;text-align:center}.admin-layout{background:#f0f4f8;display:flex;min-height:100vh}.admin-layout__main{display:flex;flex:1 1;flex-direction:column;margin-left:240px;min-width:0}.admin-layout__content{flex:1 1;max-width:1280px;padding:28px 32px}.admin-sidebar{background:#fff;border-right:1px solid #e5e7eb;bottom:0;display:flex;flex-direction:column;left:0;min-height:100vh;position:fixed;top:0;width:240px;z-index:100}.admin-sidebar__brand{align-items:center;background:#12b7ad;border-bottom:none;display:flex;gap:10px;padding:18px 20px}.admin-sidebar__logo{flex-shrink:0;font-size:22px;line-height:1}.admin-sidebar__title{color:#fff;font-size:15px;font-weight:700;letter-spacing:.3px}.admin-sidebar__nav{flex:1 1;padding:8px 0}.admin-sidebar__item{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:11px 20px;position:relative;text-align:left;text-decoration:none;transition:background .15s,color .15s;width:100%}.admin-sidebar__item:hover{background:#f0fdfb;color:#0d9488}.admin-sidebar__item--active{background:#e0f7f5;color:#0d9488;font-weight:600}.admin-sidebar__item--active:before{background:#12b7ad;border-radius:0 3px 3px 0;content:"";display:block;height:100%;left:0;position:absolute;top:0;width:4px}.admin-sidebar__icon{font-size:15px;text-align:center;width:20px}.admin-sidebar__footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:16px 20px}.admin-sidebar__user-name{color:#374151;font-size:13px;font-weight:600;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-sidebar__user-role{color:#9ca3af;font-size:11px;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.admin-sidebar__logout{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:7px 12px;width:100%}.admin-sidebar__logout:hover{background:#dc2626}.admin-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;min-height:64px;padding:0 24px;position:sticky;top:0;z-index:50}.admin-header__left{display:flex;flex-direction:column;gap:2px;justify-content:center}.admin-header__title{color:#374151;font-size:17px;font-weight:700;line-height:1.3;margin:0}.admin-header__subtitle{color:#9ca3af;font-size:12px;font-weight:400;margin:0}.admin-header__user{align-items:center;display:flex;gap:10px}.admin-header__avatar{align-items:center;background:#12b7ad;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.admin-header__user-info{text-align:right}.admin-header__user-name{color:#374151;font-size:13px;font-weight:600;line-height:1.3}.admin-header__user-role{color:#9ca3af;font-size:11px;letter-spacing:.5px;text-transform:uppercase}.admin-page__subtitle{color:#6b7280;font-size:14px;margin-bottom:24px}.admin-page__meta{color:#6b7280;font-size:13px;margin-bottom:12px}.admin-section-title{color:#374151;font-size:15px;font-weight:600;margin:24px 0 12px}.admin-summary-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));margin-bottom:32px}.admin-summary-card{background:#fff;border-left:4px solid #12b7ad;border-radius:12px;box-shadow:0 2px 8px #00000014,0 1px 2px #0000000a;padding:22px 20px 18px;transition:box-shadow .15s,transform .15s}.admin-summary-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-1px)}.admin-summary-card__value{color:#111827;font-size:36px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:6px}.admin-summary-card__label{color:#9ca3af;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase}.admin-table-wrap{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000012;overflow-x:auto}.admin-table{border-collapse:collapse;font-size:14px;width:100%}.admin-table td,.admin-table th{padding:13px 16px;text-align:left}.admin-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#9ca3af;font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase}.admin-table tbody tr{border-bottom:1px solid #f3f4f6}.admin-table tbody tr:nth-child(2n){background:#fafafa}.admin-table tbody tr:hover{background:#f0fdfb}.admin-table__row--clickable{cursor:pointer;transition:background .1s}.admin-table__row--clickable:hover td{color:#0d9488}.admin-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px;margin-top:8px}.admin-section-header .admin-section-title{color:#111827;font-size:16px;font-weight:700;margin:0}.admin-pagination{align-items:center;display:flex;gap:16px;justify-content:center;margin-top:20px}.admin-pagination button{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;font-size:13px;padding:6px 14px}.admin-pagination button:hover:not(:disabled){background:#f0fdfb;border-color:#12b7ad;color:#0d9488}.admin-pagination button:disabled{color:#d1d5db;cursor:default}.admin-pagination span{color:#6b7280;font-size:13px}.admin-btn-link{align-items:center;background:#f0fdfb;border:1px solid #a7f3d0;border-radius:6px;color:#0d9488;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:6px 14px;text-decoration:none;transition:background .15s,border-color .15s}.admin-btn-link:hover{background:#ccfbf1;border-color:#12b7ad}.admin-role-tag{background:#ccfbf1;border-radius:4px;color:#0f766e;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.3px;padding:2px 8px;text-transform:uppercase}.admin-detail-card{align-items:center;background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000f;display:flex;gap:16px;margin-bottom:24px;padding:20px}.admin-detail-card__avatar{align-items:center;background:#12b7ad;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:22px;font-weight:700;height:52px;justify-content:center;width:52px}.admin-detail-card__name{color:#374151;font-size:18px;font-weight:700;margin-bottom:4px}.admin-detail-card__email{color:#6b7280;font-size:13px;margin-bottom:8px}.dash-root{display:flex;flex-direction:column}.dash-mid-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 280px;margin-bottom:28px}@media(max-width:1024px){.dash-mid-grid{grid-template-columns:1fr 1fr}}@media(max-width:640px){.dash-mid-grid{grid-template-columns:1fr}}.dash-card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000f;padding:20px}.dash-card__title{color:#9ca3af;font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.dash-empty-chart{align-items:center;color:#d1d5db;display:flex;font-size:14px;height:200px;justify-content:center}.dash-quick-actions{display:flex;flex-direction:column}.dash-qa-grid{grid-gap:10px;display:grid;flex:1 1;gap:10px;grid-template-columns:1fr 1fr}.dash-qa-btn{align-items:center;background:#f8fffe;border:1.5px solid #e0f7f5;border-radius:10px;box-shadow:0 1px 3px #0000000d;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:6px;justify-content:center;padding:14px 8px;transition:background .15s,border-color .15s,transform .15s,box-shadow .15s}.dash-qa-btn:hover{background:#e0f7f5;border-color:#12b7ad;box-shadow:0 6px 16px #12b7ad2e;transform:scale(1.04)}.dash-qa-btn:active{transform:scale(.98)}.dash-qa-icon{font-size:1.4rem;line-height:1}.dash-qa-label{color:#374151;font-size:11px;font-weight:600;line-height:1.3;text-align:center}.gender-badge{border-radius:99px;display:inline-block;font-size:.78rem;font-weight:600;padding:.25rem .65rem;white-space:nowrap}.gender-badge--female{background:#fce7f3;color:#be185d}.gender-badge--male{background:#dbeafe;color:#1d4ed8}.gender-badge--all{background:#f0f0f0;color:#666}.uniform-name-cell{display:flex;flex-direction:column;gap:.15rem}.uniform-name-cell .uniform-code{color:#12b7ad;font-size:.78rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.uniform-name-cell .uniform-name{color:#1a3a42;font-size:.95rem;font-weight:600}.uniform-name-cell .uniform-sub{color:#6b7280;font-size:.75rem;letter-spacing:.1px}.status-badge{border-radius:99px;display:inline-block;font-size:.78rem;font-weight:600;padding:.25rem .65rem;white-space:nowrap}.status-badge--active{background:#d1fae5;color:#065f46}.status-badge--inactive{background:#fee2e2;color:#991b1b}.search-icon-wrap{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;flex:1 1 220px;gap:.5rem;min-width:180px;padding:0 .75rem}.search-icon-wrap:focus-within{border-color:#12b7ad;box-shadow:0 0 0 2px #12b7ad26}.search-icon-wrap .search-icon{color:#9ca3af;display:block;flex-shrink:0;line-height:0}.search-icon-wrap input{background:#0000;border:none!important;box-shadow:none!important;color:#374151;font-size:.875rem;outline:none!important;padding:.55rem 0;width:100%}.search-icon-wrap input::placeholder{color:#9ca3af}.filter-select{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;padding:.6rem .75rem}.filter-select:focus{border-color:#12b7ad;outline:none}.text-muted{color:#6b7280;font-size:.9rem}.desc-truncate{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-name-cell strong{color:#1a3a42;font-size:.95rem}.form-section-label{border-bottom:1px solid #e8f8f7;color:#12b7ad;font-size:.75rem;font-weight:700;letter-spacing:1px;margin-top:.5rem;padding-bottom:.4rem;text-transform:uppercase}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}@media(max-width:500px){.form-row{grid-template-columns:1fr}}.uniforms-table tbody tr:hover{background:#f0fdfb}.uniforms-table td{padding:.85rem 1rem;vertical-align:middle}.page-container{margin:0 auto;max-width:1400px;padding:2rem}.page-container .page-header{margin-bottom:2rem}.page-container .page-header h1{color:#1a3a42;font-size:2rem;margin-bottom:.5rem}.page-container .page-header p{color:#666;font-size:.95rem}.page-container .page-controls{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.page-container .table-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;overflow:hidden}.page-container .data-table{border-collapse:collapse;width:100%}.page-container .data-table thead{background:#f8f9fa;border-bottom:2px solid #e0e0e0}.page-container .data-table th{color:#1a3a42;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.page-container .data-table td{border-bottom:1px solid #f0f0f0;color:#333;padding:1rem}.page-container .data-table tbody tr{transition:background-color .2s}.page-container .data-table tbody tr:hover{background-color:#f9f9f9}.page-container .data-table strong{color:#1a3a42}.page-container .pagination{align-items:center;display:flex;gap:1rem;justify-content:center;margin-top:2rem}.page-container .pagination button{background:#fff;border:1px solid #ddd;border-radius:4px;color:#1a3a42;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .2s}.page-container .pagination button:hover:not(:disabled){background:#12b7ad;border-color:#12b7ad;color:#fff}.page-container .pagination button:disabled{cursor:not-allowed;opacity:.5}.page-container .pagination span{color:#666;font-size:.9rem}.page-container .error-message{background:#ffe0e0;border-radius:4px;color:#c00;margin:1rem 0;padding:1rem}.page-container .success-message{background:#e0ffe0;border-radius:4px;color:#060;margin:1rem 0;padding:1rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-overlay .modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 40px #00000026;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;width:100%}.modal-overlay .modal-content h2{color:#1a3a42;font-size:1.5rem;margin-bottom:1.5rem}.modal-overlay .modal-content form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{color:#1a3a42;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;color:#333;font-family:inherit;font-size:.95rem;padding:.75rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#12b7ad;box-shadow:0 0 0 3px #12b7ad1a;outline:none}.form-group input::placeholder,.form-group select::placeholder,.form-group textarea::placeholder{color:#999}.form-group textarea{min-height:120px;resize:vertical}.form-actions{display:flex;gap:1rem;margin-top:1rem}.form-actions button{flex:1 1}.btn-danger,.btn-info,.btn-primary,.btn-secondary,.btn-sm{border:none;border-radius:4px;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-danger:disabled,.btn-info:disabled,.btn-primary:disabled,.btn-secondary:disabled,.btn-sm:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#12b7ad;color:#fff}.btn-primary:hover:not(:disabled){background:#0d9b92;box-shadow:0 4px 12px #12b7ad4d}.btn-secondary{background:#f0f0f0;color:#1a3a42}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.btn-info{background:#4a90e2;color:#fff;font-size:.85rem;padding:.5rem 1rem}.btn-info:hover:not(:disabled){background:#357abd}.btn-danger{background:#e74c3c;color:#fff;font-size:.85rem;padding:.5rem 1rem}.btn-danger:hover:not(:disabled){background:#c0392b}.btn-sm{font-size:.8rem;margin-right:.5rem;padding:.4rem .8rem}.detail-container{margin:0 auto;max-width:1000px;padding:2rem}.detail-container .detail-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.detail-container .detail-header h1{color:#1a3a42;font-size:1.8rem}.detail-container .detail-header .btn-group{display:flex;gap:1rem}.detail-container .detail-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem;padding:2rem}.detail-container .detail-card h3{border-bottom:2px solid #f0f0f0;color:#1a3a42;font-size:1.2rem;margin-bottom:1.5rem;padding-bottom:1rem}.detail-container .detail-card .detail-row{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}@media(max-width:768px){.detail-container .detail-card .detail-row{grid-template-columns:1fr}}.detail-container .detail-card .detail-row .detail-item label{color:#999;display:block;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.detail-container .detail-card .detail-row .detail-item p{color:#1a3a42;font-size:.95rem}.search-bar{margin-bottom:2rem}.search-bar input{border:1px solid #ddd;border-radius:4px;font-size:.95rem;max-width:400px;padding:.75rem 1rem;width:100%}.search-bar input:focus{border-color:#12b7ad;box-shadow:0 0 0 3px #12b7ad1a;outline:none}@media(max-width:768px){.page-container{padding:1rem}.page-container .page-header h1{font-size:1.5rem}.page-container .data-table{font-size:.9rem}.page-container .data-table td,.page-container .data-table th{padding:.75rem}.page-container .page-controls{flex-direction:column}.page-container .page-controls button{width:100%}.modal-overlay .modal-content{max-width:95vw;padding:1.5rem}}
/*# sourceMappingURL=main.07e548d4.css.map*/