*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{height:100%;min-height:100vh}body{-webkit-font-smoothing:antialiased;background:#0f172a;background-attachment:fixed;background-image:radial-gradient(ellipse at 20% 30%,#6366f10d 0,#0000 55%),radial-gradient(ellipse at 80% 70%,#a855f70a 0,#0000 55%);color:#f1f5f9;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:#0f172acc}::-webkit-scrollbar-thumb{background:#6366f173;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6366f1b3}@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,#080e1a,#0f172a 40%,#1a1040);border-right:1px solid #6366f12e;bottom:0;box-shadow:4px 0 32px #00000080,inset 0 0 60px #6366f10d;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 #94a3b812;flex-shrink:0;padding:20px 16px 16px}.sidebar-logo{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#93c5fd,#c4b5fd);-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:800;margin-bottom:14px;white-space:nowrap}.sidebar-user{background:#6366f11a;border:1px solid #6366f133;border-radius:8px;padding:8px 10px}.sidebar-username{color:#f1f5f9;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-role{color:#94a3b8bf;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:1px solid #0000;border-radius:8px;color:#94a3b8bf;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:9px;padding:10px 12px;text-align:left;transition:background .15s,color .15s,border-color .15s;white-space:nowrap;width:100%}.nav-item:hover{background:#6366f11f;border-color:#6366f126;color:#e2e8f0}.nav-item.active{background:linear-gradient(135deg,#3b82f638,#6366f138);border-color:#6366f159;box-shadow:0 0 12px #6366f126;color:#93c5fd;font-weight:700}.nav-icon{flex-shrink:0;font-size:15px}.sidebar-logout{background:#0000;border:1px solid #94a3b81f;border-radius:8px;color:#94a3b88c;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:#ef44441a;border-color:#ef44444d;color:#fca5a5}.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;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#080e1af2;border-bottom:1px solid #6366f133;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:#93c5fd;cursor:pointer;flex-shrink:0;font-size:22px}.sidebar-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#000000b3;display:none;inset:0;position:fixed;z-index:199}.card{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#1e293ba6;border:1px solid #94a3b81a;border-radius:12px;box-shadow:0 4px 24px #0006}.page-title{color:#f1f5f9;font-size:22px;font-weight:800;margin-bottom:20px}.form-input{background:#0f172a99;border:1.5px solid #94a3b826;border-radius:8px;color:#f1f5f9;color-scheme:dark;font-size:15px;outline:none;padding:11px 14px;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.form-input option{background:#1e293b;color:#f1f5f9}.data-table{border-collapse:collapse;font-size:13px;min-width:500px;width:100%}.data-table th{background:#0f172a99;border-bottom:1px solid #94a3b81a;color:#94a3b8;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 #94a3b80f;color:#cbd5e1}.data-table tr:hover td{background:#6366f10f}.badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;padding:2px 10px}.badge-admin{background:#8b5cf62e;border:1px solid #8b5cf64d;color:#c4b5fd}.badge-user{background:#33415580;border:1px solid #94a3b826;color:#94a3b8}.badge-active{background:#10b98124;border:1px solid #10b98140;color:#6ee7b7}.badge-inactive{background:#ef44441f;border:1px solid #ef444440;color:#fca5a5}.badge-blue{background:#3b82f624;border:1px solid #3b82f640;color:#93c5fd}.badge-purple{background:#a855f724;border:1px solid #a855f740;color:#d8b4fe}.btn-primary{background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:8px;box-shadow:0 4px 14px #6366f159;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:9px 20px;transition:opacity .15s,box-shadow .15s;white-space:nowrap}.btn-primary:hover{box-shadow:0 6px 20px #6366f180;opacity:.88}.btn-secondary{background:#1e293b80;border:1.5px solid #94a3b833;border-radius:8px;color:#94a3b8;cursor:pointer;font-size:13px;padding:9px 18px;transition:all .15s;white-space:nowrap}.btn-secondary:hover{background:#33415580;border-color:#94a3b859;color:#cbd5e1}.btn-danger{background:#ef44441a;border:1px solid #ef44444d;border-radius:6px;color:#fca5a5;cursor:pointer;font-size:12px;padding:5px 12px;transition:all .15s}.btn-danger:hover{background:#ef444433;border-color:#ef444480}.btn-edit{background:#6366f11a;border:1px solid #6366f14d;border-radius:6px;color:#a5b4fc;cursor:pointer;font-size:12px;padding:5px 12px;transition:all .15s}.btn-edit:hover{background:#6366f133;border-color:#6366f180}.alert-success{background:#10b9811f;border:1px solid #10b98140;border-radius:8px;color:#6ee7b7;font-weight:600}.alert-error,.alert-success{font-size:13px;margin-bottom:14px;padding:10px 14px}.alert-error{background:#ef44441f;border:1px solid #ef444440;border-radius:8px;color:#fca5a5}@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:13px 14px}.data-table{font-size:12px}.data-table td,.data-table th{padding:8px 10px}}
/*# sourceMappingURL=main.7c3ccedc.css.map*/