*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--purple:#6b4c9a;--deep-purple:#533879;--gold:#c9a84c;--deep-gold:#a6892f;--navy:#1b2a4a;--cream:#fffdf5;--pale-purple:#f1ecf7;--pale-gold:#f8f1da;--red:#c0392b;--amber:#d68910;--green:#1e8449;--gray-700:#374151;--gray-500:#6b7280;--gray-300:#d1d5db;--gray-100:#f3f4f6}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1ecf7;background:var(--pale-purple);color:#1b2a4a;color:var(--navy);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}button{background:none;border:none;cursor:pointer;font-family:inherit}button:disabled{cursor:not-allowed;opacity:.6}a{color:#6b4c9a;color:var(--purple);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{color:#533879;color:var(--deep-purple)}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:#fff;border-bottom:3px solid #c9a84c;border-bottom:3px solid var(--gold);box-shadow:0 2px 8px #0000000f;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:14px 24px}.app-header,.app-header .brand{align-items:center;display:flex}.app-header .brand{gap:14px}.app-header .brand .logo-text{color:#6b4c9a;color:var(--purple);font-size:18px;font-weight:700;letter-spacing:.2px}.app-header .brand .divider{background:#c9a84c;background:var(--gold);height:28px;width:1px}.app-header .brand .title{color:#533879;color:var(--deep-purple);font-size:18px;font-weight:700}.app-header .user{align-items:center;color:#374151;color:var(--gray-700);display:flex;font-size:14px;gap:14px}.app-header .user .name{color:#533879;color:var(--deep-purple);font-weight:700}.btn{align-items:center;border-radius:8px;display:inline-flex;font-size:14px;font-weight:700;justify-content:center;padding:10px 18px;transition:transform .1s,box-shadow .15s,background .15s;white-space:nowrap}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn-primary{background:#6b4c9a;background:var(--purple);color:#fff}.btn-primary:hover:not(:disabled){background:#533879;background:var(--deep-purple)}.btn-gold{background:#c9a84c;background:var(--gold);color:#1b2a4a;color:var(--navy)}.btn-gold:hover:not(:disabled){background:#a6892f;background:var(--deep-gold);color:#fff}.btn-outline{background:#0000;border:2px solid #6b4c9a;border:2px solid var(--purple);color:#6b4c9a;color:var(--purple)}.btn-outline:hover:not(:disabled){background:#6b4c9a;background:var(--purple);color:#fff}.btn-ghost{background:#0000;color:#374151;color:var(--gray-700);font-size:13px;padding:8px 14px}.btn-ghost:hover:not(:disabled){color:#6b4c9a;color:var(--purple)}.btn-success{background:#1e8449;background:var(--green);color:#fff}.btn-lg{font-size:16px;padding:14px 28px}.app-main{flex:1 1;margin:0 auto;max-width:1100px;padding:32px 24px;width:100%}.page-title{font-size:28px;margin-bottom:6px}.page-subtitle{color:#6b7280;color:var(--gray-500);font-size:15px;margin-bottom:28px}.status-section{margin-bottom:32px}.status-section h2{align-items:center;display:flex;font-size:18px;gap:8px;margin-bottom:12px}.status-section .count{color:#6b7280;color:var(--gray-500);font-size:14px;font-weight:400}.card-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.card{background:#fff;border-left:5px solid #d1d5db;border-left:5px solid var(--gray-300);border-radius:12px;box-shadow:0 2px 6px #0000000a;display:flex;flex-direction:column;gap:10px;padding:20px}.card.overdue{border-left-color:#c0392b;border-left-color:var(--red)}.card.due-soon{border-left-color:#d68910;border-left-color:var(--amber)}.card.assigned{border-left-color:#6b4c9a;border-left-color:var(--purple)}.card.completed{border-left-color:#1e8449;border-left-color:var(--green)}.card-title{color:#533879;color:var(--deep-purple);font-size:16px;font-weight:700;line-height:1.3}.card-meta{color:#6b7280;color:var(--gray-500);display:flex;flex-wrap:wrap;font-size:13px;gap:6px 12px}.card-meta .due{font-weight:700}.category-badge{background:#f8f1da;background:var(--pale-gold);border:1px solid #c9a84c;border:1px solid var(--gold);color:#a6892f;color:var(--deep-gold);letter-spacing:.4px;padding:2px 8px}.badge,.category-badge{align-self:flex-start;border-radius:999px;display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase}.badge{letter-spacing:.5px;padding:3px 10px}.badge.overdue{background:#fadbd8;color:#c0392b;color:var(--red)}.badge.due-soon{background:#fcf3cf;color:#d68910;color:var(--amber)}.badge.assigned{background:#f1ecf7;background:var(--pale-purple);color:#533879;color:var(--deep-purple)}.badge.completed{background:#d1f2eb;color:#1e8449;color:var(--green)}.card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:8px}.empty-state,.loading-state{background:#fff;border-radius:12px;color:#6b7280;color:var(--gray-500);padding:48px 24px;text-align:center}.empty-state h3{color:#533879;color:var(--deep-purple);font-size:18px;margin-bottom:8px}.quiz-overlay{background:#f1ecf7;background:var(--pale-purple);inset:0;overflow-y:auto;position:fixed;z-index:100}.quiz-container{margin:0 auto;max-width:820px;padding:32px 24px 80px}.quiz-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.quiz-card{background:#fff;border-radius:14px;box-shadow:0 4px 14px #0000000f;padding:32px}.module-content{border:1px solid #f3f4f6;border:1px solid var(--gray-100);border-radius:8px;color:#374151;color:var(--gray-700);font-size:15px;line-height:1.7;margin-bottom:16px;max-height:55vh;overflow-y:auto;padding:16px}.module-content h1,.module-content h2,.module-content h3{margin:16px 0 8px}.module-content p{margin-bottom:12px}.module-content ol,.module-content ul{margin:8px 0 12px 24px}.module-content li{margin-bottom:4px}.module-content::-webkit-scrollbar{width:8px}.module-content::-webkit-scrollbar-track{background:#f1ecf7;background:var(--pale-purple);border-radius:4px}.module-content::-webkit-scrollbar-thumb{background:#6b4c9a;background:var(--purple);border-radius:4px}.scroll-hint{color:#6b7280;color:var(--gray-500);font-size:13px;font-style:italic;margin:8px 0 16px;text-align:center}.progress-bar{background:#f3f4f6;background:var(--gray-100);border-radius:999px;height:8px;margin-bottom:20px;overflow:hidden}.progress-bar-fill{background:#6b4c9a;background:var(--purple);height:100%;transition:width .3s}.question-text{color:#533879;color:var(--deep-purple);font-size:18px;font-weight:700;line-height:1.5;margin-bottom:20px}.option{align-items:center;background:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:10px;color:#374151;color:var(--gray-700);display:flex;font-size:15px;gap:12px;margin-bottom:10px;padding:14px 18px;text-align:left;transition:all .15s;width:100%}.option.selected,.option:hover:not(:disabled){background:#f1ecf7;background:var(--pale-purple);border-color:#6b4c9a;border-color:var(--purple)}.option.selected{color:#533879;color:var(--deep-purple);font-weight:700}.option.correct{background:#e8f8f0;border-color:#1e8449;border-color:var(--green);color:#1e8449;color:var(--green);font-weight:700}.option.incorrect{background:#fdecea;border-color:#c0392b;border-color:var(--red);color:#c0392b;color:var(--red)}.option-mark{align-items:center;background:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:50%;display:inline-flex;flex-shrink:0;height:22px;justify-content:center;width:22px}.option-mark.checkbox{border-radius:4px}.option.selected .option-mark{background:#6b4c9a;background:var(--purple);border-color:#6b4c9a;border-color:var(--purple);color:#fff}.tf-row{display:flex;gap:12px;margin-bottom:10px}.tf-button{background:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:10px;color:#374151;color:var(--gray-700);flex:1 1;font-size:16px;font-weight:700;padding:18px;transition:all .15s}.tf-button:hover:not(:disabled){background:#f1ecf7;background:var(--pale-purple);border-color:#6b4c9a;border-color:var(--purple)}.tf-button.selected{background:#6b4c9a;background:var(--purple);border-color:#6b4c9a;border-color:var(--purple);color:#fff}.quiz-footer{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-top:24px}.score-icon{font-size:64px;margin-bottom:16px;text-align:center}.score-pass{color:#1e8449;color:var(--green)}.score-fail{color:#c0392b;color:var(--red)}.score-percent{font-size:48px;font-weight:700;margin-bottom:8px;text-align:center}.score-detail{color:#6b7280;color:var(--gray-500);margin-bottom:24px;text-align:center}.cert-id{background:#f8f1da;background:var(--pale-gold);border:1px solid #c9a84c;border:1px solid var(--gold);border-radius:8px;color:#1b2a4a;color:var(--navy);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:14px;font-weight:700;margin:16px 0 24px;padding:12px 18px;text-align:center}.review-block{border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:10px;margin-bottom:14px;padding:16px}.review-block .q{color:#533879;color:var(--deep-purple);font-weight:700;margin-bottom:8px}.review-block .explanation{background:#f1ecf7;background:var(--pale-purple);border-radius:6px;color:#374151;color:var(--gray-700);font-size:14px;margin-top:10px;padding:10px}.login-redirect{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh;padding:24px;text-align:center}@media (max-width:600px){.app-header{padding:12px 16px}.app-header .brand .logo-text,.app-header .brand .title{font-size:15px}.app-main{padding:20px 16px}.quiz-container{padding:16px 12px 60px}.quiz-card{padding:20px}.tf-row{flex-direction:column}}
/*# sourceMappingURL=main.2871c6dc.css.map*/