*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.login-container{align-items:center;background:linear-gradient(135deg,#ed9ab4,#f5c4d4);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026;max-width:420px;padding:40px;width:100%}.login-header{margin-bottom:32px;text-align:center}.logo-circle{align-items:center;background:linear-gradient(135deg,#ed9ab4,#f5c4d4);border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.logo-text{color:#fff;font-size:32px;font-weight:700}.login-header h1{color:#0f172a;font-size:24px;margin-bottom:8px}.login-header p{color:#64748b;font-size:14px}.login-form{gap:20px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{font-weight:500}.form-group input{border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:12px 16px;transition:all .2s}.form-group input:focus{border-color:#ed9ab4;box-shadow:0 0 0 3px #ed9ab41a;outline:none}.btn-login{align-items:center;background:linear-gradient(135deg,#ed9ab4,#f5c4d4);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;margin-top:8px;padding:14px;transition:transform .2s,box-shadow .2s}.btn-login:hover{box-shadow:0 8px 20px #0891b24d;transform:translateY(-2px)}.btn-login:active{transform:translateY(0)}.error-message{background:#fee2e2;border-radius:8px;color:#991b1b;font-size:14px;padding:12px;text-align:center}.login-footer{margin-top:24px;text-align:center}.login-footer p{color:#94a3b8;font-size:12px}@media (max-width:480px){.login-card{padding:30px 20px}.login-header h1{font-size:20px}.logo-circle{height:60px;width:60px}.logo-text{font-size:24px}}.shimmer{animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#fce7f3,#fbcfe8 20%,#fce7f3 40%,#fce7f3);background-size:200% 100%;border-radius:4px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer-text{height:16px;margin-bottom:8px}.shimmer-circle{border-radius:50%}.shimmer-input{border-radius:8px;height:42px}.shimmer-textarea{border-radius:8px;height:80px}.shimmer-chart{border-radius:8px;height:300px}.stat-card .shimmer{display:inline-block}.data-table .shimmer{display:inline-block;min-width:60px}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.resizing{z-index:1}.react-grid-item.react-draggable-dragging{z-index:3}.react-grid-item.react-grid-placeholder{background:red}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{height:20px;opacity:0;position:absolute;width:20px}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{border-bottom:2px solid #0006;border-right:2px solid #0006;bottom:3px;content:"";height:5px;position:absolute;right:3px;width:5px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;cursor:sw-resize;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;cursor:se-resize;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;left:0;top:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;right:0;top:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e,.react-grid-item>.react-resizable-handle.react-resizable-handle-w{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;left:50%;margin-left:-10px}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.dashboard{max-width:1400px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:16px;padding:20px;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;height:56px;justify-content:center;width:56px}.stat-card.primary .stat-icon{background:linear-gradient(135deg,#ed9ab4,#f5c4d4)}.stat-card.success .stat-icon{background:linear-gradient(135deg,#10b981,#34d399)}.stat-card.warning .stat-icon{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.stat-card.danger .stat-icon{background:linear-gradient(135deg,#ef4444,#f87171)}.stat-content{flex:1 1}.stat-label{color:#64748b;font-size:13px;margin-bottom:4px}.stat-value{color:#0f172a;font-size:32px;font-weight:700;margin-bottom:2px}.stat-desc{color:#94a3b8;font-size:12px}.alerts{flex-direction:column;margin-bottom:0}.alert,.alerts{display:flex;gap:12px}.alert{align-items:flex-start;background:#fff;border-left:4px solid;border-radius:12px;padding:12px 16px}.alert-warning{background:#fffbeb;border-color:#f59e0b}.alert-danger{background:#fef2f2;border-color:#ef4444}.alert strong{display:block;font-size:14px;margin-bottom:2px}.alert p{color:#64748b;font-size:13px;margin:0}.alert table{border-collapse:collapse;font-size:12px;margin-top:8px;width:100%}.alert table thead tr{border-bottom:1px solid #0000001a}.alert table th{font-size:11px;font-weight:600;padding:6px 8px;text-align:left}.alert table td{border-bottom:1px solid #0000000d;padding:6px 8px}.alert table tbody tr:last-child td{border-bottom:none}.alert table tbody tr:hover{background:#00000005}.alert button{background:#0000;border:none;cursor:pointer;font-size:14px;font-weight:600;padding:4px 8px;transition:opacity .2s}.alert button:hover{opacity:.8}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:24px}.dashboard-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{border-bottom:1px solid #e2e8f0;padding:20px}.card-header h3{color:#0f172a;font-size:16px;font-weight:600}.card-body{padding:20px}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{background:#f8fafc;gap:12px;padding:12px}.activity-icon,.activity-item{align-items:center;border-radius:8px;display:flex}.activity-icon{color:#fff;height:36px;justify-content:center;width:36px}.activity-icon.masuk{background:#10b981}.activity-icon.keluar{background:#f59e0b}.activity-icon.donasi{background:#ef4444}.activity-content{flex:1 1}.activity-title{color:#0f172a;font-size:14px;font-weight:600;margin-bottom:2px}.activity-desc{color:#64748b;font-size:12px}.activity-date{color:#94a3b8;font-size:12px}.empty-state{font-size:14px;padding:40px}.dashboard-grid-layout{position:relative;transition:height .2s ease}.dashboard-widget{background:#0000;border-radius:12px;overflow:visible;position:relative}.dashboard-widget>*{height:100%;width:100%}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;will-change:width,height;z-index:100}.react-grid-item.react-draggable-dragging{cursor:move;transition:none;will-change:transform;z-index:100}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:#ed9ab4;border-radius:12px;opacity:.2;transition-duration:.1s;-webkit-user-select:none;user-select:none;z-index:2}.drag-handle{cursor:move;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.drag-handle:active{cursor:grabbing}.dashboard-widget .alerts,.dashboard-widget .dashboard-card,.dashboard-widget .stats-grid{height:auto;margin-bottom:0;min-height:100%}.dashboard-widget .alerts{display:flex;flex-direction:column;gap:12px;height:auto}.dashboard-widget .dashboard-card{display:flex;flex-direction:column;height:100%}.dashboard-widget .dashboard-card .card-body{flex:1 1;overflow:auto}.page-header{align-items:flex-start}.page-header>div:first-child{flex:1 1;min-width:200px}.page-header>div:last-child{display:flex;flex-wrap:wrap;gap:12px}@media (max-width:768px){.dashboard-grid,.stats-grid{grid-template-columns:1fr}.page-header{flex-direction:column}.page-header h1{font-size:24px}.stat-value{font-size:28px}.stat-card{padding:16px}.stat-icon{height:48px;width:48px}.dashboard-card{margin-bottom:16px}.card-body,.card-header{padding:16px}.activity-item{align-items:flex-start;flex-direction:column;gap:8px}.activity-date{font-size:11px}.dashboard-grid-layout,.react-grid-item{width:100%!important}.react-grid-item{margin-bottom:16px;position:relative!important;transform:none!important}.drag-handle{display:none}}.notification-wrapper{position:relative}.notification-bell{align-items:center;background:none;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:8px;position:relative;transition:all .2s}.notification-bell:hover{background:#f1f5f9;color:#ed9ab4}.notification-badge{background:#ef4444;border-radius:10px;color:#fff;font-size:10px;font-weight:700;line-height:1.2;min-width:18px;padding:2px 5px;position:absolute;right:4px;text-align:center;top:4px}.notification-overlay{background:#0000004d;inset:0;position:fixed;z-index:999}.notification-panel{animation:slideIn .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:calc(100vh - 100px);max-width:calc(100vw - 40px);position:fixed;right:20px;top:70px;width:400px;z-index:1000}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 20px}.notification-header h3{color:#0f172a;font-size:18px;margin:0}.notification-actions{display:flex;gap:8px}.btn-close-panel,.btn-mark-all{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.btn-mark-all:hover{background:#f1f5f9;color:#ed9ab4}.btn-close-panel:hover{background:#fee2e2;color:#dc2626}.notification-filters{border-bottom:1px solid #e2e8f0;display:flex;gap:8px;overflow-x:auto;padding:12px 16px}.notification-filters button{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s;white-space:nowrap}.notification-filters button:hover{background:#f1f5f9;border-color:#cbd5e1}.notification-filters button.active{background:linear-gradient(135deg,#ed9ab4,#f5c4d4);border-color:#ed9ab4;color:#fff}.notification-list{flex:1 1;overflow-y:auto;padding:8px}.notification-empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.notification-empty svg{margin-bottom:16px;opacity:.5}.notification-empty p{font-size:14px;margin:0}.notification-item{border-radius:8px;cursor:pointer;display:flex;gap:12px;margin-bottom:8px;padding:12px;position:relative;transition:all .2s}.notification-item:hover{background:#f8fafc}.notification-item.unread{background:#fef3f8}.notification-item.unread:hover{background:#fce7f3}.notification-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.notification-item.danger .notification-icon{background:#fee2e2;color:#dc2626}.notification-item.warning .notification-icon{background:#fef3c7;color:#f59e0b}.notification-item.info .notification-icon{background:#dbeafe;color:#3b82f6}.notification-content{flex:1 1;min-width:0}.notification-title{color:#0f172a;font-size:14px;font-weight:600;margin-bottom:4px}.notification-message{color:#64748b;font-size:13px;line-height:1.4;margin-bottom:4px}.notification-time{color:#94a3b8;font-size:12px}.notification-dot{background:#ed9ab4;border-radius:50%;height:8px;position:absolute;right:12px;top:16px;width:8px}@media (max-width:768px){.notification-panel{max-height:calc(100vh - 80px);right:10px;top:60px;width:calc(100vw - 20px)}}.global-search-overlay{align-items:flex-start;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding-top:100px;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.global-search-modal{animation:slideDown .3s cubic-bezier(.16,1,.3,1);background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:70vh;max-width:600px;width:90%}.global-search-header{align-items:center;border-bottom:2px solid #f1f5f9;display:flex;gap:12px;padding:16px 20px}.global-search-input{border:none;color:#1e293b;flex:1 1;font-size:16px;font-weight:500;outline:none}.global-search-input::placeholder{color:#94a3b8}.global-search-close{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s}.global-search-close:hover{background:#f1f5f9;color:#ed9ab4}.global-search-hint{color:#64748b;padding:40px 20px;text-align:center}.global-search-hint p{font-size:14px;margin-bottom:20px}.search-shortcuts{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.shortcut-item{align-items:center;color:#64748b;display:flex;font-size:13px;gap:6px}.shortcut-item kbd{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;box-shadow:0 1px 2px #0000000d;font-family:monospace;font-size:12px;padding:4px 8px}.global-search-empty{color:#64748b;padding:40px 20px;text-align:center}.global-search-results{flex:1 1;overflow-y:auto;padding:8px}.search-result-item{align-items:center;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:all .2s}.search-result-item.selected,.search-result-item:hover{background:#fce7f3;border-color:#ed9ab4}.result-icon{align-items:center;background:#fef3f7;border-radius:8px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.result-content{flex:1 1;min-width:0}.result-title{color:#1e293b;font-size:14px;font-weight:600;margin-bottom:4px}.result-subtitle,.result-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-subtitle{color:#64748b;font-size:13px}.result-type{flex-shrink:0}.type-badge{background:#f1f5f9;border-radius:6px;color:#64748b;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.global-search-footer{border-top:2px solid #f1f5f9;color:#94a3b8;font-size:12px;padding:12px 20px;text-align:center}.global-search-results::-webkit-scrollbar{width:8px}.global-search-results::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.global-search-results::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.global-search-results::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:768px){.global-search-overlay{padding-top:60px}.global-search-modal{max-height:80vh;width:95%}.global-search-input{font-size:14px}.search-shortcuts{display:none}.result-title{font-size:13px}.result-subtitle{font-size:12px}}.layout{background:#f8fafc;display:flex;min-height:100vh}.sidebar{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:transform .3s ease;width:280px;z-index:100}.sidebar-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:24px 20px}.sidebar-header,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{gap:12px}.logo-icon{align-items:center;background:linear-gradient(135deg,#ed9ab4,#f5c4d4);border-radius:12px;color:#fff;display:flex;font-size:18px;font-weight:700;height:48px;justify-content:center;width:48px}.logo-text h2{word-wrap:break-word;color:#0f172a;font-size:14px;line-height:1.3;margin-bottom:2px;overflow-wrap:break-word}.logo-text p{color:#64748b;font-size:12px}.close-sidebar{background:none;border:none;color:#64748b;cursor:pointer;display:none;padding:4px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:16px 12px}.nav-item{align-items:center;border-radius:8px;color:#64748b;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:4px;padding:12px 16px;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.nav-item:hover{background:#fce7f3;color:#ed9ab4;transform:translateX(2px)}.nav-item.active{background:linear-gradient(135deg,#ed9ab4,#f5c4d4);box-shadow:0 2px 8px #ed9ab44d;color:#fff}.nav-item.active .submenu-arrow{opacity:1}.nav-group{margin-bottom:4px}.nav-item{cursor:pointer;position:relative}.nav-group>.nav-item{-webkit-user-select:none;user-select:none}.submenu-arrow{margin-left:auto;opacity:.7;transition:transform .3s cubic-bezier(.4,0,.2,1)}.submenu-arrow.expanded{opacity:1;transform:rotate(180deg)}.submenu{animation:slideDown .3s cubic-bezier(.4,0,.2,1);overflow:hidden;transform-origin:top}@keyframes slideDown{0%{max-height:0;opacity:0;transform:translateY(-8px)}to{max-height:500px;opacity:1;transform:translateY(0)}}.submenu-item{align-items:center;border-radius:6px;color:#64748b;display:flex;font-size:13px;font-weight:500;margin:2px 8px 2px 12px;padding:10px 16px 10px 48px;position:relative;text-decoration:none}.submenu-item,.submenu-item:before{transition:all .2s cubic-bezier(.4,0,.2,1)}.submenu-item:before{background:#cbd5e1;border-radius:50%;content:"";height:4px;left:20px;position:absolute;top:50%;transform:translateY(-50%);width:4px}.submenu-item:hover{background:#f8fafc;color:#ed9ab4;transform:translateX(2px)}.submenu-item:hover:before{background:#ed9ab4;height:6px;width:6px}.submenu-item.active{background:#fce7f3;color:#ed9ab4;font-weight:600}.submenu-item.active:before{background:#ed9ab4;box-shadow:0 0 0 3px #ed9ab433;height:6px;width:6px}.sidebar-footer{border-top:1px solid #e2e8f0;padding:16px}.user-info{background:#f8fafc;border-radius:8px;gap:12px;margin-bottom:12px;padding:12px}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#ed9ab4,#f5c4d4);border-radius:50%;color:#fff;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.user-details{flex:1 1}.user-name{color:#0f172a;font-size:14px;font-weight:600;margin-bottom:2px}.user-role{color:#64748b;font-size:12px}.btn-logout{align-items:center;background:#fee2e2;border:none;border-radius:8px;color:#dc2626;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:10px;transition:all .2s;width:100%}.btn-logout:hover{background:#fecaca}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:280px}.topbar{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;gap:16px;height:64px;justify-content:space-between;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.menu-toggle{background:none;border:none;color:#64748b;cursor:pointer;display:none;flex-shrink:0;padding:8px}.topbar-title{flex:1 1;min-width:0}.topbar-title h1{color:#0f172a;font-size:18px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-actions{align-items:center;display:flex;flex-shrink:0;gap:16px}.topbar-user{color:#64748b;font-size:14px;font-weight:500;white-space:nowrap}.content{flex:1 1;padding:24px}.sidebar-overlay{display:none}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.close-sidebar{display:block}.main-content{margin-left:0}.menu-toggle{display:block}.topbar{gap:12px;padding:0 16px}.topbar-title h1{font-size:16px}.topbar-actions{gap:8px}.topbar-user{display:none}.sidebar-overlay{background:#00000080;display:block;inset:0;position:fixed;z-index:99}.content{padding:16px}}.image-upload{margin-bottom:20px}.image-upload-label{color:#334155;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.image-upload-actions{display:flex;gap:12px;margin-bottom:16px}.btn-camera,.btn-upload{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s}.btn-camera:hover,.btn-upload:hover{background:#fdf2f8;border-color:#ed9ab4;color:#ed9ab4}.btn-camera:disabled,.btn-upload:disabled{cursor:not-allowed;opacity:.5}.image-previews{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.image-preview-item{aspect-ratio:1;border:2px solid #e2e8f0;border-radius:8px;overflow:hidden;position:relative}.image-preview-item img{height:100%;object-fit:cover;width:100%}.btn-remove-image{align-items:center;background:#ef4444e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:24px;justify-content:center;position:absolute;right:4px;top:4px;transition:all .2s;width:24px}.btn-remove-image:hover{background:#dc2626;transform:scale(1.1)}.image-upload-empty{align-items:center;background:#f8fafc;border:2px dashed #e2e8f0;border-radius:8px;display:flex;flex-direction:column;justify-content:center;padding:40px}.image-upload-empty p{color:#94a3b8;font-size:14px;margin-top:12px}.camera-modal-overlay{align-items:center;background:#000c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:2000}.camera-modal{background:#fff;border-radius:16px;max-width:600px;overflow:hidden;width:100%}.camera-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.camera-header h3{color:#0f172a;font-size:18px}.camera-body{background:#000;position:relative}.camera-body video{display:block;height:auto;width:100%}.camera-footer{border-top:1px solid #e2e8f0;display:flex;justify-content:center;padding:20px}.btn-capture{align-items:center;background:linear-gradient(135deg,#ed9ab4,#f5c4d4);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s}.btn-capture:hover{box-shadow:0 8px 20px #ed9ab44d;transform:translateY(-2px)}@media (max-width:768px){.image-upload-actions{flex-direction:column}.btn-camera,.btn-upload{justify-content:center;width:100%}.image-previews{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.camera-modal{border-radius:0;max-height:100vh;max-width:100%}.camera-modal-overlay{padding:0}.camera-header{padding:16px}.camera-footer{background:#fff;bottom:0;padding:16px;position:-webkit-sticky;position:sticky}.btn-capture{font-size:18px;justify-content:center;padding:16px 24px;width:100%}}.print-modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.print-modal{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column;max-height:90vh;max-width:600px;width:100%}.print-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:24px}.print-modal-header h2{color:#0f172a;font-size:20px;margin:0}.print-modal-body{flex:1 1;overflow-y:auto;padding:24px}.print-settings{border-bottom:1px solid #e2e8f0;display:flex;gap:24px;margin-bottom:24px;padding-bottom:24px}.print-preview{margin-top:16px}.print-preview h4{color:#64748b;font-size:14px;margin-bottom:12px}.label-preview{background:#f8fafc;border-radius:8px;display:flex;justify-content:center;padding:20px}.label-item{background:#fff;border:2px dashed #e2e8f0;border-radius:8px;padding:16px;text-align:center;width:200px}.label-info{margin-top:12px}.label-code{color:#0f172a;font-size:14px;font-weight:700;margin-bottom:4px}.label-name{color:#64748b;font-size:12px;line-height:1.4}.print-modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.print-only{display:none}@media print{body *{visibility:hidden}.print-only,.print-only *{visibility:visible}.print-only{display:block;left:0;position:absolute;top:0;width:100%}.print-page{padding:20mm}.print-header{margin-bottom:20mm;text-align:center}.print-header h3{font-size:18pt;margin:0 0 5mm}.print-header p{color:#666;font-size:10pt;margin:0}.labels-grid{grid-gap:10mm;display:grid;gap:10mm;grid-template-columns:repeat(3,1fr)}.print-label{background:#fff;border:1px solid #ddd;padding:5mm;page-break-inside:avoid;text-align:center}.print-label img{height:auto;margin-bottom:3mm;width:100%}.print-label-info{margin-top:3mm}.print-label-code{font-size:11pt;font-weight:700;margin-bottom:2mm}.print-label-name{color:#333;font-size:9pt;line-height:1.3}@page{size:A4;margin:10mm}}@media (max-width:768px){.print-modal{border-radius:0;max-height:100vh;max-width:100%}.print-settings{flex-direction:column;gap:16px}}.page{max-width:1400px}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.page-header h1{color:#0f172a;font-size:28px;margin-bottom:4px}.page-header p{color:#64748b;font-size:14px}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#ed9ab4,#f5c4d4);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #ec48994d;transform:translateY(-2px)}.btn-secondary{background:#e2e8f0;color:#475569}.btn-secondary:hover{background:#cbd5e1}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.filters{flex-wrap:wrap;margin-bottom:20px}.filters,.search-box{display:flex;gap:12px}.search-box{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;flex:1 1;min-width:250px;padding:10px 16px;transition:border-color .2s}.search-box:focus-within{border-color:#ed9ab4}.search-box input{border:none;flex:1 1;font-size:14px;outline:none}.search-box svg{color:#94a3b8}.filter-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:14px;padding:10px 16px;transition:border-color .2s}.filter-select:focus{border-color:#ed9ab4;outline:none}.table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.data-table th{color:#475569;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:14px;padding:16px}.data-table tbody tr:hover{background:#f8fafc}.code-badge{background:#fce7f3;border-radius:4px;color:#ed9ab4;display:inline-block;font-family:monospace;padding:4px 8px}.badge,.code-badge{font-size:12px;font-weight:600}.badge{align-items:center;border-radius:12px;display:inline-flex;gap:4px;padding:4px 12px}.badge-aman{background:#d1fae5;color:#065f46}.badge-menipis{background:#fef3c7;color:#92400e}.badge-habis{background:#fee2e2;color:#991b1b}.badge-success{background:#d1fae5;color:#065f46}.badge-info{background:#dbeafe;color:#1e40af}.badge-primary{background:#fce7f3;color:#ed9ab4}.badge-secondary{background:#f1f5f9;color:#64748b}.text-muted{color:#94a3b8;font-size:13px}.action-buttons{display:flex;gap:8px}.btn-icon{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.btn-edit{background:#dbeafe;color:#1e40af}.btn-edit:hover{background:#bfdbfe}.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#fecaca}.btn-view{background:#fce7f3;color:#ed9ab4}.btn-view:hover{background:#f5c4d4}.empty-state{color:#94a3b8;padding:60px 20px;text-align:center}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;overflow:auto;padding:20px;position:fixed;z-index:1000}.modal{border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;flex-direction:column;margin:auto;max-height:90vh;max-width:600px;width:100%}.modal,.modal-header{background:#fff;display:flex}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-radius:16px 16px 0 0;flex:0 0 auto;justify-content:space-between;padding:24px}.modal-header h2{color:#0f172a;font-size:20px;margin:0}.btn-close{align-items:center;background:#f1f5f9;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;height:32px;justify-content:center;transition:background .2s;width:32px}.btn-close:hover{background:#e2e8f0}.modal-body{-webkit-overflow-scrolling:touch;flex:1 1;max-height:calc(90vh - 160px);min-height:0;overflow-x:hidden;overflow-y:auto;padding:24px}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.modal-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.form-group{margin-bottom:20px}.form-group label{color:#334155;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#ed9ab4;outline:none}.form-group textarea{font-family:inherit;resize:vertical}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.input-with-icon{align-items:center;display:flex;position:relative}.input-with-icon input,.input-with-icon select{flex:1 1;padding-right:48px}.input-icon-btn{align-items:center;background:none;border:none;border-radius:6px;color:#ed9ab4;cursor:pointer;display:flex;justify-content:center;padding:8px;position:absolute;right:8px;transition:all .2s cubic-bezier(.4,0,.2,1)}.input-icon-btn:hover:not(:disabled){background:#fce7f3;color:#ed9ab4;transform:scale(1.1)}.input-icon-btn:active:not(:disabled){transform:scale(.95)}.input-icon-btn:disabled{color:#cbd5e1;cursor:not-allowed;opacity:.5}.modal-footer{background:#fff;border-radius:0 0 16px 16px;border-top:1px solid #e2e8f0;box-shadow:0 -4px 6px -1px #0000001a;display:flex;flex:0 0 auto;gap:12px;justify-content:flex-end;padding:20px 24px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.info-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.info-label{color:#64748b;font-size:12px;margin-bottom:4px}.info-value{color:#0f172a;font-size:18px;font-weight:600}@media (max-width:768px){.page-header{align-items:flex-start}.filters,.page-header{flex-direction:column}.search-box{min-width:100%}.table-container{overflow-x:auto}.data-table{min-width:800px}.form-row{grid-template-columns:1fr}.modal{border-radius:0;max-height:100vh;max-width:100%}.modal-overlay{align-items:stretch;padding:0}.modal-body,.modal-header{padding:20px}.modal-footer{padding:16px 20px}.btn{justify-content:center;width:100%}.action-buttons{flex-direction:column;width:100%}.action-buttons button{width:100%}}
/*# sourceMappingURL=main.0de0adcb.css.map*/