@import "https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap";
:root{--color-primary:#00a5e6;--color-primary-hover:#0090cc;--color-primary-light:#e6f7fd;--color-secondary:#004178;--color-secondary-hover:#003562;--color-bg:#fff;--color-bg-secondary:#326b9c;--color-bg-alt:#f8fafb;--color-surface:#fff;--color-surface-raised:#f9fafb;--color-text:#212529;--color-text-secondary:#666;--color-text-inverse:#fff;--color-text-link:#00a5e6;--color-border:#f2f2f2;--color-border-strong:#dee2e6;--color-border-focus:#00a5e6;--color-success:green;--color-success-bg:#e6f5e6;--color-warning:#e7e247;--color-warning-bg:#fefce8;--color-error:#cf2e2e;--color-error-bg:#fef2f2;--color-info:#00a5e6;--color-info-bg:#e6f7fd;--color-button-fill:#0056a7;--color-accent-dark:#293c5b;--font-heading:"Poppins", sans-serif;--font-body:"Poppins", sans-serif;--text-display:100px;--text-h1:52px;--text-h2:42px;--text-h3:28px;--text-h4:24px;--text-body-lg:20px;--text-body:18px;--text-sm:16px;--text-xs:14px;--text-caption:12px;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--space-1:3px;--space-2:6px;--space-3:9px;--space-4:12px;--space-5:15px;--space-6:18px;--space-7:21px;--space-8:24px;--space-10:30px;--space-12:36px;--space-16:48px;--space-20:60px;--space-24:72px;--space-32:96px;--radius-subtle:4px;--radius-base:6px;--radius-button:10px;--radius-card:16px;--radius-card-lg:24px;--radius-full:9999px;--shadow-low:0px 2px 10px #acabab26;--shadow-mid:-1px 3px 6px #0000001a;--shadow-high:0px 8px 30px #0000001f;--shadow-deep:0px 32px 68px #00000026;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--container-max:1400px;--sidebar-width:260px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%}body{min-height:100%;font-family:var(--font-body);font-size:var(--text-body);font-weight:var(--weight-regular);color:var(--color-text);background-color:var(--color-bg);line-height:1.5}a{color:var(--color-text-link);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--weight-medium);color:var(--color-text);line-height:1.2}h1{font-size:var(--text-h1)}h2{font-size:var(--text-h2)}h3{font-size:var(--text-h3)}h4{font-size:var(--text-h4)}p{color:var(--color-text-secondary);line-height:1.6}.btn{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-8);font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-button);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:2px solid #0000;line-height:1;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:var(--shadow-mid)}.btn-secondary{background:var(--color-secondary);color:var(--color-text-inverse);border-color:var(--color-secondary)}.btn-secondary:hover:not(:disabled){background:var(--color-secondary-hover);border-color:var(--color-secondary-hover)}.btn-outline{color:var(--color-secondary);border-color:var(--color-secondary);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-secondary);color:var(--color-text-inverse)}.btn-ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--color-bg-alt);color:var(--color-text)}.btn-danger{background:var(--color-error);color:var(--color-text-inverse);border-color:var(--color-error)}.btn-danger:hover:not(:disabled){background:#b82828;border-color:#b82828}.btn-lg{padding:var(--space-5) var(--space-10);font-size:var(--text-sm)}.btn-sm{padding:var(--space-2) var(--space-5);font-size:var(--text-caption)}.btn-full{width:100%}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.input-label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text)}.input{padding:var(--space-4) var(--space-5);font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border-strong);border-radius:var(--radius-base);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;width:100%}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input::placeholder{color:var(--color-text-secondary);opacity:.6}.input-error{border-color:var(--color-error)}.input-error:focus{box-shadow:0 0 0 3px var(--color-error-bg)}.error-text{font-size:var(--text-caption);color:var(--color-error)}textarea.input{resize:vertical;min-height:80px}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23666666' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);padding:var(--space-8);transition:box-shadow var(--transition-base), transform var(--transition-base)}.card-hover:hover{box-shadow:var(--shadow-mid);transform:translateY(-2px)}.card-elevated{box-shadow:var(--shadow-low);border-color:#0000}.badge{padding:var(--space-1) var(--space-3);font-size:var(--text-caption);font-weight:var(--weight-semibold);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;align-items:center;line-height:1.4;display:inline-flex}.badge-login{background:var(--color-info-bg);color:var(--color-primary)}.badge-module-open{background:var(--color-success-bg);color:var(--color-success)}.badge-pdf-view{color:var(--color-button-fill);background:#e8f4fd}.badge-active{background:var(--color-success-bg);color:var(--color-success)}.badge-inactive{background:var(--color-error-bg);color:var(--color-error)}.badge-published{background:var(--color-info-bg);color:var(--color-primary)}.badge-draft{background:var(--color-bg-alt);color:var(--color-text-secondary)}.table-container{border:1px solid var(--color-border);border-radius:var(--radius-card);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:var(--text-xs)}thead{background:var(--color-secondary);color:var(--color-text-inverse)}th{padding:var(--space-4) var(--space-5);text-align:left;font-weight:var(--weight-semibold);white-space:nowrap}td{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}tbody tr:nth-child(2n){background:var(--color-bg-alt)}tbody tr:hover{background:var(--color-primary-light)}.modal-overlay{z-index:1000;padding:var(--space-8);animation:fadeIn var(--transition-fast) ease;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-card-lg);padding:var(--space-10);width:100%;max-width:540px;max-height:90vh;box-shadow:var(--shadow-deep);animation:slideUp var(--transition-base) ease;overflow-y:auto}.modal-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:var(--text-h4)}.modal-close{font-size:var(--text-h4);cursor:pointer;color:var(--color-text-secondary);padding:var(--space-2);transition:color var(--transition-fast);background:0 0;border:none;line-height:1}.modal-close:hover{color:var(--color-text)}.modal-body{gap:var(--space-6);flex-direction:column;display:flex}.modal-footer{justify-content:flex-end;gap:var(--space-4);margin-top:var(--space-8);display:flex}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.text-center{text-align:center}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-caption{font-size:var(--text-caption)}.text-muted{color:var(--color-text-secondary)}.font-medium{font-weight:var(--weight-medium)}.font-semibold{font-weight:var(--weight-semibold)}.font-bold{font-weight:var(--weight-bold)}.w-full{width:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.skeleton{background:linear-gradient(90deg, var(--color-border) 25%, var(--color-bg-alt) 50%, var(--color-border) 75%);border-radius:var(--radius-base);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{width:100%;height:16px;margin-bottom:var(--space-3)}.skeleton-heading{width:60%;height:28px;margin-bottom:var(--space-5)}.skeleton-card{border-radius:var(--radius-card);height:180px}.empty-state{padding:var(--space-24) var(--space-8);text-align:center;color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{width:64px;height:64px;margin-bottom:var(--space-6);opacity:.4}.empty-state h4{color:var(--color-text);margin-bottom:var(--space-3)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-lg{border-width:3px;width:40px;height:40px}.page-loader{justify-content:center;align-items:center;min-height:400px;display:flex}.pagination{justify-content:center;align-items:center;gap:var(--space-2);margin-top:var(--space-8);display:flex}.pagination button{padding:var(--space-3) var(--space-4);font-size:var(--text-xs);font-family:var(--font-body);border:1px solid var(--color-border-strong);border-radius:var(--radius-base);background:var(--color-bg);cursor:pointer;transition:all var(--transition-fast);color:var(--color-text)}.pagination button:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary)}.pagination button.active{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.filters-bar{gap:var(--space-4);padding:var(--space-6);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-card);margin-bottom:var(--space-8);flex-wrap:wrap;display:flex}.filters-bar .input{max-width:220px}:root{--toastify-font-family:var(--font-body)}@media (max-width:1024px){:root{--text-h1:36px;--text-h2:30px;--text-h3:24px;--text-h4:20px}}@media (max-width:640px){:root{--text-h1:28px;--text-h2:24px;--text-h3:20px;--text-h4:18px;--text-body:16px;--space-8:18px;--space-10:24px}.filters-bar{flex-direction:column}.filters-bar .input{max-width:100%}.modal{padding:var(--space-6);margin:var(--space-4)}}
