*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #0d6efd;--primary-dark: #0b5ed7;--secondary: #6c757d;--success: #198754;--danger: #dc3545;--warning: #ffc107;--info: #0dcaf0;--bg: #f8f9fa;--sidebar-bg: #0f460b;--sidebar-text: #cbd5e1;--sidebar-active: #0d6efd}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:#1e293b;min-height:100vh}a{text-decoration:none;color:inherit}.app-layout{--sidebar-width: 260px;display:flex;min-height:100vh}.app-layout.collapsed{--sidebar-width: 60px}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width .25s ease,transform .3s;overflow:hidden}.collapsed .sidebar{overflow:visible;z-index:105}.collapsed .sidebar-nav{overflow:visible!important}.sidebar-brand{padding:1rem;color:#fff;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:.6rem}.sidebar-brand .brand-icon{font-size:1.5rem;flex-shrink:0}.sidebar-brand .brand-info{flex:1;min-width:0;transition:opacity .2s}.sidebar-brand .brand-title{font-weight:700;font-size:1.05rem;line-height:1.3}.sidebar-brand .brand-sub{font-size:.65rem;font-weight:400;opacity:.85;line-height:1.3;margin-top:1px}.collapsed .sidebar-brand .brand-info{opacity:0;width:0;overflow:hidden}.collapsed .sidebar-brand{padding:.6rem;justify-content:center}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto;overflow-x:hidden}.nav-section{padding:.5rem 1.25rem .25rem;font-size:.7rem;text-transform:uppercase;letter-spacing:1px;opacity:.6;white-space:nowrap;transition:opacity .2s}.collapsed .nav-section{opacity:0;height:0;overflow:hidden;padding:0;margin:0}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.25rem;color:var(--sidebar-text);transition:all .2s;font-size:.9rem;cursor:pointer;border:none;background:none;width:100%;text-align:left;white-space:nowrap}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.router-link-exact-active,.nav-item.active{background:var(--sidebar-active);color:#fff}.nav-item .nav-icon{width:1.25rem;text-align:center;font-size:1.1rem;flex-shrink:0}.nav-item .nav-text{transition:opacity .2s}.collapsed .nav-item .nav-text{opacity:0;width:0;overflow:hidden;display:inline-block}.collapsed .nav-item{position:relative}.collapsed .nav-item:hover{background:var(--sidebar-active);color:#fff;width:auto;min-width:100%;padding-right:1rem}.collapsed .nav-item:hover .nav-text{opacity:1;width:auto;overflow:visible;display:inline-block;background:#fff;color:#000!important;padding:.4rem 1rem;border-radius:6px;box-shadow:0 2px 8px #0003;position:absolute;left:calc(100% + .5rem);top:50%;transform:translateY(-50%);white-space:nowrap;z-index:200;font-size:.85rem;font-weight:500}.nav-toggle{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.25rem;color:var(--sidebar-text);transition:all .2s;font-size:.9rem;cursor:pointer;border:none;background:none;width:100%;text-align:left;white-space:nowrap}.nav-toggle:hover{background:#ffffff14;color:#fff}.nav-toggle.active{background:#ffffff0d;color:#fff}.nav-toggle .nav-icon{width:1.25rem;text-align:center;font-size:1.1rem;flex-shrink:0}.nav-toggle .nav-text{transition:opacity .2s;flex:1}.toggle-chevron{font-size:.6rem;transition:transform .25s ease;opacity:.6}.toggle-chevron.open{transform:rotate(90deg)}.collapsed .nav-toggle .nav-text{opacity:0;width:0;overflow:hidden;display:inline-block;flex:none}.collapsed .nav-toggle .toggle-chevron{opacity:0;width:0;overflow:hidden}.collapsed .nav-toggle{justify-content:center}.collapsed .nav-toggle:hover{background:var(--sidebar-active);color:#fff;width:auto;min-width:100%;padding-right:1rem}.collapsed .nav-toggle:hover .nav-text{opacity:1;width:auto;overflow:visible;display:inline-block;background:#fff;color:#000!important;padding:.4rem 1rem;border-radius:6px;box-shadow:0 2px 8px #0003;position:absolute;left:calc(100% + .5rem);top:50%;transform:translateY(-50%);white-space:nowrap;z-index:200;font-size:.85rem;font-weight:500}.nav-submenu{max-height:0;overflow:hidden;transition:max-height .35s ease;background:#00000026}.nav-submenu.open{max-height:600px}.nav-submenu .nav-sub{padding-left:2.5rem;font-size:.82rem;padding-top:.5rem;padding-bottom:.5rem}.nav-submenu .nav-sub .nav-icon{font-size:.7rem;opacity:.6;width:.9rem}.collapsed .nav-submenu{max-height:0!important;overflow:hidden!important;height:0!important}.main-content{width:calc(100% - var(--sidebar-width));margin-left:auto;display:flex;flex-direction:column;min-height:100vh;transition:width .25s ease,margin-left .25s ease}.sidebar-toggle-float{position:fixed;top:1.2rem;left:calc(var(--sidebar-width) + -1.5rem);z-index:110;width:2rem;height:2rem;border:none;border-radius:.375rem;background:var(--sidebar-bg);color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:left .25s ease,background .2s;box-shadow:0 1px 3px #0003}.sidebar-toggle-float:hover{background:var(--sidebar-active)}.collapsed .sidebar-toggle-float{left:calc(var(--sidebar-width) + -1.2rem)}.navbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.navbar-left,.navbar-right{display:flex;align-items:center;gap:1rem}.navbar-toggler{display:none;background:none;border:none;font-size:1.25rem;cursor:pointer}.page-title{font-size:1.25rem;font-weight:600}.user-badge{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:var(--bg);border-radius:.5rem;font-size:.85rem}.user-avatar{width:2rem;height:2rem;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem}.btn-logout{background:none;border:1px solid #e2e8f0;padding:.4rem .75rem;border-radius:.375rem;cursor:pointer;font-size:.85rem;transition:all .2s}.btn-logout:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.page-content{padding:1.5rem;flex:1}.card{background:#fff;border-radius:.5rem;border:1px solid #e2e8f0;padding:1.25rem;margin-bottom:1rem}.card-header{font-size:1rem;font-weight:600;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.grid{display:grid;gap:1rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.stat-card{background:#fff;border-radius:.5rem;border:1px solid #e2e8f0;padding:1.25rem;text-align:center}.stat-value{font-size:2rem;font-weight:700}.stat-label{font-size:.85rem;color:var(--secondary);margin-top:.25rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem;color:#374151}.form-input,.form-select,.form-textarea{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.9rem;transition:border-color .2s;background:#fff}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0d6efd26}.form-textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.375rem;border:none;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#157347}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b02a37}.btn-warning{background:var(--warning);color:#000}.btn-outline{background:transparent;border:1px solid #d1d5db}.btn-outline:hover{background:var(--bg)}.btn-sm{padding:.3rem .6rem;font-size:.8rem}.btn-icon{padding:.25rem .35rem;font-size:.85rem;line-height:1;min-width:1.75rem;text-align:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:.375rem}.btn-icon:hover{background:var(--bg);border-color:#d1d5db}.btn-icon[title=Edit]:hover{background:#dbeafe;border-color:var(--primary)}.btn-icon[title=Hapus]:hover{background:#fee2e2;border-color:var(--danger)}.btn-icon[title=Detail]:hover{background:#f3f4f6;border-color:#9ca3af}.action-cell{white-space:nowrap;display:flex;gap:.25rem;align-items:center}.table-container{overflow-x:auto;position:relative}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{padding:.625rem .75rem;text-align:left;border-bottom:1px solid #e2e8f0}th{background:#f8fafc;font-weight:600;color:#475569;font-size:.8rem;text-transform:uppercase;letter-spacing:.025em}tr:hover{background:#f8fafc}.badge{display:inline-block;padding:.2rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.modal-content{background:#fff;border-radius:.5rem;padding:1.5rem;min-width:400px;max-width:90vw}.modal-header{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.loading{display:flex;justify-content:center;padding:2rem;color:var(--secondary)}.spinner{width:2rem;height:2rem;border:3px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-1{gap:.5rem}.cursor-pointer{cursor:pointer;-webkit-user-select:none;user-select:none}.pagination{display:flex;align-items:center;gap:.25rem;padding:1rem 0 0;flex-wrap:wrap}.btn-page{min-width:2rem;height:2rem;border:1px solid #d1d5db;background:#fff;border-radius:.375rem;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-page:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.btn-page.active{background:var(--primary);border-color:var(--primary);color:#fff}.btn-page:disabled{opacity:.4;cursor:default}.page-dots{padding:0 .25rem;color:var(--secondary)}.page-info{margin-left:auto;font-size:.85rem;color:var(--secondary)}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{background:#f1f5f9}@media print{body *{visibility:hidden}#print-area,#print-area *{visibility:visible}#print-area{position:relative;left:0;top:0;width:100%;margin:0;padding:.5in}#print-area .table-container{overflow:visible!important}#print-area table{font-size:.75rem}#print-area .card-header{font-size:.85rem}.badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-page{page-break-after:always;break-after:page}@page{margin:.5in}}@media (max-width: 768px){.app-layout{--sidebar-width: 260px}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.navbar-toggler{display:block}.sidebar-toggle-float{display:none}.grid-2,.grid-3,.grid-4,.form-row{grid-template-columns:1fr}}
