@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=DM+Sans:wght@300;400;500;600;700&display=swap);:root{--bg:#f7f5f0;--surface:#fff;--primary:#5b8a75;--primary-dk:#3d6b57;--primary-lt:#eaf2ee;--accent:#c17b5c;--accent-lt:#f5ebe5;--gold:#c9a84c;--gold-lt:#fbf5e6;--text:#1c1c1e;--text2:#4a4a4f;--text3:#8e8e93;--border:#e5e0d8;--error:#d94f3d;--error-lt:#fdecea;--success:#5b8a75;--radius:12px;--radius-sm:8px;--shadow:0 2px 12px #00000014;--shadow-lg:0 8px 32px #0000001f}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;background:#f7f5f0;background:var(--bg);color:#1c1c1e;color:var(--text);font-family:DM Sans,sans-serif;line-height:1.6;min-height:100vh}h1,h2,h3,h4{font-family:Playfair Display,serif;font-weight:700;line-height:1.3}a{color:#5b8a75;color:var(--primary);text-decoration:none}a:hover{color:#3d6b57;color:var(--primary-dk)}button{cursor:pointer;font-family:inherit}.container{margin:0 auto;max-width:1200px;padding:0 24px}.page{min-height:100vh;padding:32px 0}.card{background:#fff;background:var(--surface);border:1px solid #e5e0d8;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 12px #00000014;box-shadow:var(--shadow);padding:24px}.card-header{border-bottom:1px solid #e5e0d8;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.btn,.card-header{align-items:center}.btn{border:none;border-radius:8px;border-radius:var(--radius-sm);display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .15s ease;white-space:nowrap}.btn-primary{background:#5b8a75;background:var(--primary);color:#fff}.btn-primary:hover{background:#3d6b57;background:var(--primary-dk)}.btn-secondary{background:#eaf2ee;background:var(--primary-lt);color:#5b8a75;color:var(--primary)}.btn-secondary:hover{background:#d4e8df}.btn-accent{background:#c17b5c;background:var(--accent);color:#fff}.btn-accent:hover{background:#a85e3f}.btn-ghost{background:#0000;border:1px solid #e5e0d8;border:1px solid var(--border);color:#4a4a4f;color:var(--text2)}.btn-ghost:hover{background:#f7f5f0;background:var(--bg)}.btn-danger{background:#fdecea;background:var(--error-lt);border:1px solid #f5c2bc;color:#d94f3d;color:var(--error)}.btn-danger:hover{background:#f5c2bc}.btn-lg{border-radius:12px;border-radius:var(--radius);font-size:16px;padding:14px 28px}.btn-sm{font-size:13px;padding:6px 14px}.btn:disabled{cursor:not-allowed;opacity:.5}.form-group{margin-bottom:16px}.form-label{color:#4a4a4f;color:var(--text2);display:block;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.form-input,.form-select,.form-textarea{background:#fff;background:var(--surface);border:1.5px solid #e5e0d8;border:1.5px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#1c1c1e;color:var(--text);font-family:inherit;font-size:15px;outline:none;padding:10px 14px;transition:border-color .15s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#5b8a75;border-color:var(--primary);box-shadow:0 0 0 3px #eaf2ee;box-shadow:0 0 0 3px var(--primary-lt)}.form-input.error,.form-select.error{border-color:#d94f3d;border-color:var(--error)}.form-error{color:#d94f3d;color:var(--error);font-size:12px;margin-top:4px}.form-textarea{min-height:80px;resize:vertical}.table-wrap{overflow-x:auto}table{border-collapse:collapse;font-size:14px;width:100%}th{background:#f7f5f0;background:var(--bg);color:#8e8e93;color:var(--text3);font-size:11px;font-weight:700;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase}td,th{border-bottom:1px solid #e5e0d8;border-bottom:1px solid var(--border)}td{color:#1c1c1e;color:var(--text);padding:12px 14px}tr:hover td{background:#f7f5f0;background:var(--bg)}tr:last-child td{border-bottom:none}.badge{align-items:center;border-radius:100px;display:inline-flex;font-size:12px;font-weight:600;padding:3px 10px}.badge-green{background:#eaf2ee;background:var(--primary-lt);color:#3d6b57;color:var(--primary-dk)}.badge-orange{background:#fef3e8;color:#b8650c}.badge-red{background:#fdecea;background:var(--error-lt);color:#d94f3d;color:var(--error)}.badge-blue{background:#e8f0fe;color:#1a56db}.badge-gray{background:#f0efed;color:#8e8e93;color:var(--text3)}.badge-gold{background:#fbf5e6;background:var(--gold-lt);color:#8b6a1c}.alert{border-radius:8px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px;padding:12px 16px}.alert-error{background:#fdecea;background:var(--error-lt);border:1px solid #f5c2bc;color:#d94f3d;color:var(--error)}.alert-success{background:#eaf2ee;background:var(--primary-lt);border:1px solid #c8dfd5;color:#3d6b57;color:var(--primary-dk)}.alert-warning{background:#fef3e8;border:1px solid #fddcaa;color:#b8650c}.quiz-option{background:#fff;background:var(--surface);border:2px solid #e5e0d8;border:2px solid var(--border);border-radius:12px;border-radius:var(--radius);color:#1c1c1e;color:var(--text);cursor:pointer;font-size:16px;font-weight:500;padding:16px 20px;text-align:left;transition:all .15s;width:100%}.quiz-option.correct,.quiz-option.selected,.quiz-option:hover:not(:disabled){background:#eaf2ee;background:var(--primary-lt);border-color:#5b8a75;border-color:var(--primary)}.quiz-option.wrong{background:#fdecea;background:var(--error-lt);border-color:#d94f3d;border-color:var(--error)}.quiz-option:disabled{cursor:default}.timer-bar{background:#e5e0d8;background:var(--border);border-radius:3px;height:6px;overflow:hidden}.timer-fill{background:#5b8a75;background:var(--primary);border-radius:3px;height:100%;transition:width 1s linear}.timer-fill.warning{background:#c17b5c;background:var(--accent)}.timer-fill.danger{background:#d94f3d;background:var(--error)}.score-big{color:#5b8a75;color:var(--primary);font-family:Playfair Display,serif;font-size:48px;font-weight:700}.leaderboard-item{border-bottom:1px solid #e5e0d8;border-bottom:1px solid var(--border);gap:12px;padding:10px 0}.leaderboard-item,.rank-number{align-items:center;display:flex}.rank-number{background:#f7f5f0;background:var(--bg);border-radius:50%;color:#4a4a4f;color:var(--text2);flex-shrink:0;font-size:13px;font-weight:700;height:28px;justify-content:center;width:28px}.rank-number.rank-1{background:#fbf5e6;background:var(--gold-lt);color:#c9a84c;color:var(--gold)}.rank-number.rank-2{background:#f0efed;color:#666}.rank-number.rank-3{background:#f5ebe5;background:var(--accent-lt);color:#c17b5c;color:var(--accent)}.mobile-top-bar{display:none}.mobile-menu-btn{align-items:center;background:none;border:none;border-radius:8px;color:#1c1c1e;color:var(--text);cursor:pointer;display:flex;padding:8px}.mobile-menu-btn:hover{background:#f7f5f0;background:var(--bg)}.mobile-logo{color:#3d6b57;color:var(--primary-dk);font-family:Playfair Display,serif;font-size:20px;font-weight:700;letter-spacing:-.5px}.sidebar-overlay{display:none}.sidebar{background:#fff;background:var(--surface);border-right:1px solid #e5e0d8;border-right:1px solid var(--border);box-shadow:2px 0 12px #0000000a;display:flex;flex-direction:column;left:0;min-height:100vh;position:fixed;top:0;transition:transform .25s ease;width:256px;z-index:100}.sidebar-logo{border-bottom:1px solid #e5e0d8;border-bottom:1px solid var(--border);padding:20px 20px 16px}.sidebar-logo h2{color:#3d6b57;color:var(--primary-dk);font-family:Playfair Display,serif;font-size:18px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logo p{color:#8e8e93;color:var(--text3);font-size:11px;margin-top:2px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:8px 0}.nav-item{align-items:center;border-radius:8px;border-radius:var(--radius-sm);color:#4a4a4f;color:var(--text2);display:flex;font-size:14px;font-weight:500;gap:11px;margin:2px 8px;padding:10px 16px;transition:all .15s}.nav-item svg{flex-shrink:0}.nav-item:hover{background:#f7f5f0;background:var(--bg);color:#1c1c1e;color:var(--text)}.nav-item.active{background:#eaf2ee;background:var(--primary-lt);color:#5b8a75;color:var(--primary);font-weight:600}.sidebar-footer{border-top:1px solid #e5e0d8;border-top:1px solid var(--border);padding:12px}.main-content{box-sizing:border-box;margin-left:256px;min-height:100vh;overflow-x:hidden;padding:32px 36px;width:calc(100% - 256px)}.page-header{margin-bottom:28px}.page-header h1{color:#1c1c1e;color:var(--text);font-size:26px}.page-header p{color:#8e8e93;color:var(--text3);font-size:14px;margin-top:4px}.stat-card{background:#fff;background:var(--surface);border:1px solid #e5e0d8;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);padding:20px}.stat-value{color:#1c1c1e;color:var(--text);font-family:Playfair Display,serif;font-size:32px;font-weight:700}.stat-label{color:#8e8e93;color:var(--text3);font-size:13px;font-weight:500;margin-top:4px}.grid-2{grid-gap:20px;grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{display:grid;gap:20px}.grid-3{grid-gap:20px;grid-template-columns:repeat(3,1fr)}.grid-4{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr)}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.main-content{padding:24px}}@media (max-width:640px){.mobile-top-bar{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e5e0d8;border-bottom:1px solid var(--border);box-shadow:0 2px 8px #0000000f;display:flex;height:56px;justify-content:space-between;left:0;padding:0 16px;position:fixed;right:0;top:0;z-index:98}.sidebar-overlay{background:#00000073;display:block;inset:0;position:fixed;z-index:99}.sidebar{min-height:calc(100vh - 56px);top:56px;transform:translateX(-100%);z-index:100}.sidebar.sidebar-open{transform:translateX(0)}.main-content{margin-left:0;padding:72px 16px 16px;width:100%}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.card{padding:16px}.page-header{flex-wrap:wrap;gap:10px}.modal{border-radius:12px 12px 0 0;padding:20px}.modal-overlay{align-items:flex-end;padding:0}}.spinner{animation:spin .7s linear infinite;border:3px solid #eaf2ee;border-top-color:#5b8a75;border:3px solid var(--primary-lt);border-radius:50%;border-top-color:var(--primary);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.spinner-wrap{padding:48px}.modal-overlay,.spinner-wrap{align-items:center;display:flex;justify-content:center}.modal-overlay{background:#0006;inset:0;padding:20px;position:fixed;z-index:1000}.modal{background:#fff;background:var(--surface);border-radius:12px;border-radius:var(--radius);box-shadow:0 8px 32px #0000001f;box-shadow:var(--shadow-lg);max-height:90vh;max-width:520px;overflow-y:auto;padding:28px;width:100%}.modal-title{color:#1c1c1e;color:var(--text);font-size:20px;font-weight:700;margin-bottom:20px}@keyframes fall{0%{opacity:1;transform:translateY(-20px) rotate(0deg)}to{opacity:0;transform:translateY(100vh) rotate(2turn)}}.projector-mode{align-items:center;background:#0a0a0f;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.flex,.flex-col{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:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-sm{font-size:13px}.text-lg{font-size:18px}.text-muted{color:#8e8e93;color:var(--text3)}.text-center{text-align:center}.font-bold{font-weight:700}.w-full{width:100%}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
/*# sourceMappingURL=main.284c6be0.css.map*/