/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}:root{--color-primary:#4f46e5;--color-primary-hover:#4338ca;--color-primary-light:#eef2ff;--color-secondary:#0ea5e9;--color-success:#16a34a;--color-warning:#d97706;--color-danger:#dc2626;--color-muted:#6b7280;--color-border:#e5e7eb;--color-bg:#fff;--color-surface:#f9fafb;--color-surface-2:#f3f4f6;--color-text:#111827;--color-text-secondary:#6b7280;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000012,0 4px 6px -4px #0000000d}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:15px}body,html{color:var(--color-text);background:var(--color-bg)}body{line-height:1.6}}@layer components{.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1.4;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{color:var(--color-text);border-color:var(--color-border);box-shadow:var(--shadow-sm);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--color-surface)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--color-surface);color:var(--color-text)}.btn-sm{padding:.3rem .7rem;font-size:.8rem}.btn-lg{padding:.7rem 1.5rem;font-size:1rem}.btn-full{justify-content:center;width:100%}.input{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);background:#fff;outline:none;padding:.55rem .85rem;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51a}.input::placeholder{color:#9ca3af}.input-error{border-color:var(--color-danger)}.input-error:focus{box-shadow:0 0 0 3px #dc26261a}textarea.input{resize:vertical;min-height:100px}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right .7rem center;background-repeat:no-repeat;padding-right:2.2rem}.label{color:var(--color-text);margin-bottom:.35rem;font-size:.82rem;font-weight:500;display:block}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-error{color:var(--color-danger)}.form-error,.form-hint{margin-top:.2rem;font-size:.78rem}.form-hint{color:var(--color-text-secondary)}.card{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff}.card-hover:hover{box-shadow:var(--shadow-md);border-color:#d1d5db;transition:all .2s}.card-body{padding:1.25rem}.card-header{border-bottom:1px solid var(--color-border);padding:1rem 1.25rem}.card-footer{border-top:1px solid var(--color-border);background:var(--color-surface);border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:.875rem 1.25rem}.badge{white-space:nowrap;border-radius:99px;align-items:center;padding:.2rem .6rem;font-size:.75rem;font-weight:500;line-height:1;display:inline-flex}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.badge-success{color:var(--color-success);background:#dcfce7}.badge-warning{color:var(--color-warning);background:#fef3c7}.badge-danger{color:var(--color-danger);background:#fee2e2}.badge-gray{background:var(--color-surface-2);color:var(--color-text-secondary)}.badge-sky{color:#0284c7;background:#e0f2fe}.type-tugas{color:#1d4ed8;background:#eff6ff}.type-kuis{color:#a16207;background:#fefce8}.type-uts{color:#c2410c;background:#fff7ed}.type-uas{color:#a21caf;background:#fdf2f8}.type-praktikum{color:#15803d;background:#f0fdf4}.type-presentasi{color:#7c3aed;background:#f5f3ff}.type-default{background:var(--color-surface-2);color:var(--color-text-secondary)}.table-wrapper{border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto}table.table{border-collapse:collapse;width:100%;font-size:.875rem}.table thead th{text-align:left;color:var(--color-text-secondary);background:var(--color-surface);text-transform:uppercase;letter-spacing:.04em;padding:.7rem 1rem;font-size:.78rem;font-weight:600}.table tbody td,.table thead th{border-bottom:1px solid var(--color-border)}.table tbody td{color:var(--color-text);padding:.85rem 1rem}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--color-surface)}.sidebar{border-right:1px solid var(--color-border);z-index:40;background:#fff;flex-direction:column;flex-shrink:0;width:240px;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--color-border);padding:1.25rem 1.25rem 1rem}.sidebar-nav{flex-direction:column;flex:1;gap:.15rem;padding:.75rem;display:flex;overflow-y:auto}.sidebar-section-title{color:#9ca3af;text-transform:uppercase;letter-spacing:.07em;margin-top:.5rem;padding:.5rem .5rem .25rem;font-size:.7rem;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.6rem;width:100%;padding:.55rem .75rem;font-size:.875rem;font-weight:450;text-decoration:none;transition:all .12s;display:flex}.nav-item:hover{background:var(--color-surface);color:var(--color-text)}.nav-item.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:500}.sidebar-footer{border-top:1px solid var(--color-border);padding:.75rem}.main-layout{background:var(--color-surface)}.main-content,.main-layout{min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;margin-left:240px}.topbar{border-bottom:1px solid var(--color-border);z-index:30;background:#fff;justify-content:space-between;align-items:center;height:56px;padding:0 1.5rem;display:flex;position:sticky;top:0}.page-container{flex:1;padding:1.75rem}.page-header{margin-bottom:1.5rem}.page-title{color:var(--color-text);font-size:1.35rem;font-weight:600;line-height:1.3}.page-subtitle{color:var(--color-text-secondary);margin-top:.2rem;font-size:.875rem}.stat-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;padding:1.25rem}.stat-card-value{color:var(--color-text);margin-bottom:.25rem;font-size:1.75rem;font-weight:700;line-height:1}.stat-card-label{color:var(--color-text-secondary);font-size:.82rem}.stat-card-icon{justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin-bottom:.875rem}.alert,.stat-card-icon{border-radius:var(--radius-md);display:flex}.alert{align-items:flex-start;gap:.6rem;padding:.875rem 1rem;font-size:.875rem}.alert-info{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.alert-success{color:var(--color-success);background:#f0fdf4;border:1px solid #bbf7d0}.alert-warning{color:var(--color-warning);background:#fffbeb;border:1px solid #fde68a}.alert-error{color:var(--color-danger);background:#fef2f2;border:1px solid #fecaca}.modal-overlay{z-index:100;background:#0006;padding:1rem}.modal{border-radius:var(--radius-lg);background:#fff;width:100%;max-width:520px;max-height:90vh;animation:modal-in .2s;overflow-y:auto;box-shadow:0 20px 60px -10px #0003}.modal-header{border-bottom:1px solid var(--color-border);padding:1.25rem 1.5rem}.modal-title{font-size:1rem;font-weight:600}.modal-body{padding:1.25rem 1.5rem}.modal-footer{background:var(--color-surface);border-radius:0 0 var(--radius-lg) var(--radius-lg);justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;display:flex}@keyframes modal-in{0%{opacity:0;transform:scale(.97)translateY(-8px)}to{opacity:1;transform:scale(1)translateY(0)}}.progress-bar{background:var(--color-surface-2);border-radius:99px;height:6px;overflow:hidden}.progress-fill{background:var(--color-primary);border-radius:99px;height:100%;transition:width .3s}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:1.25rem;height:1.25rem;animation:spin .6s linear infinite;display:inline-block}.timer-display{font-variant-numeric:tabular-nums;letter-spacing:.02em;font-size:1.1rem;font-weight:600}.timer-warning{color:var(--color-warning)}.timer-danger{color:var(--color-danger)}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-md);text-align:center;cursor:pointer;background:var(--color-surface);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;min-height:140px;padding:2rem 1.5rem;transition:all .2s;display:flex}.upload-zone.drag-over,.upload-zone:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.upload-zone-text{color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.integrity-flag{border-radius:var(--radius-sm);color:#c2410c;background:#fff7ed;border:1px solid #fed7aa;gap:.5rem;padding:.5rem .75rem;font-size:.8rem}.breadcrumb,.integrity-flag{align-items:center;display:flex}.breadcrumb{color:var(--color-text-secondary);gap:.35rem;font-size:.82rem}.breadcrumb-sep{color:#d1d5db}.breadcrumb a{color:var(--color-text-secondary);text-decoration:none}.breadcrumb a:hover{color:var(--color-primary)}.breadcrumb-current{color:var(--color-text);font-weight:500}.step-indicator{gap:0;margin-bottom:2rem}.step-indicator,.step-item{align-items:center;display:flex}.step-item{flex:1;gap:.5rem}.step-circle{border:2px solid var(--color-border);width:28px;height:28px;color:var(--color-text-secondary);background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.78rem;font-weight:600;display:flex}.step-circle.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.step-circle.done{border-color:var(--color-success);background:var(--color-success);color:#fff}.step-label{color:var(--color-text-secondary);white-space:nowrap;font-size:.82rem}.step-label.active{color:var(--color-primary);font-weight:500}.step-connector{background:var(--color-border);flex:1;height:1px;margin:0 .5rem}.grid-2{grid-template-columns:1fr 1fr}.grid-2,.grid-3{gap:1rem;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr}.grid-4{grid-template-columns:1fr 1fr 1fr 1fr;gap:1rem;display:grid}.flex-between{justify-content:space-between}.flex-between,.flex-center{align-items:center;display:flex}.flex-center{justify-content:center}.flex-gap-2{gap:.5rem}.flex-gap-2,.flex-gap-3{align-items:center;display:flex}.flex-gap-3{gap:.75rem}.text-sm{font-size:.875rem}.text-xs{font-size:.78rem}.text-muted{color:var(--color-text-secondary)}.text-primary{color:var(--color-primary)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.stack{gap:1rem}.stack,.stack-sm{flex-direction:column;display:flex}.stack-sm{gap:.5rem}.divider{background:var(--color-border);height:1px;margin:1rem 0}.empty-state{text-align:center;color:var(--color-text-secondary);padding:3rem 1.5rem}.empty-state-title{color:var(--color-text);margin-bottom:.375rem;font-size:1rem;font-weight:500}.empty-state-desc{font-size:.875rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#11182799;justify-content:center;align-items:center;animation:fadeIn .2s ease-out;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);padding:1.5rem;animation:slideUpFade .3s cubic-bezier(.16,1,.3,1)}.modal-footer{border-top:1px solid var(--color-border);margin-top:1.5rem;padding-top:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (max-width:768px){.sidebar{transition:transform .25s;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-container{padding:1rem}}}@layer utilities{.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.text-center{text-align:center}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.uppercase{text-transform:uppercase}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@keyframes spin{to{transform:rotate(1turn)}}