*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{height:100%;min-height:100vh}body{-webkit-font-smoothing:antialiased;background:#f1f5f9;color:#1e293b;font-family:Hiragino Kaku Gothic ProN,Hiragino Sans,Meiryo,Yu Gothic,sans-serif;font-size:14px;line-height:1.5}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .2s ease-out}.layout{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#1e40af,#1e3a8a);bottom:0;display:flex;flex-direction:column;flex-shrink:0;left:0;min-width:220px;overflow-x:hidden;overflow-y:auto;position:fixed;top:0;width:220px;z-index:200}.sidebar-header{border-bottom:1px solid #ffffff26;flex-shrink:0;padding:20px 16px 16px}.sidebar-logo{color:#fff;font-size:18px;font-weight:800;margin-bottom:14px;white-space:nowrap}.sidebar-user{background:#ffffff1f;border-radius:8px;padding:8px 10px}.sidebar-username{color:#fff;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-role{color:#ffffffa6;font-size:11px;margin-top:2px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:8px 10px}.nav-item{align-items:center;background:#0000;border:none;border-radius:8px;color:#ffffffbf;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:9px;padding:10px 12px;text-align:left;transition:background .15s,color .15s;white-space:nowrap;width:100%}.nav-item:hover{background:#ffffff1f;color:#fff}.nav-item.active{background:#ffffff38;color:#fff;font-weight:700}.nav-icon{flex-shrink:0;font-size:15px}.sidebar-logout{background:#0000;border:1px solid #ffffff40;border-radius:8px;color:#ffffffa6;cursor:pointer;flex-shrink:0;font-size:13px;margin:10px 10px 16px;padding:9px 12px;text-align:left;transition:all .15s;white-space:nowrap}.sidebar-logout:hover{background:#ffffff1a;color:#fff}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:220px;min-height:100vh;min-width:0}.page-content{flex:1 1;max-width:100%;min-width:0;overflow-x:hidden;padding:24px 28px}.mobile-header{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:none;gap:12px;justify-content:space-between;padding:10px 14px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.mobile-menu-btn{background:none;border:none;color:#374151;cursor:pointer;flex-shrink:0;font-size:22px}.sidebar-overlay{background:#00000073;display:none;inset:0;position:fixed;z-index:199}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014}.page-title{color:#1e293b;font-size:22px;font-weight:800;margin-bottom:20px}.form-input{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:14px;outline:none;padding:8px 12px;transition:border-color .15s;width:100%}.form-input:focus{border-color:#3b82f6}.data-table{border-collapse:collapse;font-size:13px;min-width:500px;width:100%}.data-table th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-weight:600;text-align:left}.data-table td,.data-table th{padding:10px 12px;white-space:nowrap}.data-table td{border-bottom:1px solid #f1f5f9;color:#1e293b}.data-table tr:hover td{background:#fafafa}.badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;padding:2px 10px}.badge-admin{background:#ede9fe;color:#6d28d9}.badge-user{background:#f1f5f9;color:#475569}.badge-active{background:#f0fdf4;color:#15803d}.badge-inactive{background:#fef2f2;color:#dc2626}.badge-blue{background:#eff6ff;color:#1e40af}.badge-purple{background:#ede9fe;color:#6d28d9}.btn-primary{background:#1e40af;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:9px 20px;transition:opacity .15s;white-space:nowrap}.btn-primary:hover{opacity:.88}.btn-secondary{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;font-size:13px;padding:9px 18px;white-space:nowrap}.btn-danger{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626}.btn-danger,.btn-edit{cursor:pointer;font-size:12px;padding:5px 12px}.btn-edit{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#1e40af}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#15803d;font-weight:600}.alert-error,.alert-success{font-size:13px;margin-bottom:14px;padding:10px 14px}.alert-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .25s ease}.sidebar.open{transform:translateX(0)}.sidebar-overlay.open{display:block}.main-content{margin-left:0;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-header{display:flex;padding-left:max(14px,env(safe-area-inset-left,14px));padding-right:max(14px,env(safe-area-inset-right,14px));padding-top:max(10px,env(safe-area-inset-top,10px))}.page-content{padding:12px max(12px,env(safe-area-inset-right,12px)) 12px max(12px,env(safe-area-inset-left,12px))}.page-title{font-size:18px;margin-bottom:14px}.btn-primary,.btn-secondary{font-size:14px;padding:11px 16px}.form-input{font-size:16px;padding:10px 12px}.data-table{font-size:12px}.data-table td,.data-table th{padding:8px 10px}}
/*# sourceMappingURL=main.19856cea.css.map*/