.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:90}.sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;transition:transform .25s ease}.sidebar__brand{padding:22px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.sidebar__logo{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));font-size:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar__title{display:block;font-size:17px;font-weight:600;color:var(--text)}.sidebar__subtitle{display:block;font-size:11px;font-weight:500;color:var(--text-secondary)}.sidebar__nav{flex:1;padding:12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.sidebar__link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .15s}.sidebar__link:hover{background:var(--bg);color:var(--text)}.sidebar__link--active{background:var(--primary-light);color:var(--primary-dark);font-weight:600}.sidebar__icon{width:22px;height:22px;flex-shrink:0}.sidebar__footer{border-top:1px solid var(--border);padding:12px}.sidebar__user{display:flex;align-items:center;gap:10px;padding:8px 10px;margin-bottom:6px}.sidebar__user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-light);color:var(--primary-dark);display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.sidebar__user-info strong{display:block;font-size:13px;font-weight:600}.sidebar__user-info span{display:block;font-size:11px;color:var(--text-secondary)}.sidebar__logout{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;color:var(--error);background:none;border-radius:10px;transition:background .15s}.sidebar__logout:hover{background:#c5303014}@media (max-width: 768px){.sidebar-overlay{display:block}.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0)}}.bottom-nav{display:none}.bottom-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 0;background:none;border:none;font-size:11px;font-weight:500;color:var(--text-secondary);-webkit-tap-highlight-color:transparent}.bottom-nav__icon-wrap{display:flex;align-items:center;justify-content:center;width:46px;height:28px;border-radius:14px;transition:background .18s ease}.bottom-nav__icon{font-size:19px;line-height:1}.bottom-nav__label{transition:color .15s ease}.bottom-nav__item--active{color:var(--primary-dark);font-weight:600}.bottom-nav__item--active .bottom-nav__icon-wrap{background:var(--primary-light)}@media (max-width: 768px){.bottom-nav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:80;justify-content:space-around;align-items:stretch;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -2px 14px #1f242112;padding:6px 4px;padding-bottom:calc(6px + env(safe-area-inset-bottom))}}.app-layout{display:flex;min-height:100vh}.app-layout__main{flex:1;margin-left:260px;display:flex;flex-direction:column}.app-layout__header{display:none;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.app-layout__brand{font-size:16px;font-weight:600;display:inline-flex;align-items:center;gap:8px;color:var(--primary-dark)}.app-layout__content{flex:1;padding:28px;max-width:1280px;width:100%}@media (max-width: 768px){.app-layout__main{margin-left:0}.app-layout__header{display:flex}.app-layout__content{padding:16px;padding-bottom:calc(76px + env(safe-area-inset-bottom))}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--secondary-dark));padding:16px}.login-card{width:100%;max-width:420px;background:var(--surface);border-radius:20px;overflow:hidden;box-shadow:0 8px 32px #0000002e}.login-card__header{padding:36px 32px 0;text-align:center}.login-card__logo{width:64px;height:64px;border-radius:18px;background:var(--primary-light);font-size:32px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px}.login-card__title{font-size:24px;font-weight:700;color:var(--text)}.login-card__subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.login-card__form{padding:24px 32px 32px;display:flex;flex-direction:column;gap:16px}.login-card__error{background:#c5303014;color:var(--error);font-size:13px;font-weight:500;padding:10px 14px;border-radius:10px;text-align:center}.login-card__field{display:flex;flex-direction:column;gap:6px}.login-card__field label{font-size:13px;font-weight:500;color:var(--text)}.login-card__field input{padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--text);background:var(--bg);transition:border-color .15s}.login-card__field input:focus{border-color:var(--primary);background:var(--surface)}.login-card__password{position:relative;display:flex}.login-card__password input{flex:1;padding-right:44px}.login-card__password-toggle{position:absolute;top:0;right:0;height:100%;width:42px;display:flex;align-items:center;justify-content:center;background:none;color:var(--text-secondary);border-radius:0 10px 10px 0}.login-card__password-toggle:hover{color:var(--primary-dark)}.login-card__btn{padding:13px;background:var(--primary);color:#fff;font-size:15px;font-weight:600;border-radius:10px;margin-top:8px;transition:background .15s}.login-card__btn:hover{background:var(--primary-dark)}.login-card__btn:disabled{opacity:.6;cursor:not-allowed}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-header__title{font-size:24px;font-weight:600;color:var(--text)}.page-header__subtitle{font-size:14px;color:var(--text-secondary);margin-top:2px}.page-header__action{padding:10px 20px;background:var(--primary);color:#fff;font-size:14px;font-weight:500;border-radius:10px;transition:background .15s}.page-header__action:hover{background:var(--primary-dark)}@media (max-width: 768px){.page-header__title{font-size:20px}.page-header__action{width:100%;text-align:center}}.dashboard__loading{text-align:center;padding:60px;color:var(--text-secondary)}.dashboard__section{font-size:15px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:8px 0 14px}.dashboard__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}.dashboard__card{background:var(--surface);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000f}.dashboard__card-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.dashboard__card-value{font-size:22px;font-weight:700;color:var(--text)}.dashboard__card-label{font-size:13px;color:var(--text-secondary)}.data-table__wrapper{overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 1px 2px #1f24210a,0 4px 16px #1f24210f}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:14px 18px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap}.data-table th:first-child{border-top-left-radius:var(--radius-lg)}.data-table th:last-child{border-top-right-radius:var(--radius-lg)}.data-table td{padding:15px 18px;font-size:14px;color:var(--text);border-bottom:1px solid var(--border);vertical-align:middle}.data-table tbody tr{transition:background .12s ease}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--primary-light)}.data-table__row--clickable{cursor:pointer}.data-table__empty{text-align:center;padding:56px 24px;color:var(--text-secondary);font-size:14px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-lg)}.data-table__empty p{margin:0}@media (max-width: 768px){.data-table__wrapper{overflow:visible;background:transparent;border:none;box-shadow:none}.data-table thead{display:none}.data-table,.data-table tbody{display:block}.data-table tr{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 3px #1f24210f;padding:14px 16px;margin-bottom:12px}.data-table tr:last-child{margin-bottom:0}.data-table tbody tr:hover{background:var(--surface)}.data-table__row--clickable:active{background:var(--bg)}.data-table td{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:7px 0;border-bottom:1px solid var(--border);font-size:14px}.data-table td:last-child{border-bottom:none;padding-bottom:0}.data-table td:first-child{padding-top:0}.data-table td:before{content:attr(data-label);font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}}.badge{display:inline-block;padding:3px 10px;border-radius:8px;font-size:12px;font-weight:500;white-space:nowrap}.badge--success{background:#2f855a20;color:#276749}.badge--error{background:#c5303018;color:#c53030}.badge--warning{background:#dd6b2020;color:#b45309}.badge--info{background:#8b5e3420;color:#5c3d20}.badge--neutral{background:#6b728018;color:#6b7280}.modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:200}.modal{width:100%;background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 12px 40px #0003;max-height:90vh;display:flex;flex-direction:column}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.modal__header h3{font-size:18px;font-weight:600}.modal__close{background:none;font-size:26px;line-height:1;color:var(--text-secondary)}.modal__body{padding:24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.modal__footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border);background:#fafafa}.modal__btn{padding:10px 22px;border-radius:10px;font-size:14px;font-weight:500;transition:all .15s}.modal__btn--cancel{background:none;color:var(--text-secondary);border:1px solid var(--border)}.modal__btn--cancel:hover{background:var(--bg)}.modal__btn--save{background:var(--primary);color:#fff}.modal__btn--save:hover{background:var(--primary-dark)}.modal__btn--save:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.modal__footer{flex-direction:column-reverse}.modal__btn{width:100%;text-align:center}}.input-field{display:flex;flex-direction:column;gap:4px}.input-field__label{font-size:13px;font-weight:500;color:var(--text)}.input-field__input{padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--text);background:var(--bg);transition:border-color .15s;width:100%}.input-field__input:focus{border-color:var(--primary);background:var(--surface)}.input-field__textarea{resize:vertical;min-height:72px}.input-field__input--error{border-color:var(--error)}.input-field__error{font-size:12px;color:var(--error)}.input-field__input::placeholder{color:var(--text-secondary)}.btn-group{display:flex;flex-wrap:wrap;gap:8px}.btn-group__btn{padding:9px 16px;border:1px solid var(--border);border-radius:10px;font-size:14px;font-weight:500;color:var(--text);background:var(--bg);cursor:pointer;transition:all .15s}.btn-group__btn:hover{border-color:var(--primary);background:var(--surface)}.btn-group__btn--active{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-group__btn--active:hover{background:var(--primary-dark);color:#fff}.form-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 2px 8px #0000000f;overflow:hidden}.form-card__body{padding:24px;display:flex;flex-direction:column;gap:16px}.form-card__row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.form-card__footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border);background:#fafafa}.form-card__btn{padding:10px 24px;border-radius:10px;font-size:14px;font-weight:500;transition:all .15s}.form-card__btn--cancel{background:none;color:var(--text-secondary);border:1px solid var(--border)}.form-card__btn--cancel:hover{background:var(--bg)}.form-card__btn--submit{background:var(--primary);color:#fff}.form-card__btn--submit:hover{background:var(--primary-dark)}.form-card__btn--submit:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.form-card__footer{flex-direction:column-reverse}.form-card__btn{width:100%;text-align:center}}.list-toolbar{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.list-search{flex:1;min-width:220px;padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--text);background:var(--surface);transition:border-color .15s}.list-search:focus{border-color:var(--primary)}.list-filter{padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;background:var(--surface);color:var(--text)}.list-loading,.list-error{text-align:center;padding:40px;color:var(--text-secondary)}.list-error{background:#c5303014;color:var(--error);border-radius:10px;margin-bottom:16px;padding:14px}.list-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;font-size:14px}.list-pagination button{padding:8px 16px;border-radius:8px;background:var(--surface);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text);transition:all .15s}.list-pagination button:hover:not(:disabled){background:var(--primary-light);color:var(--primary-dark);border-color:var(--primary)}.list-pagination button:disabled{opacity:.4;cursor:not-allowed}.list-pagination span{color:var(--text-secondary);font-size:13px}.row-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-sm{padding:6px 12px;border-radius:8px;font-size:12px;font-weight:500;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:all .15s}.btn-sm:hover{background:var(--bg)}.btn-sm--primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-sm--primary:hover{background:var(--primary-dark)}.btn-sm--danger{color:var(--error);border-color:#c5303040}.btn-sm--danger:hover{background:#c5303014}.detail__loading{text-align:center;padding:60px;color:var(--text-secondary)}.detail__back{display:inline-flex;align-items:center;gap:4px;background:none;color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:12px}.detail__back:hover{color:var(--primary-dark)}.detail__card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 2px 8px #0000000f;padding:24px;margin-bottom:28px}.detail__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px;margin-bottom:16px}.detail__info{display:flex;flex-direction:column;gap:2px}.detail__info--block{margin-top:12px}.detail__info-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.detail__info-value{font-size:15px;color:var(--text)}.detail__section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}.detail__section-header h2{font-size:18px;font-weight:600}.detail__empty{background:var(--surface);border-radius:var(--radius-lg);padding:28px;text-align:center;color:var(--text-secondary);font-size:14px;margin-bottom:28px}.detail__list{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}.detail__item{background:var(--surface);border-radius:var(--radius);box-shadow:0 2px 8px #0000000d;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.detail__item-main{display:flex;flex-direction:column;gap:3px}.detail__item-main strong{font-size:15px}.detail__item-main span{font-size:13px;color:var(--text)}.detail__muted{color:var(--text-secondary)!important}.detail__item-side{display:flex;align-items:center;gap:8px;flex-wrap:wrap}:root{--primary: #2F855A;--primary-dark: #276749;--primary-light: #E6F2EB;--secondary: #8B5E34;--secondary-dark: #5C3D20;--accent: #DD6B20;--bg: #F4F5F2;--surface: #FFFFFF;--text: #1F2421;--text-secondary: #6B7280;--error: #C53030;--warning: #DD6B20;--border: #E2E5E0;--radius: 12px;--radius-lg: 16px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:inherit;outline:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}
