.modern-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;max-height:calc(100vh - 250px);overflow:auto;position:relative}.modern-table{position:relative}.modern-table thead{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-bottom:2px solid #d1d5db;position:-webkit-sticky;position:sticky;top:0;z-index:100}.modern-table thead tr,.modern-table thead tr th{position:relative;z-index:100}.modern-table thead tr th{background:inherit;border-right:1px solid #d1d5db;color:#1f2937;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.modern-table thead tr th:last-child{border-right:none}.modern-table tbody tr{position:relative;z-index:1}.modern-table tbody tr:last-child{border-bottom:none}.modern-table tbody tr:hover{box-shadow:0 2px 4px #0000000d;z-index:10}.modern-table tbody tr td{border-bottom:1px solid #e5e7eb;border-right:1px solid #f3f4f6;color:#374151;font-size:14px;padding:16px 20px;vertical-align:middle}.modern-table tbody tr td:last-child{border-right:none}.modern-table tbody tr td strong{color:#111827;font-weight:600}.modern-table.striped tbody tr:nth-child(2n){background:#f9fafb}.modern-table.striped tbody tr:nth-child(2n):hover{background:#f3f4f6}.modern-table.compact tbody tr td,.modern-table.compact thead tr th{padding:12px 16px}.modern-table.bordered{border:1px solid #e5e7eb}.modern-table.bordered tbody tr td,.modern-table.bordered thead tr th{border-right:1px solid #e5e7eb}.modern-table.bordered tbody tr td:last-child,.modern-table.bordered thead tr th:last-child{border-right:none}.modern-table.accent-blue thead{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-bottom:2px solid #3b82f6;position:-webkit-sticky;position:sticky;top:0;z-index:100}.modern-table.accent-green thead{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-bottom:2px solid #10b981;position:-webkit-sticky;position:sticky;top:0;z-index:100}.modern-table.accent-purple thead{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-bottom:2px solid #8b5cf6;position:-webkit-sticky;position:sticky;top:0;z-index:100}.modern-table.accent-indigo thead{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-bottom:2px solid #6366f1;position:-webkit-sticky;position:sticky;top:0;z-index:100}.table-actions{align-items:center}.table-btn:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.table-btn-view{background:#f0fdf4;color:#16a34a}.table-btn-view:hover{background:#dcfce7;color:#15803d}.table-btn-edit{background:#eff6ff;color:#2563eb}.table-btn-edit:hover{background:#dbeafe;color:#1d4ed8}.table-btn-delete{background:#fef2f2}.table-btn-delete:hover{background:#fee2e2;color:#b91c1c}.table-btn-download{background:#fef3c7;color:#d97706}.table-btn-download:hover{background:#fde68a;color:#b45309}.table-badge{align-items:center;border-radius:20px;display:inline-flex;letter-spacing:.3px;padding:6px 12px}.table-badge-success{box-shadow:0 2px 4px #10b98133}.table-badge-warning{box-shadow:0 2px 4px #f59e0b33}.table-badge-danger{box-shadow:0 2px 4px #ef444433}.table-badge-info{box-shadow:0 2px 4px #3b82f633}.table-badge-secondary{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);box-shadow:0 2px 4px #6b728033;color:#4b5563}@media (max-width:1200px){.modern-table-container{max-height:calc(100vh - 300px)}.modern-table tbody tr td,.modern-table thead tr th{font-size:13px;padding:14px 16px}}@media (max-width:1024px){.modern-table tbody tr td,.modern-table thead tr th{font-size:13px;padding:12px 14px}.table-actions{gap:6px}}@media (max-width:768px){.modern-table-container{-webkit-overflow-scrolling:touch;border-radius:8px;overflow-x:auto}.modern-table{min-width:600px}.modern-table tbody tr td,.modern-table thead tr th{font-size:12px;padding:10px 12px}.table-btn{font-size:13px;height:30px;width:30px}.table-badge{font-size:11px;padding:4px 8px}.table-pagination{align-items:stretch;flex-direction:column;gap:12px}.table-pagination-info{text-align:center}.table-pagination-buttons{justify-content:center}}@media (max-width:576px){.modern-table{font-size:11px;min-width:500px}.modern-table tbody tr td,.modern-table thead tr th{font-size:11px;padding:8px 10px}.table-btn{font-size:12px;height:28px;width:28px}.table-badge{font-size:10px;padding:3px 6px}.table-pagination-button{font-size:12px;padding:6px 12px}}.table-loading{padding:60px 20px;text-align:center}.table-loading-spinner{animation:table-spin .8s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#6366f1;display:inline-block;height:40px;width:40px}@keyframes table-spin{to{transform:rotate(1turn)}}.table-empty{color:#6b7280;padding:60px 20px;text-align:center}.table-empty-icon{color:#d1d5db;font-size:48px;margin-bottom:16px}.table-empty-text{color:#374151;font-size:16px;font-weight:500;margin-bottom:8px}.table-empty-subtext{color:#6b7280;font-size:14px}.table-pagination{background:#fafafa;padding:16px 20px}.table-pagination-button{border-radius:6px}.table-pagination-button:hover:not(:disabled){background:#f9fafb;border-color:#6366f1;color:#6366f1}.table-pagination-button.active{background:#6366f1;border-color:#6366f1;color:#fff}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#4f46e5;--primary-dark:#4338ca;--secondary-color:#10b981;--danger-color:#ef4444;--warning-color:#f59e0b;--dark-color:#1f2937;--light-color:#f3f4f6;--border-color:#e5e7eb;--text-primary:#111827;--text-secondary:#6b7280;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f3f4f6;background-color:var(--light-color);color:#111827;color:var(--text-primary);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}.container{margin:0 auto;max-width:1200px;padding:0 20px}.btn-primary{background-color:#4f46e5;background-color:var(--primary-color)}.btn-primary:hover:not(:disabled){background-color:#4338ca;background-color:var(--primary-dark)}.btn-secondary{background-color:#10b981;background-color:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background-color:#059669}.btn-danger{background-color:#ef4444;background-color:var(--danger-color)}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-outline{background-color:initial;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#111827;color:var(--text-primary)}.btn-outline:hover:not(:disabled){background-color:#f3f4f6;background-color:var(--light-color)}.card{border-radius:8px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow);padding:20px}.form-group label{color:#111827;color:var(--text-primary)}.form-control{border:1px solid var(--border-color);border-radius:6px;padding:10px 12px;transition:border-color .3s ease}.form-control:focus{border-color:#4f46e5;border-color:var(--primary-color)}.table-container{margin-top:20px}table:not(.modern-table){background:#fff;border-collapse:collapse;width:100%}table:not(.modern-table) thead{background-color:#f3f4f6;background-color:var(--light-color)}table:not(.modern-table) td,table:not(.modern-table) th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:12px;text-align:left}table:not(.modern-table) th{color:#111827;color:var(--text-primary);font-weight:600}table:not(.modern-table) tbody tr:hover{background-color:#f9fafb}.badge-success{background-color:#d1fae5}.badge-warning{background-color:#fef3c7}.badge-danger{background-color:#fee2e2}.badge-info{background-color:#dbeafe}.spinner{border:3px solid #f3f4f6;border-top:3px solid #4f46e5;border:3px solid var(--light-color);border-top-color:var(--primary-color);height:40px;margin:40px auto;width:40px}.alert{border-radius:6px;font-size:14px;line-height:1.5;padding:12px 16px}.alert strong{font-weight:600;margin-right:4px}.alert ul{list-style-type:disc}.alert ul li{margin-bottom:4px}.alert-info{background-color:#dbeafe;border-left:4px solid #3b82f6;color:#1e40af}.alert-success{background-color:#d1fae5;border-left:4px solid #10b981;color:#065f46}.alert-warning{background-color:#fef3c7}.alert-danger{background-color:#fee2e2;border-left:4px solid #ef4444}@media (max-width:1200px){.container{max-width:100%;padding:0 20px}}@media (max-width:992px){.container{padding:0 16px}.btn{font-size:13px;padding:8px 16px}}@media (max-width:768px){.container{padding:0 12px}table{font-size:14px}td,th{padding:8px}.btn{font-size:13px;padding:8px 14px}.card{padding:16px}h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}}@media (max-width:576px){.container{padding:0 10px}.btn{font-size:12px;padding:6px 12px}.card{border-radius:8px;padding:12px}.form-control{font-size:14px;padding:8px 12px}h1{font-size:20px}h2{font-size:18px}h3{font-size:16px}}.w-100{width:100%}.d-flex{display:flex}.flex-wrap{flex-wrap:wrap}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.gap-10{gap:10px}.gap-15{gap:15px}.gap-20{gap:20px}.text-left{text-align:left}.text-right{text-align:right}@media (max-width:768px){.hide-mobile{display:none!important}}@media (min-width:769px){.show-mobile{display:none!important}}.table-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.table-badge-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.table-badge-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.table-badge-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.table-badge-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.table-badge-primary{background:linear-gradient(135deg,#dbeafe,#93c5fd);color:#1e3a8a}.table-badge-secondary{background:linear-gradient(135deg,#e5e7eb,#d1d5db);color:#374151}.table-badge-purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#5b21b6}.table-badge-cyan{background:linear-gradient(135deg,#cffafe,#a5f3fc);color:#155e75}.table-badge-pink{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#9f1239}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74c3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-toast-width:320px;--toastify-toast-background:#fff;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error)}.Toastify__toast-container{box-sizing:border-box;color:#fff;padding:4px;position:fixed;-webkit-transform:translateZ(9999);-webkit-transform:translateZ(var(--toastify-z-index));width:320px;width:var(--toastify-toast-width);z-index:9999;z-index:var(--toastify-z-index)}.Toastify__toast-container--top-left{left:1em;top:1em}.Toastify__toast-container--top-center{left:50%;top:1em;transform:translateX(-50%)}.Toastify__toast-container--top-right{right:1em;top:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translateX(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width:480px){.Toastify__toast-container{left:0;margin:0;padding:0;width:100vw}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:0;transform:translateX(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:0;transform:translateX(0)}.Toastify__toast-container--rtl{left:auto;right:0}}.Toastify__toast{border-radius:4px;box-shadow:0 1px 10px 0 #0000001a,0 2px 15px 0 #0000000d;box-sizing:border-box;cursor:default;direction:ltr;display:flex;font-family:sans-serif;font-family:var(--toastify-font-family);justify-content:space-between;margin-bottom:1rem;max-height:800px;max-height:var(--toastify-toast-max-height);min-height:64px;min-height:var(--toastify-toast-min-height);overflow:hidden;padding:8px;position:relative;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{align-items:center;display:flex;flex:1 1 auto;margin:auto 0;padding:6px}.Toastify__toast-body>div:last-child{flex:1 1;word-break:break-word}.Toastify__toast-icon{-webkit-margin-end:10px;display:flex;flex-shrink:0;margin-inline-end:10px;width:20px}.Toastify--animate{animation-duration:.7s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}@media only screen and (max-width:480px){.Toastify__toast{border-radius:0;margin-bottom:0}}.Toastify__toast-theme--dark{background:#121212;background:var(--toastify-color-dark);color:#fff;color:var(--toastify-text-color-dark)}.Toastify__toast-theme--colored.Toastify__toast--default,.Toastify__toast-theme--light{background:#fff;background:var(--toastify-color-light);color:#757575;color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{background:#3498db;background:var(--toastify-color-info);color:#fff;color:var(--toastify-text-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{background:#07bc0c;background:var(--toastify-color-success);color:#fff;color:var(--toastify-text-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{background:#f1c40f;background:var(--toastify-color-warning);color:#fff;color:var(--toastify-text-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{background:#e74c3c;background:var(--toastify-color-error);color:#fff;color:var(--toastify-text-color-error)}.Toastify__progress-bar-theme--light{background:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:#bb86fc;background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:#3498db;background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:#07bc0c;background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:#f1c40f;background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:#e74c3c;background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning{background:#ffffffb3;background:var(--toastify-color-transparent)}.Toastify__close-button{align-self:flex-start;background:#0000;border:none;color:#fff;cursor:pointer;opacity:.7;outline:none;padding:0;transition:.3s ease}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:focus,.Toastify__close-button:hover{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{bottom:0;height:5px;left:0;opacity:.7;position:absolute;transform-origin:left;width:100%;z-index:9999;z-index:var(--toastify-z-index)}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{left:auto;right:0;transform-origin:right}.Toastify__spinner{animation:Toastify__spin .65s linear infinite;border:2px solid #e0e0e0;border-color:var(--toastify-spinner-color-empty-area);border-radius:100%;border-right-color:#616161;border-right-color:var(--toastify-spinner-color);box-sizing:border-box;height:20px;width:20px}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--bottom-left,.Toastify__bounce-enter--top-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--bottom-right,.Toastify__bounce-enter--top-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--bottom-left,.Toastify__bounce-exit--top-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--bottom-right,.Toastify__bounce-exit--top-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{animation-timing-function:ease-in;opacity:0;transform:perspective(400px) rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px) rotateX(-20deg)}60%{opacity:1;transform:perspective(400px) rotateX(10deg)}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:perspective(400px)}30%{opacity:1;transform:perspective(400px) rotateX(-20deg)}to{opacity:0;transform:perspective(400px) rotateX(90deg)}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{transform:translate3d(110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{transform:translate3d(-110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{transform:translate3d(0,500px,0);visibility:hidden}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(0)}to{transform:translate3d(0,-500px,0);visibility:hidden}}.Toastify__slide-enter--bottom-left,.Toastify__slide-enter--top-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--bottom-right,.Toastify__slide-enter--top-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--bottom-left,.Toastify__slide-exit--top-left{animation-name:Toastify__slideOutLeft}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.layout{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#1a1f3a,#0f1419);box-shadow:4px 0 20px #00000026;color:#fff;height:100vh;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;top:0;transition:all .3s cubic-bezier(.4,0,.2,1);width:280px;z-index:1000}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#ffffff0d}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sidebar.closed{transform:translateX(-100%)}.sidebar-profile{align-items:center;background:linear-gradient(135deg,#3b82f61a,#6366f11a);border-bottom:1px solid #ffffff14;display:flex;gap:16px;padding:24px 20px;transition:all .3s ease}.sidebar-profile:hover{background:linear-gradient(135deg,#3b82f626,#6366f126)}.profile-avatar{background:linear-gradient(135deg,#3b82f6,#6366f1);box-shadow:0 4px 12px #3b82f666;color:#fff;flex-shrink:0;font-size:32px;height:56px;transition:all .3s ease;width:56px}.profile-avatar img{border-radius:50%}.sidebar-profile:hover .profile-avatar{box-shadow:0 6px 16px #3b82f680;transform:scale(1.05)}.profile-info{flex:1 1;min-width:0}.profile-name{color:#fff;font-size:16px;font-weight:600;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-role{align-items:center;border-radius:12px;display:inline-flex;font-size:11px;font-weight:600;gap:6px;letter-spacing:.5px;padding:4px 12px;transition:all .3s ease}.role-badge-admin{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d;color:#fff}.role-badge-staff{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;color:#fff}.role-badge-leader{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 2px 8px #8b5cf64d;color:#fff}.role-badge-academic{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px #3b82f64d;color:#fff}.role-badge-quality{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #f59e0b4d;color:#fff}.role-badge-student{background:linear-gradient(135deg,#06b6d4,#0891b2);box-shadow:0 2px 8px #06b6d44d;color:#fff}.role-badge-prospect{background:linear-gradient(135deg,#ec4899,#db2777);box-shadow:0 2px 8px #ec48994d;color:#fff}.role-badge-user{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 2px 8px #6b72804d;color:#fff}.profile-role svg{font-size:10px}.sidebar-brand{gap:14px;padding:20px;transition:all .3s ease}.brand-icon,.sidebar-brand{align-items:center;display:flex}.brand-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:12px;box-shadow:0 4px 12px #3b82f64d;color:#fff;flex-shrink:0;font-size:24px;height:48px;justify-content:center;width:48px}.brand-text h2{color:#fff;font-size:18px;font-weight:700;letter-spacing:.5px;margin:0 0 4px}.brand-text p{color:#fff9;font-size:12px;font-weight:500;margin:0}.sidebar-divider{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);height:1px;margin:0 20px}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:20px}.sidebar-header h2{font-size:20px;font-weight:600}.sidebar-nav{padding:16px 0 20px}.nav-item{align-items:center;border-radius:10px;color:#ffffffb3;display:flex;font-size:14px;font-weight:500;gap:12px;margin:2px 12px;padding:12px 20px;position:relative;text-decoration:none;transition:all .3s ease}.nav-item:before{background:linear-gradient(180deg,#3b82f6,#6366f1);border-radius:0 2px 2px 0;content:"";height:0;left:0;position:absolute;top:50%;transform:translateY(-50%);transition:height .3s ease;width:4px}.nav-item:hover{background:#3b82f626;color:#fff;transform:translateX(4px)}.nav-item:hover:before{height:60%}.nav-item.active{background:linear-gradient(135deg,#3b82f633,#6366f133);box-shadow:0 2px 8px #3b82f64d;color:#fff}.nav-item.active:before{height:70%}.nav-item svg{flex-shrink:0;font-size:18px}.nav-dropdown{margin:2px 12px}.dropdown-toggle{border-radius:10px;cursor:pointer;justify-content:space-between;position:relative;transition:all .3s ease}.dropdown-toggle:hover{background:#3b82f626;color:#fff;transform:translateX(4px)}.dropdown-icon{flex-shrink:0;font-size:14px;margin-left:auto;transition:transform .3s ease}.nav-dropdown .dropdown-menu{background:#00000026;border:1px solid #ffffff0d;border-radius:10px;box-shadow:none;margin:8px 0;min-width:auto;padding:4px 0;position:relative;right:0;top:0}.nav-dropdown .dropdown-menu .nav-item{font-size:13px;margin:2px 8px;padding:10px 20px 10px 48px}.nav-dropdown .dropdown-menu .nav-item.level-1{padding-left:60px}.nav-dropdown .dropdown-menu .nav-item.level-2{padding-left:72px}.nav-dropdown .dropdown-menu .nav-dropdown{background:#0000001a;border-radius:8px;margin:2px 8px}.nav-dropdown .dropdown-menu .dropdown-toggle{font-size:13px;margin:2px 0;padding:10px 20px 10px 48px}.nav-dropdown .dropdown-menu .nav-dropdown .dropdown-toggle{padding-left:60px}.main-content{background:#f8fafc;flex:1 1;margin-left:280px;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.main-content.sidebar-closed{margin-left:0}.header{align-items:center;background:#fff;box-shadow:var(--shadow);display:flex;justify-content:space-between;padding:15px 30px;position:-webkit-sticky;position:sticky;top:0;z-index:999}.menu-toggle{background:none;border:none;color:var(--text-primary);cursor:pointer;font-size:24px;padding:5px}.header-title h1{font-size:24px;font-weight:600}.header-right{align-items:center;gap:20px}.user-menu{position:relative}.user-info{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:8px 12px;transition:background-color .3s ease}.user-info:hover{background-color:var(--light-color)}.user-avatar{align-items:center;background-color:var(--primary-color);border-radius:50%;color:#fff;display:flex;font-weight:600;height:36px;justify-content:center;width:36px}.user-details h4{font-size:14px;font-weight:500}.user-details p{color:var(--text-secondary);font-size:12px}.dropdown-menu{background:#fff;border-radius:6px;box-shadow:var(--shadow-lg);margin-top:8px;min-width:200px;position:absolute;right:0;top:100%;z-index:1000}.dropdown-item{align-items:center;color:var(--text-primary);display:flex;gap:10px;text-decoration:none;transition:background-color .3s ease}.dropdown-item:hover{background-color:var(--light-color)}.dropdown-divider{background-color:var(--border-color);height:1px;margin:8px 0}.content-wrapper{min-height:calc(100vh - 70px);padding:30px}@media (max-width:1024px){.sidebar{width:260px}.main-content{margin-left:260px}}@media (max-width:768px){.sidebar{transform:translateX(-100%);width:280px}.sidebar.open{box-shadow:8px 0 30px #0000004d;transform:translateX(0)}.main-content{margin-left:0}.content-wrapper{padding:20px 15px}.user-details{display:none}.sidebar.open .sidebar-profile{padding:20px 16px}.sidebar.open .profile-avatar{font-size:28px;height:48px;width:48px}.sidebar.open .profile-name{font-size:15px}.sidebar.open .brand-icon{font-size:20px;height:42px;width:42px}.sidebar.open .brand-text h2{font-size:16px}}@media (max-width:480px){.sidebar{width:260px}.sidebar-profile{padding:16px}.profile-avatar{font-size:24px;height:44px;width:44px}.profile-name{font-size:14px}.brand-text h2{font-size:15px}.nav-item{font-size:13px;padding:10px 16px}}@media (max-width:768px){.layout:before{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;content:"";left:0;opacity:0;pointer-events:none;position:fixed;right:0;top:0;transition:opacity .3s ease;z-index:999}.layout.sidebar-open:before{opacity:1;pointer-events:auto}}.login-page{align-items:center;background:linear-gradient(135deg,#fff,#e0f2fe 25%,#bae6fd 50%,#7dd3fc 75%,#38bdf8);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-page:before{animation:rotate 20s linear infinite;background:radial-gradient(circle,#fffc 0,#38bdf833 50%,#0000 100%);left:-50%;top:-50%}.login-page:after,.login-page:before{content:"";height:200%;position:absolute;width:200%}.login-page:after{animation:rotate 25s linear infinite reverse;background:radial-gradient(circle,#e0f2fe99 0,#0ea5e94d 50%,#0000 100%);bottom:-50%;right:-50%}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-container{box-shadow:0 20px 60px #0ea5e940;position:relative;z-index:1}.login-brand{align-items:center;background:linear-gradient(135deg,#0ea5e9,#0284c7 50%,#0369a1);color:#fff;display:flex;justify-content:center;overflow:hidden;padding:clamp(30px,5vw,60px) clamp(20px,4vw,40px);position:relative}.login-brand:before{animation:float 15s ease-in-out infinite;background:radial-gradient(circle,#ffffff26 0,#0000 60%);content:"";height:200%;position:absolute;right:-50%;top:-50%;width:200%}.brand-content{position:relative;z-index:1}.brand-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0f2fe);-webkit-background-clip:text;background-clip:text;font-size:clamp(28px,4.5vw,42px);font-weight:700;line-height:1.2;margin-bottom:10px}.brand-content>p{color:#e0f2fe;font-size:clamp(14px,1.8vw,18px);margin-bottom:40px;opacity:.95}.features{display:flex;flex-direction:column;gap:20px}.feature{font-size:clamp(13px,1.6vw,16px);gap:15px;opacity:.95}.feature,.feature .icon{align-items:center;display:flex}.feature .icon{background:#ffffff40;border-radius:50%;flex-shrink:0;font-size:clamp(16px,1.8vw,18px);font-weight:700;height:clamp(26px,3vw,30px);justify-content:center;width:clamp(26px,3vw,30px)}.login-form-section{background:linear-gradient(180deg,#fff,#f0f9ff80);display:flex;flex-direction:column;padding:clamp(30px,5vw,60px) clamp(20px,4vw,40px)}.form-wrapper{margin:0 auto;max-width:400px;width:100%}.logo{align-items:center;background:linear-gradient(135deg,#0ea5e9,#0284c7);border-radius:20px;box-shadow:0 10px 30px #0ea5e94d;display:flex;height:clamp(60px,8vw,80px);justify-content:center;margin:0 auto 20px;width:clamp(60px,8vw,80px)}.logo svg{filter:drop-shadow(0 2px 8px rgba(0,0,0,.15));height:50px;width:50px}.logo img{height:100%;object-fit:contain;padding:8px;width:100%}.form-wrapper h2{color:#0c4a6e;font-size:clamp(20px,3.5vw,32px);font-weight:700;line-height:1.3;margin:20px 0 10px;text-align:center}.subtitle{color:#0369a1;font-size:clamp(14px,1.6vw,16px);margin-bottom:30px;text-align:center}.form-group label{color:#075985;font-size:clamp(13px,1.4vw,14px)}.form-group input{background:#ffffffe6;border:2px solid #bae6fd;border-radius:10px;font-family:inherit;font-size:clamp(14px,1.5vw,15px);padding:12px 15px;transition:all .3s ease;width:100%}.form-group input:focus{background:#fff;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a;outline:none}.form-group input::placeholder{color:#7dd3fc}.hint-text{color:#0369a1;margin:10px 0 5px;text-align:center}.hint-text small{font-size:13px}button[type=submit]{background:linear-gradient(135deg,#0ea5e9,#0284c7 50%,#0369a1);border:none;border-radius:10px;box-shadow:0 4px 15px #0ea5e94d;color:#fff;cursor:pointer;font-size:clamp(15px,1.6vw,16px);font-weight:600;margin-top:10px;padding:14px;transition:all .3s ease;width:100%}button[type=submit]:hover:not(:disabled){background:linear-gradient(135deg,#38bdf8,#0ea5e9 50%,#0284c7);box-shadow:0 10px 30px #0ea5e980;transform:translateY(-2px)}button[type=submit]:disabled{cursor:not-allowed;opacity:.6}.footer{background:#e0f2fe4d;border-radius:10px;color:#0369a1;font-size:clamp(12px,1.3vw,13px);margin-top:25px;padding:15px;text-align:center}.footer p{margin:0}@media (max-width:768px){.login-container{grid-template-columns:1fr;max-width:500px}.login-brand{padding:40px 30px}.brand-content h1{font-size:clamp(24px,5vw,32px)}.features{gap:15px}}@media (max-width:480px){.login-page{padding:15px}.login-brand{padding:30px 20px}.brand-content h1{font-size:clamp(22px,6vw,28px)}.brand-content>p{margin-bottom:30px}.login-form-section{padding:30px 20px}.form-wrapper h2{font-size:clamp(18px,5vw,24px)}.form-group input{padding:11px 15px}.button[type=submit]{padding:12px}}.mahasiswa-dashboard{background:linear-gradient(135deg,#e3f2fd,#bbdefb 25%,#90caf9 50%,#64b5f6 75%,#42a5f5);margin:0 auto;max-width:1600px;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.mahasiswa-dashboard:before{animation:bgMove 20s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#ffffff4d 0,#0000 50%),radial-gradient(circle at 80% 80%,#2196f333 0,#0000 50%),radial-gradient(circle at 40% 20%,#64b5f633 0,#0000 50%);content:"";height:100%;left:0;position:fixed;top:0;width:100%;z-index:0}@keyframes bgMove{0%,to{transform:translate(0)}50%{transform:translate(20px,20px)}}.mahasiswa-dashboard>*{position:relative;z-index:1}.dashboard-header{animation:slideDown .6s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#1976d2f2,#0d47a1f2);border:1px solid #fff3;border-radius:25px;box-shadow:0 20px 60px #1976d266,0 0 40px #2196f34d,inset 0 1px 0 #fff3;margin-bottom:2.5rem;overflow:hidden}.dashboard-header:before{animation:shine 3s infinite;background:linear-gradient(45deg,#0000,#ffffff0d,#0000);content:"";height:200%;left:-50%;position:absolute;top:-50%;transform:rotate(45deg);width:200%}.profile-avatar-large{animation:pulse 2s ease-in-out infinite;border:4px solid #ffffff80;box-shadow:0 10px 30px #0003,0 0 20px #2196f399,inset 0 0 20px #fff3;position:relative}.profile-details h1{font-size:2.2rem;font-weight:700;letter-spacing:-.5px;text-shadow:0 2px 10px #fdfdfd4d}.nim-display{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fafafae6;border-radius:20px;display:inline-block;font-size:1.15rem;font-weight:600;padding:.4rem 1rem}.semester-display{background:#f9f9f9e8;border-radius:20px;display:inline-flex;font-size:1rem;gap:.6rem;margin-top:.8rem;padding:.5rem 1rem}.stats-grid{grid-gap:2rem;gap:2rem;margin-bottom:2.5rem}.stat-card{animation:fadeInUp .6s ease-out backwards;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #fffc;border-radius:20px;box-shadow:0 8px 32px #0000001a,inset 0 1px 0 #fff;padding:2rem;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.stat-card:first-child{animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.2s}.stat-card:nth-child(3){animation-delay:.3s}.stat-card:nth-child(4){animation-delay:.4s}.stat-card:before{background:linear-gradient(135deg,#0000,#2196f30d);height:100%;opacity:0;transition:opacity .3s ease;width:100%}.stat-card:hover{box-shadow:0 20px 60px #00000026,0 0 30px #2196f34d,inset 0 1px 0 #fff;transform:translateY(-10px) scale(1.02)}.stat-card:hover:before{opacity:1}.stat-icon{box-shadow:0 8px 20px #0000004d;font-size:2rem;height:70px;position:relative;width:70px}.stat-icon:after{background:linear-gradient(135deg,#ffffff4d,#0000);border-radius:16px;content:"";inset:0;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:2px;position:absolute}.stat-ipk .stat-icon{box-shadow:0 8px 20px #667eea66}.stat-ips .stat-icon{box-shadow:0 8px 20px #f093fb66}.stat-sks .stat-icon{box-shadow:0 8px 20px #4facfe66}.stat-keuangan .stat-icon{box-shadow:0 8px 20px #43e97b66}.stat-content h3{color:#546e7a;font-size:.85rem;font-weight:600;letter-spacing:1.5px;margin:0 0 .5rem}.stat-value{color:#1565c0;font-size:2.5rem;font-weight:800;text-shadow:0 2px 10px #1565c033}.stat-label{color:#78909c;font-size:.9rem;margin-top:.5rem}.content-grid{grid-gap:2rem;gap:2rem}.content-card{animation:fadeInUp .6s ease-out backwards;animation-delay:.5s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #fffc;border-radius:20px;box-shadow:0 8px 32px #0000001a,inset 0 1px 0 #fff;transition:all .3s ease}.content-card:hover{box-shadow:0 15px 40px #00000026,inset 0 1px 0 #fff;transform:translateY(-5px)}.card-header{background:linear-gradient(135deg,#1976d2e6,#0d47a1e6);border-bottom:1px solid #fff3;position:relative}.card-header:before{background:linear-gradient(90deg,#2196f3,#1976d2,#0000);bottom:0;content:"";height:2px;left:0;position:absolute;width:100%}.card-header h2{font-size:1.3rem;font-weight:700;gap:.7rem;text-shadow:0 2px 8px #0003}.jadwal-item{background:#fff9;border-left:4px solid #2196f3;border-radius:12px;overflow:hidden;padding:1.3rem;position:relative}.jadwal-item:before{background:linear-gradient(180deg,#2196f3,#1976d2);box-shadow:0 0 10px #2196f3;content:"";height:100%;left:0;position:absolute;top:0;width:4px}.jadwal-item:hover{background:#ffffffe6;box-shadow:0 5px 20px #2196f34d;transform:translateX(10px)}.jadwal-time{color:#1976d2;font-size:.95rem;font-weight:700;gap:.6rem;margin-bottom:.8rem}.jadwal-details h4{color:#0d47a1;font-size:1.1rem;font-weight:600;margin:0 0 .6rem}.jadwal-details p{color:#546e7a;margin:.3rem 0}.jadwal-details .lecturer{color:#78909c}.empty-state svg{filter:drop-shadow(0 0 10px rgba(33,150,243,.3));font-size:3.5rem;opacity:.4}.empty-state p{font-size:1.05rem}.keuangan-item{background:#fff9;border:1px solid #2196f31a;border-radius:12px;padding:1rem;transition:all .3s ease}.keuangan-item:hover{background:#ffffffe6;border-color:#2196f333;transform:translateX(5px)}.keuangan-item .label{color:#546e7a;font-size:.95rem;font-weight:600}.keuangan-item .value{color:#0d47a1;font-size:1.2rem;font-weight:800;text-shadow:0 2px 8px #0d47a133}.keuangan-item.paid .value{color:#43e97b;text-shadow:0 0 15px #43e97b80}.keuangan-item.unpaid .value{color:#f5576c;text-shadow:0 0 15px #f5576c80}.progress-bar-container{margin-top:1.5rem}.progress-bar{background:#2196f326;border:1px solid #2196f333;height:14px;margin-bottom:.7rem;position:relative}.progress-bar:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";inset:0;position:absolute}.progress-fill{box-shadow:0 0 20px #43e97b99;overflow:hidden;position:relative;transition:width .8s cubic-bezier(.65,0,.35,1)}.progress-fill:before{animation:progressShine 1.5s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";inset:0;position:absolute}@keyframes progressShine{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.progress-label{color:#1976d2;font-size:.9rem;font-weight:700;text-shadow:0 2px 5px #1976d21a}.alert-warning{animation:alertPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#f5576c1a,#f093fb1a);border:1px solid #f5576c33;border-radius:12px;color:#fca5a5;gap:1rem;padding:1.2rem}@keyframes alertPulse{0%,to{box-shadow:0 0 10px #f5576c33}50%{box-shadow:0 0 20px #f5576c66}}.alert-warning svg{color:#f5576c;filter:drop-shadow(0 0 8px rgba(245,87,108,.5));font-size:1.5rem}.quick-links{grid-gap:1.2rem;gap:1.2rem}.quick-link{background:#fff9;border:2px solid #2196f333;border-radius:16px;color:#1976d2;gap:1rem;overflow:hidden;padding:2rem 1.5rem;position:relative;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.quick-link:before{background:linear-gradient(135deg,#2196f3,#1976d2);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease}.quick-link:hover:before{opacity:1}.quick-link>*{position:relative;z-index:1}.quick-link:hover{border-color:#ffffff80;box-shadow:0 15px 40px #2196f366,0 0 30px #1976d24d;transform:translateY(-8px) scale(1.05)}.quick-link svg{font-size:2.5rem;transition:all .3s ease}.quick-link:hover svg{filter:drop-shadow(0 5px 15px rgba(255,255,255,.5));transform:scale(1.2) rotate(5deg)}.quick-link span{font-size:1rem;font-weight:700;letter-spacing:.5px}.loading-spinner{animation:fadeIn .3s ease-in;color:#1976d2;font-size:1.3rem}.mahasiswa-dashboard::-webkit-scrollbar{width:10px}.mahasiswa-dashboard::-webkit-scrollbar-track{background:#2196f31a;border-radius:10px}.mahasiswa-dashboard::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#2196f3,#1976d2);border-radius:10px;box-shadow:0 0 10px #2196f380}.mahasiswa-dashboard::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#1976d2,#0d47a1)}@media (max-width:1200px){.content-grid{grid-template-columns:1fr}}@media (max-width:768px){.mahasiswa-dashboard{padding:1rem}.dashboard-header{padding:1.5rem}.profile-section{flex-direction:column;text-align:center}.profile-avatar-large{height:100px;width:100px}.profile-details h1{font-size:1.6rem}.stats-grid{gap:1.2rem;grid-template-columns:1fr}.stat-card{padding:1.5rem}.stat-icon{font-size:1.6rem;height:60px;width:60px}.stat-value{font-size:2rem}.content-grid{gap:1.5rem}.content-grid,.quick-links{grid-template-columns:1fr}.quick-link{padding:1.5rem 1rem}}@media (max-width:480px){.mahasiswa-dashboard{padding:.8rem}.dashboard-header{padding:1.2rem}.profile-avatar-large{height:80px;width:80px}.profile-details h1{font-size:1.3rem}.nim-display{font-size:.95rem;padding:.3rem .8rem}.semester-display{font-size:.85rem;padding:.4rem .8rem}.stat-card{flex-direction:column;gap:1rem;text-align:center}.stat-value{font-size:1.8rem}.card-header h2{font-size:1.1rem}.jadwal-item{padding:1rem}.keuangan-item{flex-direction:column;gap:.5rem;text-align:center}}.dashboard-header{border-radius:20px;box-shadow:0 10px 30px #667eea4d;color:#fff;padding:2.5rem}.profile-section{align-items:center;display:flex;gap:2rem}.profile-avatar-large{border:4px solid #ffffff4d;box-shadow:0 5px 20px #0003;height:100px;overflow:hidden;width:100px}.profile-avatar-large img{height:100%;object-fit:cover;width:100%}.profile-details h1{font-size:2rem;font-weight:600;margin:0 0 .5rem}.nim-display{font-size:1.1rem;font-weight:500;margin:.3rem 0;opacity:.95}.semester-display{align-items:center;display:flex;font-size:.95rem;gap:.5rem;margin-top:.5rem;opacity:.9}.stat-card{border-radius:15px;box-shadow:0 4px 15px #00000014;gap:1.5rem}.stat-card:hover{box-shadow:0 8px 25px #0000001f}.stat-icon{font-size:1.8rem}.stat-ipk .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-ips .stat-icon{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-sks .stat-icon{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-keuangan .stat-icon{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-content h3{color:#6b7280;font-size:.9rem;font-weight:500;letter-spacing:.5px;margin:0 0 .3rem;text-transform:uppercase}.stat-label{color:#9ca3af;display:block;font-size:.85rem;margin-top:.3rem}.content-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.content-card{background:#fff;border-radius:15px;box-shadow:0 4px 15px #00000014;overflow:hidden}.card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.2rem 1.5rem}.card-header h2{align-items:center;display:flex;font-size:1.2rem;gap:.5rem}.jadwal-list{display:flex;flex-direction:column;gap:1rem}.jadwal-item{background:#f9fafb;border-left:4px solid #667eea;border-radius:8px;padding:1rem;transition:all .3s ease}.jadwal-item:hover{background:#f3f4f6;transform:translateX(5px)}.jadwal-time{align-items:center;color:#667eea;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;margin-bottom:.5rem}.jadwal-details h4{color:#1f2937;font-size:1.05rem;margin:0 0 .5rem}.jadwal-details p{color:#6b7280;font-size:.9rem;margin:.2rem 0}.jadwal-details .lecturer{color:#9ca3af;font-style:italic}.keuangan-summary{display:flex;flex-direction:column;gap:1rem}.keuangan-item{align-items:center;background:#f9fafb;border-radius:8px;display:flex;justify-content:space-between;padding:.8rem}.keuangan-item .label{color:#6b7280;font-weight:500}.keuangan-item .value{color:#1f2937;font-size:1.1rem;font-weight:700}.keuangan-item.paid .value{color:#10b981}.keuangan-item.unpaid .value{color:#ef4444}.progress-bar-container{margin-top:1rem}.progress-bar{background:#e5e7eb;border-radius:20px;height:12px;margin-bottom:.5rem}.progress-fill{background:linear-gradient(90deg,#43e97b,#38f9d7);border-radius:20px;transition:width .5s ease}.progress-label{color:#6b7280;font-size:.85rem;font-weight:600}.alert-warning{align-items:center;border-left:4px solid #f59e0b;border-radius:8px;display:flex;gap:.8rem;margin-top:1rem;padding:1rem}.alert-warning svg{color:#f59e0b;font-size:1.3rem}.quick-links{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.quick-link{align-items:center;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:2px solid #0000;border-radius:12px;color:#1f2937;display:flex;flex-direction:column;gap:.8rem;padding:1.5rem;text-decoration:none;transition:all .3s ease}.quick-link:hover{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 5px 15px #667eea4d;color:#fff;transform:translateY(-3px)}.quick-link svg{font-size:2rem}.quick-link span{font-size:.95rem;font-weight:600}.loading-spinner{color:#6b7280;font-size:1.2rem}@media (max-width:768px){.mahasiswa-dashboard{padding:1rem}.dashboard-header{padding:1.5rem}.profile-section{flex-direction:column;text-align:center}.profile-details h1{font-size:1.5rem}.content-grid,.quick-links,.stats-grid{grid-template-columns:1fr}}.dashboard{max-width:1400px}.dashboard-header h2{font-size:28px;margin-bottom:5px}.dashboard-header p{color:var(--text-secondary)}.stat-card{border-radius:8px}.stat-details h3{margin-bottom:5px}.stat-details p{color:var(--text-secondary)}.semester-aktif-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;margin-bottom:30px}.semester-header{align-items:center;border-bottom:2px solid #bae6fd;display:flex;gap:20px;margin-bottom:25px;padding-bottom:20px}.semester-icon{background:linear-gradient(135deg,#0ea5e9,#0284c7);border-radius:16px;box-shadow:0 8px 24px #0ea5e94d;color:#fff;height:70px;justify-content:center;width:70px}.semester-icon,.semester-title{align-items:center;display:flex}.semester-title{flex:1 1;gap:15px}.semester-title h3{color:#0c4a6e;font-size:24px;margin:0}.badge{padding:6px 16px}.badge-success{box-shadow:0 4px 12px #10b9814d;color:#fff}.badge-info{box-shadow:0 4px 12px #3b82f64d}.semester-content{padding:10px 0}.semester-info-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.semester-info-item label{color:#0369a1;display:block;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.semester-info-item h4{color:#0c4a6e;font-size:22px;font-weight:700;margin:0}.semester-info-item p{color:#075985;font-size:15px;font-weight:500;margin:0}.semester-empty-state{padding:50px 30px;text-align:center}.semester-empty-state .semester-icon.empty{align-items:center;background:linear-gradient(135deg,#e0f2fe,#bae6fd);border-radius:20px;box-shadow:0 8px 24px #0ea5e926;color:#0369a1;display:flex;height:90px;justify-content:center;margin:0 auto 25px;width:90px}.semester-empty-state h3{color:#0c4a6e;font-size:22px;margin:0 0 12px}.semester-empty-state p{color:#0369a1;font-size:15px;line-height:1.6;margin:0 auto 25px;max-width:500px}.sync-btn{border-radius:10px!important;font-size:15px!important;font-weight:600!important;padding:12px 24px!important;transition:all .3s ease!important}.sync-btn:hover{box-shadow:0 8px 20px #0ea5e94d!important;transform:translateY(-2px)}.sync-btn svg{transition:transform .3s ease}.sync-btn:hover svg{transform:rotate(180deg)}.charts-grid .card h3{margin-bottom:20px}.card-header-with-filter{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.card-header-with-filter h3{font-size:20px;margin:0}.program-filter-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;font-size:14px;font-weight:500;min-width:200px;padding:8px 16px;transition:all .3s ease}.program-filter-select:hover{border-color:#4f46e5}.program-filter-select:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.quick-actions{display:flex;flex-wrap:wrap;gap:15px;margin-top:15px}.top-students-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:20px}.top-student-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:25px}.top-student-card:hover{border-color:#4f46e5;box-shadow:0 8px 16px #0000001a;transform:translateY(-5px)}.top-student-card:first-child{background:linear-gradient(135deg,#fef3c7,#fde68a)}.top-student-card:first-child .rank-badge{background:linear-gradient(135deg,#f59e0b,#d97706)}.top-student-card:nth-child(2){background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}.top-student-card:nth-child(2) .rank-badge{background:linear-gradient(135deg,#818cf8,#6366f1)}.top-student-card:nth-child(3){background:linear-gradient(135deg,#fce7f3,#fbcfe8)}.top-student-card:nth-child(3) .rank-badge{background:linear-gradient(135deg,#ec4899,#db2777)}.rank-badge{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 8px #00000026;font-size:16px;font-weight:700;right:15px;top:15px}.student-photo{border:4px solid #fff;box-shadow:0 4px 12px #00000026;margin:0 auto 15px}.photo-placeholder{background:linear-gradient(135deg,#4f46e5,#6366f1);font-size:40px}.student-info h4{color:#1e293b;font-size:18px;margin-bottom:5px}.student-nim{color:#64748b;font-size:13px;font-weight:500;margin-bottom:8px}.student-program{color:#475569;font-size:14px;font-weight:500;margin-bottom:15px}.student-details{border-top:2px solid #fffc;display:flex;flex-direction:column;gap:8px;padding-top:12px}.detail-item{color:#334155;font-size:13px;justify-content:space-between}.detail-item strong{color:#1e293b}.ipk-badge{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:8px 12px}.ipk-value{color:#4f46e5;font-size:18px}.no-data{color:var(--text-secondary);font-size:14px;padding:40px 20px}@media (max-width:768px){.charts-grid,.stats-grid,.top-students-grid{grid-template-columns:1fr}.quick-actions{flex-direction:column}.quick-actions .btn{width:100%}.semester-header{gap:15px}.semester-header,.semester-title{align-items:flex-start;flex-direction:column}.semester-title{gap:10px}.semester-title h3{font-size:20px}.semester-info-grid{gap:20px;grid-template-columns:1fr}.semester-info-item h4{font-size:20px}.modern-header{border-radius:16px;min-height:140px}.modern-header .header-content{padding:20px 25px}.modern-header .header-icon-wrapper{border-radius:14px;height:55px;width:55px}.modern-header .header-icon{font-size:24px}.modern-header .header-title{font-size:22px}.modern-header .header-subtitle{font-size:13px}}@media (max-width:480px){.modern-header{border-radius:14px;min-height:auto}.modern-header .header-content{padding:18px 20px}.modern-header .header-left{gap:12px}.modern-header .header-icon-wrapper{border-radius:12px;height:50px;width:50px}.modern-header .header-icon{font-size:22px}.modern-header .header-title{font-size:20px}.modern-header .header-subtitle{font-size:12px;line-height:1.4}.modern-header .header-background:after,.modern-header .header-background:before{height:300px;width:300px}}.btn-sm{font-size:13px;padding:6px 12px}.spinner-small{animation:spin 1s linear infinite;border:2px solid #0000001a;border-left-color:#4f46e5;height:20px;width:20px}.krs-mahasiswa-container{background:linear-gradient(135deg,#e3f2fd,#bbdefb 50%,#90caf9);margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.krs-header{background:linear-gradient(135deg,#1976d2f2,#0d47a1f2);border-radius:20px;box-shadow:0 10px 30px #1976d24d;color:#fff;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:25px;padding:30px}.header-content h1,.krs-header{align-items:center;display:flex}.header-content h1{font-size:32px;gap:15px;margin:0 0 8px}.header-content p{font-size:16px;margin:0;opacity:.95}.header-info{display:flex;gap:15px}.info-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;flex-direction:column;gap:5px;min-width:150px;padding:12px 20px}.info-label{opacity:.9}.semester-selector{align-items:center;background:#fff;border-radius:15px;box-shadow:0 4px 15px #00000014;display:flex;gap:15px;margin-bottom:25px;padding:20px}.semester-selector label{align-items:center;color:#1565c0;display:flex;font-size:16px;font-weight:600;gap:8px}.semester-select{border:2px solid #bbdefb;border-radius:10px;color:#0d47a1;min-width:250px;padding:10px 20px}.semester-select:hover{border-color:#2196f3}.semester-select:focus{border-color:#1976d2;box-shadow:0 0 0 3px #2196f31a}.krs-tabs{margin-bottom:25px}.krs-tabs,.tab-btn{display:flex;gap:10px}.tab-btn{align-items:center;background:#fff;border:none;border-radius:12px;box-shadow:0 2px 10px #0000000d;color:#546e7a;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;justify-content:center;padding:15px 30px;transition:all .3s ease}.tab-btn:hover{background:#e3f2fd;box-shadow:0 4px 15px #2196f333;color:#1976d2;transform:translateY(-2px)}.tab-btn.active{background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 4px 20px #2196f366;color:#fff}.krs-content{background:#fff;border-radius:15px;box-shadow:0 4px 20px #00000014;min-height:400px;padding:25px}.loading-state{color:#78909c;padding:60px 20px}.spinner{border:4px solid #e3f2fd;border-top-color:#2196f3;margin-bottom:20px}.empty-state{color:#78909c}.empty-state svg{color:#bbdefb;font-size:64px}.empty-state h3{color:#546e7a;font-size:24px}.empty-state p{color:#90a4ae;margin:0 0 20px}.krs-summary{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.summary-card{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:12px;box-shadow:0 2px 10px #2196f31a;padding:20px;text-align:center}.summary-card h4{color:#1565c0;font-size:14px;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.summary-value{color:#0d47a1;font-size:36px;margin:0}.summary-value.success{color:#2e7d32}.summary-value.warning{color:#f57c00}.krs-actions-bar{flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:20px;padding:15px 0}.krs-actions-bar,.print-info{align-items:center;display:flex}.print-info{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:8px;color:#1565c0;flex:1 1;font-size:14px;gap:10px;padding:10px 15px}.print-info svg{flex-shrink:0;font-size:20px}.btn-print{background:linear-gradient(135deg,#4caf50,#2e7d32);border-radius:10px;box-shadow:0 4px 15px #4caf504d;display:inline-flex;font-size:16px;gap:10px;padding:12px 24px}.btn-print:hover{box-shadow:0 6px 20px #4caf5066}.btn-print:active{transform:translateY(0)}.krs-table-wrapper{border-radius:12px;box-shadow:0 2px 10px #0000000d;overflow-x:auto}.krs-table{background:#fff;border-collapse:collapse;width:100%}.krs-table thead{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.krs-table th{font-size:14px;font-weight:600;letter-spacing:.5px;padding:15px;text-align:left;text-transform:uppercase}.krs-table td{border-bottom:1px solid #e3f2fd;color:#546e7a;padding:15px}.krs-table tbody tr:hover{background:#f5f5f5}.nama-mk{color:#1565c0;font-weight:500}.status-badge{display:inline-flex;gap:5px}.status-badge.approved{background:#e8f5e9;color:#2e7d32}.status-badge.pending{background:#fff3e0;color:#f57c00}.status-badge.rejected{background:#ffebee;color:#c62828}.btn-action{display:inline-flex;padding:8px 12px}.btn-action.view{background:#e3f2fd;color:#1976d2}.btn-action.view:hover{background:#2196f3;color:#fff}.btn-action.delete{background:#ffebee;color:#c62828}.btn-action.delete:hover{background:#f44336;color:#fff}.isi-krs-section{min-height:400px}.isi-krs-header{align-items:center;border-bottom:2px solid #e3f2fd;display:flex;justify-content:space-between;margin-bottom:25px;padding-bottom:15px}.isi-krs-header h3{color:#1565c0;font-size:24px;margin:0}.selected-courses{margin-bottom:25px}.selected-courses h4{color:#1565c0;font-size:18px;margin:0 0 15px}.selected-courses-list{display:flex;flex-direction:column;gap:12px}.selected-course-item{align-items:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-left:4px solid #2196f3;border-radius:12px;display:flex;gap:15px;padding:15px;transition:all .3s ease}.selected-course-item:hover{box-shadow:0 4px 15px #2196f333;transform:translateX(5px)}.course-number{align-items:center;background:linear-gradient(135deg,#2196f3,#1976d2);border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:700;height:35px;justify-content:center;width:35px}.course-info{flex:1 1}.course-code{color:#0d47a1;font-weight:700;margin-bottom:4px}.course-name{color:#546e7a;font-size:15px}.course-sks{background:#ffffffb3;border-radius:20px;color:#1976d2;font-size:16px;font-weight:700;padding:6px 15px}.btn-remove{align-items:center;background:#ffebee;border:none;border-radius:50%;color:#c62828;cursor:pointer;display:flex;height:35px;justify-content:center;padding:8px;transition:all .3s ease;width:35px}.btn-remove:hover{background:#f44336;color:#fff;transform:rotate(90deg)}.empty-selection{color:#90a4ae;padding:80px 20px;text-align:center}.empty-selection svg{color:#bbdefb;font-size:72px;margin-bottom:20px}.empty-selection p{font-size:16px;margin:10px 0}.empty-selection .hint{color:#b0bec5;font-size:14px}.krs-footer{border-top:2px solid #e3f2fd;justify-content:space-between;margin-top:30px;padding-top:20px}.krs-footer,.total-sks{align-items:center;display:flex}.total-sks{color:#546e7a;font-size:18px;font-weight:600;gap:15px}.sks-value{color:#2196f3;font-size:28px;font-weight:700}.sks-value.exceed{animation:shake .5s ease;color:#f44336}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.footer-actions{display:flex;gap:12px}.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 4px 15px #2196f34d}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #2196f366}.btn-primary:disabled{background:#b0bec5;box-shadow:none}.btn-secondary{border:2px solid #bbdefb;color:#546e7a}.btn-secondary:hover{background:#e3f2fd;border-color:#2196f3;color:#1976d2}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content.large{max-width:900px}.modal-header{border-bottom:2px solid #e3f2fd}.modal-header h3{color:#1565c0;gap:12px}.btn-close{background:#ffebee;border-radius:50%;color:#c62828;font-size:20px}.btn-close:hover{background:#f44336;color:#fff;transform:rotate(90deg)}.modal-footer{align-items:center;border-top:2px solid #e3f2fd;justify-content:space-between}.search-box{background:#f5f5f5;border:2px solid #e0e0e0;border-radius:12px;gap:12px;margin-bottom:20px;padding:12px 20px;transition:all .3s ease}.search-box:focus-within{background:#fff;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.search-box svg{color:#90a4ae;font-size:20px}.search-box input{background:#0000;border:none;color:#546e7a;flex:1 1;font-size:16px;outline:none}.courses-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.course-item{background:#f5f5f5;border:2px solid #0000;border-radius:12px;cursor:pointer;padding:15px 20px;transition:all .3s ease}.course-item:hover{background:#e3f2fd;border-color:#2196f3;transform:translateX(5px)}.course-item.selected{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#2196f3;pointer-events:none}.course-details{flex:1 1}.selected-info{color:#546e7a;font-weight:600}.detail-row{border-bottom:1px solid #e3f2fd;justify-content:space-between;padding:12px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#546e7a;font-weight:600}.detail-value{color:#1565c0;font-weight:500}@media (max-width:768px){.krs-mahasiswa-container{padding:15px}.krs-header{align-items:flex-start;flex-direction:column}.header-info{flex-direction:column;width:100%}.info-card{width:100%}.semester-selector{align-items:flex-start;flex-direction:column}.semester-select{width:100%}.krs-tabs{flex-direction:column}.krs-summary{grid-template-columns:repeat(2,1fr)}.krs-actions-bar{align-items:stretch;flex-direction:column;justify-content:center}.print-info{width:100%}.btn-print{justify-content:center;width:100%}.krs-table-wrapper{overflow-x:scroll}.krs-footer{align-items:flex-start;flex-direction:column;gap:20px}.footer-actions{width:100%}.btn-primary,.btn-secondary{flex:1 1}.modal-content{max-height:95vh;max-width:100%}}@media print{.krs-mahasiswa-container{background:#fff}.action-buttons,.btn-print,.krs-actions-bar,.krs-header,.krs-tabs,.modal-overlay,.semester-selector{display:none!important}.krs-content{box-shadow:none}.krs-table{border:1px solid #000}.krs-table td,.krs-table th{border:1px solid #000;padding:8px}}.khs-mahasiswa-container{margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.khs-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 10px 40px #667eea4d;margin-bottom:30px;overflow:hidden;padding:40px;position:relative}.btn-print,.selector-icon{color:#667eea}.semester-select:hover{border-color:#667eea}.semester-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.stat-card:before{background:linear-gradient(90deg,#667eea,#764ba2)}.stat-card.gradient-blue:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.stat-card.gradient-green:before{background:linear-gradient(90deg,#10b981,#059669)}.stat-card.gradient-purple:before{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.gradient-blue .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.gradient-green .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}.gradient-purple .stat-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-badge{border-radius:20px;color:#fff;display:inline-block;font-size:12px;margin-top:8px;padding:4px 12px}.khs-table-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;overflow:hidden}.table-header{border-bottom:2px solid #f3f4f6;justify-content:space-between;padding:24px}.table-header,.table-header h3{align-items:center;display:flex}.table-header h3{color:#1f2937;gap:12px}.modern-table thead{background:linear-gradient(135deg,#667eea,#764ba2)}.modern-table thead th{color:#fff;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.modern-table tbody tr{border-bottom:1px solid #f3f4f6}.modern-table tbody tr:hover{background:#f9fafb}.modern-table tbody td{color:#374151;font-size:14px;padding:16px}.modern-table tfoot tr{background:#f9fafb;font-weight:600}.modern-table tfoot td{color:#1f2937;font-size:15px;padding:16px}.text-right{padding-right:20px!important}.code-badge{background:#f3f4f6;border-radius:6px;color:#374151;font-family:Courier New,monospace;padding:4px 10px}.code-badge,.sks-badge{display:inline-block;font-size:13px;font-weight:600}.sks-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;color:#fff;padding:4px 12px}.grade-badge{border-radius:8px;font-size:14px;padding:6px 16px}.info-box p{color:#78350f}@media (max-width:768px){.khs-mahasiswa-container{padding:15px}.khs-header{padding:24px 20px}.header-title{font-size:24px}.header-subtitle{font-size:14px}.icon-wrapper{height:50px;width:50px}.header-icon{font-size:24px}.stats-grid{grid-template-columns:1fr}.stat-value{font-size:28px}.table-container{overflow-x:scroll}.modern-table{min-width:800px}.btn-action span{display:none}}@media (max-width:480px){.header-content{align-items:flex-start;flex-direction:column}.header-actions{width:100%}.btn-action{flex:1 1;justify-content:center}}.akm-mahasiswa-container{margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.akm-header{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:20px;box-shadow:0 10px 40px #f093fb4d;margin-bottom:30px;overflow:hidden;padding:40px;position:relative}.header-actions{gap:12px}.btn-action{border-radius:12px;box-shadow:0 4px 15px #0000001a;font-size:14px;gap:8px;padding:12px 24px}.btn-print{color:#f5576c}.btn-print:hover{box-shadow:0 6px 20px #00000026}.semester-selector-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;padding:24px}.selector-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.selector-icon{color:#f5576c;font-size:24px}.selector-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.semester-select{background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#1f2937;cursor:pointer;font-size:15px;font-weight:500;padding:14px 20px;transition:all .3s ease;width:100%}.semester-select:hover{border-color:#f5576c}.semester-select:focus{border-color:#f5576c;box-shadow:0 0 0 3px #f5576c1a;outline:none}.ipk-highlight-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 10px 40px #667eea4d;margin-bottom:30px;overflow:hidden;padding:40px;position:relative}.ipk-background{background:radial-gradient(circle at 80% 20%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 20% 80%,#ffffff1a 0,#0000 50%);bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0}.ipk-content{flex-wrap:wrap;gap:30px;justify-content:space-between;position:relative;z-index:1}.ipk-content,.ipk-left{align-items:center;display:flex}.ipk-left{gap:24px}.ipk-icon-wrapper{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:20px;display:flex;height:80px;justify-content:center;width:80px}.ipk-icon-wrapper svg{color:#fff;font-size:40px}.ipk-label{color:#ffffffe6;font-size:16px;font-weight:500;margin:0 0 8px}.ipk-value{color:#fff;font-size:64px;margin:0 0 12px;text-shadow:0 4px 20px #0003}.ipk-status-badge{border-radius:20px;color:#fff;display:inline-block;font-size:14px;font-weight:600;padding:8px 20px}.ips-mini-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:16px;min-width:180px;padding:24px;text-align:center}.mini-label{color:#ffffffe6;font-size:14px;font-weight:500;margin:0 0 8px}.mini-value{color:#fff;font-size:36px;font-weight:700;margin:0;text-shadow:0 2px 10px #0003}.akm-stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.akm-stat-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;display:flex;gap:20px;overflow:hidden;padding:24px;position:relative;transition:all .3s ease}.akm-stat-card:before{content:"";height:4px;left:0;position:absolute;right:0;top:0}.akm-stat-card.blue:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.akm-stat-card.green:before{background:linear-gradient(90deg,#10b981,#059669)}.akm-stat-card.purple:before{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.akm-stat-card.orange:before{background:linear-gradient(90deg,#f59e0b,#d97706)}.akm-stat-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-4px)}.stat-icon-circle{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:28px;height:60px;justify-content:center;width:60px}.akm-stat-card.blue .stat-icon-circle{background:linear-gradient(135deg,#3b82f6,#2563eb)}.akm-stat-card.green .stat-icon-circle{background:linear-gradient(135deg,#10b981,#059669)}.akm-stat-card.purple .stat-icon-circle{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.akm-stat-card.orange .stat-icon-circle{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-title{color:#6b7280;font-size:14px;font-weight:500;margin:0 0 8px}.stat-number{color:#1f2937;font-size:28px;font-weight:700;margin:0}.stat-number.small{font-size:18px}.details-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;overflow:hidden}.details-grid{grid-gap:1px;background:#e5e7eb;display:grid;gap:1px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.detail-item{background:#fff;padding:20px 24px}.detail-label{font-size:13px}.detail-value{font-size:16px}.detail-value.highlight{color:#667eea;font-size:20px}.status-badge{padding:6px 16px;width:-webkit-fit-content;width:fit-content}.status-badge.active{background:#10b981}.status-badge.inactive{background:#ef4444}.empty-state-full,.loading-state{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:80px 20px}.empty-state-full{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-top:20px}.empty-state-full svg{color:#d1d5db;margin-bottom:20px}.empty-state-full h3{color:#1f2937;font-size:24px;font-weight:600;margin:0 0 8px}.empty-state-full p{color:#6b7280;font-size:16px;margin:0}.info-box strong{margin-bottom:4px}.info-box p{color:#1e40af;font-size:14px;line-height:1.6;margin:0}@media (max-width:768px){.akm-mahasiswa-container{padding:15px}.akm-header,.ipk-highlight-card{padding:24px 20px}.header-title{font-size:24px}.icon-wrapper{height:50px;width:50px}.header-icon{font-size:24px}.ipk-value{font-size:48px}.ipk-icon-wrapper{height:60px;width:60px}.ipk-icon-wrapper svg{font-size:30px}.akm-stats-grid,.details-grid{grid-template-columns:1fr}.btn-action span{display:none}}@media (max-width:480px){.header-content,.ipk-content,.ipk-left{align-items:flex-start;flex-direction:column}.header-actions,.ips-mini-card{width:100%}.btn-action{flex:1 1;justify-content:center}}.tagihan-mahasiswa-container{margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.tagihan-header{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:20px;box-shadow:0 10px 40px #f093fb4d;margin-bottom:30px;overflow:hidden;padding:40px;position:relative}.stat-card.green:before{background:linear-gradient(90deg,#10b981,#059669)}.stat-card.red:before{background:linear-gradient(90deg,#ef4444,#dc2626)}.stat-card.red .stat-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.filter-header{margin-bottom:16px}.filter-header svg{color:#f5576c}.filter-btn:hover{border-color:#f5576c;color:#f5576c}.filter-btn.active{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 15px #f5576c4d}.tagihan-list-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;overflow:hidden}.tagihan-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));padding:24px}.tagihan-item{background:#fff;border:2px solid #e5e7eb;border-radius:16px;overflow:hidden;padding:20px}.tagihan-item:before{background:linear-gradient(90deg,#f093fb,#f5576c);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.tagihan-item:hover{border-color:#f5576c;box-shadow:0 8px 25px #f5576c26}.tagihan-item:hover:before{transform:scaleX(1)}.tagihan-header-section{margin-bottom:20px}.tagihan-title{align-items:flex-start;gap:12px;justify-content:space-between;margin-bottom:12px}.tagihan-title h4{color:#1f2937;flex:1 1;font-size:18px;font-weight:600;margin:0}.status-badge{font-size:12px;padding:6px 12px}.status-badge svg{font-size:14px}.tagihan-amount{color:#f5576c;font-size:28px;margin-bottom:16px}.tagihan-details{border-top:1px solid #e5e7eb;gap:12px;margin-bottom:16px;padding-top:16px}.detail-row{align-items:flex-start;display:flex;gap:12px}.detail-row.full-width{flex-direction:column}.detail-icon{color:#6b7280;font-size:18px}.detail-content{display:flex;flex:1 1;flex-direction:column;gap:4px}.tagihan-actions{border-top:1px solid #e5e7eb;display:flex;gap:10px;padding-top:16px}.btn-bayar,.btn-detail{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 16px;transition:all .3s ease}.btn-bayar{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 15px #f5576c4d;color:#fff}.btn-bayar:hover{box-shadow:0 6px 20px #f5576c66;transform:translateY(-2px)}.btn-detail{background:#f3f4f6;color:#6b7280}.btn-detail:hover{background:#e5e7eb;color:#1f2937}.spinner{border-top-color:#f5576c}.tagihan-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.tagihan-card:hover{border-color:#f59e0b;box-shadow:0 15px 40px #f9731626;transform:translateY(-5px)}.tagihan-card.overdue{background:linear-gradient(180deg,#fef2f2 0,#fff 60px);border-color:#ef4444}.tagihan-card.overdue:hover{border-color:#dc2626;box-shadow:0 15px 40px #ef444433}.tagihan-card-header{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-bottom:2px solid #e2e8f0;justify-content:space-between;padding:20px}.tagihan-card-header,.tagihan-type{align-items:center;display:flex;gap:15px}.tagihan-type{flex:1 1}.type-icon{align-items:center;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:12px;box-shadow:0 4px 12px #f5576c4d;color:#fff;display:flex;flex-shrink:0;font-size:22px;height:48px;justify-content:center;width:48px}.type-title{color:#1a202c;font-size:18px;font-weight:700;margin:0 0 5px}.type-subtitle{color:#718096;font-size:13px;font-weight:500;margin:0}.status-badge-new{align-items:center;border-radius:20px;box-shadow:0 2px 8px #0000001a;display:flex;font-size:12px;font-weight:700;gap:6px;letter-spacing:.5px;padding:8px 14px;text-transform:uppercase;white-space:nowrap}.tagihan-card-body{display:flex;flex:1 1;flex-direction:column;gap:20px;padding:24px}.amount-section{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:12px;box-shadow:0 6px 20px #f5576c40;padding:20px;text-align:center}.amount-label{color:#ffffffe6;font-size:13px;font-weight:600;letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.amount-value{color:#fff;font-size:28px;font-weight:700;text-shadow:0 2px 4px #0000001a}.info-grid{grid-gap:16px;gap:16px}.info-item{border:1px solid #e2e8f0;border-radius:10px;gap:12px;padding:12px}.info-icon{color:#f5576c;flex-shrink:0;font-size:20px;margin-top:2px}.info-label{font-size:11px;margin-bottom:4px}.info-label,.info-value{display:block}.keterangan-section{background:#fffbeb;border-left:4px solid #f59e0b;border-radius:8px;display:flex;gap:12px;padding:12px}.keterangan-section svg{color:#f59e0b;flex-shrink:0;font-size:18px;margin-top:2px}.keterangan-text{color:#92400e;font-size:14px;line-height:1.5}.tagihan-card-footer{background:#f7fafc;border-top:2px solid #e2e8f0;display:flex;gap:12px;padding:20px}.tagihan-card-footer.paid{align-items:center;background:linear-gradient(135deg,#d1fae5,#a7f3d0);justify-content:space-between}.paid-badge{align-items:center;color:#065f46;display:flex;font-size:14px;font-weight:700;gap:10px}.paid-badge svg{font-size:20px}.btn-primary-action{align-items:center;background:linear-gradient(135deg,#f093fb,#f5576c);border:none;border-radius:10px;box-shadow:0 4px 12px #f5576c4d;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:700;gap:10px;justify-content:center;padding:14px 24px;transition:all .3s ease}.btn-primary-action:hover{box-shadow:0 10px 25px #f5576c66;transform:translateY(-2px)}.btn-secondary-action{align-items:center;background:#fff;border:2px solid #f5576c;border-radius:10px;color:#f5576c;cursor:pointer;display:flex;font-size:14px;font-weight:700;justify-content:center;padding:14px 20px;transition:all .3s ease}.btn-secondary-action:hover{background:#f5576c;color:#fff;transform:translateY(-2px)}.info-box{background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b}.info-box svg{color:#d97706}.info-box strong{color:#92400e}.info-box ul{color:#78350f}@media (max-width:768px){.tagihan-mahasiswa-container{padding:15px}.tagihan-header{padding:24px 20px}.header-title{font-size:24px}.icon-wrapper{height:50px;width:50px}.header-icon{font-size:24px}.stats-grid{grid-template-columns:1fr}.stat-value{font-size:20px}.tagihan-grid{grid-template-columns:1fr;padding:16px}.filter-buttons{flex-direction:column}.filter-btn{width:100%}.info-grid{grid-template-columns:1fr}.tagihan-card-footer{flex-direction:column}.btn-primary-action,.btn-secondary-action{width:100%}.tagihan-card-header{padding:16px}.type-icon{font-size:20px;height:42px;width:42px}.type-title{font-size:16px}.amount-value{font-size:24px}.tagihan-actions{flex-direction:column}.btn-bayar,.btn-detail{width:100%}}@media (max-width:480px){.tagihan-title{align-items:flex-start;flex-direction:column}.status-badge{align-self:flex-start}.tagihan-amount{font-size:24px}.header-left{align-items:flex-start;flex-direction:column;gap:12px}.tagihan-card-body,.tagihan-card-footer{padding:16px}}.riwayat-pembayaran-container{margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.riwayat-header{background:linear-gradient(135deg,#11998e,#38ef7d);border-radius:20px;box-shadow:0 10px 40px #11998e4d;margin-bottom:30px;overflow:hidden;padding:40px;position:relative}.header-backdrop{background:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff1a 0,#0000 50%)}.stat-card{border:1px solid #e5e7eb}.stat-card:before{height:4px}.stat-card.blue:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.stat-card.green:before{background:linear-gradient(90deg,#11998e,#38ef7d)}.stat-card.success:before{background:linear-gradient(90deg,#10b981,#059669)}.stat-card.orange:before{background:linear-gradient(90deg,#f59e0b,#d97706)}.stat-card:hover{box-shadow:0 8px 30px #0000001f}.stat-icon{border-radius:16px}.stat-card.blue .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-card.green .stat-icon{background:linear-gradient(135deg,#11998e,#38ef7d)}.stat-card.success .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}.stat-value{line-height:1.2}.filter-card{border:1px solid #e5e7eb;margin-bottom:24px;padding:24px}.filter-header{gap:12px}.filter-header svg{color:#11998e;font-size:24px}.filter-header h3{color:#1f2937;font-size:18px;font-weight:600}.filter-content{display:flex;flex-direction:column;gap:20px}.filter-section{flex-direction:column;gap:12px}.filter-label{color:#374151;font-size:14px;font-weight:600}.filter-btn{border:2px solid #e5e7eb;border-radius:12px;color:#6b7280;padding:10px 20px}.filter-btn:hover{border-color:#11998e;color:#11998e}.filter-btn.active{background:linear-gradient(135deg,#11998e,#38ef7d);border-color:#0000;box-shadow:0 4px 15px #11998e4d}.date-range-inputs{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.date-input-group{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;display:flex;gap:10px;padding:10px 16px;transition:all .3s ease}.date-input-group:focus-within{background:#fff;border-color:#11998e}.date-input-group svg{color:#6b7280;font-size:18px}.date-input{background:#0000;border:none;color:#1f2937;font-family:inherit;font-size:14px;min-width:140px;outline:none}.date-separator{color:#6b7280;font-size:14px;font-weight:500}.btn-reset{background:#ef4444;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-reset:hover{background:#dc2626;box-shadow:0 4px 15px #ef44444d;transform:translateY(-2px)}.pembayaran-list-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;overflow:hidden}.card-header{border-bottom:2px solid #f3f4f6;padding:24px}.card-header h3{gap:12px}.table-count{background:#f3f4f6;color:#6b7280;font-size:13px}.pembayaran-timeline{padding:24px;position:relative}.timeline-item{display:flex;gap:24px;padding-bottom:32px}.timeline-item:not(:last-child):before{background:linear-gradient(180deg,#e5e7eb 0,#f3f4f6);bottom:0;content:"";left:19px;position:absolute;top:40px;width:2px}.timeline-marker{align-items:center;border-radius:12px;box-shadow:0 4px 15px #0000001a;color:#fff;display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;position:relative;width:40px;z-index:1}.timeline-marker.success{background:linear-gradient(135deg,#10b981,#059669)}.timeline-marker.pending{background:linear-gradient(135deg,#f59e0b,#d97706)}.timeline-marker.failed{background:linear-gradient(135deg,#ef4444,#dc2626)}.timeline-content{flex:1 1}.pembayaran-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:20px;transition:all .3s ease}.pembayaran-card:hover{border-color:#11998e;box-shadow:0 8px 25px #11998e26}.pembayaran-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.pembayaran-info{flex:1 1}.pembayaran-title{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 8px}.pembayaran-desc{color:#6b7280;font-size:14px;margin:0}.status-badge{font-size:13px;gap:6px;padding:8px 16px;white-space:nowrap}.status-badge svg{font-size:16px}.status-badge.success{background:linear-gradient(135deg,#10b981,#059669)}.status-badge.pending{background:linear-gradient(135deg,#f59e0b,#d97706)}.status-badge.failed{background:linear-gradient(135deg,#ef4444,#dc2626)}.pembayaran-details{display:flex;flex-direction:column;gap:16px}.detail-row{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.detail-item{align-items:flex-start;background:#f9fafb;border-radius:12px;gap:12px;padding:12px}.detail-icon{color:#11998e;flex-shrink:0;font-size:20px;margin-top:2px}.detail-item>div{display:flex;flex-direction:column;gap:4px}.detail-label{color:#6b7280;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#1f2937;font-size:14px;font-weight:600}.payment-method{align-items:center;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-left:4px solid #10b981;border-radius:8px;color:#065f46;display:flex;font-size:14px;font-weight:500;gap:10px;padding:12px 16px}.payment-method svg{color:#10b981;font-size:18px}.pembayaran-actions{border-top:1px solid #e5e7eb;margin-top:16px;padding-top:16px}.btn-download{align-items:center;background:linear-gradient(135deg,#11998e,#38ef7d);border:none;border-radius:12px;box-shadow:0 4px 15px #11998e4d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .3s ease}.btn-download:hover{box-shadow:0 6px 20px #11998e66;transform:translateY(-2px)}.btn-download svg{font-size:16px}.empty-state,.loading-state{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.spinner{border-top-color:#11998e;margin-bottom:16px}.empty-state p{font-weight:500;margin:0 0 8px}.empty-state small{color:#9ca3af}.info-box{align-items:flex-start;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-left:4px solid #3b82f6;border-radius:12px;display:flex;gap:16px;padding:16px 20px}.info-box svg{color:#1e40af;flex-shrink:0;font-size:24px;margin-top:2px}.info-box strong{color:#1e3a8a;display:block;font-size:15px;margin-bottom:8px}.info-box ul{color:#1e40af;font-size:14px;line-height:1.8;margin:0;padding-left:20px}.info-box li{margin-bottom:4px}@media (max-width:768px){.riwayat-pembayaran-container{padding:15px}.riwayat-header{padding:24px 20px}.header-title{font-size:24px}.icon-wrapper{height:50px;width:50px}.header-icon{font-size:24px}.stats-grid{grid-template-columns:1fr}.stat-value{font-size:20px}.filter-content{gap:16px}.date-range-inputs{align-items:stretch;flex-direction:column}.btn-reset,.date-input-group{width:100%}.date-separator{text-align:center}.timeline-item{gap:16px}.timeline-item:before{left:15px}.timeline-marker{font-size:16px;height:32px;width:32px}.detail-row{grid-template-columns:1fr}.pembayaran-header{align-items:flex-start;flex-direction:column}.status-badge{align-self:flex-start}}@media (max-width:480px){.pembayaran-timeline{padding:16px}.filter-buttons{flex-direction:column}.filter-btn{width:100%}}.students-page{box-sizing:border-box;max-width:100%;padding:0 20px;width:100%}.page-header{gap:15px}.page-header h2{font-size:clamp(20px,4vw,28px);margin-bottom:5px}.page-header p{color:var(--text-secondary)}.btn-info,.page-header p{font-size:clamp(12px,2vw,14px)}.btn-info{align-items:center;background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;border-radius:8px;box-shadow:0 4px 12px #06b6d44d;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:8px;padding:10px 16px;transition:all .3s ease;white-space:nowrap}.btn-info:hover:not(:disabled){box-shadow:0 6px 16px #06b6d466;transform:translateY(-2px)}.btn-info:disabled{cursor:not-allowed;opacity:.6}.filters-card{margin-bottom:20px}.filters-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.search-box svg{color:var(--text-secondary)}.search-box input{color:#010101;padding-left:40px}.btn-icon{border-radius:4px;color:var(--text-secondary);padding:6px}.btn-icon:hover{background-color:var(--light-color);color:var(--primary-color)}.btn-icon-danger:hover{color:var(--danger-color)}.pagination{align-items:center;border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-top:20px;padding-top:20px}.pagination-info{color:var(--text-secondary);font-size:clamp(12px,2vw,14px)}.pagination-buttons{display:flex;flex-wrap:wrap;gap:10px}@media (max-width:1200px){.students-page{padding:0 15px}.filters-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width:992px){.page-header{align-items:flex-start;flex-direction:column}.header-actions{justify-content:flex-start;width:100%}.filters-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}@media (max-width:768px){.students-page{padding:0 10px}.page-header{margin-bottom:20px}.header-actions{flex-direction:column;width:100%}.header-actions .btn,.header-actions button{justify-content:center;width:100%}.filters-grid{grid-template-columns:1fr}.pagination{align-items:stretch;flex-direction:column}.pagination-info{text-align:center}.pagination-buttons{justify-content:center;width:100%}.pagination button{flex:1 1;min-width:80px}}@media (max-width:576px){.btn-info{font-size:12px;padding:8px 12px}.btn-info svg{height:14px;width:14px}.form-control,.search-box input{font-size:14px}}.modal-overlay{background-color:#00000080}.modal-content{animation:modalSlideIn .3s ease-out}.modal-large{max-width:1200px}.modal-header{border-bottom:1px solid var(--border-color);padding:20px 24px}.modal-header h3{color:var(--dark-color)}.modal-close{color:var(--text-secondary);font-size:28px;height:32px;padding:0;width:32px}.modal-close:hover{background-color:var(--light-color);color:var(--dark-color)}.modal-footer{border-top:1px solid var(--border-color)}.biodata-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr)}.biodata-avatar{align-items:center;background:#fff;border:2px solid #e3f2fd;border-radius:50%;box-shadow:0 2px 8px #0000001a;display:flex;height:60px;justify-content:center;overflow:hidden;width:60px}.biodata-avatar img{height:100%;object-fit:cover;width:100%}.biodata-section{background:var(--light-color);border-radius:8px;padding:20px}.biodata-section-title{border-bottom:2px solid var(--primary-color);color:var(--primary-color);font-size:16px;font-weight:600;margin:0 0 16px;padding-bottom:12px}.biodata-row{border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:10px 0}.biodata-row:last-child{border-bottom:none}.biodata-label{color:var(--text-secondary);flex:0 0 45%;font-size:14px;font-weight:500}.biodata-value{word-wrap:break-word;color:var(--dark-color);flex:0 0 50%;font-size:14px;text-align:right}.biodata-value strong{color:var(--primary-color)}@media (max-width:1024px){.biodata-grid{grid-template-columns:1fr}}@media (max-width:768px){.modal-overlay{align-items:flex-start;padding:10px}.modal-content{margin:20px 0}.biodata-row{flex-direction:column;gap:5px}.biodata-label,.biodata-value{flex:1 1;text-align:left}.biodata-value{font-weight:500}}.top-students-section{margin-bottom:30px}.section-title{font-size:20px;margin-bottom:20px}.top-students-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.top-student-card{background:#fff;border:2px solid #0000;border-radius:16px;box-shadow:0 4px 16px #00000014;overflow:hidden;padding:24px;position:relative;transition:all .3s ease}.top-student-card:before{content:"";height:4px;left:0;position:absolute;right:0;top:0}.top-student-card.rank-1:before,.top-student-card:before{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.top-student-card.rank-2:before{background:linear-gradient(90deg,#94a3b8,#64748b)}.top-student-card.rank-3:before{background:linear-gradient(90deg,#d97706,#b45309)}.top-student-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.rank-badge{align-items:center;border-radius:50%;box-shadow:0 2px 8px #00000026;color:#fff;display:flex;font-size:18px;font-weight:800;height:40px;justify-content:center;position:absolute;right:16px;top:16px;width:40px}.rank-1 .rank-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.rank-2 .rank-badge{background:linear-gradient(135deg,#94a3b8,#64748b)}.rank-3 .rank-badge{background:linear-gradient(135deg,#d97706,#b45309)}.student-photo{border:4px solid #f3f4f6;border-radius:50%;box-shadow:0 4px 12px #0000001a;height:100px;margin:0 auto 16px;overflow:hidden;width:100px}.student-photo img{height:100%;object-fit:cover;width:100%}.photo-placeholder{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:36px;font-weight:700;height:100%;width:100%}.student-info{text-align:center}.student-name{color:#1f2937;font-size:18px;font-weight:700;line-height:1.3;margin:0 0 8px}.student-nim{color:#6b7280;font-family:Courier New,monospace;font-size:14px;font-weight:600;margin:0 0 4px}.student-program{color:#4b5563;font-size:13px;line-height:1.4;margin:0 0 16px;min-height:36px}.ipk-badge{align-items:center;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #86efac;border-radius:12px;display:inline-flex;gap:8px;margin-top:8px;padding:8px 16px}.ipk-label{color:#166534;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.ipk-value{color:#15803d;font-size:24px;font-weight:800;line-height:1}@media (max-width:768px){.top-students-grid{grid-template-columns:1fr}.section-title{font-size:18px}.top-student-card{padding:20px}.student-photo{height:80px;width:80px}.photo-placeholder{font-size:28px}.student-name{font-size:16px}.ipk-value{font-size:20px}}@media (max-width:992px){.modern-header{min-height:160px}.modern-header .header-content{padding:25px 30px}.modern-header .header-icon-wrapper{height:60px;width:60px}.modern-header .header-icon{font-size:28px}.modern-header .header-actions{justify-content:flex-start;width:100%}.btn-glass .btn-text{display:inline}}@media (max-width:768px){.modern-header{border-radius:16px;min-height:140px}.modern-header .header-content{align-items:flex-start;flex-direction:column;padding:20px 25px}.modern-header .header-left{gap:15px;width:100%}.modern-header .header-icon-wrapper{border-radius:14px;height:55px;width:55px}.modern-header .header-icon{font-size:24px}.modern-header .header-title{font-size:22px}.modern-header .header-subtitle{font-size:13px}.modern-header .header-actions{gap:10px;width:100%}.btn-glass{border-radius:10px;flex:1 1;font-size:13px;justify-content:center;min-width:calc(50% - 5px);padding:10px 16px}.btn-glass svg{font-size:16px}}@media (max-width:480px){.modern-header{border-radius:14px;min-height:auto}.modern-header .header-content{padding:18px 20px}.modern-header .header-left{gap:12px}.modern-header .header-icon-wrapper{border-radius:12px;height:50px;width:50px}.modern-header .header-icon{font-size:22px}.modern-header .header-title{font-size:20px}.modern-header .header-subtitle{font-size:12px;line-height:1.4}.btn-glass{font-size:12px;min-width:100%;padding:9px 14px;width:100%}.btn-glass .btn-text{display:none}.btn-glass svg{font-size:18px;margin:0}.modern-header .header-background:after,.modern-header .header-background:before{height:300px;width:300px}}.student-form-page{margin:0 auto;max-width:1000px}.form-grid{grid-gap:30px;gap:30px;grid-template-columns:1fr 1fr}.form-section{background:var(--light-color);border-radius:8px;padding:20px}.form-section h3{border-bottom:2px solid var(--primary-color);color:var(--text-primary)}.photo-section{grid-column:1/-1}.photo-upload-container{align-items:flex-start;display:flex;gap:30px}.photo-preview{align-items:center;background:#fff;border:3px solid #e3f2fd;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;height:200px;justify-content:center;overflow:hidden;width:200px}.photo-preview img{height:100%;object-fit:cover;width:100%}.photo-placeholder{align-items:center;color:#999;display:flex;flex-direction:column;justify-content:center;text-align:center}.photo-placeholder p{font-size:14px;margin-top:10px}.photo-actions{display:flex;flex:1 1;flex-direction:column;gap:15px}.photo-actions .btn{width:-webkit-fit-content;width:fit-content}.photo-actions small{color:#666;display:block;font-size:13px}.btn-outline-danger{align-items:center;background:#fff;border:1px solid #dc3545;border-radius:6px;color:#dc3545;cursor:pointer;display:inline-flex;font-size:14px;gap:5px;padding:8px 16px;transition:all .3s ease}.btn-outline-danger:hover{background:#dc3545;color:#fff}.form-actions{border-top:1px solid var(--border-color);gap:15px;margin-top:30px;padding-top:20px}@media (max-width:768px){.form-grid,.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.student-detail-page{margin:0 auto;max-width:1200px}.detail-grid{grid-gap:30px;align-items:start;gap:30px;grid-template-columns:350px 1fr}.profile-card{height:-webkit-fit-content;height:fit-content;position:-webkit-sticky;position:sticky;top:20px}.profile-header{border-bottom:1px solid var(--border-color);padding-bottom:20px;text-align:center}.profile-avatar{align-items:center;background:#fff;border:3px solid #e3f2fd;border-radius:50%;box-shadow:0 4px 12px #0000001a;display:flex;height:120px;justify-content:center;margin:0 auto 15px;overflow:hidden;width:120px}.profile-avatar img{height:100%;object-fit:cover;width:100%}.profile-header h2{font-size:22px;margin-bottom:5px}.profile-header .nim{color:var(--text-secondary);margin-bottom:10px}.profile-info{margin-top:20px}.info-item{align-items:flex-start;border-bottom:1px solid var(--border-color);gap:15px;padding:15px 0}.info-item:last-child{border-bottom:none}.info-item svg{color:var(--primary-color);font-size:20px;margin-top:2px}.info-item label{color:var(--text-secondary);display:block;margin-bottom:3px}.info-item p{color:var(--text-primary);font-size:14px}.info-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(2,1fr);margin-top:20px}.info-box{background:var(--light-color);border-radius:6px;padding:15px}.info-box label{color:var(--text-secondary);display:block;font-size:12px;font-weight:500;margin-bottom:5px}.info-box p{color:var(--text-primary);font-size:16px;font-weight:600}.info-box .gpa{color:var(--primary-color);font-size:24px}.courses-list{margin-top:15px}.course-item{align-items:center;background:var(--light-color);border-radius:6px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px}.course-item strong{display:block;margin-bottom:3px}.course-item p{color:var(--text-secondary);font-size:14px}.education-timeline{margin-top:20px;padding-left:30px;position:relative}.education-timeline:before{background:linear-gradient(to bottom,var(--primary-color),var(--secondary-color));bottom:10px;content:"";left:8px;position:absolute;top:10px;width:2px}.timeline-item{margin-bottom:30px;padding-bottom:20px}.timeline-item:last-child{margin-bottom:0;padding-bottom:0}.timeline-marker{border:3px solid var(--primary-color);box-shadow:0 0 0 4px var(--light-color);height:16px;left:-26px;top:5px;width:16px}.timeline-content{background:var(--light-color);border-left:3px solid var(--primary-color);border-radius:8px;padding:20px}.timeline-header{align-items:flex-start;border-bottom:2px solid #0000000d;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:12px}.timeline-header h4{color:var(--text-primary);flex:1 1;font-size:16px;font-weight:600;margin:0;padding-right:10px}.timeline-details{grid-gap:10px;display:grid;gap:10px}.detail-row{grid-gap:10px;align-items:start;display:grid;gap:10px;grid-template-columns:160px 1fr}.detail-row label{color:var(--text-secondary);font-size:13px;font-weight:500}.detail-row span{color:var(--text-primary);font-size:13px}@media (max-width:768px){.detail-grid,.info-grid{grid-template-columns:1fr}.education-history-card{grid-column:1}.timeline-header{flex-direction:column;gap:10px}.detail-row{gap:3px;grid-template-columns:1fr}}:root{--primary-gradient:linear-gradient(135deg,#8b5cf6,#7c3aed);--radius-xl:20px}.krs-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);background:var(--secondary-gradient);margin:0 auto;max-width:1600px;min-height:100vh;padding:1.5rem}.page-header{border-left:5px solid #8b5cf6}.page-header h2{align-items:center;color:#1a202c;display:flex;font-size:2rem;gap:.75rem;margin-bottom:.5rem}.page-header h2 svg{color:#8b5cf6}.page-header p{color:#64748b;font-size:1rem;margin-left:2.5rem}.page-header .header-actions{display:flex;gap:1rem;margin-top:1rem}.card-header h3{gap:.75rem}.card-header h3 svg{color:#8b5cf6}.search-panel{animation:fadeInUp .5s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 8px 16px #0000001a;box-shadow:var(--shadow-lg);margin-bottom:2rem;padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.search-panel:hover{box-shadow:0 12px 24px #00000026;box-shadow:var(--shadow-xl);transform:translateY(-2px)}.search-panel h3{align-items:center;border-bottom:2px solid #f1f5f9;color:#1a202c;display:flex;font-size:1.375rem;font-weight:600;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem}.search-panel h3 svg{color:#8b5cf6}.search-controls{grid-gap:1.25rem;align-items:end;display:grid;gap:1.25rem;grid-template-columns:200px 1fr 200px auto;margin-bottom:1.5rem}.form-group label{letter-spacing:.5px;text-transform:uppercase}.form-group input,.form-group select{background:#fff;border:2px solid #e2e8f0;border-radius:12px;border-radius:var(--radius-md);font-size:.9375rem;padding:.75rem 1rem;transition:all .3s ease}.input-with-icon svg{color:#94a3b8;left:1rem;pointer-events:none}.input-with-icon input{padding-left:2.75rem}.form-control:hover,.form-group input:hover,.form-group select:hover{border-color:#cbd5e1}.form-control:focus,.form-group input:focus,.form-group select:focus{border-color:#8b5cf6;box-shadow:0 0 0 4px #8b5cf626;outline:none;transform:translateY(-1px)}.form-control:disabled,.form-group input:disabled,.form-group select:disabled{background:#f8fafc;cursor:not-allowed;opacity:.6}.form-group.flex-grow{flex:1 1}.search-info{align-items:center;animation:fadeIn .3s ease;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #93c5fd;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;box-shadow:var(--shadow-sm);color:#1e40af;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;padding:1rem 1.25rem}.search-info svg{flex-shrink:0;font-size:1.125rem}.stats-grid{animation:fadeInUp .6s ease}.stat-card{border:1px solid #f1f5f9;padding:1.75rem}.stat-card:before{background:linear-gradient(135deg,#8b5cf6,#7c3aed);background:var(--primary-gradient);height:3px;left:0;transform:scaleX(0);transition:transform .3s ease}.stat-card:hover{box-shadow:0 12px 24px #8b5cf626}.stat-card:hover:before{transform:scaleX(1)}.stat-card .icon{align-items:center;border-radius:12px;display:flex;justify-content:center}.stat-card .icon,.stat-card .stat-icon{border-radius:var(--radius-md);font-size:1.5rem;height:56px;transition:transform .3s ease;width:56px}.stat-card:hover .icon,.stat-card:hover .stat-icon{transform:scale(1.1)}.stat-card .icon.primary{background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#6366f1}.stat-card .icon.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#22c55e}.stat-card .icon.info{background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#3b82f6}.stat-card .content,.stat-card .stat-details{flex:1 1}.stat-card .content h4,.stat-card .stat-details p{color:#64748b;font-size:.8125rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.stat-card .content p,.stat-card .stat-details h3{color:#1a202c;font-size:1.75rem;font-weight:700;line-height:1;margin:0}.print-section{animation:slideInUp .5s ease}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.print-info-box{background:linear-gradient(135deg,#8b5cf6,#7c3aed);background:var(--primary-gradient);border:1px solid #fff3;box-shadow:0 8px 24px #8b5cf64d;color:#fff;gap:1.5rem;overflow:hidden;padding:2rem;position:relative}.print-info-box:before{animation:pulse 3s infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:200%;position:absolute;right:-50%;top:-50%;width:200%}.print-info-box>svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));font-size:2.5rem;position:relative;z-index:1}.print-info-box>div{flex:1 1;position:relative;z-index:1}.print-info-box h4{font-size:1.25rem;font-weight:700;margin:0 0 .375rem;text-shadow:0 2px 4px #0000001a}.print-info-box p{font-size:.9375rem;margin:0;opacity:.95}.table-container{animation:fadeInUp .7s ease;background:#fff;border:1px solid #f1f5f9;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);margin-bottom:2rem;overflow:hidden}.modern-table{border-collapse:collapse}.modern-table thead{background:linear-gradient(135deg,#8b5cf6,#7c3aed);background:var(--primary-gradient);border-bottom:3px solid #6d28d9}.modern-table th{color:#fff;font-size:.8125rem;letter-spacing:.05em;padding:1.125rem 1rem}.modern-table td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:.875rem;padding:1rem;transition:background .2s ease}.modern-table tbody tr{transition:all .2s ease}.modern-table tbody tr:hover{background:linear-gradient(90deg,#faf5ff,#f5f3ff);box-shadow:0 2px 8px #8b5cf61a;transform:scale(1.001)}.modern-table tbody tr:last-child td{border-bottom:none}.btn{box-shadow:0 2px 4px #0000000d;box-shadow:var(--shadow-sm);font-size:.875rem;gap:.625rem;overflow:hidden;position:relative}.btn:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn:hover:before{height:300px;width:300px}.btn:disabled{transform:none}.btn-primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.btn-primary:hover:not(:disabled){box-shadow:0 6px 12px #8b5cf64d}.btn-secondary{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.btn-secondary:hover:not(:disabled){box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);background:var(--success-gradient)}.btn-success:hover:not(:disabled){box-shadow:0 6px 12px #22c55e4d}.btn-outline{background:#fff;border:2px solid #e2e8f0;color:#475569}.btn-outline:hover:not(:disabled){background:#f8fafc;border-color:#8b5cf6;color:#8b5cf6;transform:translateY(-2px)}.btn-sm{font-size:.8125rem;padding:.5rem 1rem}.btn-search{white-space:nowrap}.btn-print{background:#fff;box-shadow:0 4px 12px #00000026;color:#8b5cf6;font-size:.9375rem;font-weight:700;margin-left:auto;padding:.875rem 2rem;position:relative;z-index:1}.btn-print:hover:not(:disabled){background:#faf5ff;box-shadow:0 6px 16px #0003;transform:translateY(-3px)}.btn-icon{background:none;padding:.625rem;position:relative}.btn-icon,.btn-icon:after{border-radius:8px;border-radius:var(--radius-sm)}.btn-icon:after{content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease}.btn-edit{color:#3b82f6}.btn-edit:after{background:#eff6ff}.btn-edit:hover{color:#2563eb;transform:scale(1.1)}.btn-edit:hover:after{opacity:1}.btn-delete{color:#ef4444}.btn-delete:after{background:#fef2f2}.btn-delete:hover{color:#dc2626;transform:scale(1.1)}.btn-delete:hover:after{opacity:1}.badge{font-size:.75rem}.badge-warning{background:linear-gradient(135deg,#fef3c7,#fde68a)}.badge-danger{background:linear-gradient(135deg,#fee2e2,#fecaca)}.badge-primary{background:linear-gradient(135deg,#ddd6fe,#c4b5fd);color:#5b21b6}.action-buttons{align-items:center}.text-muted{color:#94a3b8}.modal-content{animation:slideInUp .3s ease;border:1px solid #ffffff80;border-radius:var(--radius-xl);max-width:650px;padding:2.5rem}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.modal-content::-webkit-scrollbar-thumb{background:#8b5cf6;border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:#7c3aed}.modal-header{border-bottom:2px solid #f1f5f9;margin-bottom:2rem;padding-bottom:1.25rem}.modal-header h3{font-size:1.625rem;gap:.75rem}.modal-header h3:before{background:linear-gradient(135deg,#8b5cf6,#7c3aed);background:var(--primary-gradient);border-radius:2px;content:"";height:28px;width:4px}.close-btn{background:#f1f5f9;border-radius:12px;border-radius:var(--radius-md);color:#64748b;font-size:1.5rem;padding:0;transition:all .3s ease}.close-btn:hover{background:#8b5cf6;color:#fff}.form-actions{border-top:2px solid #f1f5f9;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.75rem}.form-actions .btn{min-width:120px}.empty-state{animation:fadeIn .5s ease;color:#64748b;padding:4rem 1.5rem}.empty-state svg{animation:float 3s ease-in-out infinite;color:#8b5cf6;font-size:4rem;margin-bottom:1.5rem;opacity:.3}.empty-state h3{color:#334155;font-size:1.25rem;font-weight:700}.empty-state p{font-size:.9375rem;line-height:1.6;margin:0 auto;max-width:400px}@media (max-width:1200px){.search-controls{gap:1rem;grid-template-columns:180px 1fr 180px auto}}@media (max-width:1024px){.krs-page{padding:1.25rem}.search-controls{grid-template-columns:1fr 1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.page-header h2{font-size:1.75rem}.print-info-box{flex-wrap:wrap}.btn-print{margin-left:0;width:100%}}@media (max-width:768px){.krs-page{background:#f8fafc;padding:1rem}.page-header{margin-bottom:1.5rem;padding:1.5rem}.page-header h2{align-items:flex-start;flex-direction:column;font-size:1.5rem;gap:.5rem}.page-header p{font-size:.875rem;margin-left:0}.search-panel{padding:1.5rem}.search-controls,.stats-grid{gap:1rem;grid-template-columns:1fr}.stat-card{padding:1.25rem}.stat-card .icon{height:48px;width:48px}.stat-card .content p{font-size:1.5rem}.table-container{border-radius:12px;border-radius:var(--radius-md);overflow-x:auto}.modern-table{font-size:.8125rem;min-width:800px}.modern-table td,.modern-table th{padding:.75rem .625rem}.modern-table th{font-size:.75rem}.print-info-box{flex-direction:column;padding:1.5rem;text-align:center}.print-info-box>div{width:100%}.btn{font-size:.8125rem;padding:.625rem 1.25rem}.btn-print{padding:.75rem 1.5rem}.modal-content{padding:2rem}}@media (max-width:480px){.krs-page{padding:.75rem}.page-header{border-radius:12px;border-radius:var(--radius-md);padding:1.25rem}.page-header h2{font-size:1.375rem}.search-panel{border-radius:12px;border-radius:var(--radius-md);padding:1.25rem}.search-panel h3{font-size:1.125rem}.stat-card .content h4{font-size:.75rem}.stat-card .content p{font-size:1.375rem}.modern-table td,.modern-table th{padding:.625rem .5rem}.modal-content{padding:1.5rem}.modal-header h3{font-size:1.375rem}}.loading{color:#64748b;padding:3rem}.loading svg{animation:spin 1s linear infinite;font-size:3rem}@media print{.no-print{display:none!important}}.print-by-year-panel{border:2px solid #8b5cf6}.print-by-year-panel .card-header{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-bottom:2px solid #8b5cf6}.print-by-year-content{padding:2rem}.print-by-year-content .form-row{align-items:end;margin-bottom:1.5rem}.print-by-year-content .info-box{align-items:flex-start;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #3b82f6;border-radius:12px;border-radius:var(--radius-md);display:flex;gap:1rem;padding:1.25rem}.print-by-year-content .info-box svg{color:#3b82f6;flex-shrink:0;font-size:1.5rem;margin-top:.25rem}.print-by-year-content .info-box strong{color:#1e40af;display:block;margin-bottom:.5rem}.print-by-year-content .info-box p{color:#1e3a8a;font-size:.875rem;margin:.25rem 0}.btn-print{border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 12px #8b5cf64d}.btn-print:hover:not(:disabled){box-shadow:0 6px 16px #8b5cf666}.btn-print.btn-lg{font-size:1.125rem;padding:1rem 2rem}.form-group.align-end{align-items:flex-end;display:flex}@media (max-width:1024px){.print-by-year-content .form-row{grid-template-columns:1fr}.form-group.align-end{justify-content:stretch}.btn-print{justify-content:center;width:100%}}:root{--primary-gradient:linear-gradient(135deg,#10b981,#059669);--secondary-gradient:linear-gradient(135deg,#f5f7fa,#c3cfe2);--success-gradient:linear-gradient(135deg,#22c55e,#16a34a);--info-gradient:linear-gradient(135deg,#3b82f6,#2563eb);--shadow-sm:0 2px 4px #0000000d;--shadow-md:0 4px 6px #00000012;--shadow-lg:0 8px 16px #0000001a;--shadow-xl:0 12px 24px #00000026;--radius-sm:8px;--radius-md:12px;--radius-lg:16px}.khs-container{margin:0 auto;max-width:1600px;min-height:100vh;padding:1.5rem}.btn-glass.btn-primary,.btn-glass.btn-secondary,.btn-glass.btn-success{background:#ffffff40;border:2px solid #ffffff80;font-weight:700}.btn-glass.btn-primary:hover:not(:disabled),.btn-glass.btn-secondary:hover:not(:disabled),.btn-glass.btn-success:hover:not(:disabled){background:#ffffff59;box-shadow:0 8px 25px #0003}.page-header{animation:slideInDown .5s ease;border-left:5px solid #10b981;border-radius:var(--radius-lg);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);padding:2rem}.page-header .header-content{align-items:center;display:flex;justify-content:space-between}.page-header .header-text h2{color:#1a202c;font-size:2rem;font-weight:700;margin-bottom:.5rem}.page-header .header-text p{color:#64748b;font-size:1rem}.ipk-badge{background:linear-gradient(135deg,#10b981,#059669);background:var(--primary-gradient);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 8px 16px #0000001a;box-shadow:var(--shadow-lg);color:#fff;min-width:180px;padding:1.5rem 2rem;text-align:center}.ipk-label{font-size:.875rem;margin-bottom:.5rem;opacity:.9}.ipk-value{font-size:2.5rem;font-weight:700;margin-bottom:.25rem}.ipk-detail{font-size:.875rem;opacity:.85}.card{animation:fadeInUp .5s ease;border-radius:var(--radius-lg);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);margin-bottom:2rem}.card-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:1.5rem 2rem}.card-header h3{font-size:1.25rem;margin:0 0 .25rem}.header-subtitle{color:#64748b;font-size:.875rem;font-weight:400}.card-actions{align-items:center;display:flex;gap:.75rem}.card-body{padding:2rem}.search-form{margin:0}.form-row{grid-gap:1.25rem;align-items:end;gap:1.25rem;grid-template-columns:1fr 1fr auto}.form-group label{color:#475569;font-size:.875rem}.form-control{border-radius:12px;border-radius:var(--radius-md);font-size:.9375rem;padding:.75rem 1rem}.input-icon{color:#94a3b8;left:1rem;pointer-events:none;position:absolute}.input-with-icon .form-control{padding-left:2.75rem}.align-end{align-items:flex-end;display:flex}.btn{border-radius:var(--radius-md);font-size:.9375rem;gap:.5rem;padding:.75rem 1.5rem}.btn-primary{background:linear-gradient(135deg,#10b981,#059669);background:var(--primary-gradient);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:0 8px 16px #0000001a;box-shadow:var(--shadow-lg)}.btn-print{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.btn-print:hover{box-shadow:0 8px 16px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-search{min-width:150px}.student-info-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #86efac}.student-info-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(4,1fr);padding:1.5rem 2rem}.info-item{gap:.5rem}.info-label{color:#059669;font-size:.875rem}.info-value{color:#065f46;font-size:1rem}.stats-grid{grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.stat-card{border-radius:var(--radius-lg);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);gap:1.25rem;padding:1.5rem}.stat-card:hover{box-shadow:0 12px 24px #00000026;box-shadow:var(--shadow-xl)}.stat-card.stat-primary{border-left-color:#8b5cf6}.stat-card.stat-success{border-left-color:#22c55e}.stat-card.stat-info{border-left-color:#3b82f6}.stat-card.stat-warning{border-left-color:#f59e0b}.stat-icon{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--radius-md);font-size:2.5rem}.stat-label{color:#64748b;font-size:.875rem;margin-bottom:.25rem}.stat-value{font-size:2rem}.print-section{margin-bottom:2rem}.print-info-box{align-items:center;animation:pulse 2s ease infinite;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border:2px solid #c4b5fd;border-radius:16px;border-radius:var(--radius-lg);display:flex;justify-content:space-between;padding:1.5rem 2rem}.print-info-content{align-items:center;display:flex;gap:1.5rem}.print-icon{color:#8b5cf6;font-size:2.5rem}.print-info-box h4{color:#6b21a8;font-size:1.125rem;margin-bottom:.25rem}.print-info-box p{color:#7c3aed;font-size:.875rem}.table{border-collapse:collapse;width:100%}.table thead{background:linear-gradient(135deg,#1e293b,#334155);color:#fff}.table th{font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.table tbody tr{border-bottom:1px solid #e2e8f0;transition:all .3s ease}.table tbody tr:hover{background:linear-gradient(135deg,#f0fdf4,#dcfce7);box-shadow:0 2px 8px #10b9811a;transform:scale(1.005)}.table td{color:#475569;padding:1rem;vertical-align:middle}.table tbody tr:last-child{border-bottom:none}.table tfoot{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-top:3px solid #10b981;font-weight:600}.table tfoot td{color:#1e293b;font-size:1.05rem;padding:1.25rem 1rem}.total-row{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)!important;font-weight:700}.total-row:hover{background:linear-gradient(135deg,#e2e8f0,#cbd5e1)!important;box-shadow:none!important;transform:none!important}.text-center{text-align:center!important}.text-right{text-align:right!important}.badge{border-radius:8px;border-radius:var(--radius-sm);font-size:.875rem;padding:.375rem .75rem}.badge-secondary{background:#f1f5f9;border:1px solid #cbd5e1;color:#475569}.badge-outline{background:#0000;border:1.5px solid #10b981;color:#059669;font-weight:600;padding:.375rem .875rem;transition:all .3s ease}.badge-outline:hover{background:#10b981;color:#fff}.course-info{display:flex;flex-direction:column;gap:.25rem}.course-name{color:#1e293b;font-size:.95rem;font-weight:600}.course-meta{color:#64748b;font-size:.75rem;font-style:italic}.nilai-angka{background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1e40af}.nilai-angka,.nilai-indeks{border-radius:8px;border-radius:var(--radius-sm);display:inline-block;font-weight:600;min-width:60px;padding:.5rem .75rem}.nilai-indeks{background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#166534}.mutu-sks{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;border-radius:var(--radius-sm);box-shadow:0 2px 4px #fbbf2433;color:#92400e;display:inline-block;font-weight:700;min-width:60px;padding:.5rem .75rem}.grade-badge{border-radius:var(--radius-md);font-size:1rem;padding:.5rem 1rem}.grade-a{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 6px #10b9814d;color:#fff}.grade-b{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 6px #3b82f64d;color:#fff}.grade-c{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 6px #f59e0b4d;color:#fff}.grade-d{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 6px #ef44444d;color:#fff}.grade-e{background:linear-gradient(135deg,#991b1b,#7f1d1d);box-shadow:0 4px 6px #991b1b4d;color:#fff}.empty-state{padding:4rem 2rem}.empty-icon{font-size:5rem;margin-bottom:1.5rem}.empty-state h3{color:#1a202c;font-size:1.5rem;margin-bottom:.75rem}.empty-state p{color:#64748b;font-size:1rem}@media (max-width:992px){.modern-header .header-content{padding:25px 30px}.modern-header .header-icon-wrapper{height:60px;width:60px}.modern-header .header-icon{font-size:28px}.modern-header .header-actions{justify-content:flex-start;width:100%}}@media (max-width:768px){.modern-header{min-height:160px}.modern-header .header-content{padding:20px 25px}.modern-header .header-left{gap:15px;min-width:100%}.modern-header .header-icon-wrapper{height:55px;width:55px}.modern-header .header-icon{font-size:26px}.modern-header .header-actions{gap:10px}.btn-glass{font-size:13px;padding:10px 16px}.btn-glass svg{font-size:16px}}@media (max-width:480px){.modern-header{border-radius:16px;min-height:140px}.modern-header .header-content{padding:18px 20px}.modern-header .header-left{gap:12px}.modern-header .header-icon-wrapper{border-radius:14px;height:50px;width:50px}.modern-header .header-icon{font-size:24px}.modern-header .header-title{font-size:20px}.modern-header .header-subtitle{font-size:12px;padding:6px 12px}.modern-header .header-actions{gap:8px;width:100%}.btn-glass{border-radius:10px;font-size:12px;padding:10px 14px}.btn-glass .btn-text{display:none}.btn-glass svg{font-size:18px;margin:0}}@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.khs-container{padding:1rem}.page-header .header-content{align-items:flex-start;flex-direction:column;gap:1rem}.form-row,.stats-grid,.student-info-grid{grid-template-columns:1fr}.print-info-box{flex-direction:column;gap:1rem}.btn-search{width:100%}}.empty-state ul{color:var(--text-secondary);line-height:2;list-style:none;margin:20px auto;padding:0}.empty-state ul li{padding:8px 0 8px 24px;position:relative}.empty-state ul li:before{color:var(--primary-color);content:"✓";font-weight:700;left:0;position:absolute}.grade-distribution{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-top:2px solid #e2e8f0;padding:2rem}.distribution-title{align-items:center;color:#1e293b;display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;margin-bottom:1.5rem}.distribution-title:before{content:"📊";font-size:1.5rem}.distribution-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:2rem}.distribution-item{background:#fff;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.75rem;padding:1rem;transition:all .3s ease}.distribution-item:hover{box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transform:translateY(-4px)}.distribution-info{display:flex;flex-direction:column;gap:.5rem}.distribution-count{color:#64748b;font-size:.875rem;font-weight:600}.distribution-bar{background:#e2e8f0;border-radius:4px;height:8px;overflow:hidden;position:relative}.distribution-fill{border-radius:4px;height:100%;transition:width .6s ease}.distribution-fill.grade-a{background:linear-gradient(90deg,#10b981,#059669)}.distribution-fill.grade-b{background:linear-gradient(90deg,#3b82f6,#2563eb)}.distribution-fill.grade-c{background:linear-gradient(90deg,#f59e0b,#d97706)}.distribution-fill.grade-d{background:linear-gradient(90deg,#ef4444,#dc2626)}.distribution-fill.grade-e{background:linear-gradient(90deg,#991b1b,#7f1d1d)}.distribution-percentage{color:#1e293b;font-size:.875rem;font-weight:700}.khs-summary{grid-gap:1rem;border-top:2px dashed #cbd5e1;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:1.5rem;padding-top:1.5rem}.summary-item{align-items:center;background:#fff;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;padding:1rem 1.25rem;transition:all .3s ease}.summary-item:hover{box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transform:translateY(-2px)}.summary-item.highlight{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d;color:#fff}.summary-item.highlight:hover{box-shadow:0 6px 16px #10b98166}.summary-label{font-size:.875rem;font-weight:500}.summary-item.highlight .summary-label{color:#fffffff2}.summary-value{font-size:1.25rem}.summary-item.highlight .summary-value{color:#fff;font-size:1.5rem}.btn-detail{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;border-radius:var(--radius-sm);box-shadow:0 2px 4px #3b82f633;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease}.btn-detail:hover{box-shadow:0 4px 8px #3b82f64d;transform:translateY(-2px)}.btn-detail:active{transform:translateY(0)}.modal-content{border-radius:var(--radius-lg);max-width:1000px}.modal-header{align-items:flex-start;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.modal-header h3{color:#1e293b;font-size:1.5rem}.modal-subtitle{color:#64748b;font-size:.875rem;margin:.5rem 0 0}.modal-subtitle strong{color:#10b981;font-size:1rem}.modal-close{background:#0000;border-radius:var(--radius-sm);color:#64748b;padding:.5rem}.modal-close:hover{background:#f1f5f9;color:#1e293b}.modal-body{flex:1 1}.modal-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.modal-loading .spinner{animation:spin .8s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#10b981;height:48px;width:48px}.modal-loading p{color:#64748b;font-size:.875rem}.modal-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:2rem}.modal-stat-item{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:12px;border-radius:var(--radius-md);padding:1.25rem;text-align:center;transition:all .3s ease}.modal-stat-item:hover{box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transform:translateY(-2px)}.modal-stat-item.highlight{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff}.modal-stat-label{color:#64748b;display:block;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.modal-stat-item.highlight .modal-stat-label{color:#ffffffe6}.modal-stat-value{color:#1e293b;display:block;font-size:1.75rem;font-weight:700}.modal-stat-item.highlight .modal-stat-value{color:#fff}.modal-table-wrapper{border:2px solid #e2e8f0;border-radius:12px;border-radius:var(--radius-md);overflow-x:auto}.modal-table{border-collapse:collapse;width:100%}.modal-table thead{background:linear-gradient(135deg,#1e293b,#334155);color:#fff}.modal-table th{font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:1rem .75rem;text-align:left;text-transform:uppercase}.modal-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background .2s ease}.modal-table tbody tr:hover{background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.modal-table tbody tr:last-child{border-bottom:none}.modal-table td{color:#475569;font-size:.875rem;padding:.875rem .75rem}.course-name-modal{color:#1e293b;font-size:.875rem;font-weight:600}.course-class{color:#64748b;font-size:.75rem;font-style:italic}.nilai-angka-sm{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:6px;color:#1e40af;display:inline-block;font-weight:600;padding:.375rem .625rem}.grade-badge-sm{border-radius:8px;display:inline-block;font-size:.875rem;font-weight:700;min-width:40px;padding:.375rem .75rem;text-align:center}.modal-empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.modal-empty p{font-size:1rem;margin:0}.modal-footer{background:#f8fafc}.btn-secondary{background:#fff;border:2px solid #cbd5e1;border-radius:var(--radius-sm)}.btn-secondary:hover{background:#f1f5f9;border-color:#94a3b8}@media (max-width:768px){.modal-content{margin:.5rem;max-height:95vh;max-width:100%}.modal-header{padding:1.25rem 1.5rem}.modal-header h3{font-size:1.25rem}.modal-body{padding:1.5rem}.modal-stats{grid-template-columns:1fr}.modal-footer{flex-direction:column;padding:1rem 1.5rem}.modal-footer button{width:100%}.btn-detail{font-size:.8rem;padding:.375rem .75rem}}.print-by-year-panel{animation:slideDown .3s ease-out;border:2px solid #10b981!important;border-radius:12px;box-shadow:0 4px 12px #10b9811a;margin-bottom:2rem;overflow:hidden}.print-by-year-panel .card-header{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-bottom:none;color:#fff;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.print-by-year-panel .card-header h3{align-items:center;display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;margin:0}.print-by-year-panel .btn-close{align-items:center;background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .3s ease}.print-by-year-panel .btn-close:hover{background:#ffffff4d;transform:rotate(90deg)}.print-by-year-content{padding:0}.print-by-year-content .form-row{grid-gap:1.5rem;align-items:start;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr 1fr auto}.print-by-year-content .form-group{display:flex;flex-direction:column;gap:.5rem}.print-by-year-content .form-group.align-end{align-self:end}.print-by-year-content .form-group label{color:#1f2937;font-size:.9rem;font-weight:600}.print-by-year-content .form-control{border:1px solid #d1d5db;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease}.print-by-year-content .form-control:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;outline:none}.print-by-year-content .text-muted{color:#6b7280;font-size:.8rem;margin-top:.25rem}.btn-print{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 4px 12px #10b9814d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.btn-print:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 6px 16px #10b98166;transform:translateY(-2px)}.btn-print:active:not(:disabled){transform:translateY(0)}.btn-print:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.btn-print svg{font-size:1.25rem}.print-by-year-panel .info-box{align-items:start;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-left:4px solid #3b82f6;border-radius:8px;display:flex;gap:1rem;margin-top:1.5rem;padding:1rem 1.25rem}.print-by-year-panel .info-box svg{color:#3b82f6;flex-shrink:0;font-size:1.5rem;margin-top:.25rem}.print-by-year-panel .info-box strong{color:#1e40af;display:block;margin-bottom:.5rem}.print-by-year-panel .info-box p{color:#1e3a8a;font-size:.9rem;line-height:1.5;margin:.25rem 0}.print-by-year-panel .info-box p:last-child{margin-bottom:0}.header-stats .btn-secondary{align-items:center;background:linear-gradient(135deg,#6b7280,#4b5563);border:none;border-radius:8px;box-shadow:0 2px 8px #6b728033;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:all .3s ease;white-space:nowrap}.header-stats .btn-secondary:hover{background:linear-gradient(135deg,#4b5563,#374151);box-shadow:0 4px 12px #6b72804d;transform:translateY(-2px)}.header-stats .btn-secondary svg{font-size:1.125rem}@media (max-width:992px){.print-by-year-content .form-row{grid-template-columns:1fr}.print-by-year-content .form-group.align-end{align-self:stretch}.btn-print{justify-content:center;width:100%}}@media (max-width:768px){.header-stats{align-items:stretch;flex-direction:column;gap:.75rem}.header-stats .btn-secondary{justify-content:center;width:100%}.print-by-year-panel{margin-bottom:1.5rem}.print-by-year-panel .card-header{padding:1rem}.print-by-year-panel .card-header h3{font-size:1rem}.print-by-year-panel .info-box{padding:.875rem 1rem}.print-by-year-panel .info-box svg{font-size:1.25rem}}.akm-container{animation:fadeIn .3s ease-in;margin:0 auto;max-width:1600px;min-height:100vh;padding:1.5rem}.modern-header{background:#0000;border:none;box-shadow:none;margin-bottom:2rem}.page-header{animation:slideInDown .5s ease-out;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:15px;box-shadow:0 10px 30px #2563eb33;color:#fff;padding:30px}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.header-icon{animation:pulse 2s infinite;color:#ffffffe6}.page-header h1{font-size:32px;font-weight:700;text-shadow:0 2px 10px #0000001a}.page-header p{font-size:16px;opacity:.9}.search-card{animation:fadeInUp .5s ease-out;border-radius:12px;box-shadow:0 4px 15px #00000014;margin-bottom:25px;padding:25px}.search-card h3{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 20px}.search-form{grid-gap:15px;align-items:end;display:grid;gap:15px;grid-template-columns:1fr 1fr auto}.form-control{border:2px solid #e5e7eb}.form-control:disabled{background-color:#f3f4f6}.form-actions{display:flex;gap:10px}.btn:disabled{opacity:.5}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d;color:#fff}.btn-success:hover:not(:disabled){box-shadow:0 6px 16px #10b98166;transform:translateY(-2px)}.student-info-card{animation:fadeInUp .6s ease-out;background:linear-gradient(135deg,#f8fafc,#e0f2fe);border-left:4px solid #3b82f6;border-radius:12px;margin-bottom:25px;padding:25px}.student-profile{align-items:flex-start;display:flex;gap:25px}.student-avatar{flex-shrink:0}.student-avatar img{object-fit:cover}.avatar-placeholder,.student-avatar img{border:4px solid #fff;border-radius:12px;box-shadow:0 4px 12px #00000026;height:120px;width:120px}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;display:flex;font-size:48px;font-weight:700;justify-content:center}.student-details{flex:1 1}.student-details h3{color:#1f2937;font-size:24px;font-weight:700;margin:0 0 15px}.student-info-card h3{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 20px}.info-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item .label{color:#6b7280;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.info-item .value{color:#1f2937;font-size:16px;font-weight:600}.info-item .badge{align-self:flex-start}.akm-card{animation:fadeInUp .7s ease-out;background:#fff;border-radius:12px;box-shadow:0 4px 15px #00000014;overflow:hidden}.card-header{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-bottom:2px solid #e5e7eb}.badge{gap:5px}.badge-info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.badge-active{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.badge-inactive{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.badge-default{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.akm-table-container{overflow-x:auto}.akm-table{border-collapse:collapse;width:100%}.akm-table thead{background:linear-gradient(135deg,#1e40af,#1e3a8a);color:#fff}.akm-table th{font-size:13px;font-weight:600;letter-spacing:.5px;padding:15px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.akm-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s ease}.akm-table tbody tr:hover{background-color:#f9fafb}.akm-table tbody tr:last-child{border-bottom:none}.akm-table td{color:#374151;font-size:14px;padding:15px 12px}.akm-table .text-center{text-align:center}.akm-table .text-right{text-align:right}.grade-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:20px;color:#fff;font-weight:700;min-width:50px;padding:6px 14px;text-align:center}.grade-badge.grade-ipk{background:linear-gradient(135deg,#8b5cf6,#7c3aed);font-size:14px;padding:8px 16px}.empty-state{box-shadow:0 4px 15px #00000014}.empty-icon{color:#d1d5db;font-size:80px;margin-bottom:20px}.empty-state h3{color:#6b7280;font-weight:600;margin:0 0 10px}.empty-state p{color:#9ca3af}@media (max-width:992px){.modern-header .header-content{padding:25px 30px}.modern-header .header-icon-wrapper{height:60px;width:60px}.modern-header .header-icon{font-size:28px}}@media (max-width:768px){.modern-header{min-height:160px}.modern-header .header-content{padding:20px 25px}.modern-header .header-left{gap:15px;min-width:100%}.modern-header .header-icon-wrapper{height:55px;width:55px}.modern-header .header-icon{font-size:26px}}@media (max-width:480px){.modern-header{border-radius:16px;min-height:140px}.modern-header .header-content{padding:18px 20px}.modern-header .header-left{gap:12px}.modern-header .header-icon-wrapper{border-radius:14px;height:50px;width:50px}.modern-header .header-icon{font-size:24px}.modern-header .header-title{font-size:20px}.modern-header .header-subtitle{font-size:12px;padding:6px 12px}}@media (max-width:1200px){.akm-container{padding:15px}.search-form{grid-template-columns:1fr}.form-actions{grid-column:1}}@media (max-width:768px){.page-header{padding:20px}.header-content{gap:15px}.header-icon{font-size:36px}.page-header h1{font-size:24px}.page-header p{font-size:14px}.akm-card,.search-card,.student-info-card{padding:15px}.info-grid{gap:15px;grid-template-columns:1fr}.akm-table{font-size:12px}.akm-table td,.akm-table th{padding:10px 8px}.btn{font-size:13px;padding:10px 18px}}@media (max-width:480px){.card-header{align-items:flex-start;flex-direction:column;gap:10px}.form-actions{flex-direction:column;width:100%}.btn{justify-content:center;width:100%}}.lecturers-page{padding:20px}.btn-glass.btn-success{background:#ffffff40;border:2px solid #ffffff80;font-weight:700}.btn-glass.btn-primary:hover:not(:disabled),.btn-glass.btn-success:hover:not(:disabled){background:#ffffff59;box-shadow:0 8px 25px #0003}.page-header{margin-bottom:30px}.page-header-actions{display:flex;gap:10px}.page-header h2{margin:0}.page-header p{margin:5px 0 0}.stat-card{box-shadow:0 1px 3px #0000001a}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-details h3{color:#1f2937;font-size:28px;margin:0}.stat-details p{color:#6b7280;margin:5px 0 0}.card{border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px}.card h3{color:#1f2937;margin:0 0 20px}.filters{grid-template-columns:2fr 1fr 1fr}.search-box svg{left:12px}.search-box input{border:1px solid #e5e7eb;border-radius:8px;padding:10px 10px 10px 40px}.search-box input:focus{border-color:#4f46e5}.filter-select{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:10px}.filter-select:focus{border-color:#4f46e5}.table-container{overflow-x:auto}.lecturers-container table{border-collapse:collapse;width:100%}.lecturers-container table:not(.modern-table) thead{background:#f9fafb}.lecturers-container table:not(.modern-table) th{border-bottom:2px solid #e5e7eb;color:#374151;font-weight:600;padding:12px;text-align:left}.lecturers-container table:not(.modern-table) td{border-bottom:1px solid #f3f4f6;padding:12px}tr:hover{background:#f9fafb}.badge-secondary{background:#f3f4f6;color:#4b5563}.edit-input,.edit-select,.edit-textarea{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:13px;padding:6px 10px;transition:border-color .2s;width:100%}.edit-input:focus,.edit-select:focus,.edit-textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.edit-input[type=date]{padding:5px 10px}.edit-select{background:#fff;cursor:pointer}.edit-textarea{min-height:80px;resize:vertical}.edit-actions{display:flex;gap:8px;justify-content:center}.btn-icon{display:inline-flex;font-size:16px;height:32px;transition:all .2s;width:32px}.btn-icon-edit{background:#eff6ff;color:#2563eb}.btn-icon-edit:hover{background:#dbeafe;color:#1d4ed8}.btn-icon-view{background:#f0fdf4;color:#16a34a}.btn-icon-view:hover{background:#dcfce7;color:#15803d}.btn-icon-save{background:#dcfce7;color:#16a34a}.btn-icon-save:hover{background:#bbf7d0;color:#15803d}.btn-icon-cancel{background:#fee2e2;color:#dc2626}.btn-icon-cancel:hover{background:#fecaca;color:#b91c1c}tr.editing-row,tr.editing-row:hover{background:#f0f9ff}.btn{transition:all .2s}.btn-primary{background:#4f46e5}.btn-primary:hover{background:#4338ca}.spinner{height:400px}.spinner:after{border-top-color:#4f46e5}.modal-header{padding:20px 25px}.modal-header-actions{align-items:center;display:flex;gap:10px}.btn-cancel-modal,.btn-edit-modal,.btn-save-modal{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.btn-edit-modal{background:#eff6ff;color:#2563eb}.btn-edit-modal:hover{background:#dbeafe;color:#1d4ed8}.btn-save-modal{background:#dcfce7;color:#16a34a}.btn-save-modal:hover{background:#bbf7d0;color:#15803d}.btn-cancel-modal{background:#fee2e2;color:#dc2626}.btn-cancel-modal:hover{background:#fecaca;color:#b91c1c}.modal-close{background:#f3f4f6;border-radius:8px;font-size:20px;height:36px;transition:all .2s;width:36px}.modal-close:hover{background:#e5e7eb;color:#374151}.modal-body{padding:25px}.detail-grid{grid-gap:20px;gap:20px}.detail-item{gap:6px}.detail-item label{color:#6b7280}.detail-item p{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#1f2937;font-size:15px;padding:10px 12px}.detail-item p strong{color:#111827;font-size:16px}.detail-item .edit-input,.detail-item .edit-select,.detail-item .edit-textarea{background:#fff;border:2px solid #d1d5db;font-size:15px;margin:0;padding:10px 12px}.detail-item .edit-input:focus,.detail-item .edit-select:focus,.detail-item .edit-textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}@media (max-width:768px){.detail-grid,.filters,.stats-grid{grid-template-columns:1fr}.modal-content{max-width:100%}.modal-header-actions{flex-wrap:wrap}}.modal-sync{max-width:600px}.sync-info{background:#f0f9ff;border:1px solid #bfdbfe;border-radius:8px;margin-bottom:20px;padding:15px}.sync-info p{color:#1e40af;font-weight:600;margin:0 0 10px}.sync-info ul{color:#1e40af;margin:0;padding-left:20px}.sync-info ul li{margin:5px 0}.alert{margin-top:15px;padding:12px 15px}.alert-warning{background:#fef3c7;border:1px solid #fde047;color:#92400e}.alert ul{margin:8px 0 0;padding-left:20px}.alert ul li{margin:4px 0}.modal-footer{padding:20px 25px}.spinner-small{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;margin-right:8px;width:16px}.detail-section{border-bottom:1px solid #e5e7eb}.section-title{border-bottom:2px solid #4f46e5;color:#1f2937;margin:0 0 15px;padding-bottom:10px}.detail-table{border-collapse:collapse;margin-top:10px;width:100%}.detail-table td,.detail-table th{border:1px solid #e5e7eb;font-size:14px;padding:10px 12px;text-align:left}.detail-table th{background:#f9fafb;color:#374151;font-weight:600}.detail-table td{color:#1f2937}.detail-table tbody tr:hover{background:#f9fafb}.table-wrapper{overflow-x:auto}.text-muted{color:#6b7280}.program-stat-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;cursor:default;display:flex;flex-direction:column;gap:12px;padding:20px;transition:all .3s ease}.program-stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.program-stat-content{align-items:center;display:flex;gap:15px}.program-icon{border-radius:10px;box-shadow:0 2px 8px #00000026;flex-shrink:0;font-size:24px;height:50px;width:50px}.program-info{display:flex;flex-direction:column;gap:2px}.program-count{color:#1f2937;font-size:28px;font-weight:800;line-height:1}.program-label{color:#6b7280;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.program-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#4b5563;display:-webkit-box;font-size:14px;font-weight:500;line-height:1.3;min-height:36px;overflow:hidden;text-overflow:ellipsis}.program-stat-more{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:1px dashed #d1d5db}.program-stat-more .program-name{color:#6b7280;font-weight:600}.program-stat-more .program-label{color:#9ca3af}@media (max-width:768px){.program-stat-card{gap:10px;padding:16px}.program-stat-content{gap:12px}.program-icon{font-size:20px;height:45px;width:45px}.program-count{font-size:24px}.program-label{font-size:11px}.program-name{font-size:13px}.modern-header{border-radius:16px;min-height:140px}.modern-header .header-content{padding:20px 25px}.modern-header .header-icon-wrapper{border-radius:14px;height:55px;width:55px}.modern-header .header-icon{font-size:24px}.modern-header .header-title{font-size:22px}.btn-glass,.modern-header .header-subtitle{font-size:13px}.btn-glass{padding:10px 16px}}@media (max-width:480px){.modern-header{border-radius:14px;min-height:auto}.modern-header .header-content{padding:18px 20px}.modern-header .header-left{gap:12px;width:100%}.modern-header .header-icon-wrapper{border-radius:12px;height:50px;width:50px}.modern-header .header-icon{font-size:22px}.modern-header .header-title{font-size:20px}.modern-header .header-subtitle{font-size:12px;line-height:1.4}.modern-header .header-actions{width:100%}.btn-glass{flex:1 1;justify-content:center}.btn-glass .btn-text{display:none}.btn-glass svg{font-size:18px;margin:0}.modern-header .header-background:after,.modern-header .header-background:before{height:300px;width:300px}}.lecturer-avatar-table{border:2px solid #e3f2fd;border-radius:50%;display:inline-block;height:40px;overflow:hidden;width:40px}.lecturer-avatar-table img{height:100%;object-fit:cover;width:100%}.lecturer-avatar-modal{background:#fff;border:2px solid #e3f2fd;border-radius:50%;box-shadow:0 2px 8px #0000001a;flex-shrink:0;height:60px;overflow:hidden;width:60px}.lecturer-avatar-modal img{height:100%;object-fit:cover;width:100%}.photo-section-lecturer{background:#f8fafc;border:2px solid #e3f2fd;border-radius:12px;margin-bottom:20px;padding:20px}.photo-upload-container-lecturer{align-items:flex-start;display:flex;gap:30px}.photo-preview-lecturer{align-items:center;background:#fff;border:3px solid #e3f2fd;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;flex-shrink:0;height:150px;justify-content:center;overflow:hidden;width:150px}.photo-preview-lecturer img{height:100%;object-fit:cover;width:100%}.photo-placeholder-lecturer{align-items:center;color:#999;display:flex;flex-direction:column;justify-content:center;text-align:center}.photo-placeholder-lecturer p{font-size:14px;margin-top:10px}.photo-actions-lecturer{display:flex;flex:1 1;flex-direction:column;gap:15px}.photo-actions-lecturer .btn{width:-webkit-fit-content;width:fit-content}.photo-actions-lecturer small{color:#666;display:block;font-size:13px}.staff-page{padding:0}.staff-page .header-icon-wrapper,.staff-page .modern-table.accent-purple thead{background:linear-gradient(135deg,#667eea,#764ba2)}.staff-page .table-btn-delete{color:#ef4444;transition:all .3s ease}.staff-page .table-btn-delete:hover{background:#ef44441a;transform:scale(1.1)}.staff-page .empty-state{color:#6b7280;padding:60px 20px;text-align:center}.staff-page .empty-state p{font-size:16px;margin:0}.add-mode-selection{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);padding:20px}.mode-card{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;padding:30px;text-align:center;transition:all .3s ease}.mode-card:hover{border-color:#667eea;box-shadow:0 10px 25px #00000026;transform:translateY(-5px)}.mode-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:36px;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.mode-card h4{color:#1e293b;font-size:20px;margin-bottom:10px}.mode-card p{color:#64748b;font-size:14px;margin:0}.excel-upload-section{padding:20px}.upload-info{background:#f0f9ff;border-left:4px solid #3b82f6;border-radius:8px;margin-bottom:20px;padding:15px}.upload-info p{color:#1e293b;margin:0 0 10px}.upload-info ul{color:#475569;margin:10px 0 0 20px}.upload-info li{font-size:14px;margin:5px 0}.file-upload-area{margin:20px 0}.file-upload-label{align-items:center;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:40px;transition:all .3s ease}.file-upload-label:hover{background:#f0f4ff;border-color:#667eea}.file-upload-label p{color:#475569;font-size:16px;margin:0}.download-template{border-top:1px solid #e2e8f0;margin-top:20px;padding-top:20px;text-align:center}download-template p{color:#64748b;margin-bottom:10px}.staff-avatar-table{border:2px solid #e3f2fd;border-radius:50%;display:inline-block;height:40px;overflow:hidden;width:40px}.staff-avatar-table img{height:100%;object-fit:cover;width:100%}.staff-avatar-modal{background:#fff;border:2px solid #e3f2fd;border-radius:50%;box-shadow:0 2px 8px #0000001a;flex-shrink:0;height:60px;overflow:hidden;width:60px}.staff-avatar-modal img{height:100%;object-fit:cover;width:100%}.photo-section-staff{background:#f8fafc;border:2px solid #e3f2fd;margin-bottom:20px}.photo-upload-container-staff{align-items:flex-start;display:flex;gap:30px}.photo-preview-staff{align-items:center;background:#fff;border:3px solid #e3f2fd;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;flex-shrink:0;height:150px;justify-content:center;overflow:hidden;width:150px}.photo-preview-staff img{height:100%;object-fit:cover;width:100%}.photo-placeholder-staff{align-items:center;color:#999;display:flex;flex-direction:column;justify-content:center;text-align:center}.photo-placeholder-staff p{font-size:14px;margin-top:10px}.photo-actions-staff{display:flex;flex:1 1;flex-direction:column;gap:15px}.photo-actions-staff .btn{width:-webkit-fit-content;width:fit-content}.photo-actions-staff small{color:#666;display:block;font-size:13px}@media (max-width:768px){.staff-page .header-actions{flex-direction:column;gap:8px;width:100%}.staff-page .header-actions .btn{justify-content:center;width:100%}.staff-page .filters{flex-direction:column}.staff-page .filter-select,.staff-page .search-box{width:100%}.add-mode-selection,.staff-page .detail-grid,.staff-page .stats-grid{grid-template-columns:1fr}}.courses-page{max-width:1400px}.modern-header{align-items:center;border-radius:20px;display:flex;min-height:180px;padding:0}.modern-header .header-background{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:linear-gradient(135deg,#6366f1e6,#8b5cf6d9 50%,#ec4899cc);height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.modern-header .header-background:before{animation:float 6s ease-in-out infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);border-radius:50%;content:"";height:500px;position:absolute;right:-10%;top:-50%;width:500px}.modern-header .header-background:after{animation:float 8s ease-in-out infinite reverse;background:radial-gradient(circle,#ffffff14 0,#0000 70%);border-radius:50%;bottom:-30%;content:"";height:400px;left:-5%;position:absolute;width:400px}.modern-header .header-content{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;padding:30px 35px;position:relative;width:100%;z-index:2}.modern-header .header-left{align-items:center;display:flex;flex:1 1;gap:20px;min-width:250px}.modern-header .header-icon-wrapper{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:18px;box-shadow:0 8px 32px #0000001a;display:flex;height:70px;justify-content:center;transition:all .3s ease;width:70px}.modern-header .header-icon-wrapper:hover{box-shadow:0 12px 40px #00000026;transform:scale(1.05) rotate(5deg)}.modern-header .header-icon{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:32px}.modern-header .header-text{flex:1 1}.modern-header .header-title{color:#fff;font-size:clamp(24px,4vw,36px);font-weight:700;letter-spacing:-.5px;margin:0 0 8px;text-shadow:0 2px 10px #0000001a}.modern-header .header-subtitle{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffffe6;border:1px solid #fff9;border-radius:8px;box-shadow:0 2px 8px #00000014;color:#1f2937e6;display:inline-block;font-size:clamp(13px,2vw,16px);font-weight:500;margin:0;padding:8px 16px;text-shadow:0 1px 2px #0000000d}.modern-header .header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px;z-index:2}.btn-glass{background:#ffffff26;border:1px solid #ffffff4d;box-shadow:0 4px 15px #0000001a;display:inline-flex;font-size:clamp(13px,2vw,14px);padding:12px 20px;text-decoration:none;white-space:nowrap}.btn-glass:hover:not(:disabled){background:#ffffff40;border-color:#ffffff80;box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.btn-glass:active:not(:disabled){transform:translateY(0)}.btn-glass:disabled{cursor:not-allowed;opacity:.5}.btn-glass.btn-primary{background:#ffffff40;border:2px solid #ffffff80;font-weight:700}.btn-glass.btn-primary:hover:not(:disabled){background:#ffffff59;box-shadow:0 8px 25px #0003}.btn-glass svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.1));font-size:18px}.stats-cards-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.stat-card{box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-card .stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;font-size:28px;height:60px;justify-content:center;width:60px}.stat-card .stat-content h3{color:var(--text-primary);font-size:32px;font-weight:700;margin:0 0 5px}.stat-card .stat-content p{color:var(--text-secondary);font-size:14px;font-weight:500;margin:0}.filters-grid{grid-template-columns:repeat(4,1fr)}@media (max-width:1200px){.filters-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.filters-grid,.stats-cards-grid{grid-template-columns:1fr}.stat-card{padding:15px}.stat-card .stat-icon{font-size:24px;height:50px;width:50px}.stat-card .stat-content h3{font-size:28px}.stat-card .stat-content p{font-size:13px}}.courses-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.course-card{background:#fff;border-radius:8px;box-shadow:var(--shadow);padding:20px;transition:transform .3s ease,box-shadow .3s ease}.course-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.course-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.course-code{background:var(--primary-color);border-radius:6px;color:#fff;font-size:14px;font-weight:600;padding:6px 12px}.course-actions{display:flex;gap:8px}.course-card h3{color:var(--text-primary);font-size:18px;margin-bottom:15px;min-height:48px}.course-info{margin:15px 0}.info-row{border-bottom:1px solid var(--border-color);font-size:14px;padding:8px 0}.info-row:last-child{border-bottom:none}.info-row .label{color:var(--text-secondary);font-weight:500}.course-schedule{background:var(--light-color);border-radius:6px;font-size:13px;line-height:1.6;margin:15px 0;padding:12px}.course-schedule strong{color:var(--text-primary)}.lecturers-section{background:#f8f9fa;border-left:3px solid var(--primary-color);border-radius:6px;margin:15px 0;padding:15px}.lecturers-section strong{color:var(--text-primary);display:block;font-size:14px;margin-bottom:10px}.lecturers-list{list-style:none;margin:0;padding:0}.lecturer-item{background:#fff;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:8px;padding:10px}.lecturer-item:last-child{margin-bottom:0}.lecturer-name{color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:6px}.lecturer-name .nidn{color:var(--text-secondary);font-size:12px;font-weight:400}.lecturer-details{display:flex;flex-wrap:wrap;gap:8px}.detail-badge{background:#e3f2fd;border-radius:4px;color:#1976d2;font-size:11px;font-weight:500;padding:3px 8px}.course-description{color:var(--text-secondary);font-size:14px;line-height:1.5;margin-top:15px}.empty-state{color:var(--text-secondary);grid-column:1/-1}.empty-state svg{color:var(--text-secondary);margin-bottom:15px}@media (max-width:768px){.courses-grid,.filters-grid{grid-template-columns:1fr}.modern-header{border-radius:16px;min-height:140px}.modern-header .header-content{padding:20px 25px}.modern-header .header-icon-wrapper{border-radius:14px;height:55px;width:55px}.modern-header .header-icon{font-size:24px}.modern-header .header-title{font-size:22px}.btn-glass,.modern-header .header-subtitle{font-size:13px}.btn-glass{padding:10px 16px}}@media (max-width:480px){.modern-header{border-radius:14px;min-height:auto}.modern-header .header-content{padding:18px 20px}.modern-header .header-left{gap:12px}.modern-header .header-icon-wrapper{border-radius:12px;height:50px;width:50px}.modern-header .header-icon{font-size:22px}.modern-header .header-title{font-size:20px}.modern-header .header-subtitle{font-size:12px;line-height:1.4}.btn-glass .btn-text{display:none}.btn-glass svg{font-size:18px;margin:0}.modern-header .header-background:after,.modern-header .header-background:before{height:300px;width:300px}}.nilai-transfer-page{padding:0}.nilai-transfer-page .header-icon-wrapper,.nilai-transfer-page .modern-table.accent-purple thead{background:linear-gradient(135deg,#8b5cf6,#6366f1)}.grade-badge{border-radius:12px;display:inline-block;font-size:13px;font-weight:600;padding:4px 12px}.grade-A{background:#dcfce7;color:#166534}.grade-A-{background:#d1fae5;color:#065f46}.grade-B,.grade-B\+{background:#dbeafe;color:#1e40af}.grade-B-{background:#e0e7ff;color:#4338ca}.grade-C,.grade-C\+{background:#fef3c7;color:#92400e}.grade-D,.grade-E{background:#fee2e2;color:#991b1b}.table-btn-primary{background:linear-gradient(135deg,#8b5cf6,#6366f1)!important;color:#fff!important}.table-btn-primary:hover{background:linear-gradient(135deg,#7c3aed,#4f46e5)!important;transform:translateY(-1px)}@media (max-width:768px){.nilai-transfer-page .header-actions{flex-direction:column;gap:8px;width:100%}.nilai-transfer-page .header-actions .btn{justify-content:center;width:100%}.nilai-transfer-page .filters{flex-direction:column}.nilai-transfer-page .search-box{width:100%}.nilai-transfer-page .detail-grid,.nilai-transfer-page .stats-grid{grid-template-columns:1fr}}.transkrip-nilai-page{padding:0}.transkrip-nilai-page .header-icon-wrapper,.transkrip-nilai-page .modern-table.accent-green thead{background:linear-gradient(135deg,#10b981,#059669)}.empty-state{color:#6b7280}.table-btn-primary{color:#4f46e5;transition:all .3s ease}.table-btn-primary:hover{background:#4f46e51a;transform:scale(1.1)}@media (max-width:768px){.transkrip-nilai-page .header-actions{flex-direction:column;gap:8px;width:100%}.transkrip-nilai-page .header-actions .btn{justify-content:center;width:100%}.transkrip-nilai-page .filters{flex-direction:column}.transkrip-nilai-page .filter-select,.transkrip-nilai-page .search-box{width:100%}.transkrip-nilai-page .stats-grid{grid-template-columns:1fr}}.kurikulum-container{padding:20px}.kurikulum-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.kurikulum-header h2{color:#2c3e50;font-size:24px;font-weight:600;margin:0}.btn-add:disabled{background:#95a5a6;cursor:not-allowed;transform:none}.kurikulum-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.stat-value{color:#2c3e50}.stat-label{color:#7f8c8d}.kurikulum-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.table-header{border-bottom:1px solid #ecf0f1;padding:20px}.table-header h3{color:#2c3e50;font-size:18px;font-weight:600;margin:0 0 15px}.kurikulum-table{border-collapse:collapse;width:100%}.kurikulum-table thead{background:#f8f9fa}.kurikulum-table thead th{border-bottom:2px solid #ecf0f1;color:#2c3e50;font-size:13px;font-weight:600;letter-spacing:.5px;padding:15px;text-align:left;text-transform:uppercase}.kurikulum-table tbody td{border-bottom:1px solid #ecf0f1;color:#34495e;font-size:14px;padding:15px}.kurikulum-table tbody tr:hover{background:#f8f9fa}.kurikulum-table tbody tr:last-child td{border-bottom:none}.badge{font-weight:500}.badge.semester{background:#e3f2fd;color:#1976d2}.loading{padding:40px;text-align:center}.empty-state,.loading{color:#7f8c8d}.empty-state svg{color:#bdc3c7;height:80px;width:80px}.empty-state p{margin-bottom:10px}.modal-content.modal-large{max-width:700px}.modal-header{margin-bottom:20px}.modal-header h3{margin:0 0 5px}.modal-subtitle{color:#7f8c8d;margin:0}.modal-body{margin-bottom:25px}.form-row{margin-bottom:0}@media (max-width:768px){.form-row{grid-template-columns:1fr}}.form-group label .required{color:#e74c3c;margin-left:3px}.form-group input,.form-group select{border:1px solid #dfe6e9;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#667eea;outline:none}.btn{border-radius:6px}.btn-secondary:hover{background:#dfe6e9}.btn-danger:disabled{background:#95a5a6;transform:none}.action-buttons,.btn-action{justify-content:center}.btn-action{align-items:center;background:none;display:flex;padding:8px}.btn-action svg{height:18px;width:18px}.btn-action.btn-edit{color:#3498db}.btn-action.btn-edit:hover{background:#e3f2fd;color:#2980b9}.btn-action.btn-view-matkul{align-items:center;color:#fff;display:flex;padding:6px 10px}.btn-action.btn-view-matkul:hover{background:#f0f3ff;color:#764ba2}.mata-kuliah-row{background:#f8f9fa}.mata-kuliah-row td{border-bottom:2px solid #dfe6e9!important;padding:0!important}.mata-kuliah-container{animation:slideDown .3s ease;padding:20px}.mata-kuliah-header{border-bottom:2px solid #ecf0f1;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.mata-kuliah-header,.mata-kuliah-header .mk-header-left{align-items:center;display:flex}.mata-kuliah-header h4{color:#2c3e50;font-size:16px;font-weight:600;margin:0}.mata-kuliah-loading{color:#7f8c8d;padding:30px;text-align:center}.mata-kuliah-empty{color:#7f8c8d;padding:40px 20px;text-align:center}.mata-kuliah-empty p{font-size:14px;margin:5px 0}.mata-kuliah-empty small{color:#95a5a6;font-size:12px}.mata-kuliah-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-top:15px}.mata-kuliah-card{background:#fff;border:1px solid #ecf0f1;border-radius:8px;padding:15px;position:relative;transition:all .3s ease}.mata-kuliah-card:hover{border-color:#667eea;box-shadow:0 3px 10px #667eea1a;transform:translateY(-2px)}.mata-kuliah-card:hover .mk-actions{opacity:1}.mk-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.mk-semester{color:#7f8c8d;letter-spacing:.5px}.mk-badge,.mk-semester{font-size:11px;font-weight:600;text-transform:uppercase}.mk-badge{border-radius:12px;padding:3px 10px}.mk-badge.wajib{background:#e8f5e9;color:#2e7d32}.mk-badge.pilihan{background:#fff3e0;color:#e65100}.mk-body{margin-bottom:12px}.mk-kode{color:#667eea;font-size:12px;font-weight:600;margin:0 0 5px}.mk-nama{color:#2c3e50;font-size:14px;font-weight:500;line-height:1.4;margin:0}.mk-footer{align-items:center;border-top:1px solid #ecf0f1;display:flex;justify-content:space-between;padding-top:10px}.mk-sks{color:#2c3e50;font-size:13px}.mk-sks strong{color:#667eea;font-size:16px}.mk-detail{color:#7f8c8d;display:flex;font-size:11px;gap:8px}.mk-detail span{background:#f8f9fa;border-radius:4px;padding:3px 6px}.mk-actions{display:flex;gap:5px;opacity:0;position:absolute;right:10px;top:10px;transition:opacity .3s ease}.mk-actions .btn-action{font-size:12px;padding:6px 8px}.kelas-container{padding:20px}.kelas-header{justify-content:space-between;margin-bottom:20px}.kelas-header,.kelas-header h2{align-items:center;display:flex}.kelas-header h2{color:#2c3e50;font-size:24px;font-weight:600;gap:10px;margin:0}.header-actions{gap:10px}.kelas-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.stat-card{border-left:4px solid;border-radius:12px;box-shadow:0 2px 8px #0000001a;gap:15px;padding:20px}.stat-card.primary{border-left-color:#667eea}.stat-card.success{border-left-color:#27ae60}.stat-card.warning{border-left-color:#f39c12}.stat-card.info{border-left-color:#3498db}.stat-icon{border-radius:10px;font-size:24px;height:50px;width:50px}.stat-card.primary .stat-icon{background:#667eea1a;color:#667eea}.stat-card.success .stat-icon{background:#27ae601a;color:#27ae60}.stat-card.warning .stat-icon{background:#f39c121a;color:#f39c12}.stat-card.info .stat-icon{background:#3498db1a;color:#3498db}.stat-info h3{color:#2c3e50;font-size:28px;font-weight:700;margin:0}.stat-info p{color:#7f8c8d;font-size:13px;margin:5px 0 0}.kelas-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.filter-search{border:1px solid #dfe6e9;border-radius:8px;flex:1 1;font-size:14px;min-width:250px;padding:10px 15px;transition:all .3s ease}.filter-search:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-input{background:#fff;border:1px solid #dfe6e9;border-radius:8px;cursor:pointer;flex:0 0 200px;font-size:14px;padding:10px 15px;transition:all .3s ease}.filter-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.btn-reset-filter{align-items:center;background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-reset-filter:hover{box-shadow:0 4px 12px #e74c3c4d;transform:translateY(-2px)}.btn-reset-filter:active{transform:translateY(0)}.kelas-table-container{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.kelas-table{border-collapse:collapse;width:100%}.kelas-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.kelas-table thead th{border-right:1px solid #fff3;font-size:13px;font-weight:600;letter-spacing:.5px;padding:15px;text-align:left;text-transform:uppercase}.kelas-table thead th:last-child{border-right:none}.kelas-table tbody td{border-bottom:1px solid #ecf0f1;border-right:1px solid #ecf0f1;color:#34495e;font-size:14px;padding:15px}.kelas-table tbody td:last-child{border-right:none}.kelas-table tbody tr:last-child td{border-bottom:none}.kelas-table tbody tr:hover{background:#f8f9fa}.action-buttons{gap:8px}.btn-action{background:#0000;border-radius:6px;font-size:16px;padding:8px 10px}.btn-action.btn-view{color:#3498db}.btn-action.btn-view:hover{background:#e3f2fd;color:#2980b9}.btn-action.btn-edit{color:#f39c12}.btn-action.btn-edit:hover{background:#fff3e0;color:#e67e22}.btn-action.btn-delete{color:#e74c3c}.btn-action.btn-delete:hover{background:#ffebee;color:#c0392b}.btn-add{background:linear-gradient(135deg,#56ab2f,#a8e063);border-radius:8px;color:#fff;font-size:14px;font-weight:500;gap:8px;padding:10px 20px}.btn-add:hover{box-shadow:0 5px 15px #56ab2f66;transform:translateY(-2px)}.btn-sync{background:linear-gradient(135deg,#667eea,#764ba2);font-size:14px;font-weight:500;padding:10px 20px}.btn-sync:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.btn-sync:disabled{background:#95a5a6;transform:none}.empty-state,.loading{color:#7f8c8d;padding:60px 20px;text-align:center}.empty-state svg,.loading svg{color:#bdc3c7;height:80px;margin-bottom:20px;width:80px}.modal-overlay{background:#00000080}.modal-content{border-radius:12px;box-shadow:0 10px 40px #0003;padding:30px}.modal-content.modal-lg{max-width:700px}.modal-header h3{color:#2c3e50;margin:0 0 20px}.modal-body{margin-bottom:20px}.modal-footer{gap:10px}.form-group input,.form-group select,.form-group textarea{border:1px solid #dfe6e9;padding:10px 15px;transition:border-color .3s ease}.form-group small{color:#7f8c8d}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.required{color:#e74c3c}.checkbox-label{display:flex!important;margin-bottom:0!important}.checkbox-label input[type=checkbox]{transform:scale(1.2);width:auto!important}.checkbox-label:hover span{color:#667eea}.btn{border-radius:8px;font-weight:500;padding:10px 20px}.btn-primary:hover{box-shadow:0 5px 15px #667eea66}.btn-primary:disabled{background:#95a5a6;transform:none}.btn-secondary{background:#ecf0f1;color:#2c3e50}.btn-secondary:hover{background:#d5dbdb}.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b)}.btn-danger:hover{box-shadow:0 5px 15px #e74c3c66;transform:translateY(-2px)}.alert{align-items:flex-start;border-radius:8px;gap:10px;padding:15px 20px;white-space:pre-line}.alert-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-info{background:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.detail-section{border-bottom:1px solid #ecf0f1}.detail-section:last-child{padding-bottom:0}.detail-section h4{align-items:center;display:flex;gap:8px}.detail-item label{font-size:12px;margin-bottom:5px}.detail-item p{color:#2c3e50;font-size:14px}.peserta-list{max-height:300px;overflow-y:auto}.peserta-item{background:#f8f9fa;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:8px;padding:10px 15px}.peserta-nim{color:#667eea;font-weight:600}.peserta-nama{color:#2c3e50}.btn-peserta-count{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:20px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;justify-content:center;padding:6px 14px;transition:all .3s ease}.btn-peserta-count:hover{background:linear-gradient(135deg,#764ba2,#667eea);box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-peserta-count:active{transform:translateY(0)}.modal-lg{max-width:900px;width:90%}.peserta-kelas-info{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;margin-bottom:20px;padding:20px}.info-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-bottom:15px}.info-row:last-child{margin-bottom:0}.info-item{gap:5px}.info-item label{color:#7f8c8d}.info-item strong{color:#2c3e50;font-size:16px}.info-item span{color:#34495e}.peserta-count-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 2px 8px #667eea4d;color:#fff;display:inline-flex;font-size:14px;gap:6px;padding:8px 16px}.loading-peserta{padding:40px 20px;text-align:center}.loading-peserta .spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 20px;width:50px}.loading-peserta p{color:#7f8c8d;font-size:14px}.peserta-table-container{border-radius:8px;box-shadow:0 2px 8px #0000000d;max-height:400px;overflow-y:auto}.peserta-table{background:#fff;border-collapse:collapse;width:100%}.peserta-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.peserta-table thead th{border-bottom:2px solid #5568d3;font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 12px;text-align:left;text-transform:uppercase}.peserta-table tbody tr{border-bottom:1px solid #ecf0f1;transition:background-color .2s ease}.peserta-table tbody tr:hover{background-color:#f8f9fa}.peserta-table tbody tr:last-child{border-bottom:none}.peserta-table tbody td{color:#2c3e50;font-size:14px;padding:12px}.peserta-table tbody td strong{color:#667eea;font-weight:600}.peserta-summary{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:0 0 8px 8px;border-top:3px solid #667eea;color:#2c3e50;display:flex;font-size:14px;gap:10px;padding:15px 20px}.peserta-summary strong{color:#667eea;font-size:16px}.no-peserta{color:#7f8c8d;padding:60px 20px;text-align:center}.no-peserta p{color:#95a5a6;font-size:16px;margin-top:15px}.no-peserta small{display:block;margin-top:10px}.users-page{padding:20px}.page-header{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;margin-bottom:25px;padding:24px}.page-header h2{color:#1f2937;font-size:28px;font-weight:700;margin:0 0 8px}.page-header p{margin:0}.btn{display:inline-flex;text-decoration:none}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 12px #3b82f64d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 16px #3b82f666}.btn-secondary{border:1px solid #e5e7eb}.btn-danger{box-shadow:0 4px 12px #ef44444d}.btn-danger:hover:not(:disabled){box-shadow:0 6px 16px #ef444466}.btn:disabled{cursor:not-allowed;opacity:.6}.search-container{align-items:center;display:flex;flex-wrap:wrap;gap:16px;padding:20px}.search-box{min-width:300px}.search-icon{color:#6b7280;left:16px}.search-input{border:2px solid #e5e7eb;border-radius:10px;font-family:inherit;font-size:14px;padding:12px 48px}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:#9ca3af}.clear-search{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;height:28px;justify-content:center;position:absolute;right:12px;transition:all .2s ease;width:28px}.clear-search:hover{background:#e5e7eb;color:#1f2937}.role-filter-container{position:relative}.btn-filter{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:10px;color:#374151;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:all .3s ease;white-space:nowrap}.btn-filter:hover{background:#eff6ff;border-color:#3b82f6}.btn-filter svg{font-size:16px}.btn-filter .rotate{transform:rotate(180deg);transition:transform .3s ease}.role-dropdown{animation:dropdownSlideIn .2s ease;background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px #00000026;max-height:400px;min-width:220px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 8px);z-index:100}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.role-option{color:#374151;cursor:pointer;font-size:14px;padding:12px 16px;transition:all .2s ease}.role-option:hover{background:#f3f4f6}.role-option.active{background:#eff6ff;color:#3b82f6;font-weight:600}.role-option:first-child{border-top-left-radius:10px;border-top-right-radius:10px}.role-option:last-child{border-bottom-left-radius:10px;border-bottom-right-radius:10px}.search-info{color:#6b7280;font-size:13px;padding-left:4px}.role-group-header{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-top:2px solid #e5e7eb;cursor:pointer;transition:all .2s ease}.role-group-header:hover{background:linear-gradient(135deg,#e5e7eb,#d1d5db)}.role-group-header td{font-weight:600;padding:16px 20px!important}.role-header-content{align-items:center;color:#1f2937;display:flex;gap:12px}.chevron-icon{color:#6b7280;font-size:18px;transition:transform .3s ease}.chevron-icon.expanded{transform:rotate(180deg)}.role-title{color:#1f2937;font-size:15px;font-weight:700}.role-count{color:#6b7280;font-size:13px;font-weight:500}.role-group-row{background:#fff;transition:all .2s ease}.role-group-row:hover{background:#f9fafb}.table-actions{justify-content:center}.table-btn-delete{color:#dc2626}.table-btn-delete:hover{background:#dc2626;box-shadow:0 4px 12px #dc26264d;transform:translateY(-2px)}.table-btn-warning{background:#fef3c7;color:#d97706}.table-btn-warning:hover{background:#f59e0b;box-shadow:0 4px 12px #f59e0b4d;color:#fff;transform:translateY(-2px)}.user-nim{color:#6b7280;font-weight:400;margin-top:4px}.user-nim small{font-size:12px}.modal-overlay{overflow-y:auto}.modal-lg{max-width:700px}.modal-header{padding:24px}.modal-header h3{align-items:center;display:flex;gap:10px}.modal-close{background:none;border:none;border-radius:6px;color:#6b7280;padding:4px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-footer{background:#f9fafb}.form-group{gap:8px}.form-group-full{grid-column:1/-1}.form-group label{align-items:center;display:flex;gap:6px}.form-group label .required{color:#ef4444}.form-control:disabled{background:#f9fafb}select.form-control{cursor:pointer}.checkbox-label{border-radius:10px;padding:12px;transition:all .2s ease}.checkbox-label:hover{background:#f9fafb}.checkbox-label input[type=checkbox]{height:20px;width:20px}.checkbox-label span{color:#374151;font-size:14px}.user-avatar-table{border:2px solid #e5e7eb;border-radius:50%;height:40px;object-fit:cover;width:40px}.avatar-upload-container{align-items:center;background:#f9fafb;border:2px dashed #d1d5db;border-radius:12px;display:flex;gap:24px;padding:20px}.avatar-preview{flex-shrink:0}.avatar-preview-img{border:3px solid #3b82f6;border-radius:50%;box-shadow:0 4px 12px #3b82f633;height:100px;object-fit:cover;width:100px}.avatar-upload-input{flex:1 1}.file-input{display:none}.file-label{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:10px;box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.file-label:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 16px #3b82f666;transform:translateY(-2px)}.file-hint{color:#6b7280;font-size:12px;margin:8px 0 0}@media (max-width:768px){.users-page{padding:15px}.page-header{align-items:flex-start;flex-direction:column;gap:16px;padding:20px}.page-header h2{font-size:24px}.btn{justify-content:center;width:100%}.form-grid{grid-template-columns:1fr}.modal-content{max-height:95vh;width:95%}.modal-header{padding:20px}.modal-header h3{font-size:18px}.modal-body{padding:20px}.modal-footer{flex-direction:column-reverse;padding:12px 20px}.modal-footer .btn{width:100%}.avatar-upload-container{flex-direction:column;text-align:center}.avatar-preview-img{height:80px;width:80px}.file-label{justify-content:center;width:100%}}.neofeeder-page{max-width:1400px}.action-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:20px}.action-btn{background:#fff;border:2px solid var(--border-color);border-radius:8px;padding:30px 20px;text-align:center}.action-btn:hover:not(:disabled){background:var(--light-color);border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.action-btn:disabled{cursor:not-allowed;opacity:.5}.action-btn svg{color:var(--primary-color)}.action-btn span{color:var(--text-primary);font-size:16px;font-weight:600}.action-btn p{color:var(--text-secondary);font-size:13px;margin:0}.text-success{color:var(--secondary-color);font-weight:600}.text-danger{color:var(--danger-color);font-weight:600}.form-row{grid-gap:15px;gap:15px}@media (max-width:768px){.action-grid,.form-row{grid-template-columns:1fr}}.profil-pt-container{margin:0 auto;max-width:1400px;padding:24px}.page-header{flex-wrap:wrap;gap:16px;margin-bottom:32px}.header-content{gap:16px}.header-icon{color:#6366f1;font-size:48px}.page-header h1{color:#111827;font-size:28px;margin:0}.page-header p{color:#6b7280;font-size:14px;margin:4px 0 0}.btn-sync{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;box-shadow:0 2px 8px #6366f133;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.btn-sync:hover:not(:disabled){box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.btn-sync:disabled{cursor:not-allowed;opacity:.6}.btn-sync svg.spinning{animation:spin 1s linear infinite}.loading-spinner{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.spinner{border-top-color:#6366f1}.loading-spinner p{color:#6b7280;font-size:14px}.profil-content{display:flex;flex-direction:column;gap:24px}.info-card{border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-bottom:2px solid #d1d5db;padding:20px 24px}.card-header h2{color:#111827;font-size:18px;font-weight:600;margin:0}.info-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));padding:24px}.info-item{flex-direction:column;gap:8px}.info-item.full-width{grid-column:1/-1}.info-item label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-item span{color:#111827;font-size:14px;font-weight:500}.info-item a{color:#6366f1;text-decoration:none;transition:color .2s}.info-item a:hover{color:#4f46e5;text-decoration:underline}.badge{border-radius:6px;font-size:13px;text-align:center}.badge-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.badge-secondary{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#374151}.badge-primary{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.empty-state{background:#fff;border-radius:12px;gap:16px;min-height:400px;padding:48px}.empty-state svg{color:#d1d5db}.empty-state h3{color:#111827;font-size:20px;margin:0}.empty-state p{color:#6b7280}@media (max-width:768px){.profil-pt-container{padding:16px}.header-content,.page-header{align-items:flex-start;flex-direction:column}.header-content{gap:8px}.header-icon{font-size:36px}.page-header h1{font-size:24px}.info-grid{gap:16px;grid-template-columns:1fr;padding:16px}.btn-sync{justify-content:center;width:100%}}.profile-page{margin:0 auto;max-width:1200px}.profile-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:300px 1fr}.profile-avatar-large{align-items:center;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:50%;color:#fff;display:flex;font-size:48px;height:120px;justify-content:center;margin:0 auto 20px;width:120px}.profile-grid .card:first-child{height:-webkit-fit-content;height:fit-content;text-align:center}.profile-grid .card:first-child h3{font-size:22px;margin-bottom:5px}.user-role{background:var(--primary-color);border-radius:20px;color:#fff;display:inline-block;font-size:13px;font-weight:500;margin:10px 0;padding:6px 16px;text-transform:capitalize}.user-email{color:var(--text-secondary);font-size:14px}.card-header{border-bottom:1px solid var(--border-color)}@media (max-width:768px){.profile-grid{grid-template-columns:1fr}}.setting-pembiayaan-page{padding:0}.setting-pembiayaan-page .header-icon-wrapper,.setting-pembiayaan-page .modern-table thead{background:linear-gradient(135deg,#10b981,#059669)}.form-control{border:2px solid #e3f2fd;padding:10px 15px}.form-control:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}textarea.form-control{font-family:inherit}.checkbox-label{align-items:center;gap:10px;padding:10px 0}.checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.checkbox-label span{color:#2c3e50;font-weight:500}.setting-pembiayaan-page .modern-table tbody tr:hover{background:#10b9810d}@media (max-width:768px){.form-grid{grid-template-columns:1fr}.setting-pembiayaan-page .filters{flex-direction:column}.setting-pembiayaan-page .filter-select,.setting-pembiayaan-page .search-box{width:100%}.setting-pembiayaan-page .stats-grid{grid-template-columns:1fr}.setting-pembiayaan-page .modern-table{font-size:12px}.setting-pembiayaan-page .modern-table td,.setting-pembiayaan-page .modern-table th{padding:8px}}.pembayaran-mahasiswa-page{padding:0}.pembayaran-mahasiswa-page .header-icon-wrapper,.pembayaran-mahasiswa-page .modern-table thead{background:linear-gradient(135deg,#3b82f6,#2563eb)}.detail-section{border-bottom:2px solid #e3f2fd;margin-bottom:25px;padding-bottom:20px}.detail-section:last-child{border-bottom:none;margin-bottom:0}.detail-section h4{border-bottom:2px solid #3b82f6;color:#2c3e50;display:inline-block;font-size:16px;font-weight:600;margin:0 0 15px;padding-bottom:10px}.detail-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(2,1fr);margin-top:15px}.detail-item{flex-direction:column;gap:5px}.detail-item.full-width{grid-column:1/-1}.detail-item label{color:#7f8c8d;font-size:13px;font-weight:500}.detail-item span{color:#2c3e50;font-size:14px;font-weight:400}.badge{border-radius:12px;padding:4px 12px}.table-btn-view{color:#3b82f6}.table-btn-view:hover{background:#3b82f61a}.form-group label{font-weight:500}.required{margin-left:3px}@media (max-width:768px){.pembayaran-mahasiswa-page .filters{flex-direction:column}.pembayaran-mahasiswa-page .filter-select,.pembayaran-mahasiswa-page .search-box{width:100%}.detail-grid,.form-grid,.pembayaran-mahasiswa-page .stats-grid{grid-template-columns:1fr}.pembayaran-mahasiswa-page .modern-table{font-size:12px}.pembayaran-mahasiswa-page .modern-table td,.pembayaran-mahasiswa-page .modern-table th{padding:8px}}.search-icon{color:#9ca3af;font-size:18px;left:12px;z-index:1}.search-input{padding-left:40px!important}.searchable-dropdown{animation:slideDown .2s ease;border:2px solid #3b82f6;border-radius:8px;box-shadow:0 4px 20px #3b82f626;margin-top:4px;top:100%;z-index:1000}.dropdown-header{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-bottom:2px solid #3b82f6;color:#1e40af;padding:8px 16px;text-align:center}.dropdown-item{border-bottom:1px solid #f3f4f6;padding:12px 16px}.dropdown-item:hover{background:linear-gradient(135deg,#e0f2fe,#dbeafe)}.dropdown-item-main{color:#1f2937;margin-bottom:4px}.dropdown-item-main strong{color:#3b82f6;font-weight:600}.dropdown-item-sub{color:#6b7280;font-size:12px}.program-badge{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-radius:4px;color:#6b21a8;display:inline-block;padding:2px 8px}.dropdown-item-empty{color:#9ca3af;font-size:14px;padding:12px 16px}.selected-info{background:linear-gradient(135deg,#dbeafe,#e0f2fe);border-left:3px solid #3b82f6;border-radius:6px;margin-top:8px;padding:8px 12px}.selected-info small{color:#1e40af;display:block;font-size:13px}.selected-info strong{color:#1e3a8a;font-weight:600}.searchable-dropdown::-webkit-scrollbar{width:6px}.searchable-dropdown::-webkit-scrollbar-track{background:#f3f4f6;border-radius:10px}.searchable-dropdown::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:10px}.searchable-dropdown::-webkit-scrollbar-thumb:hover{background:#2563eb}.tagihan-list{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto;padding:4px}.tagihan-item{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px 14px 20px;position:relative;transition:all .3s ease}.tagihan-item:hover{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;transform:translateX(4px)}.tagihan-item.selected{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6;box-shadow:0 4px 16px #3b82f633}.tagihan-item.selected:before{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;content:"✓";display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;left:8px;position:absolute;top:50%;transform:translateY(-50%);width:24px}.tagihan-info{display:flex;flex:1 1;flex-direction:column;gap:6px}.tagihan-title{align-items:center;display:flex;gap:10px;margin-bottom:4px}.tagihan-title strong{color:#1e293b;font-size:15px;font-weight:600}.tagihan-badge{border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:3px 10px;text-transform:uppercase}.tagihan-badge.badge-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24;color:#92400e}.tagihan-badge.badge-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #ef4444;color:#991b1b}.tagihan-details{color:#64748b;display:flex;flex-direction:column;font-size:13px;gap:4px}.tagihan-deadline{color:#94a3b8;font-size:12px;font-weight:500}.tagihan-amount{color:#3b82f6;font-size:18px;font-weight:700;min-width:140px;text-align:right}.tagihan-loading{color:#94a3b8;font-style:italic;padding:20px;text-align:center}.form-hint{color:#64748b;display:block;font-size:13px;font-style:italic;margin-top:8px}.no-tagihan-info{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;border-radius:10px;color:#065f46;font-size:14px;font-weight:500;padding:16px;text-align:center}.tagihan-list::-webkit-scrollbar{width:6px}.tagihan-list::-webkit-scrollbar-track{background:#f3f4f6;border-radius:10px}.tagihan-list::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:10px}.tagihan-list::-webkit-scrollbar-thumb:hover{background:#2563eb}@media (max-width:768px){.tagihan-item{align-items:flex-start;flex-direction:column;gap:10px}.tagihan-amount{text-align:left;width:100%}}.manajemen-keuangan-page{padding:0}.filters{grid-gap:15px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-select{background:#ffffffe6;border:1px solid #ffffff4d;color:#2c3e50;padding:10px 15px}.filter-select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}@media print{.btn,.filters,.modern-header,.table-actions{display:none!important}.card{border:1px solid #ddd;box-shadow:none!important}.modern-table{font-size:12px}.modern-table td,.modern-table th{padding:8px!important}}.badge-success{background:linear-gradient(135deg,#10b981,#059669)}.badge-danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.modern-table tbody td strong{font-size:15px;font-weight:600}@media (max-width:768px){.filters,.form-grid,.stats-grid-4{grid-template-columns:1fr}}.formulir-pendaftaran-page{padding:0}.card-header{background:linear-gradient(135deg,#3498db0d,#9b59b60d);border-bottom:2px solid #3498db33;padding:20px}.card-header h3{color:#2c3e50}.modal-large{max-width:800px}.badge-secondary{background:linear-gradient(135deg,#6c757d,#495057)}@media (max-width:768px){.modal-large{max-width:none;width:95%}}.user-pmb-page{padding:0}.stats-grid-4{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .form-control{padding-right:45px}.password-toggle{align-items:center;background:none;border:none;color:#6c757d;cursor:pointer;display:flex;justify-content:center;padding:5px;position:absolute;right:10px;transition:color .3s ease}.password-toggle:hover{color:#3498db}.status-select{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .3s ease}.status-select.status-pending{background:#f59e0b1a;color:#f59e0b}.status-select.status-approved{background:#10b9811a;color:#10b981}.status-select.status-rejected{background:#ef44441a;color:#ef4444}.status-select.status-registered{background:#3b82f61a;color:#3b82f6}.status-select:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}@media (max-width:768px){.stats-grid-4{grid-template-columns:1fr}}.halaman-pmb-page{padding:0}.modal-large{width:90%}.input-with-icon svg{left:12px}.input-with-icon .form-control{padding-left:40px}code{background:#3498db1a;border-radius:4px;color:#3498db;font-family:Courier New,monospace;font-size:13px;padding:4px 8px}.toggle-btn{align-items:center;background:#ef44441a;border:none;border-radius:6px;color:#ef4444;cursor:pointer;display:inline-flex;font-size:13px;gap:5px;padding:6px 12px;transition:all .3s ease}.toggle-btn.active{background:#10b9811a;color:#10b981}.toggle-btn:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}small{color:#6c757d;display:block;font-size:12px;margin-top:5px}.table-btn-view{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.table-btn-view:hover{box-shadow:0 4px 12px #3b82f666}.modal-preview{max-height:90vh;max-width:1000px;overflow-y:auto;width:95%}.preview-header-info{flex:1 1}.preview-header-info h3{color:#2c3e50;font-size:24px;margin:0 0 10px}.preview-badges{display:flex;flex-wrap:wrap;gap:8px}.preview-badges .badge{font-size:12px;padding:4px 10px}.preview-body{background:#f8f9fa;padding:25px}.preview-info-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d;margin-bottom:20px;padding:20px}.preview-info-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:15px}.preview-info-item{display:flex;flex-direction:column;gap:5px}.preview-info-item label{color:#6c757d;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.preview-info-item code,.preview-info-item span{color:#2c3e50;font-size:14px}.preview-meta{border-top:1px solid #e9ecef;margin-top:15px;padding-top:15px}.preview-meta label{color:#6c757d;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.meta-description{background:#f8f9fa;border-left:3px solid #3b82f6;border-radius:4px;color:#495057;font-size:14px;line-height:1.6;margin:0;padding:12px}.preview-banner{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d;margin-bottom:20px;padding:20px}.preview-banner label{color:#6c757d;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.banner-preview{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:center;max-height:300px;overflow:hidden;width:100%}.banner-preview img{height:auto;object-fit:cover;width:100%}.preview-content-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d;margin-bottom:20px;padding:20px}.preview-content-section label{color:#6c757d;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:15px;text-transform:uppercase}.preview-content{background:#fff;border:1px solid #e9ecef;border-radius:8px;color:#2c3e50;font-size:15px;min-height:200px;padding:20px}.preview-content h1,.preview-content h2,.preview-content h3,.preview-content h4{color:#2c3e50;margin-bottom:10px;margin-top:20px}.preview-content h1{font-size:28px}.preview-content h2{font-size:24px}.preview-content h3{font-size:20px}.preview-content h4{font-size:18px}.preview-content p{margin-bottom:15px;text-align:justify}.preview-content li{margin-bottom:8px}.preview-content a{color:#3b82f6;text-decoration:underline}.preview-content img{margin:15px 0}.preview-content blockquote{background:#f8f9fa;border-left:4px solid #3b82f6;color:#495057;font-style:italic;margin:20px 0;padding:15px 20px}.preview-content table{margin:15px 0}.preview-content table td,.preview-content table th{border:1px solid #dee2e6;padding:10px;text-align:left}.preview-content table th{background:#f8f9fa}.preview-footer-info{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d;padding:15px 20px;text-align:right}.preview-footer-info small{color:#6c757d;font-size:13px}.preview-footer-info strong{color:#2c3e50}@media (max-width:768px){.modal-large{max-width:none;width:95%}.modal-preview{max-height:95vh;width:98%}.preview-info-grid{grid-template-columns:1fr}.preview-badges{margin-top:10px}.preview-body,.preview-content{padding:15px}}.halaman-editor-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:20px;position:relative}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.loading-spinner{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;padding:40px 60px;text-align:center}.loading-spinner p{color:#475569;font-size:16px;font-weight:600;margin:0}.editor-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px 30px}.header-left{gap:15px}.header-left h1{color:#1e293b;font-size:24px;font-weight:700;margin:0}.btn-back{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-back:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.header-right{display:flex;gap:10px}.btn-toggle{background:#f1f5f9;border:2px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-toggle:hover{background:#e2e8f0;border-color:#cbd5e1}.btn-toggle.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff}.editor-layout{grid-gap:20px;display:grid;gap:20px;grid-template-columns:350px 1fr;min-height:calc(100vh - 150px)}.editor-sidebar{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;height:-webkit-fit-content;height:fit-content;max-height:calc(100vh - 40px);overflow-y:auto;padding:25px;position:-webkit-sticky;position:sticky;top:20px}.form-section h3{border-bottom:2px solid #e2e8f0;color:#1e293b;font-size:18px;padding-bottom:10px}.form-group{margin-bottom:20px}.form-group label{color:#334155}.form-control{border-radius:8px;font-family:inherit;padding:12px 14px}.form-control::placeholder{color:#94a3b8}textarea.form-control{min-height:80px;resize:vertical}.form-group small{color:#64748b}.input-group{display:flex;gap:5px}.input-group .form-control{flex:1 1}.btn-generate{background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;padding:0 15px;transition:all .3s ease}.btn-generate:hover{box-shadow:0 2px 8px #f59e0b66;transform:scale(1.05)}.form-actions-sidebar{border-top:2px solid #e2e8f0;display:flex;flex-direction:column;gap:10px;margin-top:30px;padding-top:20px}.btn-block{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .3s ease;width:100%}.btn-primary{box-shadow:0 2px 8px #667eea4d}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#f1f5f9;border:2px solid #e2e8f0;color:#475569}.btn-secondary:hover{background:#e2e8f0}.editor-main{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;overflow:hidden}.editor-toolbar{background:#f8fafc;border-bottom:2px solid #e2e8f0;flex-wrap:wrap;gap:8px;padding:12px 15px}.editor-toolbar,.toolbar-group{align-items:center;display:flex}.toolbar-group{gap:5px}.toolbar-group button,.toolbar-group select{background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#334155;cursor:pointer;font-size:14px;font-weight:500;padding:8px 12px;transition:all .2s ease}.toolbar-group button:hover,.toolbar-group select:hover{background:#f1f5f9;border-color:#94a3b8}.toolbar-group button:active{background:#e2e8f0}.toolbar-group select{min-width:120px}.toolbar-divider{background:#cbd5e1;height:30px;width:1px}.editor-content{color:#1e293b;flex:1 1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.8;max-height:calc(100vh - 300px);min-height:500px;outline:none;overflow-y:auto;padding:30px}.editor-content:empty:before{color:#94a3b8;content:attr(placeholder);font-style:italic}.editor-content h1{color:#0f172a;font-size:32px;font-weight:800;margin:20px 0}.editor-content h2{color:#1e293b;font-size:28px;font-weight:700;margin:18px 0}.editor-content h3{color:#334155;font-size:24px;font-weight:600;margin:16px 0}.editor-content h4{color:#475569;font-size:20px;font-weight:600;margin:14px 0}.editor-content h5{color:#64748b;font-size:18px;font-weight:600;margin:12px 0}.editor-content h6{color:#64748b;font-size:16px;font-weight:600;margin:10px 0}.editor-content p{margin:12px 0}.editor-content ol,.editor-content ul{margin:12px 0;padding-left:30px}.editor-content li{margin:6px 0}.editor-content a{color:#667eea;text-decoration:underline}.editor-content img{border-radius:8px;height:auto;margin:15px 0;max-width:100%}.editor-content table{border-collapse:collapse;margin:15px 0;width:100%}.editor-content table td,.editor-content table th{border:1px solid #e2e8f0;padding:10px}.editor-content table th{background:#f1f5f9;font-weight:600}.editor-content blockquote{border-left:4px solid #667eea;color:#64748b;font-style:italic;margin:15px 0;padding-left:20px}.editor-content pre{background:#1e293b;border-radius:8px;color:#e2e8f0;margin:15px 0;overflow-x:auto}.editor-code,.editor-content pre{font-family:Courier New,monospace;padding:20px}.editor-code{border:none;flex:1 1;font-size:14px;line-height:1.6;max-height:calc(100vh - 300px);min-height:500px;outline:none;resize:none}.editor-preview{max-height:calc(100vh - 200px);overflow-y:auto;padding:40px}.preview-header{border-bottom:2px solid #e2e8f0;margin-bottom:30px;padding-bottom:20px}.preview-header h2{color:#0f172a;font-size:32px;font-weight:800;margin-bottom:10px}.preview-description{color:#64748b;font-size:16px;line-height:1.6}.preview-content{color:#1e293b;font-size:16px;line-height:1.8}.preview-content h1,.preview-content h2,.preview-content h3,.preview-content h4,.preview-content h5,.preview-content h6{color:#0f172a;font-weight:700;margin:20px 0 15px}.preview-content p{margin:15px 0}.preview-content ol,.preview-content ul{margin:15px 0;padding-left:30px}.preview-content img{border-radius:8px;box-shadow:0 4px 12px #0000001a;height:auto;margin:20px 0;max-width:100%}.preview-content table{border-collapse:collapse;box-shadow:0 2px 8px #0000001a;margin:20px 0;width:100%}.preview-content table td,.preview-content table th{border:1px solid #e2e8f0;padding:12px}.preview-content table th{background:#f8fafc;font-weight:600}@media (max-width:1024px){.editor-layout{grid-template-columns:1fr}.editor-sidebar{max-height:none;position:relative;top:0}}@media (max-width:768px){.editor-header{align-items:flex-start;flex-direction:column;gap:15px}.header-right{justify-content:flex-end;width:100%}.editor-toolbar{padding:10px}.toolbar-group button,.toolbar-group select{font-size:13px;padding:6px 10px}.editor-content,.editor-preview{padding:20px}.preview-header h2{font-size:24px}}@media (max-width:480px){.halaman-editor-container{padding:10px}.editor-header{padding:15px}.header-left h1{font-size:20px}.btn-back{font-size:14px;padding:8px 15px}.btn-toggle{font-size:13px;padding:8px 12px}.editor-sidebar{padding:20px}.editor-code,.editor-content{font-size:14px}.toolbar-group select{font-size:12px;min-width:100px}}.editor-content::-webkit-scrollbar,.editor-preview::-webkit-scrollbar,.editor-sidebar::-webkit-scrollbar{width:8px}.editor-content::-webkit-scrollbar-track,.editor-preview::-webkit-scrollbar-track,.editor-sidebar::-webkit-scrollbar-track{background:#f1f5f9}.editor-content::-webkit-scrollbar-thumb,.editor-preview::-webkit-scrollbar-thumb,.editor-sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.editor-content::-webkit-scrollbar-thumb:hover,.editor-preview::-webkit-scrollbar-thumb:hover,.editor-sidebar::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:768px){.mobile-logo-right{flex-direction:row-reverse!important;justify-content:flex-end;width:100%}.mobile-logo-right .logo-text{align-items:flex-end;text-align:right}}html{scroll-behavior:smooth}.beranda-pmb{background:#f8f9fa;min-height:100vh}.pmb-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 20px #667eea4d;padding:15px 0;position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;z-index:1000}.pmb-container{margin:0 auto;max-width:1200px;padding:0 20px}.pmb-nav{justify-content:space-between;width:100%}.mobile-menu-toggle,.pmb-logo,.pmb-nav{align-items:center;display:flex}@media (max-width:768px){.pmb-nav{align-items:center;flex-direction:row;justify-content:space-between;width:100%}.pmb-logo{flex-shrink:0;margin-right:0}.mobile-menu-toggle,.pmb-logo{align-items:center;display:flex}.mobile-menu-toggle{margin-left:0}.pmb-menu{flex:1 1;justify-content:flex-end}}.pmb-logo{align-items:center;cursor:pointer;display:flex;gap:15px;transition:transform .3s ease}.pmb-logo:hover{transform:translateX(5px)}.logo-image{background:#fff;border-radius:14px;box-shadow:0 4px 15px #0003;height:55px;object-fit:contain;padding:8px;transition:all .3s ease;width:55px}.logo-image:hover{box-shadow:0 6px 20px #00000040;transform:rotate(5deg) scale(1.05)}.logo-text{display:flex;flex-direction:column;gap:2px}.pmb-logo h1{background:linear-gradient(90deg,#fff,#f0f0f0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:26px;font-weight:800;letter-spacing:-.5px;margin:0;text-shadow:0 2px 4px #0000001a}.pmb-logo p{color:#fffffff2;font-size:12px;font-weight:500;letter-spacing:.5px;margin:0;opacity:.9;text-transform:uppercase}.pmb-menu{gap:10px}.pmb-menu,.pmb-menu a{align-items:center;display:flex}.pmb-menu a{border-radius:10px;color:#fff;font-size:14px;font-weight:600;gap:6px;overflow:hidden;padding:10px 20px;position:relative;text-decoration:none;transition:all .3s ease}.pmb-menu a:before{background:#ffffff1a;content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease;width:100%}.pmb-menu a:hover:before{left:0}.pmb-menu a.active,.pmb-menu a:hover{background:#ffffff40;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.pmb-menu a:not([href="#beranda"]):not(.btn-login){display:none}.btn-login{background:#fff!important;border-radius:12px!important;box-shadow:0 4px 15px #ffffff4d;color:#667eea!important;font-weight:700!important;padding:10px 24px!important;transition:all .3s ease!important}.btn-login:before{background:linear-gradient(135deg,#667eea,#764ba2)!important;opacity:0;transition:opacity .3s ease}.btn-login:hover{background:#fffffff2!important;box-shadow:0 6px 20px #fff6!important;transform:translateY(-3px)!important}.mobile-menu-toggle{align-items:center;background:#fff3;border:none;border-radius:12px;box-shadow:0 2px 10px #0000001a;color:#fff;cursor:pointer;display:none;font-size:24px;height:45px;justify-content:center;transition:all .3s ease;width:45px}.mobile-menu-toggle:hover{background:#ffffff4d;transform:scale(1.05)}.mobile-menu-toggle:active{transform:scale(.95)}.mobile-menu-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#00000080;display:none;height:100%;left:0;position:fixed;top:0;width:100%;z-index:998}.pmb-hero{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 40px #667eea4d;overflow:hidden;padding:120px 0 100px;position:relative}.hero-background{animation:float 20s ease-in-out infinite;height:100%;left:0;opacity:.08;position:absolute;top:0;width:100%}.hero-pattern{background-image:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff1a 0,#0000 50%),radial-gradient(circle,#fff 1px,#0000 0);background-position:0 0,100% 100%,0 0;background-size:600px 600px,800px 800px,25px 25px;height:100%;width:100%}.hero-content{animation:fadeInUp 1s ease;color:#fff;position:relative;text-align:center;z-index:1}.hero-title{animation:fadeInUp 1s ease .2s both;font-size:56px;font-weight:900;letter-spacing:-1px;line-height:1.2;margin-bottom:25px;text-shadow:0 4px 20px #0003}.gradient-text{-webkit-text-fill-color:#0000;animation:shine 3s linear infinite;background:linear-gradient(90deg,#fff,gold,#fff);-webkit-background-clip:text;background-clip:text;background-size:200% auto}@keyframes shine{to{background-position:200%}}.hero-subtitle{animation:fadeInUp 1s ease .4s both;font-size:22px;font-weight:400;line-height:1.7;margin-bottom:45px;margin-left:auto;margin-right:auto;max-width:700px;opacity:.98;text-shadow:0 2px 10px #00000026}.hero-buttons{animation:fadeInUp 1s ease .6s both;display:flex;gap:20px;justify-content:center;margin-bottom:70px}.btn-outline-large,.btn-primary-large{align-items:center;border-radius:14px;display:inline-flex;font-size:18px;font-weight:700;gap:10px;letter-spacing:.3px;overflow:hidden;padding:16px 45px;position:relative;text-decoration:none;transition:all .4s cubic-bezier(.4,0,.2,1)}.btn-outline-large:before,.btn-primary-large:before{background:#fff3;content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .4s ease;width:100%}.btn-outline-large:hover:before,.btn-primary-large:hover:before{left:100%}.btn-primary-large{background:#fff;border:none;box-shadow:0 8px 25px #ffffff4d;color:#667eea}.btn-primary-large:hover{box-shadow:0 15px 40px #fff6;color:#764ba2;transform:translateY(-5px) scale(1.05)}.btn-outline-large{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:3px solid #fff;color:#fff}.btn-outline-large:hover{background:#fff;box-shadow:0 15px 40px #ffffff4d;color:#667eea;transform:translateY(-5px) scale(1.05)}.hero-stats{animation:fadeInUp 1s ease .8s both;display:flex;gap:80px;justify-content:center;margin-top:50px}.stat-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:16px;cursor:default;padding:20px 30px;position:relative;text-align:center;transition:all .4s ease}.stat-item:before{background:linear-gradient(135deg,#ffffff4d,#ffffff1a);border-radius:16px;bottom:-2px;content:"";left:-2px;opacity:0;position:absolute;right:-2px;top:-2px;transition:opacity .4s ease;z-index:-1}.stat-item:hover:before{opacity:1}.stat-item:hover{background:#ffffff26;box-shadow:0 15px 40px #0003;transform:translateY(-8px) scale(1.05)}.stat-item h3{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#fff,gold);-webkit-background-clip:text;background-clip:text;font-size:44px;font-weight:900;letter-spacing:-1px;margin:0 0 8px;text-shadow:0 2px 10px #0000001a}.stat-item p{font-size:15px;font-weight:500;letter-spacing:.5px;margin:0;opacity:.95;text-transform:uppercase}.pmb-section{padding:80px 0;position:relative}.pmb-section:before{background:radial-gradient(circle,#667eea08 0,#0000 70%);border-radius:50%;content:"";height:0;left:50%;position:absolute;top:0;transform:translateX(-50%);transition:all 1s ease;width:0}.pmb-section:hover:before{height:100%;width:100%}.bg-light{background:linear-gradient(180deg,#f8f9fa 0,#fff)}.section-header{animation:fadeInDown .8s ease;margin-bottom:60px;position:relative;text-align:center}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.section-header:after{animation:expandWidth .8s ease .3s both;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;bottom:-15px;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:80px}@keyframes expandWidth{0%{width:0}to{width:80px}}.section-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;display:inline-block;font-size:38px;font-weight:800;letter-spacing:-.5px;margin-bottom:15px;position:relative;text-transform:capitalize}.section-header p{color:#6c757d;font-size:18px;font-weight:400;line-height:1.6;margin:0 auto;max-width:600px;opacity:.9}.program-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.program-card{background:#fff;border:2px solid #0000;border-radius:20px;box-shadow:0 4px 25px #667eea1a;overflow:hidden;padding:45px 35px;position:relative;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1)}.program-card:before{background:linear-gradient(135deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .4s ease}.program-card:hover:before{transform:scaleX(1)}.program-card:hover{border-color:#667eea33;box-shadow:0 12px 45px #667eea40;transform:translateY(-12px)}.program-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 8px 25px #667eea4d;color:#fff;display:flex;font-size:40px;height:90px;justify-content:center;margin:0 auto 25px;transition:all .4s ease;width:90px}.program-card:hover .program-icon{box-shadow:0 12px 35px #667eea66;transform:scale(1.1) rotate(5deg)}.program-card h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:26px;font-weight:800;letter-spacing:-.3px;margin-bottom:18px}.program-card p{color:#6c757d;font-size:15px;line-height:1.7;margin-bottom:30px}.program-details{border-bottom:1px solid #e9ecef;border-top:1px solid #e9ecef;display:flex;gap:35px;justify-content:center;margin-bottom:30px;padding:20px 0}.detail-item{align-items:center;color:#667eea;display:flex;font-size:14px;font-weight:600;gap:8px;transition:all .3s ease}.detail-item:hover{color:#764ba2;transform:translateY(-2px)}.btn-program{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;display:inline-flex;font-size:15px;font-weight:700;gap:10px;overflow:hidden;padding:14px 35px;position:relative;text-decoration:none;transition:all .3s ease}.btn-program:before{background:#fff3;content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease;width:100%}.btn-program:hover:before{left:0}.btn-program:hover{box-shadow:0 8px 25px #667eea80;transform:translateY(-3px)}.jalur-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.jalur-card{background:#fff;border:2px solid #0000;border-radius:18px;box-shadow:0 4px 20px #00000014;overflow:hidden;padding:35px 28px;position:relative;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1)}.jalur-card:before{background:linear-gradient(135deg,#667eea0d,#764ba20d);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .4s ease}.jalur-card:hover:before{opacity:1}.jalur-card:hover{border-color:#667eea4d;box-shadow:0 12px 40px #00000026;transform:translateY(-8px) scale(1.02)}.jalur-icon{align-items:center;border-radius:16px;box-shadow:0 6px 20px #00000026;color:#fff;display:flex;font-size:32px;height:70px;justify-content:center;margin:0 auto 25px;position:relative;transition:all .4s ease;width:70px;z-index:1}.jalur-card:hover .jalur-icon{box-shadow:0 10px 30px #00000040;transform:scale(1.15) rotate(-5deg)}.jalur-card h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2c3e50,#667eea);-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:800;letter-spacing:-.3px;margin-bottom:12px;position:relative;z-index:1}.jalur-card p{color:#6c757d;font-size:14px;line-height:1.6;margin-bottom:25px}.jalur-card p,.jalur-info{position:relative;z-index:1}.jalur-info{border-top:2px solid #f0f0f0;display:flex;justify-content:space-around;padding-top:25px}.info-item{align-items:center;color:#495057;display:flex;font-size:14px;font-weight:600;gap:6px;transition:all .3s ease}.info-item:hover{color:#667eea;transform:translateY(-2px)}.timeline{margin:0 auto;max-width:850px;padding-left:60px;position:relative}.timeline:before{background:linear-gradient(180deg,#667eea 0,#764ba2);border-radius:2px;bottom:0;content:"";left:25px;opacity:.3;position:absolute;top:0;width:4px}.timeline-item{animation:fadeInUp .6s ease;margin-bottom:45px;position:relative}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.timeline-marker{background:#fff;border:4px solid #e9ecef;border-radius:50%;box-shadow:0 0 0 4px #fff,0 0 0 5px #e9ecef;height:24px;left:-48px;position:absolute;top:8px;transition:all .4s ease;width:24px;z-index:2}.timeline-item:hover .timeline-marker{transform:scale(1.3)}.timeline-item.active .timeline-marker{animation:pulse 2s infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 0 0 4px #fff,0 0 0 6px #667eea4d,0 0 20px #667eea66}.timeline-content{background:#fff;border:2px solid #0000;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden;padding:28px 30px;position:relative;transition:all .4s ease}.timeline-content:before{background:linear-gradient(135deg,#667eea,#764ba2);bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;transition:opacity .4s ease;width:5px}.timeline-item.active .timeline-content:before{opacity:1}.timeline-item:hover .timeline-content{border-color:#667eea33;box-shadow:0 8px 30px #667eea26;transform:translateX(8px)}.timeline-content h4{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800;letter-spacing:-.3px;margin-bottom:8px}.timeline-content p{align-items:center;color:#6c757d;display:flex;font-size:15px;font-weight:500;gap:8px;margin:0}.timeline-content p:before{content:"📅";font-size:18px}.faq-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.faq-card{background:#fff;border:2px solid #0000;border-radius:18px;box-shadow:0 4px 20px #00000014;overflow:hidden;padding:32px 28px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.faq-card:before{color:#667eea08;content:"?";font-size:120px;font-weight:900;position:absolute;right:-20px;top:-20px;transition:all .4s ease}.faq-card:hover:before{color:#667eea0f;transform:rotate(15deg) scale(1.1)}.faq-card:hover{border-color:#667eea33;box-shadow:0 12px 35px #667eea26;transform:translateY(-8px)}.faq-card h4{-webkit-text-fill-color:#0000;align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;display:flex;font-size:18px;font-weight:800;gap:10px;letter-spacing:-.2px;line-height:1.4;margin-bottom:15px;position:relative;z-index:1}.faq-card h4:before{content:"❓";flex-shrink:0;font-size:20px;margin-top:2px}.faq-card p{color:#6c757d;font-size:15px;line-height:1.7;margin:0;position:relative;z-index:1}.pmb-cta{background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden;padding:100px 0;position:relative;text-align:center}.pmb-cta:before{animation:float 20s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff1a 0,#0000 50%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.cta-content{position:relative;z-index:1}.cta-content h2{animation:fadeInUp .8s ease;color:#fff;font-size:42px;font-weight:900;letter-spacing:-.5px;margin-bottom:20px;text-shadow:0 4px 20px #0003}.cta-content p{animation:fadeInUp .8s ease .2s both;color:#fff;font-size:20px;line-height:1.6;margin-bottom:40px;margin-left:auto;margin-right:auto;max-width:600px;opacity:.98}.contact-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.contact-card{background:#fff;border:2px solid #0000;border-radius:18px;box-shadow:0 4px 20px #00000014;overflow:hidden;padding:40px 30px;position:relative;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1)}.contact-card:before{background:linear-gradient(135deg,#667eea0d,#764ba20d);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .4s ease}.contact-card:hover:before{opacity:1}.contact-card:hover{border-color:#667eea4d;box-shadow:0 12px 40px #667eea33;transform:translateY(-10px)}.contact-card svg{color:#667eea;filter:drop-shadow(0 4px 8px rgba(102,126,234,.2));font-size:48px;margin-bottom:20px;position:relative;transition:all .4s ease;z-index:1}.contact-card:hover svg{color:#764ba2;transform:scale(1.2) rotateY(1turn)}.contact-card h4{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800;letter-spacing:-.3px;margin-bottom:12px;position:relative;z-index:1}.contact-card p{color:#6c757d;font-size:15px;font-weight:500;line-height:1.6;margin:0;position:relative;z-index:1}.pmb-footer{background:#2c3e50;color:#fff;padding:60px 0 20px}.footer-content{grid-gap:40px;display:grid;gap:40px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:40px}.footer-section h3{font-size:24px;margin-bottom:15px}.footer-section h4{color:gold;font-size:18px;margin-bottom:15px}.footer-section p{margin:5px 0;opacity:.8}.footer-section ul{list-style:none;margin:0;padding:0}.footer-section ul li{margin-bottom:10px}.footer-section ul li a{align-items:center;color:#fffc;display:flex;gap:8px;text-decoration:none;transition:all .3s ease}.footer-section ul li a:hover{color:#fff;padding-left:5px}.footer-bottom{border-top:1px solid #ffffff1a;padding-top:20px;text-align:center}.footer-bottom p{margin:0;opacity:.7}.page-content-section{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #667eea4d;overflow:hidden;position:relative}.page-content-section:before{animation:shimmer 3s infinite;background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes shimmer{0%,to{left:-100%}50%{left:100%}}.page-content-wrapper{background:#fff;background-clip:padding-box,border-box;background-image:linear-gradient(#fff,#fff),linear-gradient(135deg,#667eea26,#764ba226);background-origin:border-box;border:2px solid #0000;border-radius:24px;box-shadow:0 4px 30px #667eea14,0 0 0 1px #667eea0d;padding:55px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.page-content-wrapper:before{animation:gradientSlide 3s ease-in-out infinite;background:linear-gradient(90deg,#667eea,#764ba2 50%,#667eea);background-size:200% 100%;border-radius:24px 24px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}@keyframes gradientSlide{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.page-content-wrapper:hover{border-color:#667eea33;box-shadow:0 8px 50px #667eea26,0 0 0 2px #667eea1a;transform:translateY(-8px) scale(1.01)}.page-banner{border:3px solid #667eea33;border-radius:20px;box-shadow:0 10px 40px #0000001f,0 4px 20px #667eea26;margin-bottom:40px;max-height:450px;overflow:hidden;position:relative;transition:all .4s ease;width:100%}.page-banner:before{background:linear-gradient(135deg,#667eea26,#0000 50%,#764ba226);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .4s ease;z-index:1}.page-banner:hover:before{opacity:1}.page-banner:after{background:linear-gradient(180deg,#0000 0,#0003);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:2}.page-banner img{filter:brightness(1.05) contrast(1.05);height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1);width:100%}.page-content-wrapper:hover .page-banner{border-color:#667eea66;box-shadow:0 15px 60px #00000026,0 8px 30px #667eea40}.page-content-wrapper:hover .page-banner img{filter:brightness(1.1) contrast(1.1);transform:scale(1.08)}.page-header{animation:fadeInDown .6s ease-out;border-bottom:3px solid #0000;border-image:linear-gradient(90deg,#fffc,#ffffff80 30%,#fff3 70%,#0000) 1;margin-bottom:40px;padding-bottom:30px;position:relative}.page-header:before{background:linear-gradient(90deg,#fff,#fff9);bottom:-3px;content:"";height:3px;left:0;position:absolute;transition:width .6s cubic-bezier(.4,0,.2,1);width:0}.page-content-wrapper:hover .page-header:before{width:200px}.page-type-badge{align-items:center;background:#fff;border-radius:30px;box-shadow:0 4px 20px #00000026,inset 0 1px 0 #667eea1a;color:#667eea;display:inline-flex;font-size:13px;font-weight:700;gap:10px;letter-spacing:.8px;margin-bottom:25px;overflow:hidden;padding:10px 22px;position:relative;text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1)}.page-type-badge:before{background:linear-gradient(90deg,#0000,#667eea1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.page-type-badge:hover:before{left:100%}.page-type-badge:hover{box-shadow:0 8px 30px #0003,inset 0 1px 0 #667eea33;color:#764ba2;transform:translateY(-3px) scale(1.05)}.page-type-badge svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));font-size:16px}.page-header h2{animation:fadeInUp .8s ease-out .2s both;color:#fff!important;display:inline-block;font-size:46px;font-weight:900!important;letter-spacing:-1px;line-height:1.25;margin:20px 0 15px;position:relative;text-shadow:0 2px 10px #0000004d,0 4px 20px #667eea66;transition:all .3s ease}.page-header h2:before{color:#fff;content:"✦";font-size:24px;left:-40px;opacity:0;position:absolute;text-shadow:0 2px 10px #667eea99;top:50%;transform:translateY(-50%);transition:all .4s ease}.page-content-wrapper:hover .page-header h2:before{left:-35px;opacity:1}.page-meta-description{animation:fadeInUp .8s ease-out .4s both;color:#fffffff2!important;font-size:20px;font-style:italic;font-weight:400;letter-spacing:.2px;line-height:1.7;margin:15px 0 0;padding-left:20px;position:relative;text-shadow:0 1px 5px #0003}.page-meta-description:before{color:#fff6;content:'"';font-family:Georgia,serif;font-size:36px;font-weight:700;left:0;opacity:.5;position:absolute;text-shadow:0 2px 8px #0003;top:-5px}.page-content-section:not(:last-of-type):after{background:linear-gradient(90deg,#0000,#ffffff4d 50%,#0000);bottom:0;content:"";height:1px;left:50%;position:absolute;transform:translateX(-50%);width:80%}.page-content-section:target .page-content-wrapper{animation:highlightPage 1.5s ease-out}@keyframes highlightPage{0%,to{box-shadow:0 8px 50px #667eea26,0 0 0 2px #667eea1a}50%{box-shadow:0 12px 80px #667eea59,0 0 0 4px #667eea4d;transform:scale(1.02)}}.page-content-wrapper.loading{opacity:.5;pointer-events:none}.page-content-wrapper.loading:after{animation:spin 1s linear infinite;border:4px solid #667eea33;border-radius:50%;border-top-color:#667eea;content:"";height:50px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:50px}.page-content-wrapper:after{align-items:center;background:linear-gradient(135deg,#667eea1a,#764ba21a);border:2px solid #667eea33;border-radius:50%;color:#667eea;content:attr(data-page-number);display:flex;font-size:18px;font-weight:800;height:50px;justify-content:center;opacity:0;position:absolute;right:20px;top:20px;transition:all .3s ease;width:50px}.page-content-wrapper:hover:after{opacity:.5;transform:rotate(1turn)}.page-html-content{animation:fadeInUp .8s ease-out .6s both;color:#2c3e50;font-size:16px;line-height:1.8}.page-html-content h1,.page-html-content h2,.page-html-content h3,.page-html-content h4,.page-html-content h5,.page-html-content h6{-webkit-text-fill-color:#0000!important;background:linear-gradient(135deg,#667eea,#764ba2)!important;-webkit-background-clip:text!important;background-clip:text!important;color:#0000!important;cursor:default;font-weight:800!important;letter-spacing:-.3px!important;line-height:1.3!important;margin-bottom:18px;margin-top:35px;padding-bottom:10px;position:relative;transition:all .3s ease}.page-html-content h1:hover,.page-html-content h2:hover,.page-html-content h3:hover,.page-html-content h4:hover,.page-html-content h5:hover,.page-html-content h6:hover{letter-spacing:-.5px!important;transform:translateX(5px)}.page-html-content h1:after,.page-html-content h2:after,.page-html-content h3:after{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;bottom:0;content:"";height:3px;left:0;position:absolute;transition:width .3s ease;width:60px}.page-html-content h1:hover:after,.page-html-content h2:hover:after,.page-html-content h3:hover:after{width:100px}.page-html-content h1{font-size:34px!important;padding-bottom:12px;text-transform:capitalize}.page-html-content h2{font-size:30px!important;padding-bottom:10px;text-transform:capitalize}.page-html-content h3{font-size:26px!important;padding-bottom:8px;text-transform:capitalize}.page-html-content h4{font-size:22px!important}.page-html-content h4,.page-html-content h5{font-weight:800!important;text-transform:capitalize}.page-html-content h5{font-size:19px!important}.page-html-content h6{font-size:17px!important;font-weight:800!important;text-transform:capitalize}.page-html-content h1 svg,.page-html-content h2 svg,.page-html-content h3 svg,.page-html-content h4 svg,.page-html-content h5 svg,.page-html-content h6 svg{color:#667eea;display:inline-block;filter:drop-shadow(0 2px 4px rgba(102,126,234,.3));margin-right:10px;vertical-align:middle}.page-html-content p{color:#4a5568;line-height:1.8;margin-bottom:18px;text-align:justify}.page-html-content ol,.page-html-content ul{margin:20px 0}.page-html-content ol li,.page-html-content ul li{line-height:1.7;margin-bottom:10px}.page-html-content ol,.page-html-content ul{margin-bottom:20px;padding-left:30px}.page-html-content ul{list-style-type:none}.page-html-content ul li{line-height:1.7;margin-bottom:12px;padding-left:30px;position:relative}.page-html-content ul li:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 2px 6px #667eea4d;content:"";height:8px;left:0;position:absolute;top:10px;width:8px}.page-html-content ol{counter-reset:item;list-style-type:none}.page-html-content ol li{counter-increment:item;line-height:1.7;margin-bottom:12px;padding-left:40px;position:relative}.page-html-content ol li:before{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 3px 10px #667eea4d;color:#fff;content:counter(item);display:flex;font-size:13px;font-weight:700;height:28px;justify-content:center;left:0;position:absolute;top:0;width:28px}.page-html-content a{border-bottom:2px solid #0000;color:#667eea;font-weight:600;position:relative;text-decoration:none;transition:all .3s ease}.page-html-content a:after{background:linear-gradient(135deg,#667eea,#764ba2);bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.page-html-content a:hover{color:#764ba2}.page-html-content a:hover:after{width:100%}.page-html-content img{border:3px solid #0000;border-radius:12px;box-shadow:0 8px 25px #667eea26;height:auto;margin:25px 0;max-width:100%;transition:all .4s ease}.page-html-content img:hover{border-color:#667eea33;box-shadow:0 12px 35px #667eea40;transform:scale(1.02)}.page-html-content blockquote{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-left:5px solid #667eea;border-radius:8px;box-shadow:0 2px 10px #667eea14;color:#495057;font-style:italic;margin:25px 0;overflow:hidden;padding:20px 25px 20px 30px;position:relative}.page-html-content blockquote:before{color:#667eea1a;content:'"';font-family:Georgia,serif;font-size:80px;left:10px;line-height:1;position:absolute;top:-10px}.page-html-content table{background:#fff;border:1px solid #667eea1a;border-collapse:initial;border-radius:12px;border-spacing:0;box-shadow:0 4px 20px #667eea1a;margin:30px 0;overflow:hidden;width:100%}.page-html-content table td,.page-html-content table th{border-bottom:1px solid #e9ecef;padding:16px 20px;text-align:left;transition:all .3s ease}.page-html-content table td:not(:last-child),.page-html-content table th:not(:last-child){border-right:1px solid #e9ecef}.page-html-content table th{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #667eea33;color:#fff;font-size:13px;font-weight:700;letter-spacing:.8px;position:relative;text-transform:uppercase}.page-html-content table th:after{background:#ffffff4d;bottom:0;content:"";height:2px;left:0;position:absolute;right:0}.page-html-content table tbody tr{transition:all .3s cubic-bezier(.4,0,.2,1)}.page-html-content table tbody tr:nth-child(2n){background:linear-gradient(90deg,#f8f9fa 0,#fff)}.page-html-content table tbody tr:hover{background:linear-gradient(135deg,#667eea14,#764ba214);box-shadow:0 4px 15px #667eea26;transform:scale(1.01)}.page-html-content table tbody tr:last-child td{border-bottom:none}.page-html-content table tbody td{color:#4a5568;font-size:15px;font-weight:500}.page-html-content table tbody td:first-child{color:#2c3e50;font-weight:600}.page-html-content{position:relative}@media (max-width:768px){.page-html-content table{-webkit-overflow-scrolling:touch;border-radius:8px;display:block;margin:20px 0;overflow-x:auto}.page-html-content table td,.page-html-content table th{font-size:13px;padding:12px 15px;white-space:nowrap}.page-html-content table th{font-size:12px;letter-spacing:.5px}}.page-html-content code{background:linear-gradient(135deg,#667eea1f,#764ba21f);border:1px solid #667eea33;border-radius:6px;box-shadow:0 2px 4px #667eea1a;color:#667eea;font-family:Courier New,Consolas,monospace;font-size:14px;font-weight:600;padding:4px 10px}.page-html-content pre{background:linear-gradient(135deg,#2c3e50,#34495e);border:1px solid #667eea33;border-radius:12px;box-shadow:0 8px 25px #0003;color:#ecf0f1;margin:30px 0;overflow-x:auto;padding:25px;position:relative}.page-html-content pre:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.page-html-content pre code{background:#0000;border:none;box-shadow:none;color:#ecf0f1;font-size:14px;line-height:1.6;padding:0}.page-html-content hr{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:2px;box-shadow:0 2px 8px #667eea4d;height:3px;margin:40px 0}.page-html-content strong{background:linear-gradient(135deg,#667eea14,#764ba214);border-radius:4px;color:#2c3e50;font-weight:700;padding:2px 6px}.page-html-content em{color:#4a5568;font-style:italic}@media (max-width:1024px){.pmb-logo h1{font-size:24px}.pmb-logo p{font-size:11px}.logo-image{height:50px;width:50px}.pmb-menu a{font-size:13px;padding:9px 18px}.btn-login{padding:9px 22px!important}.section-header h2{font-size:34px}.page-header h2{font-size:36px}.page-html-content h1{font-size:30px}.page-html-content h2{font-size:26px}.page-html-content h3{font-size:22px}.hero-title{font-size:48px}.hero-subtitle{font-size:20px}.hero-stats{gap:60px}.stat-item{padding:18px 25px}.stat-item h3{font-size:40px}}@media (max-width:768px){.pmb-header{padding:12px 0}.pmb-nav{flex-direction:column;gap:12px}.pmb-logo{gap:12px}.logo-image{border-radius:12px}.pmb-logo h1{font-size:22px;letter-spacing:-.3px}.pmb-logo p{letter-spacing:.3px}.pmb-menu{flex-wrap:wrap;gap:8px;justify-content:center;width:100%}.pmb-menu a{font-size:13px;gap:5px;padding:8px 16px}.btn-login{font-size:13px!important;padding:8px 20px!important}.pmb-hero{padding:80px 0 60px}.hero-title{font-size:36px;letter-spacing:-.5px;margin-bottom:20px}.hero-subtitle{font-size:17px;margin-bottom:35px;padding:0 15px}.hero-buttons{align-items:center;flex-direction:column;gap:15px;margin-bottom:50px}.btn-outline-large,.btn-primary-large{font-size:16px;justify-content:center;max-width:300px;padding:14px 35px;width:100%}.hero-stats{flex-direction:column;gap:25px;margin-top:30px}.stat-item{margin:0 auto;max-width:280px;padding:20px;width:100%}.stat-item h3{font-size:36px}.stat-item p{font-size:13px}.section-header h2{font-size:30px;letter-spacing:-.3px}.section-header:after{height:3px;width:60px}.section-header p{font-size:16px;padding:0 15px}.contact-grid,.faq-grid,.jalur-grid,.program-grid{grid-template-columns:1fr}.timeline{padding-left:30px}.timeline-content h4{font-size:18px}.timeline-content p{font-size:14px}.cta-content h2{font-size:32px;letter-spacing:-.3px}.cta-content p{font-size:17px;padding:0 20px}.contact-card{padding:35px 25px}.contact-card svg{font-size:42px}.contact-card h4{font-size:18px}.footer-content{grid-template-columns:1fr;text-align:center}.page-content-wrapper{border-radius:16px;box-shadow:0 4px 20px #667eea1a,0 0 0 1px #667eea0d;padding:30px 20px}.page-content-wrapper:hover{transform:translateY(-4px) scale(1.005)}.page-content-wrapper:before{border-radius:16px 16px 0 0;height:3px}.page-content-wrapper:after{font-size:14px;height:40px;right:15px;top:15px;width:40px}.page-banner{border-radius:12px;border-width:2px;margin-bottom:25px;max-height:300px}.page-type-badge{font-size:11px;gap:6px;letter-spacing:.5px;margin-bottom:15px;padding:6px 14px}.page-type-badge svg{font-size:13px}.page-header{margin-bottom:25px;padding-bottom:20px}.page-header:before{bottom:-2px;height:2px}.page-content-wrapper:hover .page-header:before{width:120px}.page-header h2{font-size:32px;letter-spacing:-.5px;margin:12px 0 10px}.page-header h2:before{font-size:18px;left:-30px}.page-content-wrapper:hover .page-header h2:before{left:-25px}.page-meta-description{font-size:16px;margin:10px 0 0;padding-left:15px}.page-meta-description:before{font-size:28px;top:-3px}.page-html-content h1{font-size:28px}.page-html-content h2{font-size:24px}.page-html-content h3{font-size:20px}.page-html-content h4{font-size:18px}.page-html-content h5{font-size:16px}.page-html-content,.page-html-content h6{font-size:15px}.page-html-content h1{font-size:26px!important}.page-html-content h2{font-size:24px!important}.page-html-content h3{font-size:20px!important}.page-html-content h4{font-size:18px!important}.page-html-content h5{font-size:16px!important}.page-html-content h6{font-size:15px!important}.page-html-content h1:after,.page-html-content h2:after,.page-html-content h3:after{width:40px}.page-html-content h1:hover:after,.page-html-content h2:hover:after,.page-html-content h3:hover:after{width:70px}.page-html-content h1:hover,.page-html-content h2:hover,.page-html-content h3:hover,.page-html-content h4:hover,.page-html-content h5:hover,.page-html-content h6:hover{transform:translateX(3px)}.page-html-content table{font-size:14px}.page-html-content table td,.page-html-content table th{padding:8px 10px}.page-html-content table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto;white-space:nowrap}.pmb-header{padding:10px 0}.pmb-logo h1{font-size:20px}.pmb-logo p{font-size:10px}.logo-image{height:45px;padding:6px;width:45px}.mobile-menu-toggle{display:flex}.mobile-menu-overlay{display:none}.mobile-menu-overlay.active,.mobile-open~.mobile-menu-overlay{display:block}.pmb-menu{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:-5px 0 30px #0000004d;flex-direction:column;gap:5px;height:100vh;overflow-y:auto;padding:80px 20px 20px;position:fixed;right:-100%;top:0;transition:right .4s cubic-bezier(.68,-.55,.265,1.55);width:280px;z-index:999}.pmb-menu.mobile-open{right:0}.pmb-menu a{border-left:3px solid #0000;border-radius:0;font-size:16px;justify-content:flex-start;padding:14px 20px;width:100%}.pmb-menu a.active,.pmb-menu a:hover{background:#fff3;border-left-color:#fff;transform:translateX(5px)}.btn-login{background:#fff!important;color:#667eea!important;justify-content:center;margin-top:15px;text-align:center}}@media (max-width:575.98px){.pmb-container{padding:0 15px}.pmb-logo h1{font-size:18px}.pmb-logo p{font-size:9px}.logo-image{height:40px;padding:5px;width:40px}.mobile-menu-toggle{font-size:22px;height:40px;width:40px}.pmb-menu{width:260px}.pmb-menu a{font-size:15px;padding:12px 16px}}.login-pmb-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;display:grid;grid-template-columns:1fr 1fr;max-width:1000px;overflow:hidden;width:100%}.login-left{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:center;padding:60px 40px}.login-branding h1{font-size:42px;font-weight:700;margin-bottom:10px}.login-branding>p{font-size:18px;margin-bottom:40px;opacity:.9}.branding-features{display:flex;flex-direction:column;gap:20px}.feature-item{font-size:16px;gap:15px}.check-icon,.feature-item{align-items:center;display:flex}.check-icon{background:#fff3;border-radius:50%;flex-shrink:0;font-weight:700;height:30px;justify-content:center;width:30px}.login-right{display:flex;flex-direction:column;padding:60px 40px}.login-form-wrapper{margin:0 auto;max-width:400px;width:100%}.back-link{color:#667eea}.back-link:hover{color:#764ba2}.login-header{margin-bottom:30px}.login-header h2{color:#2c3e50;font-size:32px;font-weight:700;margin-bottom:10px}.login-header p{color:#6c757d;font-size:16px}.login-form .form-group{margin-bottom:20px}.login-form label{color:#2c3e50;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.input-with-icon input{border:2px solid #e9ecef;border-radius:10px;font-size:15px;padding:12px 15px 12px 45px;transition:all .3s ease;width:100%}.input-with-icon input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-options{justify-content:space-between;margin-bottom:25px}.form-options,.remember-me{align-items:center;display:flex}.remember-me{color:#495057;font-size:14px;gap:8px}.remember-me,.remember-me input{cursor:pointer}.forgot-link{color:#667eea;font-size:14px;font-weight:500;text-decoration:none}.forgot-link:hover{text-decoration:underline}.btn-submit{font-size:16px;padding:14px}@media (max-width:768px){.login-container{grid-template-columns:1fr}.login-left{padding:40px 30px}.login-branding h1{font-size:32px}.login-right{padding:40px 30px}.login-header h2{font-size:28px}}.register-pmb-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:40px 20px}.register-container{margin:0 auto;max-width:800px}.back-link{align-items:center;background:#fff3;border-radius:8px;color:#fff;display:inline-flex;font-weight:500;gap:8px;margin-bottom:30px;padding:10px 20px;text-decoration:none;transition:all .3s ease}.back-link:hover{background:#ffffff4d;gap:12px}.register-content{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;padding:50px}.register-header{margin-bottom:40px;text-align:center}.register-header h1{color:#2c3e50;font-size:36px;font-weight:700;margin-bottom:10px}.register-header p{color:#6c757d;font-size:16px}.register-form{max-width:100%}.form-section{border-bottom:2px solid #f1f3f5;margin-bottom:35px;padding-bottom:30px}.form-section:last-of-type{border-bottom:none}.form-section h3{align-items:center;color:#2c3e50;display:flex;font-size:20px;font-weight:700;gap:10px;margin-bottom:20px}.form-section h3:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;content:"";height:24px;width:4px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-group{margin-bottom:0}.form-group label{color:#2c3e50}.required{color:#ef4444}.input-with-icon{align-items:center;display:flex;position:relative}.input-with-icon svg{color:#6c757d;font-size:18px;left:15px;position:absolute;z-index:1}.input-with-icon input,.input-with-icon select{background:#fff;border:2px solid #e9ecef;border-radius:10px;font-size:15px;padding:12px 15px 12px 45px;transition:all .3s ease;width:100%}.input-with-icon input:focus,.input-with-icon select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group small{color:#6c757d;display:block;font-size:12px;margin-top:5px}.form-agreement{background:#f8f9fa;border-radius:10px;margin:30px 0;padding:20px}.checkbox-label{align-items:flex-start;color:#495057;cursor:pointer;display:flex;font-size:14px;gap:12px}.checkbox-label input{cursor:pointer;height:18px;margin-top:2px;width:18px}.checkbox-label a{color:#667eea;font-weight:600;text-decoration:none}.checkbox-label a:hover{text-decoration:underline}.btn-submit{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:600;gap:10px;justify-content:center;margin-top:20px;padding:16px;transition:all .3s ease;width:100%}.btn-submit:hover:not(:disabled){box-shadow:0 10px 30px #667eea66;transform:translateY(-2px)}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.form-footer{color:#6c757d;font-size:14px;margin-top:25px;text-align:center}.form-footer a{color:#667eea;font-weight:600;text-decoration:none}.form-footer a:hover{text-decoration:underline}@media (max-width:768px){.register-pmb-page{padding:20px 15px}.register-content{padding:30px 20px}.register-header h1{font-size:28px}.form-grid{grid-template-columns:1fr}.form-section h3{font-size:18px}}.dashboard-pmb-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh}.loading{color:#667eea;font-size:18px;justify-content:center;min-height:100vh}.dashboard-nav,.loading{align-items:center;display:flex}.dashboard-nav{background:#fff;box-shadow:0 2px 10px #0000001a;justify-content:space-between;padding:20px 40px}.nav-brand h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;font-size:24px;font-weight:700;margin:0}.nav-actions{gap:15px}.nav-actions,.nav-link{align-items:center;display:flex}.nav-link{background:#f8f9fa;border-radius:8px;color:#495057;font-weight:500;gap:8px;padding:10px 20px;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#e9ecef;color:#667eea}.btn-logout{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-logout:hover{box-shadow:0 5px 15px #667eea4d;transform:translateY(-2px)}.dashboard-container{margin:0 auto;max-width:1200px;padding:40px 20px}.dashboard-header{margin-bottom:40px}.welcome-card{align-items:center;background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;display:flex;justify-content:space-between;padding:30px}.welcome-content h1{color:#2c3e50;font-size:32px;font-weight:700;margin:0 0 10px}.welcome-content p{color:#6c757d;font-size:16px;margin:0}.status-badge{align-items:center;border-radius:50px;color:#fff;display:flex;font-size:14px;gap:10px;padding:12px 24px}.status-badge svg{font-size:18px}.info-cards{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:40px}.info-card{background:#fff;border-radius:15px;box-shadow:0 5px 20px #00000014;display:flex;gap:20px;padding:25px;transition:all .3s ease}.info-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-5px)}.card-icon{align-items:center;border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:28px;height:60px;justify-content:center;width:60px}.card-content{flex:1 1}.card-content h3{color:#6c757d;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.card-value{color:#2c3e50;font-size:20px;font-weight:700;margin:0 0 5px}.card-label{color:#6c757d;font-size:14px;margin:2px 0}.action-section{background:#fff;border-radius:15px;box-shadow:0 5px 20px #00000014;padding:30px}.action-section h2{color:#2c3e50;font-size:24px;font-weight:700;margin:0 0 25px}.alert{border-radius:10px;margin-bottom:20px;padding:20px}.alert svg{flex-shrink:0;font-size:24px;margin-top:2px}.alert strong{display:block;font-size:16px;margin-bottom:5px}.alert p{font-size:14px;line-height:1.6;margin:0}.alert-info{background:#e3f2fd;border-left:4px solid #1976d2;color:#1976d2}.alert-success{background:#e8f5e9;border-left:4px solid #388e3c;color:#388e3c}.alert-danger{background:#ffebee;border-left:4px solid #c62828;color:#c62828}.action-cards{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.action-card{border:2px solid #e9ecef;border-radius:12px;padding:25px;text-align:center}.action-card:hover{border-color:#667eea;box-shadow:0 5px 15px #667eea1a}.action-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;font-size:28px;height:60px;margin:0 auto 20px;width:60px}.action-card h3{color:#2c3e50;font-size:18px;font-weight:700;margin:0 0 10px}.action-card p{color:#6c757d;font-size:14px;line-height:1.6;margin:0 0 20px}.btn-action{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 20px;position:relative;transition:all .3s ease;width:100%}.btn-action:hover:not(:disabled){box-shadow:0 5px 15px #667eea4d;transform:translateY(-2px)}.btn-action:disabled{cursor:not-allowed;opacity:.6}.btn-action .badge{background:#ffffff4d;border-radius:4px;display:inline-block;font-size:11px;font-weight:600;margin-left:8px;padding:2px 8px}@media (max-width:768px){.dashboard-nav{flex-direction:column;gap:15px;padding:15px 20px}.nav-brand h2{font-size:20px}.nav-actions{justify-content:space-between;width:100%}.dashboard-container{padding:20px 15px}.welcome-card{flex-direction:column;gap:20px;text-align:center}.welcome-content h1{font-size:24px}.action-cards,.info-cards{grid-template-columns:1fr}}.maintenance-mahasiswa-page{padding:20px}.table-header-info{border-radius:12px 12px 0 0;padding:15px 20px}@media (max-width:768px){.filters-grid,.stats-grid{grid-template-columns:1fr}}.sync-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.table-btn-sync{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:600;gap:4px;padding:6px 10px;transition:all .3s ease}.table-btn-sync:hover:not(:disabled){box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.table-btn-sync:disabled{cursor:not-allowed;opacity:.6}.table-btn-sync svg{font-size:12px}.table-btn-sync-all{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:600;gap:4px;padding:6px 10px;transition:all .3s ease}.table-btn-sync-all:hover:not(:disabled){box-shadow:0 4px 12px #10b98166;transform:translateY(-2px)}.table-btn-sync-all:disabled{cursor:not-allowed;opacity:.6}.table-btn-sync-all svg{font-size:12px}.spinning{animation:spin 1s linear infinite}.btn-delete-filter{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-weight:500;gap:8px;justify-content:center;padding:10px 20px;transition:all .3s ease;width:100%}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef44444d;transform:translateY(-2px)}.btn-danger:disabled{background:#d1d5db;cursor:not-allowed;opacity:.6}.modal-content{box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%}.modal-header{border-bottom:1px solid #e5e7eb;padding:24px 24px 16px}.modal-header h3{color:#1f2937;font-size:20px;font-weight:600}.modal-body{padding:24px}.modal-body p{color:#4b5563;line-height:1.6;margin:0 0 16px}.delete-criteria{background:#f9fafb;border-left:4px solid #3b82f6;border-radius:8px;list-style:none;margin:16px 0;padding:16px}.delete-criteria li{color:#1f2937;font-size:14px;padding:8px 0}.delete-criteria strong{color:#3b82f6;margin-right:8px}.warning-text{align-items:center;background:#fef2f2;border-left:4px solid #ef4444;border-radius:8px;color:#ef4444;display:flex;font-weight:500;gap:8px;margin-top:16px;padding:12px}.modal-footer{border-top:1px solid #e5e7eb;padding:16px 24px}.modal-footer .btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .3s ease}.btn-secondary{background:#f3f4f6;color:#4b5563}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.maintenance-kelas-page{padding:20px}.stats-grid{margin-bottom:25px}.stat-card{border-left:4px solid #0000;box-shadow:0 2px 8px #00000014;padding:24px}.stat-card:hover{box-shadow:0 6px 20px #0000001f;transform:translateY(-4px)}.stat-card-total{border-left-color:#3b82f6}.stat-card-total .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-card-warning{border-left-color:#f59e0b}.stat-card-warning .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card-danger{border-left-color:#ef4444}.stat-card-danger .stat-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-icon{font-size:26px}.stat-info{flex:1 1}.stat-label{color:#6b7280;font-size:14px;font-weight:500}.stat-value{color:#1f2937;font-size:32px;line-height:1}.filters-card{margin-bottom:25px}.filters-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:2fr 1fr}.form-group{margin:0}.search-box svg{color:#9ca3af;left:16px}.search-box input{padding-left:48px}.form-control{border:1px solid #e5e7eb;padding:12px 16px;width:100%}.form-control:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.card{box-shadow:0 2px 8px #00000014}.table-header-info{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:20px 24px}.table-header-info p{color:#4b5563;font-size:14px;margin:0}.table-header-info strong{color:#1f2937;font-weight:600}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.data-table th{color:#4b5563;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td{border-bottom:1px solid #f3f4f6;color:#1f2937;font-size:14px;padding:16px 20px}.data-table tbody tr{transition:all .2s ease}.data-table tbody tr:hover{background:#f9fafb}.data-table code{background:#f3f4f6;border-radius:6px;color:#3b82f6;font-family:Courier New,monospace;font-size:13px;padding:4px 8px}.badge{align-items:center;display:inline-flex;gap:6px;white-space:nowrap}.student-count{color:#059669;font-weight:500}.student-count.zero{color:#dc2626;font-weight:600}.table-btn{display:inline-flex;height:36px;text-decoration:none;transition:all .2s ease;width:36px}.table-btn-view{background:#dbeafe;color:#1e40af}.table-btn-view:hover{background:#3b82f6;color:#fff;transform:translateY(-2px)}.table-pagination{align-items:center;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.table-pagination-info{color:#6b7280;font-size:14px}.table-pagination-buttons{display:flex;gap:8px}.table-pagination-button{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.table-pagination-button:hover:not(:disabled){background:#3b82f6;border-color:#3b82f6;color:#fff}.table-pagination-button:disabled{cursor:not-allowed;opacity:.5}.empty-state svg{margin-bottom:16px}.empty-state p{font-size:16px}.spinner{padding:60px 20px}.spinner:after{border-top-color:#3b82f6;height:40px;width:40px}@media (max-width:768px){.filters-grid,.stats-grid{grid-template-columns:1fr}.table-pagination{flex-direction:column;gap:16px}.data-table{font-size:13px}.data-table td,.data-table th{padding:12px 8px}}.dashboard-baak{background:#f8fafc;min-height:100vh;padding:0}.dashboard-header{border-radius:0 0 20px 20px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem;padding:2rem}.dashboard-header .header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px}.dashboard-header .header-text h1{color:#fff;font-size:2rem;font-weight:700;margin-bottom:.5rem}.dashboard-header .header-text p{color:#ffffffe6;font-size:1rem}.dashboard-header .header-date{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:12px;color:#fff;display:flex;gap:.5rem;padding:.75rem 1.5rem}.dashboard-header .header-date svg{font-size:1.2rem}.stats-grid-main{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem;padding:0 2rem}.stat-card-large{box-shadow:0 2px 8px #0000001a;gap:1.5rem;padding:1.5rem}.stat-card-large:before{background:linear-gradient(90deg,currentColor,#0000);height:4px;left:0}.stat-card-large:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-4px)}.stat-card-large.stat-primary{color:#667eea}.stat-card-large.stat-success{color:#10b981}.stat-card-large.stat-warning{color:#f59e0b}.stat-card-large.stat-info{color:#3b82f6}.stat-icon-wrapper{align-items:center;background:linear-gradient(135deg,currentColor,#0000);border-radius:16px;display:flex;flex-shrink:0;height:70px;justify-content:center;opacity:.15;width:70px}.stat-icon-wrapper .stat-icon{color:currentColor;font-size:2rem;opacity:1}.stat-content h3{color:#1f2937;font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.stat-content p{color:#6b7280;font-size:.95rem;margin-bottom:.75rem}.stat-footer{display:flex;gap:.5rem}.stat-badge{align-items:center;border-radius:8px;display:inline-flex;font-size:.8rem;font-weight:600;gap:.25rem;padding:.25rem .75rem}.stat-badge.badge-success{background:#d1fae5;color:#065f46}.stat-badge.badge-info{background:#dbeafe;color:#1e40af}.stat-badge.badge-warning{background:#fef3c7;color:#92400e}.stat-badge.badge-primary{background:#e0e7ff;color:#3730a3}.stats-grid-secondary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:2rem;padding:0 2rem}.stat-card-small{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:1rem;padding:1.25rem;transition:all .3s ease}.stat-card-small:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.stat-icon-small{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:1.5rem;height:50px;justify-content:center;width:50px}.stat-icon-small.stat-icon-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.stat-icon-small.stat-icon-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.stat-icon-small.stat-icon-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626}.stat-icon-small.stat-icon-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.stat-details-small h4{color:#1f2937;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-details-small p{color:#6b7280;font-size:.85rem}.content-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:2rem;padding:0 2rem}.card{box-shadow:0 2px 8px #0000001a}.card-header{border-bottom:1px solid #f3f4f6;padding:1.5rem}.card-header h3{color:#1f2937;font-size:1.1rem;font-weight:600;gap:.5rem}.card-header-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);border-bottom-color:#fca5a5}.card-header-danger h3{color:#dc2626}.card-body{padding:1.5rem}.chart-container{align-items:flex-end;display:flex;gap:1rem;height:250px;padding:1rem 0}.chart-bar-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:.5rem}.chart-bar-container{align-items:flex-end;height:200px;width:100%}.chart-bar,.chart-bar-container{display:flex;justify-content:center}.chart-bar{align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px 8px 0 0;cursor:pointer;min-height:20px;padding-top:.5rem;position:relative;transition:all .3s ease;width:80%}.chart-bar:hover{opacity:.8;transform:scaleY(1.05)}.chart-value{color:#fff;font-size:.7rem;font-weight:600;text-orientation:mixed;writing-mode:vertical-rl}.chart-label{color:#6b7280;font-size:.8rem;font-weight:500;text-align:center}.payments-list{display:flex;flex-direction:column;gap:.75rem}.payment-item{align-items:center;background:#f9fafb;border-radius:12px;display:flex;justify-content:space-between;padding:1rem;transition:all .3s ease}.payment-item:hover{background:#f3f4f6;transform:translateX(4px)}.payment-info{flex:1 1}.payment-name{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.payment-name strong{color:#1f2937;font-size:.95rem}.payment-nim{color:#6b7280;font-size:.8rem}.payment-details{display:flex;font-size:.85rem;gap:1rem}.payment-type{color:#667eea;font-weight:500}.payment-date{color:#9ca3af}.payment-amount{color:#10b981;font-size:1.1rem;font-weight:700}.overdue-list{display:flex;flex-direction:column;gap:1rem}.overdue-item{align-items:center;background:#fff;border:2px solid #fee2e2;border-radius:12px;display:flex;justify-content:space-between;padding:1.25rem;transition:all .3s ease}.overdue-item:hover{border-color:#fca5a5;box-shadow:0 4px 6px #dc26261a}.overdue-info{flex:1 1}.overdue-student{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.overdue-student strong{color:#1f2937;font-size:1rem}.overdue-type{color:#dc2626;font-size:.9rem;font-weight:600}.overdue-details{display:flex;font-size:.85rem;gap:1rem}.overdue-semester{color:#6b7280}.overdue-deadline{color:#9ca3af}.overdue-right{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem}.overdue-amount{color:#dc2626;font-size:1.2rem;font-weight:700}.overdue-badge{border-radius:8px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.overdue-badge.badge-danger{background:#fee2e2;color:#dc2626}.quick-actions-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));padding:0 2rem 2rem}.action-card{align-items:center;background:#fff;border-left:4px solid;border-radius:16px;box-shadow:0 2px 8px #0000001a;display:flex;gap:1rem;padding:1.5rem;text-decoration:none;transition:all .3s ease}.action-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-4px)}.action-card.action-primary{color:#667eea}.action-card.action-warning{color:#f59e0b}.action-card.action-success{color:#10b981}.action-card.action-info{color:#3b82f6}.action-icon{align-items:center;background:linear-gradient(135deg,currentColor,#0000);border-radius:12px;display:flex;flex-shrink:0;font-size:1.5rem;height:50px;justify-content:center;opacity:.15;width:50px}.action-content h4{color:#1f2937;font-size:1rem;font-weight:600;margin-bottom:.25rem}.action-content p{color:#6b7280;font-size:.85rem}.empty-state{color:#9ca3af;justify-content:center;padding:3rem 1rem}.empty-state svg{font-size:3rem;margin-bottom:1rem}.empty-state p{font-size:.95rem}@media (max-width:1024px){.content-grid{grid-template-columns:1fr}.stats-grid-main{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width:768px){.dashboard-header .header-content{align-items:flex-start;flex-direction:column;gap:1rem}.dashboard-header .header-date{justify-content:center;width:100%}.content-grid,.quick-actions-grid,.stats-grid-main,.stats-grid-secondary{grid-template-columns:1fr;padding:0 1rem}.chart-container{height:200px}.chart-bar-container{height:150px}.chart-value{font-size:.6rem}}.spinner{align-items:center;display:flex;justify-content:center;min-height:100vh}.spinner:after{animation:spin .8s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#667eea;content:"";height:50px;width:50px}.baak-tagihan-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:0}.btn-glass{font-size:15px;padding:12px 28px;pointer-events:auto;position:relative;z-index:1}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.stat-card{border:1px solid #667eea1a}.stat-icon{border-radius:14px;height:65px;width:65px}.stat-details h3{color:#1a202c;font-size:32px;font-weight:700;margin:0 0 5px}.stat-details p{color:#718096;font-size:14px;font-weight:500;margin:0}.summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px;padding:0 30px}.summary-card{background:#fff;border-left:5px solid;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:25px}.summary-primary{border-left-color:#667eea}.summary-danger{border-left-color:#ef4444}.summary-label{color:#718096;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.summary-value{font-size:28px}.filters{display:flex;flex-wrap:wrap;gap:15px}.search-box{align-items:center;display:flex;flex:1 1;min-width:200px;position:relative}.search-box svg{color:#718096;font-size:18px;left:15px;position:absolute}.search-box input{background:#f7fafc;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;padding:12px 15px 12px 45px;transition:all .3s ease;width:100%}.search-box input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-select{background:#f7fafc;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;font-size:14px;padding:12px 15px;transition:all .3s ease;width:100%}.filter-select:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modern-table-container{margin-top:20px;overflow-x:auto}.modern-table th{border:none;font-size:14px}.modern-table tbody tr:hover{box-shadow:0 4px 15px #0000000d}.modern-table tbody tr.row-overdue{background:#fef2f2;border-left:4px solid #ef4444}.modern-table tbody tr.row-overdue:hover{background:#fee2e2}.modern-table td{border:none}.badge{font-size:12px}.table-actions{display:flex;gap:8px}.table-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;justify-content:center;padding:8px 12px;transition:all .3s ease}.table-btn-success{background:#d1fae5;color:#065f46}.table-btn-success:hover{background:#10b981;color:#fff;transform:scale(1.1)}.table-btn-edit{background:#dbeafe;color:#1e40af}.table-btn-edit:hover{background:#3b82f6;color:#fff;transform:scale(1.1)}.table-btn-delete{background:#fee2e2;color:#991b1b}.table-btn-delete:hover{background:#ef4444;color:#fff;transform:scale(1.1)}.modal-overlay{animation:fadeIn .3s ease;z-index:9999}.modal-content{animation:slideUp .3s ease;max-width:600px}.modal-large{max-width:900px}.modal-close,.modal-header h3{color:#fff;font-size:24px}.modal-close{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:50%;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-body{padding:30px}.modal-footer{gap:15px}.form-group .required{color:#ef4444;margin-left:2px}.form-control:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.searchable-select{position:relative}.search-input-wrapper{align-items:center;display:flex}.search-icon{font-size:16px;left:15px;pointer-events:none}.search-input{padding-left:45px!important}.searchable-dropdown{animation:dropdownSlide .2s ease;background:#fff;border:2px solid #667eea;border-radius:10px;box-shadow:0 10px 40px #00000026;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 5px);z-index:100}.dropdown-header{background:#f7fafc;border-bottom:1px solid #e2e8f0;color:#718096;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 15px;position:-webkit-sticky;position:sticky;text-transform:uppercase;top:0;z-index:1}.dropdown-item{border-bottom:1px solid #f0f0f0;cursor:pointer;padding:15px;transition:all .2s ease}.dropdown-item:hover{background:#f7fafc;transform:translateX(5px)}.dropdown-item:last-child{border-bottom:none}.dropdown-item-main{color:#2d3748;font-size:14px;font-weight:600;margin-bottom:5px}.dropdown-item-sub{align-items:center;display:flex;gap:8px}.program-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:11px;font-weight:600;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.dropdown-item-empty{color:#a0aec0;font-style:italic;padding:20px;text-align:center}.btn{align-items:center;border-radius:10px;display:flex;gap:8px;padding:12px 24px}.btn-primary:hover{box-shadow:0 10px 25px #667eea66}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1024px){.form-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.modern-header{padding:30px 20px}.header-text{align-items:flex-start;flex-direction:column}.header-icon-wrapper{height:60px;width:60px}.header-icon{font-size:28px}.header-text h1{font-size:24px}.stats-grid{grid-template-columns:1fr}.stats-grid,.summary-cards{padding:0 20px}.card{margin:0 20px 20px;padding:20px}.filters{flex-direction:column}.search-box{min-width:100%}.modern-table-container{overflow-x:scroll}.modern-table{min-width:900px}.modal-content{max-width:95%}}.modal-body::-webkit-scrollbar,.modern-table-container::-webkit-scrollbar,.searchable-dropdown::-webkit-scrollbar{height:8px;width:8px}.modal-body::-webkit-scrollbar-track,.modern-table-container::-webkit-scrollbar-track,.searchable-dropdown::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.modal-body::-webkit-scrollbar-thumb,.modern-table-container::-webkit-scrollbar-thumb,.searchable-dropdown::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px}.modal-body::-webkit-scrollbar-thumb:hover,.modern-table-container::-webkit-scrollbar-thumb:hover,.searchable-dropdown::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#764ba2,#667eea)}.baak-laporan-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:0}.header-actions{flex-wrap:wrap}.btn-glass{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.btn-glass:hover{background:#ffffff4d;box-shadow:0 10px 30px #0003;transform:translateY(-2px)}.filter-card{margin-bottom:30px}.filter-header{border-bottom:2px solid #e2e8f0;padding-bottom:15px}.filter-header h3{align-items:center;color:#1a202c;display:flex;font-size:20px;font-weight:700;gap:10px;margin:0}.filter-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-group{display:flex;flex-direction:column}.filter-group label{color:#2d3748;font-size:14px;font-weight:600;margin-bottom:8px}.form-control{background:#fff;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;padding:12px 15px;transition:all .3s ease}.form-control:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.report-title{padding:30px 30px 20px;text-align:center}.report-title h2{color:#1a202c;font-size:28px;font-weight:700;margin:0 0 10px}.report-date{color:#718096;font-size:14px;font-style:italic;margin:0}.stats-main-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px;padding:0 30px}.stat-card-large{align-items:center;background:#fff;border-left:5px solid;border-radius:16px;box-shadow:0 4px 20px #00000014;display:flex;gap:20px;overflow:hidden;padding:30px;position:relative;transition:all .3s ease}.stat-card-large:before{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);border-radius:50%;content:"";height:100px;position:absolute;right:0;top:0;transform:translate(30%,-30%);width:100px}.stat-card-large:hover{box-shadow:0 10px 35px #0000001f;transform:translateY(-5px)}.stat-icon-large{align-items:center;border-radius:14px;color:#fff;display:flex;flex-shrink:0;font-size:32px;height:70px;justify-content:center;width:70px}.stat-icon-large,.stat-primary .stat-icon-large{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-warning .stat-icon-large{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-danger .stat-icon-large{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-success .stat-icon-large{background:linear-gradient(135deg,#10b981,#059669)}.stat-content h4{color:#718096;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.stat-content h2{color:#1a202c;font-size:28px;font-weight:700;margin:0 0 5px}.stat-content p{color:#a0aec0;font-size:13px;margin:0}.charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:30px;padding:0 30px}.chart-card{margin:0}.chart-card-full{margin:0 30px 30px}.chart-header{border-bottom:2px solid #e2e8f0;margin-bottom:20px;padding-bottom:15px}.chart-header h3{align-items:center;color:#1a202c;display:flex;font-size:18px;font-weight:700;gap:10px;margin:0}.chart-content{min-height:300px}.no-data{color:#a0aec0;font-size:16px;font-style:italic;padding:80px 20px;text-align:center}.horizontal-bar-chart{gap:20px}.bar-item,.horizontal-bar-chart{display:flex;flex-direction:column}.bar-item{gap:8px}.bar-label{align-items:center;display:flex;font-size:14px;justify-content:space-between}.bar-name{color:#2d3748;font-weight:600}.bar-value{color:#667eea;font-weight:700}.bar-wrapper{background:#e2e8f0;height:30px;overflow:hidden;width:100%}.bar-fill,.bar-wrapper{border-radius:15px;position:relative}.bar-fill{animation:fillBar 1s ease;height:100%;transition:width 1s ease}@keyframes fillBar{0%{width:0}}.line-chart{align-items:flex-end;background:linear-gradient(180deg,#667eea0d 0,#0000);border-radius:12px;display:flex;gap:10px;height:300px;padding:20px}.line-chart-bar{flex:1 1;flex-direction:column;gap:10px;height:100%;justify-content:flex-end}.bar-value-top,.line-chart-bar{align-items:center;display:flex}.bar-value-top{color:#667eea;font-size:10px;font-weight:600;min-height:60px;text-orientation:mixed;transform:rotate(180deg);writing-mode:vertical-rl}.bar-column{background:linear-gradient(0deg,#667eea 0,#764ba2);border-radius:8px 8px 0 0;cursor:pointer;min-height:5px;position:relative;transition:height 1s ease;width:100%}.bar-column:hover{opacity:.8}.bar-label-bottom{color:#718096;font-size:12px;font-weight:600;text-align:center;white-space:nowrap}.table-header{border-bottom:2px solid #e2e8f0;margin-bottom:20px;padding-bottom:15px}.table-header h3{color:#1a202c;font-size:20px;font-weight:700;margin:0}.summary-table table{border-collapse:collapse;width:100%}.summary-table tr{border-bottom:1px solid #e2e8f0}.summary-table tr:last-child{border-bottom:none}.summary-table tr.summary-total{background:#f7fafc;font-weight:700}.summary-table td{padding:15px 10px}.summary-label{color:#2d3748;font-size:14px;font-weight:600}.summary-value{color:#1a202c;font-size:16px;font-weight:700;text-align:right}.text-danger{color:#ef4444!important}.text-success{color:#10b981!important}.spinner{margin:100px auto}@media print{.baak-laporan-page,.modern-header{background:#fff}.modern-header{border-bottom:3px solid #667eea;box-shadow:none;color:#000}.header-text h1,.header-text p{color:#000}.filter-card,.header-actions{display:none}.card{page-break-inside:avoid}.card,.stat-card-large{border:1px solid #e2e8f0;box-shadow:none}.btn-glass{display:none}}@media (max-width:1024px){.charts-grid{grid-template-columns:1fr}.stats-main-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.modern-header{padding:30px 20px}.header-text{align-items:flex-start;flex-direction:column}.header-icon-wrapper{height:60px;width:60px}.header-icon{font-size:28px}.header-text h1{font-size:24px}.header-actions{justify-content:stretch;width:100%}.btn-glass{flex:1 1;justify-content:center}.card{margin:0 20px 20px;padding:20px}.filter-grid,.stats-main-grid{grid-template-columns:1fr}.charts-grid,.stats-main-grid{padding:0 20px}.chart-card-full{margin:0 20px 20px}.line-chart{overflow-x:auto;padding:10px}.bar-value-top{font-size:8px;min-height:40px}.bar-label-bottom{font-size:10px}}.line-chart::-webkit-scrollbar{height:8px}.line-chart::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.line-chart::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px}.line-chart::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#764ba2,#667eea)}.status-pembayaran-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:0}.modern-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0;box-shadow:0 10px 40px #0000001a;margin-bottom:30px;overflow:hidden;padding:40px 30px;position:relative}.header-background{bottom:0;left:0;opacity:.1;position:absolute;right:0;top:0}.header-pattern{background-image:repeating-linear-gradient(45deg,#0000,#0000 35px,#ffffff1a 0,#ffffff1a 70px);height:100%;position:absolute;width:100%}.header-content{flex-wrap:wrap}.header-text{align-items:center;display:flex;gap:20px}.header-icon-wrapper{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:20px;display:flex;height:80px;justify-content:center;width:80px}.header-icon{font-size:36px}.header-text h1{color:#fff;font-size:32px;font-weight:700;margin:0;text-shadow:0 2px 10px #0003}.header-text p{color:#ffffffe6;font-size:16px;margin:5px 0 0}.card{border:1px solid #667eea1a;margin:0 30px 30px;padding:25px}.search-card{background:#fff;padding:30px}.search-form{display:flex;flex-direction:column;gap:20px}.search-type-selector{display:flex;flex-wrap:wrap;gap:15px}.type-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#718096;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:10px;justify-content:center;min-width:180px;padding:15px 25px;transition:all .3s ease}.type-btn:hover{background:#f7fafc;border-color:#667eea}.type-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.search-input-group{display:flex;flex-wrap:wrap;gap:15px}.search-input-wrapper{flex:1 1;min-width:300px;position:relative}.search-icon{color:#718096;font-size:20px;left:18px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;padding:16px 20px 16px 55px;transition:all .3s ease;width:100%}.search-input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.search-input:disabled{cursor:not-allowed;opacity:.6}.search-buttons{display:flex;gap:10px}.btn{border:none;border-radius:12px;cursor:pointer;font-size:14px;font-weight:600;padding:16px 32px;transition:all .3s ease;white-space:nowrap}.btn-primary:hover:not(:disabled){box-shadow:0 10px 25px #667eea66;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{color:#2d3748}.btn-secondary:hover{transform:translateY(-2px)}.card-header{margin-bottom:20px;padding-bottom:15px}.btn-icon{background:#fff;border:2px solid #667eea;border-radius:10px;color:#667eea;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-icon:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.student-info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{background:#f7fafc;border-left:4px solid #667eea;border-radius:12px;padding:15px}.info-label{font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.info-value{font-size:16px}.stat-card{border-left:5px solid}.stat-primary{border-left-color:#667eea}.stat-warning{border-left-color:#f59e0b}.stat-danger{border-left-color:#ef4444}.stat-success{border-left-color:#10b981}.stat-primary .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-warning .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-danger .stat-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-success .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}.stat-content{flex:1 1}.stat-label{font-size:12px;margin-bottom:8px}.stat-value{margin-bottom:5px}.stat-desc{color:#a0aec0;font-size:13px}.alert{align-items:center;animation:slideDown .5s ease;border-radius:12px;display:flex;gap:15px;margin:0 30px 30px;padding:20px 25px}.alert-danger{background:#fee2e2;border:2px solid #ef4444;color:#991b1b}.alert-icon{flex-shrink:0;font-size:32px}.alert-content h4{font-size:18px;font-weight:700;margin:0 0 5px}.alert-content p{font-size:14px;margin:0}.table-responsive{margin-top:15px;overflow-x:auto}.modern-table{border-collapse:initial;border-spacing:0;width:100%}.modern-table thead tr{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modern-table th{font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase;white-space:nowrap}.modern-table th:first-child{border-top-left-radius:12px}.modern-table th:last-child{border-top-right-radius:12px}.modern-table tbody tr{border-bottom:1px solid #e2e8f0;transition:all .3s ease}.modern-table tbody tr:hover{background:#f7fafc;transform:scale(1.01)}.modern-table tbody tr.row-danger{background:#fef2f2;border-left:4px solid #ef4444}.modern-table tbody tr.row-danger:hover{background:#fee2e2}.modern-table td{color:#2d3748;font-size:14px;padding:16px}.date-cell{align-items:center;display:flex;gap:8px}.date-icon{color:#667eea;font-size:16px}.text-success{color:#10b981}.badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.empty-state{padding:60px 20px}.empty-icon{font-size:48px;margin-bottom:15px;opacity:.5}.empty-state p{font-size:15px;font-style:italic}.empty-state-large{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin:0 30px;padding:100px 30px;text-align:center}.empty-icon-large{color:#667eea;font-size:80px;margin-bottom:25px;opacity:.6}.empty-state-large h3{color:#1a202c;font-size:28px;font-weight:700;margin:0 0 15px}.empty-state-large p{color:#718096;font-size:16px;margin:0 auto;max-width:500px}@media print{.modern-header,.status-pembayaran-page{background:#fff}.modern-header{border-bottom:3px solid #667eea;box-shadow:none;color:#000}.header-text h1,.header-text p{color:#000}.btn-icon,.search-buttons,.search-card{display:none}.card{page-break-inside:avoid}.card,.stat-card{border:1px solid #e2e8f0;box-shadow:none}}@media (max-width:768px){.modern-header{padding:30px 20px}.header-text{align-items:flex-start;flex-direction:column}.header-icon-wrapper{height:60px;width:60px}.header-icon{font-size:28px}.header-text h1{font-size:24px}.card{margin:0 20px 20px;padding:20px}.search-type-selector{flex-direction:column}.type-btn{min-width:100%}.search-input-group{flex-direction:column}.search-input-wrapper{min-width:100%}.search-buttons{width:100%}.btn{flex:1 1}.stats-grid,.student-info-grid{grid-template-columns:1fr}.stats-grid{padding:0 20px}.alert{flex-direction:column;margin:0 20px 20px;text-align:center}.table-responsive{overflow-x:scroll}.modern-table{min-width:800px}.empty-state-large{margin:0 20px;padding:60px 20px}.empty-icon-large{font-size:60px}.empty-state-large h3{font-size:22px}.empty-state-large p{font-size:14px}}.table-responsive::-webkit-scrollbar{height:8px}.table-responsive::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.table-responsive::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px}.table-responsive::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#764ba2,#667eea)}.baak-proposal-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:0}.proposal-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 40px #667eea4d;margin-bottom:30px;overflow:hidden;padding:40px 30px;position:relative}.header-left{gap:20px}.header-left,.icon-wrapper{align-items:center;display:flex}.icon-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:20px;height:70px;justify-content:center;width:70px}.header-icon{color:#fff;font-size:32px}.header-title{margin:0;text-shadow:0 2px 10px #0003}.header-subtitle{color:#ffffffe6;margin:5px 0 0}.btn-add{align-items:center;background:#fff;border:none;border-radius:12px;box-shadow:0 4px 15px #0003;color:#667eea;cursor:pointer;display:flex;font-size:15px;font-weight:700;gap:10px;padding:14px 28px;transition:all .3s ease}.btn-add:hover{box-shadow:0 8px 25px #0000004d;transform:translateY(-3px)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat-value{font-size:24px}.stat-info{font-size:11px}.filter-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin:0 30px 30px;padding:25px}.filter-header{align-items:center;color:#1a202c;display:flex;font-size:18px;font-weight:700;gap:10px;margin-bottom:20px}.filter-buttons{display:flex;flex-wrap:wrap;gap:12px}.filter-btn{background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#718096;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:all .3s ease}.filter-btn:hover{background:#f7fafc;border-color:#667eea}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.proposals-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin:0 30px 30px;padding:25px}.card-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:25px;padding-bottom:20px}.card-header h3{font-size:20px}.table-count{background:#f7fafc;border-radius:20px;color:#718096;font-size:14px;font-weight:600;padding:6px 16px}.loading-state{padding:80px 20px;text-align:center}.spinner{border:4px solid #667eea33;margin:0 auto 20px}.loading-state p{margin:0}.empty-state{padding:80px 20px}.empty-state svg{margin-bottom:20px;opacity:.5}.empty-state p{color:#718096;font-size:18px;font-weight:600;margin:0 0 10px}.empty-state small{color:#a0aec0;font-size:14px}.proposals-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.proposal-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;overflow:hidden;transition:all .3s ease}.proposal-card:hover{border-color:#667eea;box-shadow:0 15px 40px #667eea26;transform:translateY(-5px)}.proposal-card-header{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-bottom:2px solid #e2e8f0;padding:20px}.proposal-number{background:#667eea1a;border-radius:20px;color:#667eea;display:inline-block;font-size:12px;font-weight:700;margin-bottom:10px;padding:4px 12px}.proposal-title{font-size:18px;font-weight:700;line-height:1.4;margin:10px 0}.jenis-badge{border-radius:8px;display:inline-block;font-size:12px;font-weight:600;padding:6px 12px}.proposal-card-body{padding:20px}.info-row{border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:10px 0}.info-label{color:#718096;font-size:13px;font-weight:500}.info-value{color:#1a202c;font-size:14px;font-weight:600}.budget-section{grid-gap:10px;background:#f7fafc;border-radius:12px;display:grid;gap:10px;margin-top:20px;padding:15px}.budget-item{align-items:center;display:flex;justify-content:space-between}.budget-label{color:#718096;font-size:12px;font-weight:500}.budget-value{font-size:14px;font-weight:700}.budget-value.green{color:#10b981}.budget-value.orange{color:#f59e0b}.budget-value.blue{color:#3b82f6}.progress-bar{background:#e2e8f0;border-radius:10px;height:8px;margin-top:15px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#10b981,#f59e0b 70%,#ef4444);height:100%;transition:width .3s ease}.progress-label{color:#718096;font-size:12px;margin-top:8px;text-align:center}.proposal-card-footer{background:#f7fafc;border-top:2px solid #e2e8f0;display:flex;gap:10px;padding:15px 20px}.btn-invoice{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:10px 16px;transition:all .3s ease}.btn-invoice:hover{box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.btn-delete,.btn-edit{border:none;border-radius:10px;cursor:pointer;font-size:16px;padding:10px 14px;transition:all .3s ease}.btn-edit{background:#f59e0b;color:#fff}.btn-edit:hover{background:#d97706;transform:translateY(-2px)}.btn-delete{background:#ef4444;color:#fff}.btn-delete:hover{background:#dc2626;transform:translateY(-2px)}.modal-overlay{padding:20px}.modal-content{border-radius:20px;box-shadow:0 25px 50px #0000004d;display:flex;flex-direction:column;max-width:700px}.modal-content.modal-large{max-width:1000px}.modal-header{flex-shrink:0;padding:25px 30px}.modal-header h3{color:#1a202c;font-size:22px;font-weight:700;margin:0}.modal-subtitle{color:#718096;font-size:14px;margin:5px 0 0}.btn-close{align-items:center;background:#f3f4f6;border:none;border-radius:10px;color:#6b7280;cursor:pointer;display:flex;font-size:28px;height:40px;justify-content:center;line-height:1;transition:all .3s ease;width:40px}.btn-close:hover{background:#e5e7eb;color:#1f2937}.modal-body{flex:1 1 auto;min-height:0;overflow-y:auto;padding:25px 30px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1/-1}.form-group label{color:#374151;font-size:14px;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border-radius:10px;font-size:14px;padding:12px 16px}.form-group textarea{font-family:inherit;resize:vertical}.modal-footer{flex-shrink:0;gap:12px;padding:20px 30px}.btn-cancel,.btn-save{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.btn-cancel{background:#f3f4f6;color:#6b7280}.btn-cancel:hover{background:#e5e7eb;color:#1f2937}.btn-save{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-save:hover{box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.invoice-budget-info{grid-gap:15px;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr);margin-bottom:30px;padding:20px}.budget-info-item{display:flex;flex-direction:column;gap:8px}.budget-info-item .label{color:#718096;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.budget-info-item .value{font-size:18px;font-weight:700}.invoice-form-section{background:#f7fafc;border-radius:12px;margin-bottom:30px;padding:20px}.section-title{color:#1a202c;font-size:16px;margin:0 0 20px}.btn-create-invoice,.section-title{align-items:center;display:flex;font-weight:700;gap:10px}.btn-create-invoice{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;justify-content:center;margin-top:20px;padding:14px 24px;transition:all .3s ease;width:100%}.btn-create-invoice:hover{box-shadow:0 8px 20px #10b9814d;transform:translateY(-2px)}.invoice-list-section{margin-top:30px}.empty-state-small{color:#a0aec0;padding:40px 20px;text-align:center}.empty-state-small p{font-size:14px;margin:0}.invoice-table{overflow-x:auto}.invoice-table table{border-collapse:collapse;width:100%}.invoice-table th{background:#f7fafc;border-bottom:2px solid #e2e8f0;color:#374151;font-size:12px;font-weight:700;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.invoice-table td{border-bottom:1px solid #f3f4f6;color:#1a202c;font-size:14px;padding:14px 16px}.invoice-table td.amount{color:#667eea;font-weight:700}.status-badge{font-size:11px;font-weight:700;padding:4px 12px}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.disetujui{background:#d1fae5;color:#065f46}.status-badge.ditolak{background:#fee2e2;color:#991b1b}.status-badge.dibayar{background:#dbeafe;color:#1e40af}.btn-delete-small{background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:8px 12px;transition:all .3s ease}.btn-delete-small:hover{background:#dc2626;transform:scale(1.1)}@media (max-width:768px){.proposal-header{padding:24px 20px}.header-content{align-items:flex-start;flex-direction:column}.btn-add{justify-content:center;width:100%}.stats-grid{grid-template-columns:1fr;padding:0 20px}.filter-card,.proposals-card{margin:0 20px 20px;padding:20px}.form-grid,.invoice-budget-info,.proposals-grid{grid-template-columns:1fr}.invoice-table{font-size:12px}.invoice-table td,.invoice-table th{padding:10px 8px}}.dashboard-kemahasiswaan{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:0;transition:background .3s ease}[data-theme=gelap] .dashboard-kemahasiswaan{background:linear-gradient(135deg,#1a1a2e,#16213e)}[data-theme=gelap] .dashboard-header{background:linear-gradient(135deg,#0f3460,#16213e)}[data-theme=gelap] .card,[data-theme=gelap] .quick-actions-card,[data-theme=gelap] .stat-card{background:#1e1e30;border:1px solid #2d2d44;color:#e0e0e0}[data-theme=gelap] .stat-label,[data-theme=gelap] .stat-value,[data-theme=gelap] h3,[data-theme=gelap] h4{color:#e0e0e0}[data-theme=gelap] .activity-item,[data-theme=gelap] .event-item{background:#252538;border-color:#2d2d44}[data-theme=gelap] .activity-item:hover,[data-theme=gelap] .event-item:hover{background:#2d2d44}[data-theme=segar] .dashboard-kemahasiswaan{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}[data-theme=segar] .dashboard-header{background:linear-gradient(135deg,#43a047,#2e7d32)}[data-theme=segar] .stat-card.blue .stat-icon,[data-theme=segar] .stat-card.blue:before{background:linear-gradient(135deg,#66bb6a,#43a047)}[data-theme=segar] .stat-card.green .stat-icon,[data-theme=segar] .stat-card.green:before{background:linear-gradient(135deg,#81c784,#66bb6a)}[data-theme=segar] .stat-card.cyan .stat-icon,[data-theme=segar] .stat-card.cyan:before{background:linear-gradient(135deg,#4db6ac,#26a69a)}[data-theme=segar] .floating-settings-btn,[data-theme=segar] .notification-btn:hover,[data-theme=segar] .notification-header,[data-theme=segar] .settings-header{background:linear-gradient(135deg,#43a047,#2e7d32)}[data-theme=segar] .action-btn{border:2px solid #43a047}[data-theme=futuristik] .dashboard-kemahasiswaan{background:linear-gradient(135deg,#0a0e27,#1a1a2e)}[data-theme=futuristik] .dashboard-header{background:linear-gradient(135deg,#6a11cb,#2575fc);box-shadow:0 0 30px #2575fc80}[data-theme=futuristik] .stat-card{background:#1a1a2ee6;border:2px solid #2575fc;box-shadow:0 0 20px #2575fc4d;color:#e0e0e0}[data-theme=futuristik] .stat-card:before{box-shadow:0 0 30px currentColor}[data-theme=futuristik] .stat-card.blue .stat-icon{background:linear-gradient(135deg,#00f2fe,#4facfe);box-shadow:0 0 20px #00f2fe}[data-theme=futuristik] .stat-card.green .stat-icon{background:linear-gradient(135deg,#43e97b,#38f9d7);box-shadow:0 0 20px #43e97b}[data-theme=futuristik] .stat-card.cyan .stat-icon{background:linear-gradient(135deg,#fa709a,#fee140);box-shadow:0 0 20px #fa709a}[data-theme=futuristik] .stat-card.orange .stat-icon{background:linear-gradient(135deg,#ff9a56,#ff6a00);box-shadow:0 0 20px #ff9a56}[data-theme=futuristik] .stat-card.purple .stat-icon{background:linear-gradient(135deg,#a855f7,#ec4899);box-shadow:0 0 20px #a855f7}[data-theme=futuristik] .stat-card.pink .stat-icon{background:linear-gradient(135deg,#f857a6,#ff5858);box-shadow:0 0 20px #f857a6}[data-theme=futuristik] .stat-label,[data-theme=futuristik] .stat-value,[data-theme=futuristik] h3,[data-theme=futuristik] h4{color:#e0e0e0}[data-theme=futuristik] .card,[data-theme=futuristik] .quick-actions-card{background:#1a1a2ee6;border:2px solid #2575fc;box-shadow:0 0 20px #2575fc33;color:#e0e0e0}[data-theme=futuristik] .floating-settings-btn{background:linear-gradient(135deg,#6a11cb,#2575fc);box-shadow:0 0 30px #2575fc99}[data-theme=futuristik] .activity-item,[data-theme=futuristik] .event-item{background:#2575fc1a;border:1px solid #2575fc4d}[data-theme=modern] .dashboard-kemahasiswaan{background:linear-gradient(135deg,#fdfbfb,#ebedee)}[data-theme=modern] .dashboard-header{background:linear-gradient(135deg,#434343,#000)}[data-theme=modern] .stat-card{background:#fff;border:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000a}[data-theme=modern] .stat-card:before{opacity:.05}[data-theme=modern] .stat-card:hover{box-shadow:0 8px 16px #00000014}[data-theme=modern] .stat-card.blue .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}[data-theme=modern] .stat-card.green .stat-icon{background:linear-gradient(135deg,#56ab2f,#a8e063)}[data-theme=modern] .stat-card.cyan .stat-icon{background:linear-gradient(135deg,#3a7bd5,#00d2ff)}[data-theme=modern] .card,[data-theme=modern] .quick-actions-card{background:#fff;border:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000a}[data-theme=modern] .floating-settings-btn{background:linear-gradient(135deg,#434343,#000)}[data-theme=modern] .action-btn{background:#fff;border:2px solid #e0e0e0;color:#434343}[data-theme=modern] .action-btn:hover{border-color:#434343;transform:translateY(-2px)}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 40px #fbfbfb4d;margin-bottom:30px;overflow:visible;padding:40px 30px;position:relative;z-index:10}.header-backdrop{background:repeating-linear-gradient(45deg,#0000,#0000 35px,#ffffff1a 0,#ffffff1a 70px);bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0}.header-content{align-items:center;display:flex;gap:20px;justify-content:space-between;position:relative;z-index:1}.header-text{flex:1 1}.header-title{color:#fff;font-size:32px;font-weight:700;margin:0 0 10px;text-shadow:0 2px 10px #dd3d3d}.header-subtitle{color:#a92626e6;font-size:16px;margin:0}.header-actions{align-items:center;display:flex;gap:15px}.notification-container{position:relative;z-index:1050}.notification-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:22px;height:48px;justify-content:center;position:relative;transition:all .3s ease;width:48px}.notification-btn:hover{background:#ffffff4d;transform:scale(1.05)}.notification-btn:active{transform:scale(.95)}.notification-badge{align-items:center;animation:pulse 2s ease-in-out infinite;background:#ff4757;border:2px solid #667eea;border-radius:10px;color:#fff;display:flex;font-size:11px;font-weight:700;height:20px;justify-content:center;min-width:20px;padding:0 5px;position:absolute;right:-5px;top:-5px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notification-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:1100}.notification-dropdown{animation:slideDown .3s ease;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-height:500px;overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);width:380px;z-index:1101}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 20px}.notification-header h4{color:#fff;font-size:16px;font-weight:700;margin:0}.mark-all-read{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s ease}.mark-all-read:hover{background:#ffffff4d}.notification-list{max-height:380px;overflow-y:auto}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f1f1f1}.notification-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.notification-item{align-items:flex-start;border-bottom:1px solid #e2e8f0;cursor:pointer;display:flex;gap:12px;padding:16px 20px;position:relative;transition:all .2s ease}.notification-item:hover{background:#f7fafc}.notification-item.unread{background:#eef2ff}.notification-item.unread:hover{background:#e0e7ff}.notif-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;width:40px}.notif-icon.proposal{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.notif-icon.event{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.notif-icon.prestasi{background:linear-gradient(135deg,#ffd89b,#19547b);color:#fff}.notif-content{flex:1 1}.notif-content h5{color:#2d3748;font-size:14px;font-weight:700;margin:0 0 4px}.notif-content p{color:#4a5568;font-size:13px;line-height:1.4;margin:0 0 6px}.notif-time{color:#a0aec0;font-size:11px;font-weight:500}.unread-dot{background:#667eea;border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.notification-empty{align-items:center;color:#a0aec0;display:flex;flex-direction:column;justify-content:center;padding:40px 20px}.notification-empty svg{font-size:48px;margin-bottom:12px}.notification-empty p{font-size:14px;margin:0}.notification-footer{background:#f7fafc;border-top:2px solid #e2e8f0;padding:12px 20px}.view-all-btn{background:#0000;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:13px;font-weight:600;padding:10px;transition:all .2s ease;width:100%}.view-all-btn:hover{background:#667eea;color:#fff}.header-date{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:12px;color:#fff;display:flex;font-size:15px;font-weight:600;gap:10px;padding:12px 20px}.header-date svg{font-size:20px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px;padding:0 30px}.stat-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;display:flex;gap:20px;overflow:hidden;padding:25px;position:relative;transition:all .3s ease}.stat-card:before{border-radius:50%;content:"";height:100px;opacity:.1;position:absolute;right:0;top:0;transform:translate(30%,-30%);transition:all .3s ease;width:100px}.stat-card:hover{box-shadow:0 10px 35px #0000001f;transform:translateY(-5px)}.stat-card:hover:before{transform:translate(30%,-30%) scale(1.2)}.stat-card.blue .stat-icon,.stat-card.blue:before{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-card.green .stat-icon,.stat-card.green:before{background:linear-gradient(135deg,#10b981,#059669)}.stat-card.cyan .stat-icon,.stat-card.cyan:before{background:linear-gradient(135deg,#06b6d4,#0891b2)}.stat-card.orange .stat-icon,.stat-card.orange:before{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card.purple .stat-icon,.stat-card.purple:before{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-card.pink .stat-icon,.stat-card.pink:before{background:linear-gradient(135deg,#ec4899,#db2777)}.stat-card.indigo .stat-icon,.stat-card.indigo:before{background:linear-gradient(135deg,#6366f1,#4f46e5)}.stat-card.yellow .stat-icon,.stat-card.yellow:before{background:linear-gradient(135deg,#f59e0b,#eab308)}.stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:28px;height:60px;justify-content:center;width:60px}.stat-details{flex:1 1}.stat-label{color:#718096;font-size:13px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.stat-value{color:#1a202c;font-size:28px;font-weight:700;margin:0}.stat-info{color:#94a3b8;display:block;font-size:12px;margin-top:4px}.content-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:30px;padding:0 30px}.card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden}.card-header{background:linear-gradient(180deg,#fff,#f8fafc);border-bottom:2px solid #f1f5f9;padding:20px 25px}.card-header h3{align-items:center;color:#1a202c;display:flex;font-size:18px;font-weight:700;gap:10px;margin:0}.card-header h3 svg{color:#667eea;font-size:20px}.card-body{padding:20px 25px}.activities-list{display:flex;flex-direction:column;gap:15px}.activity-item{align-items:flex-start;background:#f8fafc;border-radius:12px;display:flex;gap:15px;padding:15px;transition:all .3s ease}.activity-item:hover{background:#f1f5f9;transform:translateX(5px)}.activity-item.success{border-left:4px solid #10b981}.activity-item.info{border-left:4px solid #06b6d4}.activity-item.warning{border-left:4px solid #f59e0b}.activity-icon{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;color:#667eea;display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;width:40px}.activity-content{flex:1 1}.activity-title{color:#1a202c;font-size:14px;font-weight:600;margin:0 0 5px}.activity-date{color:#94a3b8;font-size:12px}.events-list{display:flex;flex-direction:column;gap:15px}.event-item{align-items:center;background:#f8fafc;border-radius:12px;display:flex;gap:15px;padding:15px;transition:all .3s ease}.event-item:hover{background:#f1f5f9;transform:translateX(5px)}.event-date{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;flex-direction:column;flex-shrink:0;height:60px;justify-content:center;width:60px}.event-day{font-size:24px;font-weight:700;line-height:1}.event-month{font-size:12px;font-weight:600;margin-top:2px;text-transform:uppercase}.event-content{flex:1 1}.event-title{color:#1a202c;font-size:15px;font-weight:700;margin:0 0 5px}.event-location{align-items:center;color:#94a3b8;display:flex;font-size:13px;gap:5px;margin:0}.quick-actions-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin:0 30px 30px;padding:25px}.quick-actions-card h3{color:#1a202c;font-size:18px;font-weight:700;margin:0 0 20px}.quick-actions-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-btn{align-items:center;border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-size:15px;font-weight:600;gap:10px;padding:20px;transition:all .3s ease}.action-btn svg{font-size:28px}.action-btn:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.action-btn.blue{background:linear-gradient(135deg,#667eea,#764ba2)}.action-btn.green{background:linear-gradient(135deg,#10b981,#059669)}.action-btn.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.action-btn.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.empty-state{color:#94a3b8;padding:40px 20px;text-align:center}.empty-state p{font-size:14px;margin:0}.loading-state{align-items:center;display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:60vh}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;height:50px;width:50px}.loading-state p{color:#718096;font-size:16px;font-weight:600}.theme-description{background:#f7fafc;border-left:3px solid #667eea;border-radius:4px;color:#4a5568;display:block;font-size:12px;line-height:1.5;margin-top:8px;padding:8px 12px}[data-theme=gelap] .theme-description{background:#2d2d44;border-left-color:#2575fc;color:#a0aec0}[data-theme=segar] .theme-description{background:#e8f5e9;border-left-color:#43a047}[data-theme=futuristik] .theme-description{background:#2575fc1a;border-left-color:#00f2fe;color:#a0aec0}[data-theme=modern] .theme-description{background:#f5f5f5;border-left-color:#434343}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.content-grid{grid-template-columns:1fr}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dashboard-header{padding:30px 20px}.header-content{align-items:flex-start;flex-direction:column}.header-title{font-size:24px}.content-grid,.quick-actions-card,.stats-grid{margin-left:0;margin-right:0;padding:0 20px}.quick-actions-grid,.stats-grid{grid-template-columns:1fr}}.floating-settings-btn{align-items:center;animation:float 3s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;bottom:30px;box-shadow:0 8px 24px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:24px;height:56px;justify-content:center;position:fixed;right:30px;transition:all .3s ease;width:56px;z-index:999}.floating-settings-btn:hover{box-shadow:0 12px 32px #667eea80;transform:translateY(-5px) rotate(90deg)}.floating-settings-btn:active{transform:translateY(-2px) rotate(90deg)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.settings-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-panel{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;left:50%;max-height:80vh;max-width:500px;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:1001}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}.settings-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.settings-header h3{font-size:20px;font-weight:700;margin:0}.close-settings{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.close-settings:hover{background:#ffffff4d;transform:rotate(90deg)}.settings-body{max-height:calc(80vh - 140px);overflow-y:auto;padding:24px}.settings-section{border-bottom:1px solid #e2e8f0;margin-bottom:28px;padding-bottom:20px}.settings-section:last-child{border-bottom:none;margin-bottom:0}.settings-section h4{align-items:center;color:#2d3748;display:flex;font-size:16px;font-weight:700;gap:8px;margin:0 0 16px}.setting-item{margin-bottom:16px}.setting-item:last-child{margin-bottom:0}.setting-item label{align-items:center;color:#4a5568;cursor:pointer;display:flex;font-size:14px;gap:12px;transition:color .2s ease}.setting-item label:hover{color:#2d3748}.setting-item input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.setting-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#2d3748;cursor:pointer;font-size:14px;margin-top:8px;padding:10px 12px;transition:all .2s ease;width:100%}.setting-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.setting-select:hover{border-color:#cbd5e0}.settings-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px}.settings-footer .btn-secondary{background:#e2e8f0;border:none;border-radius:8px;color:#4a5568;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.settings-footer .btn-secondary:hover{background:#cbd5e0}.settings-footer .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.settings-footer .btn-primary:hover{box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}@media (max-width:768px){.floating-settings-btn{bottom:20px;font-size:20px;height:48px;right:20px;width:48px}.settings-panel{max-height:85vh;width:95%}.settings-header{padding:16px 20px}.settings-header h3{font-size:18px}.settings-body{padding:20px}.settings-footer{flex-direction:column}.settings-footer .btn-primary,.settings-footer .btn-secondary{width:100%}.notification-dropdown{right:-20px;width:calc(100vw - 40px)}.header-actions{flex-direction:row;gap:10px}.notification-btn{font-size:20px;height:42px;width:42px}.header-date{font-size:13px;padding:8px 12px}.header-date svg{font-size:16px}}.proposal-kegiatan-page{margin:0 auto;max-width:1400px;padding:2rem}.page-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem}.header-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#1a202c;font-size:2rem;font-weight:700;margin-bottom:.5rem}.header-content p{color:#718096;font-size:1rem}.btn-primary{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #667eea40;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary:hover{box-shadow:0 6px 12px #667eea59;transform:translateY(-2px)}.btn-secondary{background:#e2e8f0;border:none;border-radius:8px;color:#4a5568;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-secondary:hover{background:#cbd5e0}.filter-section{display:flex;gap:1rem;margin-bottom:2rem}.filter-box,.search-box{flex:1 1;position:relative}.search-box{max-width:400px}.filter-box{max-width:200px}.filter-box select,.search-box input{border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;padding:.75rem 1rem .75rem 2.5rem;transition:all .3s ease;width:100%}.filter-box select:focus,.search-box input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-icon,.search-icon{color:#a0aec0;font-size:1.1rem;left:.75rem;position:absolute;top:50%;transform:translateY(-50%)}.proposals-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.proposals-table{border-collapse:collapse;width:100%}.proposals-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.proposals-table th{font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.proposals-table tbody tr{border-bottom:1px solid #e2e8f0;transition:all .2s ease}.proposals-table tbody tr:hover{background:#f7fafc}.proposals-table td{color:#2d3748;font-size:.95rem;padding:1rem}.proposal-title{color:#1a202c;font-weight:600;max-width:300px}.pengusul-info{display:flex;flex-direction:column;gap:.25rem}.pengusul-info strong{color:#2d3748;font-size:.95rem}.pengusul-info small{color:#718096;font-size:.85rem}.amount{color:#2b6cb0;font-weight:600}.amount-large{color:#2b6cb0;font-size:1.25rem;font-weight:700}.status-badge{border-radius:20px;display:inline-block;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:.375rem .75rem;text-transform:uppercase}.status-badge.warning{background:#fef5e7;border:1px solid #f9e79f;color:#d68910}.status-badge.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.status-badge.danger{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.status-badge.info{background:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.action-buttons{display:flex;gap:.5rem}.btn-icon{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:.5rem;transition:all .2s ease}.btn-icon.btn-info{background:#e6f7ff;color:#0969da}.btn-icon.btn-info:hover{background:#0969da;color:#fff;transform:translateY(-2px)}.btn-icon.btn-warning{background:#fff7e6;color:#d68910}.btn-icon.btn-warning:hover{background:#d68910;color:#fff;transform:translateY(-2px)}.btn-icon.btn-danger{background:#ffe6e6;color:#dc3545}.btn-icon.btn-danger:hover{background:#dc3545;color:#fff;transform:translateY(-2px)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.modal-content.modal-detail{max-width:900px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #e2e8f0;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-header h2{color:#fff;font-size:1.5rem;font-weight:700;margin:0}.close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.75rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-body{padding:2rem}.modal-footer{background:#f7fafc;border-radius:0 0 16px 16px;border-top:2px solid #e2e8f0;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{margin-bottom:1.5rem}.form-group label{color:#2d3748;display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:.95rem;padding:.75rem;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input.disabled-input{background:#f7fafc;color:#718096;cursor:not-allowed}.form-section-title{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:1.1rem;font-weight:700;margin:2rem 0 1rem;padding-bottom:.5rem}.detail-section{margin-bottom:2rem}.detail-section h3{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:1.2rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem}.detail-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.detail-item label{color:#718096;display:block;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.detail-item p{color:#2d3748;font-size:1rem;font-weight:500;margin:0}.description-text{color:#4a5568;line-height:1.6;white-space:pre-wrap}.document-link{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:inline-flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.document-link:hover{box-shadow:0 6px 12px #667eea59;transform:translateY(-2px)}.loading-container{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:400px}.spinner{animation:spin .8s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{align-items:center;color:#a0aec0;display:flex;flex-direction:column;gap:1rem;padding:3rem}.empty-icon{color:#cbd5e0;font-size:4rem}.text-center{text-align:center}@media (max-width:1024px){.detail-grid,.form-row{grid-template-columns:1fr}}@media (max-width:768px){.proposal-kegiatan-page{padding:1rem}.page-header{align-items:flex-start;gap:1rem}.filter-section,.page-header{flex-direction:column}.filter-box,.search-box{max-width:100%}.proposals-table-container{overflow-x:auto}.proposals-table{min-width:800px}.modal-content{margin:1rem}.modal-body,.modal-footer,.modal-header{padding:1rem}.action-buttons{flex-direction:column}}
/*# sourceMappingURL=main.3485eb0b.css.map*/