.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:380px}.toast{padding:.75rem 1.25rem;border-radius:6px;color:#fff;font-size:.9rem;box-shadow:0 4px 12px #0003;animation:toast-slide-in .3s ease}.toast-success{background:var(--success-color, #28a745)}.toast-error{background:var(--danger-color, #dc3545)}.toast-info{background:var(--primary-color, #007bff)}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notification-bell-container{position:relative;display:inline-block}.notification-bell-button{position:relative;background:none;border:none;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background-color .2s}.notification-bell-button:hover{background-color:#0000000d}.bell-icon{color:#495057;width:24px;height:24px}.notification-badge{position:absolute;top:2px;right:2px;background-color:#dc3545;color:#fff;border-radius:10px;padding:.125rem .375rem;font-size:.75rem;font-weight:600;line-height:1;min-width:18px;text-align:center}.notification-dropdown{position:absolute;top:calc(100% + .5rem);right:0;width:380px;max-width:90vw;background-color:#fff;border:1px solid #dee2e6;border-radius:.5rem;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:500px;display:flex;flex-direction:column}.notification-dropdown-header{padding:1rem;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;align-items:center}.notification-dropdown-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#212529}.mark-all-read-button{background:none;border:none;color:#007bff;font-size:.875rem;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;transition:background-color .2s}.mark-all-read-button:hover:not(:disabled){background-color:#007bff1a}.mark-all-read-button:disabled{opacity:.5;cursor:not-allowed}.notification-list{overflow-y:auto;max-height:350px}.notification-item{padding:.75rem 1rem;border-bottom:1px solid #f1f3f5;cursor:pointer;transition:background-color .2s}.notification-item:hover{background-color:#f8f9fa}.notification-item:last-child{border-bottom:none}.notification-item.unread{background-color:#f0f7ff}.notification-item.unread:hover{background-color:#e7f3ff}.notification-content{display:flex;flex-direction:column;gap:.25rem}.notification-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.notification-title{margin:0;font-size:.9375rem;font-weight:600;color:#212529;flex:1;line-height:1.3}.unread-indicator{flex-shrink:0;width:8px;height:8px;background-color:#007bff;border-radius:50%;margin-top:.25rem}.notification-message{margin:0;font-size:.875rem;color:#6c757d;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.notification-time{font-size:.75rem;color:#adb5bd}.notification-empty{padding:2rem;text-align:center;color:#6c757d}.notification-empty p{margin:0}.notification-dropdown-footer{padding:.75rem;border-top:1px solid #dee2e6}.view-all-button{width:100%;padding:.5rem;background-color:#f8f9fa;border:none;border-radius:.25rem;color:#007bff;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.view-all-button:hover{background-color:#e9ecef}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f1f3f5}.notification-list::-webkit-scrollbar-thumb{background:#ced4da;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#adb5bd}@media(max-width:480px){.notification-dropdown{width:320px;max-width:calc(100vw - 2rem)}.notification-dropdown-header h3{font-size:1rem}.mark-all-read-button{font-size:.8125rem}.notification-title{font-size:.875rem}.notification-message{font-size:.8125rem}}.notification-item:focus{outline:2px solid #007bff;outline-offset:-2px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-dropdown{animation:slideDown .2s ease-out}.navbar{background-color:#242424f2;border-bottom:1px solid rgba(255,255,255,.1);padding:0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navbar-container{max-width:1400px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.navbar-brand{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none;transition:color .2s}.navbar-brand:hover{color:#667eea}.navbar-toggle{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.25rem}.navbar-menu{display:flex;align-items:center;gap:1.5rem}.navbar-user-info{display:flex;align-items:center;gap:.5rem;color:#fff;padding:.5rem 1rem;background-color:#667eea4d;border-radius:8px;border:1px solid rgba(102,126,234,.4)}.navbar-user-info .provider-icon{font-size:.85em;color:#fff;display:flex;align-items:center}.user-icon{font-size:1rem;color:#667eea}.navbar-user-info .user-name{font-size:.95rem;font-weight:500;color:#fff}.navbar-guest{color:#ffffffb3;font-size:.95rem}.navbar-link{color:#fff;text-decoration:none;font-size:.95rem;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:background-color .2s,color .2s}.navbar-link:hover{background-color:#ffffff1a;color:#667eea}.navbar-admin-link{display:flex;align-items:center;gap:.5rem;background-color:#e74c3c33;border:1px solid rgba(231,76,60,.3)}.navbar-admin-link:hover{background-color:#e74c3c4d;color:#fff}.navbar-admin-link-content{display:flex;align-items:center;gap:.5rem;position:relative}.admin-icon{font-size:.9rem}.admin-actions-badge{background-color:#dc3545;color:#fff;border-radius:10px;padding:.125rem .375rem;font-size:.75rem;font-weight:600;line-height:1;min-width:18px;text-align:center;margin-left:.25rem}.navbar-button{padding:.5rem 1.25rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.navbar-login{background-color:#667eea;color:#fff}.navbar-login:hover{background-color:#5568d3;transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.navbar-logout{background-color:#e74c3ce6;color:#fff}.navbar-logout:hover{background-color:#c0392b}@media(max-width:768px){.navbar-toggle{display:block}.navbar-menu{position:fixed;top:60px;left:0;right:0;background-color:#242424fa;flex-direction:column;gap:0;padding:1rem 0;border-top:1px solid rgba(255,255,255,.1);transform:translate(-100%);transition:transform .3s ease;max-height:calc(100vh - 60px);overflow-y:auto}.navbar-menu.active{transform:translate(0)}@media(prefers-reduced-motion:reduce){.navbar-menu{transition:none}}.navbar-user-info{margin:0 1rem;justify-content:center}.navbar-guest{padding:.75rem 1rem;text-align:center}.navbar-link{width:100%;padding:.75rem 1.5rem;border-radius:0;text-align:left}.navbar-link:hover{background-color:#ffffff0d}.navbar-admin-link{border-left:none;border-right:none;border-radius:0}.navbar-button{width:calc(100% - 2rem);margin:.5rem 1rem;padding:.75rem}}@media(max-width:480px){.navbar-container{padding:.75rem 1rem}.navbar-brand{font-size:1.25rem}.user-name{font-size:.875rem}}.app-footer{width:100%;border-top:1px solid var(--border-color);background-color:var(--bg-secondary);padding:1rem 2rem;margin-top:auto}.footer-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.footer-copyright{color:var(--text-tertiary);font-size:.85rem}.footer-links{display:flex;align-items:center;gap:.5rem}.footer-links a{color:var(--text-tertiary);text-decoration:none;font-size:.85rem;transition:color .2s ease}.footer-links a:hover{color:var(--accent-primary);text-decoration:underline}.footer-separator{color:var(--text-tertiary);font-size:.85rem;-webkit-user-select:none;user-select:none}.footer-update-time{font-size:.75rem;opacity:.8}@media(max-width:480px){.footer-content{flex-direction:column;text-align:center}}.maintenance-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;padding:10px 16px;font-size:14px;box-shadow:0 2px 8px #00000026;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.maintenance-banner-content{display:flex;align-items:center;justify-content:center;gap:8px;max-width:960px;margin:0 auto}.maintenance-banner-icon{flex-shrink:0}.maintenance-banner-text{flex:1;text-align:center}.maintenance-banner-dismiss{flex-shrink:0;background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;line-height:1;opacity:.8;transition:opacity .15s}.maintenance-banner-dismiss:hover{opacity:1;background:#ffffff26}.bid-button{display:inline-flex;align-items:center;justify-content:center;position:relative;min-width:44px;min-height:32px;padding:3px 6px;font-family:inherit;font-size:13px;font-weight:500;line-height:1.2;border:1px solid #d1d5db;border-radius:4px;background-color:#fff;cursor:pointer;transition:all .15s ease-in-out;outline:none}.bid-button:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:44px;min-height:44px}.bid-button:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.bid-button:hover:not(.disabled){background-color:#f3f4f6;border-color:#9ca3af}.bid-button.suit-black{color:#1f2937}.bid-button.suit-red{color:#dc2626}.bid-button.special-bid{color:#374151;font-weight:600}.bid-button.selected{border:2px solid #2563eb;background-color:#dbeafe}.bid-button.selected:hover:not(.disabled){background-color:#bfdbfe}.bid-button.disabled{opacity:.4;filter:grayscale(100%);cursor:not-allowed;background-color:#f9fafb}.bid-button.disabled:hover{background-color:#f9fafb;border-color:#d1d5db}.bid-button.selected.disabled{border:2px solid #2563eb;background-color:#dbeafe;opacity:.6}@media(prefers-contrast:high){.bid-button{border-width:2px}.bid-button.disabled{opacity:.5;border-style:dashed}}@media(prefers-reduced-motion:reduce){.bid-button{transition:none}}.bid-table{display:flex;flex-direction:column;width:100%;max-width:300px;margin:0 auto .75rem;padding:6px;background-color:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.bid-table.loading{position:relative}.bid-table.loading .bid-grid{opacity:.5;pointer-events:none}.bid-table-loading{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;margin-bottom:6px;background-color:#eff6ff;border-radius:4px;color:#1d4ed8;font-size:13px}.loading-spinner{width:16px;height:16px;border:2px solid #93c5fd;border-top-color:#2563eb;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.bid-table-message{display:flex;align-items:center;justify-content:center;padding:8px;margin-bottom:6px;background-color:#fef3c7;border-radius:4px;color:#92400e;font-size:13px;font-weight:500}.bid-table.disabled .bid-grid{opacity:.7}.bid-table.auction-complete .bid-grid{opacity:.5}.bid-grid{display:flex;flex-direction:column;gap:2px}.bid-level-row{display:grid;grid-template-columns:repeat(5,1fr);gap:2px}.bid-special-row{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:3px;padding-top:3px;border-top:1px solid #e5e7eb}@media(min-width:400px){.bid-table{max-width:340px;padding:10px}.bid-level-row,.bid-special-row,.bid-grid{gap:3px}}@media(prefers-contrast:high){.bid-table{border-width:2px;border-color:#000}.bid-table-loading{border:2px solid #1d4ed8}.bid-table-message{border:2px solid #92400e}}@media(prefers-reduced-motion:reduce){.loading-spinner{animation:none;border-color:#2563eb}}@media(prefers-color-scheme:dark){.bid-table{background-color:#1f2937;border-color:#374151}.bid-special-row{border-top-color:#374151}.bid-table-loading{background-color:#1e3a5f;color:#93c5fd}.bid-table-message{background-color:#451a03;color:#fcd34d}}.feedback-form-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.feedback-form-modal{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.feedback-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.feedback-form-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#111827}.feedback-form-close{background:none;border:none;font-size:2rem;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.feedback-form-close:hover{background-color:#f3f4f6;color:#111827}.feedback-form-content{padding:1.5rem}.feedback-form-success{padding:3rem 1.5rem;text-align:center}.success-icon{font-size:4rem;color:#10b981;margin-bottom:1rem}.feedback-form-success p{font-size:1.125rem;color:#374151;margin:0}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem}.required{color:#ef4444}.form-group select,.form-group textarea{width:100%;padding:.625rem;border:1px solid #d1d5db;border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group select.error,.form-group textarea.error{border-color:#ef4444}.form-group textarea{resize:vertical;min-height:120px}.feedback-form-meta{display:flex;justify-content:flex-end;margin-top:.25rem}.character-count{font-size:.875rem;color:#6b7280}.error-message{display:block;color:#ef4444;font-size:.875rem;margin-top:.25rem}.feedback-form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid #e5e7eb}.btn{padding:.625rem 1.25rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s;border:none}.btn-secondary{background-color:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.btn-primary:hover:not(:disabled){background-color:#2563eb}@media(max-width:640px){.feedback-form-modal{width:95%;max-height:95vh}.feedback-form-header,.feedback-form-content{padding:1rem}.feedback-form-header h2{font-size:1.25rem}}.feedback-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;color:#6b7280;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.feedback-button:hover{background-color:#e5e7eb;color:#374151;border-color:#9ca3af}.feedback-button:active{transform:translateY(1px)}.feedback-icon{width:1rem;height:1rem}.feedback-button-text{line-height:1}@media(max-width:640px){.feedback-button{padding:.375rem .625rem;font-size:.8125rem}.feedback-icon{width:.875rem;height:.875rem}}.multi-select-filter{position:relative;display:inline-block}.multi-select-trigger{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.3);background:#ffffff26;color:#fff;font-size:.85rem;cursor:pointer;min-width:140px;transition:all .2s ease}.multi-select-trigger:hover:not(:disabled){background:#ffffff40;border-color:#ffffff80}.multi-select-trigger:focus{outline:none;border-color:#fff9;background:#ffffff40}.multi-select-trigger:disabled{opacity:.6;cursor:not-allowed}.multi-select-label{font-weight:500}.multi-select-count{flex:1;text-align:left;opacity:.9}.multi-select-arrow{font-size:.7rem;opacity:.8}.multi-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:240px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--card-shadow);z-index:1000;max-height:320px;overflow:hidden;display:flex;flex-direction:column}.multi-select-actions{display:flex;gap:.5rem;padding:.75rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.multi-select-action-btn{flex:1;padding:.4rem .75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.multi-select-action-btn:hover:not(:disabled){background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.multi-select-action-btn:disabled{opacity:.5;cursor:not-allowed}.multi-select-options{padding:.5rem;overflow-y:auto;max-height:240px}.multi-select-option{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;border-radius:4px;transition:background .15s ease}.multi-select-option:hover{background:var(--bg-secondary)}.multi-select-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;margin:0}.multi-select-option-label{flex:1;color:var(--text-primary);font-size:.9rem;-webkit-user-select:none;user-select:none;text-align:left}@media(max-width:768px){.multi-select-dropdown{min-width:280px;max-width:calc(100vw - 2rem)}.multi-select-trigger{width:100%}}.difficulty-multi-select{position:relative;display:inline-block}.difficulty-multi-select-trigger{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.3);background:#ffffff26;color:#fff;font-size:.85rem;cursor:pointer;min-width:140px;transition:all .2s ease}.difficulty-multi-select-trigger:hover:not(:disabled){background:#ffffff40;border-color:#ffffff80}.difficulty-multi-select-trigger:focus{outline:none;border-color:#fff9;background:#ffffff40}.difficulty-multi-select-trigger:disabled{opacity:.6;cursor:not-allowed}.difficulty-multi-select-label{font-weight:500}.difficulty-multi-select-count{flex:1;text-align:left;opacity:.9}.difficulty-multi-select-arrow{font-size:.7rem;opacity:.8}.difficulty-multi-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:200px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--card-shadow);z-index:1000;overflow:hidden}.difficulty-multi-select-actions{display:flex;gap:.5rem;padding:.75rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.difficulty-multi-select-action-btn{flex:1;padding:.4rem .75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.difficulty-multi-select-action-btn:hover:not(:disabled){background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.difficulty-multi-select-action-btn:disabled{opacity:.5;cursor:not-allowed}.difficulty-multi-select-options{padding:.5rem}.difficulty-multi-select-option{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;border-radius:4px;transition:background .15s ease}.difficulty-multi-select-option:hover{background:var(--bg-secondary)}.difficulty-multi-select-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;margin:0}.difficulty-multi-select-option-label{flex:1;color:var(--text-primary);font-size:.9rem;-webkit-user-select:none;user-select:none;text-align:left}@media(max-width:768px){.difficulty-multi-select-dropdown{min-width:240px;max-width:calc(100vw - 2rem)}.difficulty-multi-select-trigger{width:100%}}.quiz-header-minimal{display:flex;align-items:center;justify-content:space-between;gap:1rem}.quiz-header-minimal h1{flex:1;text-align:left;margin:0;font-size:1.25rem}.question-count{font-size:.85rem;white-space:nowrap;opacity:.95}.header-toggle{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.header-toggle:hover{background:#ffffff4d;border-color:#ffffff80}.header-toggle:focus{outline:2px solid white;outline-offset:2px}.toggle-icon{font-size:.75rem}.quiz-header-content{margin-top:.75rem;max-height:1000px;overflow:visible;transition:max-height .3s ease,opacity .3s ease,margin-top .3s ease;opacity:1}.quiz-header.collapsed .quiz-header-content{max-height:0;opacity:0;margin-top:0;visibility:hidden;overflow:hidden}@media(prefers-reduced-motion:reduce){.quiz-header,.quiz-header-content,.header-toggle{transition:none}}@media(min-width:769px){.quiz-header-minimal{display:none}.quiz-header-content{margin-top:0;max-height:none;opacity:1;visibility:visible}.quiz-header.collapsed .quiz-header-content{max-height:none;opacity:1;margin-top:0;visibility:visible;overflow:visible}.quiz-header h1{display:block;text-align:center;margin-bottom:.5rem;font-size:1.5rem}}@media(max-width:768px){.quiz-header{padding:.75rem}.quiz-header-content h1{display:none}}.markdown-tooltip{position:relative;display:inline-flex;align-items:center}.markdown-tooltip__trigger{display:inline-flex;align-items:center;gap:.25rem;background:none;border:none;padding:.25rem .5rem;font-size:.75rem;color:var(--color-text-muted, #6c757d);cursor:pointer;border-radius:4px;transition:color .2s,background-color .2s}.markdown-tooltip__trigger:hover,.markdown-tooltip__trigger:focus-visible{color:var(--color-primary, #4a90d9);background:var(--color-primary-alpha, rgba(74, 144, 217, .1));outline:none}.markdown-tooltip__trigger svg{flex-shrink:0}.markdown-tooltip__popup{position:absolute;top:calc(100% + .5rem);right:0;z-index:1000;width:320px;background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #dee2e6);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:1rem;animation:markdown-tooltip-fade-in .2s ease-out}@keyframes markdown-tooltip-fade-in{0%{opacity:0;transform:translateY(-.5rem)}to{opacity:1;transform:translateY(0)}}.markdown-tooltip__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border, #dee2e6)}.markdown-tooltip__header h3{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text, #212529)}.markdown-tooltip__close{background:none;border:none;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;color:var(--color-text-muted, #6c757d);cursor:pointer;border-radius:4px;transition:color .2s,background-color .2s}.markdown-tooltip__close:hover,.markdown-tooltip__close:focus-visible{color:var(--color-text, #212529);background:var(--color-surface, #f8f9fa);outline:none}.markdown-tooltip__content{display:flex;flex-direction:column;gap:.75rem}.markdown-tooltip__section h4{margin:0 0 .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted, #6c757d)}.markdown-tooltip__list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.375rem}.markdown-tooltip__list li{font-size:.8125rem;color:var(--color-text-secondary, #495057);line-height:1.4;display:flex;align-items:center;gap:.5rem}.markdown-tooltip__list code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.75rem;background:var(--color-surface, #f8f9fa);padding:.125rem .375rem;border-radius:3px;color:var(--color-text, #212529);border:1px solid var(--color-border, #dee2e6);white-space:nowrap}.markdown-tooltip__list strong,.markdown-tooltip__list em{font-style:normal;font-weight:600}.markdown-tooltip__list em{font-style:italic;font-weight:400}.markdown-tooltip__footer{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border, #dee2e6)}.markdown-tooltip__link{display:inline-flex;align-items:center;font-size:.8125rem;font-weight:500;color:var(--color-primary, #4a90d9);text-decoration:none;transition:color .2s}.markdown-tooltip__link:hover,.markdown-tooltip__link:focus-visible{color:var(--color-primary-dark, #3a7bc8);text-decoration:underline}@media(max-width:640px){.markdown-tooltip__popup{position:fixed;top:auto;right:1rem;left:1rem;bottom:1rem;width:auto}}.markdown-tooltip__trigger:focus-visible,.markdown-tooltip__close:focus-visible,.markdown-tooltip__link:focus-visible{outline:2px solid var(--color-primary, #4a90d9);outline-offset:2px}@media(prefers-color-scheme:dark){.markdown-tooltip__popup{background:var(--color-surface-dark, #2d2d2d);border-color:var(--color-border-dark, #444);box-shadow:0 4px 12px #0000004d}}.comment-form{display:flex;flex-direction:column;gap:.5rem}.comment-form__toolbar{display:flex;align-items:center;gap:.25rem;padding:.25rem;background:var(--color-surface, #f8f9fa);border:1px solid var(--color-border, #dee2e6);border-bottom:none;border-radius:6px 6px 0 0}.comment-form__toolbar-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--color-text-muted, #6c757d);cursor:pointer;border-radius:4px;transition:color .2s,background-color .2s}.comment-form__toolbar-btn:hover:not(:disabled){color:var(--color-primary, #4a90d9);background:var(--color-primary-alpha, rgba(74, 144, 217, .1))}.comment-form__toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.comment-form__hint{margin-left:auto;font-size:.75rem;color:var(--color-text-muted, #6c757d)}.comment-form__toolbar .markdown-tooltip{margin-left:auto}.comment-form__guidelines{display:flex;flex-wrap:wrap;gap:.3rem;font-size:.8rem;color:var(--color-text-muted, #6c757d);margin:0 .35rem}.comment-form__guidelines a{color:var(--color-primary, #4a90d9);text-decoration:underline;font-weight:500}.comment-form__guidelines a:hover,.comment-form__guidelines a:focus-visible{color:var(--color-primary-dark, #3a7bc8)}.comment-form__textarea{width:100%;min-height:120px;padding:.75rem;border:1px solid var(--color-border, #dee2e6);border-radius:0 0 6px 6px;font-family:inherit;font-size:1rem;line-height:1.5;resize:vertical;transition:border-color .2s,box-shadow .2s}.comment-form__textarea:focus{outline:none;border-color:var(--color-primary, #4a90d9);box-shadow:0 0 0 3px var(--color-primary-alpha, rgba(74, 144, 217, .2))}.comment-form__textarea--error{border-color:var(--color-danger, #dc3545)}.comment-form__textarea--error:focus{border-color:var(--color-danger, #dc3545);box-shadow:0 0 0 3px var(--color-danger-alpha, rgba(220, 53, 69, .2))}.comment-form__textarea:disabled{background:var(--color-surface-disabled, #e9ecef);cursor:not-allowed}.comment-form__textarea::placeholder{color:var(--color-text-muted, #6c757d)}.comment-form__footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.comment-form__status{display:flex;align-items:center;gap:.75rem}.comment-form__error{font-size:.875rem;color:var(--color-danger, #dc3545)}.comment-form__counter{font-size:.75rem;color:var(--color-text-muted, #6c757d)}.comment-form__counter--warning{color:var(--color-warning-text, #856404)}.comment-form__counter--error{color:var(--color-danger, #dc3545);font-weight:600}.comment-form__actions{display:flex;gap:.5rem}.comment-form__btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s}.comment-form__btn--primary{background:var(--color-primary, #4a90d9);color:#fff}.comment-form__btn--primary:hover:not(:disabled){background:var(--color-primary-dark, #3a7bc8)}.comment-form__btn--secondary{background:var(--color-surface, #e9ecef);color:var(--color-text, #212529)}.comment-form__btn--secondary:hover:not(:disabled){background:var(--color-surface-hover, #dee2e6)}.comment-form__btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.comment-form__footer{flex-direction:column;align-items:stretch}.comment-form__status{justify-content:space-between}.comment-form__actions{justify-content:flex-end}}.voting-buttons{display:inline-flex;align-items:center;gap:.5rem}.voting-buttons__btn{width:32px;height:32px;border-radius:999px;border:1px solid var(--color-border, #dee2e6);background:var(--color-surface, #fff);color:var(--color-text-muted, #6c757d);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s ease,background-color .2s ease,border-color .2s ease;font-size:.875rem}.voting-buttons__btn--up.is-active{background:var(--color-primary, #4a90d9);border-color:var(--color-primary, #4a90d9);color:#fff}.voting-buttons__btn--down.is-active{background:var(--color-secondary, #6c757d);border-color:var(--color-secondary, #6c757d);color:#fff}.voting-buttons__btn:hover:not(:disabled){border-color:var(--color-primary, #4a90d9);color:var(--color-primary, #4a90d9)}.voting-buttons__btn:disabled{opacity:.5;cursor:not-allowed}.voting-buttons__btn.is-loading{opacity:.5}.voting-buttons__score{min-width:2rem;text-align:center;font-weight:600;color:var(--color-text, #212529)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.reaction-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.reaction-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background-color:var(--surface-light, #f5f5f5);border:1px solid var(--border-color, #ddd);border-radius:1rem;font-size:.875rem;cursor:pointer;transition:all .2s ease;color:var(--text-primary, #333)}.reaction-badge:hover:not(:disabled){background-color:var(--surface-hover, #e8e8e8);border-color:var(--primary-color, #007bff);transform:scale(1.05)}.reaction-badge:focus-visible{outline:2px solid var(--primary-color, #007bff);outline-offset:2px}@media(prefers-reduced-motion:reduce){.reaction-badge:hover:not(:disabled){transform:none}}.reaction-badge:disabled{cursor:not-allowed;opacity:.6}.reaction-badge.user-reacted{background-color:var(--primary-light, #e3f2fd);border-color:var(--primary-color, #007bff);font-weight:500}.reaction-emoji{font-size:1rem;line-height:1}.reaction-count{font-size:.75rem;font-weight:500;color:var(--text-secondary, #666)}.reaction-badge.user-reacted .reaction-count{color:var(--primary-color, #007bff)}@media(prefers-color-scheme:dark){.reaction-badge{background-color:var(--surface-dark, #2a2a2a);border-color:var(--border-dark, #444);color:var(--text-light, #e0e0e0)}.reaction-badge:hover:not(:disabled){background-color:var(--surface-hover-dark, #3a3a3a)}.reaction-badge.user-reacted{background-color:var(--primary-dark, #1a4d7a);border-color:var(--primary-light, #4a9eff)}.reaction-count{color:var(--text-secondary-light, #aaa)}.reaction-badge.user-reacted .reaction-count{color:var(--primary-light, #4a9eff)}}.reaction-picker{position:relative;display:inline-block}.reaction-picker-button{display:inline-flex;align-items:center;justify-content:center;padding:.375rem .625rem;background-color:transparent;border:1px solid var(--border-color, #ddd);border-radius:.375rem;cursor:pointer;transition:all .2s ease;color:var(--text-secondary, #666);font-size:.875rem}.reaction-picker-button:hover:not(:disabled){background-color:var(--surface-light, #f5f5f5);border-color:var(--primary-color, #007bff);color:var(--primary-color, #007bff)}.reaction-picker-button:disabled{cursor:not-allowed;opacity:.6}.reaction-icon{font-size:1rem;line-height:1}.reaction-picker-popover{position:absolute;bottom:100%;left:0;margin-bottom:.5rem;padding:.5rem;background-color:var(--surface-bg, white);border:1px solid var(--border-color, #ddd);border-radius:.5rem;box-shadow:0 4px 12px #00000026;z-index:1000;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:translateY(0)}}.reaction-picker-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.25rem}.reaction-picker-emoji{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;background-color:transparent;border:1px solid transparent;border-radius:.375rem;cursor:pointer;font-size:1.25rem;transition:all .15s ease}.reaction-picker-emoji:hover{background-color:var(--surface-light, #f5f5f5);border-color:var(--border-color, #ddd);transform:scale(1.1)}.reaction-picker-button:focus-visible{outline:2px solid var(--primary-color, #007bff);outline-offset:2px}.reaction-picker-emoji:focus-visible{outline:2px solid var(--primary-color, #007bff);outline-offset:1px;background-color:var(--surface-light, #f5f5f5);border-color:var(--border-color, #ddd)}@media(prefers-reduced-motion:reduce){.reaction-picker-emoji:hover{transform:none}@keyframes slideUp{0%{opacity:1;transform:none}to{opacity:1;transform:none}}}@media(prefers-color-scheme:dark){.reaction-picker-button{border-color:var(--border-dark, #444);color:var(--text-secondary-light, #aaa)}.reaction-picker-button:hover:not(:disabled){background-color:var(--surface-dark, #2a2a2a)}.reaction-picker-popover{background-color:var(--surface-dark-bg, #1a1a1a);border-color:var(--border-dark, #444);box-shadow:0 4px 12px #0006}.reaction-picker-emoji:hover{background-color:var(--surface-dark, #2a2a2a);border-color:var(--border-dark, #444)}}@media(max-width:640px){.reaction-picker-popover{left:50%;margin-left:-5rem}.reaction-picker-grid{grid-template-columns:repeat(5,1fr)}}.comment-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;border-radius:8px;background:var(--color-surface, #fff);transition:background-color .2s}.comment-item:hover{background:var(--color-surface-hover, #f8f9fa)}.comment-item.depth-0{margin-left:0;border-left:3px solid var(--color-primary, #4a90d9)}.comment-item.depth-1{margin-left:1.5rem;border-left:3px solid var(--color-secondary, #6c757d)}.comment-item.depth-2{margin-left:3rem;border-left:3px solid var(--color-muted, #adb5bd)}.comment-item.depth-3{margin-left:4.5rem;border-left:3px solid var(--color-muted, #adb5bd)}.comment-item--deleted{opacity:.6}.comment-item--deleted .comment-item__content{font-style:italic;color:var(--color-text-muted, #6c757d)}.comment-item--hidden{border-left-color:var(--color-warning, #ffc107);background:var(--color-warning-bg, #fff3cd)}.comment-item__header{display:flex;align-items:center;gap:.75rem}.comment-item__avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary, #4a90d9);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0}.comment-item__avatar--deleted{background:var(--color-text-muted, #6c757d);font-size:1rem}.comment-item__author--deleted{color:var(--color-text-muted, #6c757d);font-style:italic}.comment-item__meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.comment-item__author{font-weight:600;color:var(--color-text, #212529)}.comment-item__timestamp{font-size:.875rem;color:var(--color-text-muted, #6c757d)}.comment-item__edited{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--color-text-muted, #6c757d);font-style:italic}.comment-item__hidden-notice{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;background:var(--color-warning-bg, #fff3cd);border-radius:4px;font-size:.875rem;color:var(--color-warning-text, #856404)}.comment-item__hidden-message{flex:1 1 auto}.comment-item__moderation-reason{font-style:italic}.comment-item__appeal-link{background:none;border:none;padding:0;color:var(--color-link, #0066cc);font-size:.875rem;cursor:pointer;text-decoration:underline}.comment-item__appeal-link:hover{color:var(--color-link-hover, #004499)}.comment-item__reply-attribution{padding:.25rem .5rem;margin-left:calc(36px + .75rem);font-size:.8125rem;color:var(--color-text-muted, #6c757d);font-style:italic;background:var(--color-surface-alt, #f8f9fa);border-radius:4px;border-left:2px solid var(--color-primary, #4a90d9)}.comment-item__content{padding-left:calc(36px + .75rem)}.comment-item__markdown{line-height:1.6;color:var(--color-text, #212529)}.comment-item__markdown p{margin:0 0 .5rem}.comment-item__markdown p:last-child{margin-bottom:0}.comment-item__markdown h1{font-size:1.75rem;font-weight:700;margin:1rem 0 .75rem;line-height:1.3;color:var(--color-text, #212529)}.comment-item__markdown h2{font-size:1.5rem;font-weight:700;margin:.875rem 0 .625rem;line-height:1.3;color:var(--color-text, #212529)}.comment-item__markdown h3{font-size:1.25rem;font-weight:600;margin:.75rem 0 .5rem;line-height:1.4;color:var(--color-text, #212529)}.comment-item__markdown h4{font-size:1.125rem;font-weight:600;margin:.625rem 0 .5rem;line-height:1.4;color:var(--color-text, #212529)}.comment-item__markdown h5{font-size:1rem;font-weight:600;margin:.5rem 0 .375rem;line-height:1.5;color:var(--color-text, #212529)}.comment-item__markdown h6{font-size:.875rem;font-weight:600;margin:.5rem 0 .375rem;line-height:1.5;color:var(--color-text-muted, #6c757d)}.comment-item__markdown h1:first-child,.comment-item__markdown h2:first-child,.comment-item__markdown h3:first-child,.comment-item__markdown h4:first-child,.comment-item__markdown h5:first-child,.comment-item__markdown h6:first-child{margin-top:0}.comment-item__markdown code{background:var(--color-code-bg, #f1f3f4);padding:.125rem .375rem;border-radius:4px;font-size:.875em}.comment-item__markdown pre{background:var(--color-code-bg, #f1f3f4);padding:.75rem 1rem;border-radius:6px;overflow-x:auto}.comment-item__markdown pre code{background:none;padding:0}.comment-item__markdown a{color:var(--color-link, #0d6efd);text-decoration:none}.comment-item__markdown a:hover{text-decoration:underline}.comment-item__markdown ul,.comment-item__markdown ol{margin:.5rem 0;padding-left:1.5rem}.comment-item__markdown li,.comment-item__markdown ul ul,.comment-item__markdown ol ol,.comment-item__markdown ul ol,.comment-item__markdown ol ul{margin:.25rem 0}.comment-item__markdown blockquote{margin:.75rem 0;padding:.5rem 1rem;border-left:4px solid var(--color-border, #dee2e6);background:var(--color-surface, #f8f9fa);color:var(--color-text-secondary, #495057)}.comment-item__markdown blockquote p:last-child{margin-bottom:0}.comment-item__markdown hr{margin:1rem 0;border:none;border-top:2px solid var(--color-border, #dee2e6)}.comment-item__markdown del,.comment-item__markdown s{text-decoration:line-through;opacity:.7}.comment-item__edit-form{display:flex;flex-direction:column;gap:.5rem}.comment-item__edit-textarea{width:100%;min-height:100px;padding:.75rem;border:1px solid var(--color-border, #dee2e6);border-radius:6px;font-family:inherit;font-size:1rem;resize:vertical}.comment-item__edit-textarea:focus{outline:none;border-color:var(--color-primary, #4a90d9);box-shadow:0 0 0 3px var(--color-primary-alpha, rgba(74, 144, 217, .2))}.comment-item__edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.comment-item__actions{display:flex;align-items:center;gap:.75rem;padding-left:calc(36px + .75rem)}.comment-item__votes{display:flex;align-items:center;min-width:110px}.comment-item__action-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border:none;background:transparent;color:var(--color-text-muted, #6c757d);font-size:.875rem;cursor:pointer;border-radius:4px;transition:color .2s,background-color .2s}.comment-item__action-btn:hover{color:var(--color-primary, #4a90d9);background:var(--color-primary-alpha, rgba(74, 144, 217, .1))}.comment-item__action-btn--danger:hover{color:var(--color-danger, #dc3545);background:var(--color-danger-alpha, rgba(220, 53, 69, .1))}.comment-item__action-btn--flagged{color:var(--color-warning, #f59e0b);cursor:default;font-size:.75rem}.comment-item__action-btn--flagged:hover{background:transparent}.comment-item__action-btn:disabled{opacity:.5;cursor:not-allowed}.comment-item__btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.comment-item__btn--primary{background:var(--color-primary, #4a90d9);color:#fff}.comment-item__btn--primary:hover:not(:disabled){background:var(--color-primary-dark, #3a7bc8)}.comment-item__btn--secondary{background:var(--color-surface, #e9ecef);color:var(--color-text, #212529)}.comment-item__btn--secondary:hover:not(:disabled){background:var(--color-surface-hover, #dee2e6)}.comment-item__btn:disabled{opacity:.6;cursor:not-allowed}.comment-item__reply-form{padding-left:calc(36px + .75rem);margin-top:.5rem}.comment-item__replies{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}@media(max-width:640px){.comment-item.depth-1,.comment-item.depth-2,.comment-item.depth-3{margin-left:.5rem}.comment-item__content,.comment-item__actions,.comment-item__reply-form{padding-left:0}.comment-item__action-btn span{display:none}}.comment-item__reactions{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;padding-left:3.5rem}.comment-item--deleted .comment-item__reactions{display:none}@media(max-width:640px){.comment-item__reactions{padding-left:0}}.flag-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:flagModalFadeIn .2s ease-out}@keyframes flagModalFadeIn{0%{opacity:0}to{opacity:1}}.flag-modal{background:var(--background-secondary, white);border-radius:12px;box-shadow:0 20px 60px #0000004d;width:90%;max-width:480px;max-height:90vh;overflow-y:auto;animation:flagModalSlideIn .2s ease-out}@keyframes flagModalSlideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.flag-modal-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.flag-modal-icon{color:var(--color-warning, #f59e0b);font-size:1.25rem}.flag-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary, #1f2937);flex:1}.flag-modal-close{background:none;border:none;cursor:pointer;color:var(--text-secondary, #6b7280);padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.flag-modal-close:hover{background-color:var(--background-tertiary, #f3f4f6);color:var(--text-primary, #1f2937)}.flag-modal-form{padding:1.5rem}.flag-modal-description{margin:0 0 1.25rem;color:var(--text-secondary, #6b7280);font-size:.9rem;line-height:1.5}.flag-modal-error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.flag-modal-reasons{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.flag-reason-option{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border:2px solid var(--border-color, #e5e7eb);border-radius:8px;cursor:pointer;transition:border-color .2s,background-color .2s}.flag-reason-option:hover{border-color:var(--color-primary, #3b82f6);background-color:var(--background-tertiary, #f8fafc)}.flag-reason-option--selected{border-color:var(--color-primary, #3b82f6);background-color:var(--color-primary-light, #eff6ff)}.flag-reason-option input[type=radio]{margin-top:.125rem;accent-color:var(--color-primary, #3b82f6)}.flag-reason-content{display:flex;flex-direction:column;gap:.125rem}.flag-reason-label{font-weight:500;color:var(--text-primary, #1f2937)}.flag-reason-description{font-size:.8rem;color:var(--text-secondary, #6b7280)}.flag-modal-field{margin-bottom:1.25rem;position:relative}.flag-modal-field label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem;color:var(--text-primary, #1f2937)}.flag-modal-field textarea{width:100%;padding:.75rem;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:.9rem;font-family:inherit;resize:vertical;min-height:80px;background:var(--background-primary, white);color:var(--text-primary, #1f2937);transition:border-color .2s}.flag-modal-field textarea:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.flag-modal-field textarea::placeholder{color:var(--text-tertiary, #9ca3af)}.flag-modal-char-count{position:absolute;right:.5rem;bottom:-1.25rem;font-size:.75rem;color:var(--text-tertiary, #9ca3af)}.flag-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color, #e5e7eb)}.flag-modal-btn{padding:.625rem 1.25rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s}.flag-modal-btn:disabled{opacity:.6;cursor:not-allowed}.flag-modal-btn--secondary{background:var(--background-secondary, white);color:var(--text-primary, #374151);border:1px solid var(--border-color, #d1d5db)}.flag-modal-btn--secondary:hover:not(:disabled){background-color:var(--background-tertiary, #f9fafb)}.flag-modal-btn--primary{background-color:var(--color-warning, #f59e0b);color:#fff;border:none}.flag-modal-btn--primary:hover:not(:disabled){background-color:#d97706}.flag-modal-success{padding:2.5rem 1.5rem;text-align:center}.flag-modal-success .success-icon{width:48px;height:48px;background-color:#10b981;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 1rem}.flag-modal-success p{margin:0;color:var(--text-secondary, #4b5563);font-size:1rem;line-height:1.5}@media(prefers-color-scheme:dark){.flag-modal{background:#1f2937}.flag-modal-error{background-color:#7f1d1d;border-color:#dc2626;color:#fecaca}.flag-reason-option{border-color:#374151}.flag-reason-option:hover{background-color:#374151}.flag-reason-option--selected{background-color:#1e3a5f}}@media(max-width:480px){.flag-modal{width:95%;max-height:95vh;margin:1rem}.flag-modal-header,.flag-modal-form{padding:1rem}.flag-modal-actions{flex-direction:column-reverse}.flag-modal-btn{width:100%;text-align:center}}.comment-thread{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--color-background, #fff);border-radius:8px;border:1px solid var(--color-border, #dee2e6)}.comment-thread__header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border, #dee2e6)}.comment-thread__title{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text, #212529)}.comment-thread__controls{display:flex;align-items:center;gap:.75rem}.comment-thread__paused{font-size:.75rem;color:var(--color-text-muted, #6c757d);padding:.25rem .5rem;background:var(--color-surface, #f8f9fa);border-radius:4px}.comment-thread__refresh-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:var(--color-surface, #f8f9fa);color:var(--color-text-muted, #6c757d);cursor:pointer;border-radius:6px;transition:color .2s,background-color .2s}.comment-thread__refresh-btn:hover:not(:disabled){color:var(--color-primary, #4a90d9);background:var(--color-primary-alpha, rgba(74, 144, 217, .1))}.comment-thread__refresh-btn:disabled{opacity:.5;cursor:not-allowed}.comment-thread__hide-btn{display:flex;align-items:center;gap:.35rem;padding:.25rem .6rem;border:none;background:var(--color-surface, #f8f9fa);color:var(--color-text-muted, #6c757d);cursor:pointer;border-radius:6px;font-size:.8rem;transition:color .2s,background-color .2s}.comment-thread__hide-btn:hover{color:var(--color-primary, #4a90d9);background:var(--color-primary-alpha, rgba(74, 144, 217, .1))}.comment-thread__refresh-btn .spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.comment-thread__sort{position:relative;display:flex;align-items:center}.comment-thread__sort-select{appearance:none;padding:.5rem 2rem .5rem .75rem;border:1px solid var(--color-border, #dee2e6);border-radius:6px;background:var(--color-background, #fff);font-size:.875rem;color:var(--color-text, #212529);cursor:pointer;transition:border-color .2s}.comment-thread__sort-select:focus{outline:none;border-color:var(--color-primary, #4a90d9)}.comment-thread__sort-icon{position:absolute;right:.5rem;pointer-events:none;color:var(--color-text-muted, #6c757d)}.comment-thread__locked{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-warning-bg, #fff3cd);border-radius:6px;color:var(--color-warning-text, #856404);font-size:.875rem}.comment-thread__form-container{display:flex;flex-direction:column;gap:.5rem}.comment-thread__form-error{padding:.5rem .75rem;background:var(--color-danger-bg, #f8d7da);border-radius:4px;color:var(--color-danger, #dc3545);font-size:.875rem}.comment-thread__form-info{padding:.5rem .75rem;background:var(--color-info-bg, #cce5ff);border-radius:4px;color:var(--color-info, #004085);font-size:.875rem}.comment-thread__login-prompt{padding:1rem;text-align:center;background:var(--color-surface, #f8f9fa);border-radius:6px;color:var(--color-text-muted, #6c757d)}.comment-thread__login-prompt p{margin:0}.comment-thread__list{display:flex;flex-direction:column;gap:.75rem}.comment-thread__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:.75rem;color:var(--color-text-muted, #6c757d)}.comment-thread__spinner{width:32px;height:32px;border:3px solid var(--color-border, #dee2e6);border-top-color:var(--color-primary, #4a90d9);border-radius:50%;animation:spin 1s linear infinite}.comment-thread__error{display:flex;flex-direction:column;align-items:center;padding:2rem;gap:.75rem;text-align:center;color:var(--color-danger, #dc3545)}.comment-thread__retry-btn{padding:.5rem 1rem;border:none;border-radius:6px;background:var(--color-primary, #4a90d9);color:#fff;font-size:.875rem;cursor:pointer;transition:background-color .2s}.comment-thread__retry-btn:hover{background:var(--color-primary-dark, #3a7bc8)}.comment-thread__spoiler-gate{display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;gap:.5rem;text-align:center;color:var(--color-text-muted, #6c757d)}.comment-thread__spoiler-title{margin:.25rem 0 0;font-size:1.1rem;color:var(--color-text, #212529)}.comment-thread__spoiler-text{margin:0;font-size:.9rem;max-width:360px;line-height:1.4}.comment-thread__spoiler-reveal-btn{margin-top:.5rem;padding:.4rem 1rem;font-size:.85rem;color:var(--color-primary, #4263eb);background:none;border:1px solid var(--color-primary, #4263eb);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.comment-thread__spoiler-reveal-btn:hover{background:var(--color-primary, #4263eb);color:#fff}.comment-thread__empty{display:flex;flex-direction:column;align-items:center;padding:2rem;gap:.5rem;text-align:center;color:var(--color-text-muted, #6c757d)}.comment-thread__empty p{margin:0}.comment-thread__empty-hint{font-size:.875rem}.comment-thread__pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding-top:1rem;border-top:1px solid var(--color-border, #dee2e6)}.comment-thread__page-btn{padding:.5rem 1rem;border:1px solid var(--color-border, #dee2e6);border-radius:6px;background:var(--color-background, #fff);color:var(--color-text, #212529);font-size:.875rem;cursor:pointer;transition:border-color .2s,background-color .2s}.comment-thread__page-btn:hover:not(:disabled){border-color:var(--color-primary, #4a90d9);background:var(--color-primary-alpha, rgba(74, 144, 217, .1))}.comment-thread__page-btn:disabled{opacity:.5;cursor:not-allowed}.comment-thread__page-info{font-size:.875rem;color:var(--color-text-muted, #6c757d)}@media(max-width:640px){.comment-thread{padding:.75rem}.comment-thread__header{flex-direction:column;align-items:flex-start}.comment-thread__controls{width:100%;justify-content:space-between}.comment-thread__pagination{gap:.5rem}.comment-thread__page-btn{padding:.375rem .75rem;font-size:.8125rem}}.view-history-page{max-width:1200px;margin:0 auto;padding:2rem}.history-header{margin-bottom:2rem}.history-header h1{margin-bottom:1.5rem;color:var(--text-primary)}.history-controls{display:flex;gap:2rem;align-items:center;flex-wrap:wrap;padding:1rem;background-color:var(--bg-secondary);border-radius:8px}.filter-group{display:flex;align-items:center;gap:.75rem}.filter-group label{font-weight:500;color:var(--text-primary)}.category-filter{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--card-bg);color:var(--text-primary);font-size:1rem;cursor:pointer;min-width:200px}.category-filter:focus{outline:2px solid var(--accent-primary);outline-offset:2px;border-color:var(--accent-primary)}.archive-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-secondary)}.archive-toggle input[type=checkbox]{cursor:pointer;width:18px;height:18px}.attempts-list{display:flex;flex-direction:column;gap:1rem}.no-history{text-align:center;padding:3rem;background-color:var(--bg-secondary);border-radius:8px;color:var(--text-secondary)}.attempt-card{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;transition:box-shadow .3s ease}.attempt-card:hover{box-shadow:0 4px 12px var(--card-shadow)}.attempt-card.archived{opacity:.8;border-color:var(--text-tertiary)}.attempt-summary{padding:1.5rem 3.5rem 1.5rem 1.5rem;cursor:pointer;position:relative}.attempt-summary:hover{background-color:var(--bg-secondary)}.attempt-summary:focus{outline:2px solid var(--accent-primary);outline-offset:-2px;background-color:var(--bg-secondary)}.attempt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.attempt-date{font-size:.875rem;color:var(--text-secondary);font-weight:500}.marks-badge{padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:1rem}.marks-badge.correct{background-color:var(--success-color);color:#fff}.marks-badge.partial{background-color:var(--warning-color);color:#fff}.marks-badge.zero{background-color:var(--error-color);color:#fff}.question-summary{margin-bottom:1rem}.question-text-preview{color:var(--text-primary);line-height:1.6;margin-bottom:.75rem}.attempt-meta{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.difficulty{font-size:.875rem;color:var(--text-secondary);font-weight:500}.categories{display:flex;gap:.5rem;flex-wrap:wrap}.category-badge{padding:.25rem .75rem;background-color:var(--accent-primary);color:#fff;border-radius:12px;font-size:.75rem;font-weight:500}.answer-summary{margin-bottom:.5rem}.your-answer{color:var(--text-primary);margin-bottom:.5rem}.your-answer strong{color:var(--text-secondary)}.correct-indicator{font-size:.875rem;color:var(--accent-primary);font-style:italic}.expand-icon{position:absolute;top:50%;right:1.5rem;transform:translateY(-50%);font-size:1.25rem;color:var(--accent-primary);pointer-events:none}.attempt-details{padding:1.5rem;background-color:var(--bg-secondary);border-top:1px solid var(--border-color)}.question-full{margin-bottom:2rem}.question-full h3{margin-bottom:1rem;color:var(--text-primary)}.answer-details{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:1.5rem}.your-answer-detail,.correct-answer-detail,.rationale{background-color:var(--card-bg);padding:1rem;border-radius:8px;border:1px solid var(--border-color)}.your-answer-detail h4,.correct-answer-detail h4,.rationale h4{margin-bottom:.75rem;color:var(--text-primary);font-size:1rem}.answer-rationale{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.answer-rationale strong{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.875rem}.answer-rationale p{color:var(--text-primary);line-height:1.6;margin:0}.correct-answer{color:var(--success-color);font-weight:600;font-size:1.1rem}.incorrect-answer{color:var(--error-color);font-weight:600;font-size:1.1rem}.rationale p{color:var(--text-primary);line-height:1.6}.archived-notice{display:flex;gap:.75rem;align-items:center;padding:1rem;background-color:var(--warning-color);color:#fff;border-radius:4px;font-size:.875rem}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.archived-badge{background-color:var(--text-tertiary);color:#fff}.active-badge{background-color:var(--success-color);color:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:2rem;padding:1rem}.pagination-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:transform .2s ease,opacity .2s ease;text-shadow:0 1px 2px rgba(0,0,0,.2)}.pagination-btn:hover:not(:disabled){transform:translateY(-2px)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{font-weight:500;color:var(--text-primary)}@media(max-width:768px){.view-history-page{padding:1rem}.history-controls{flex-direction:column;align-items:stretch;gap:1rem}.filter-group{flex-direction:column;align-items:stretch}.category-filter{min-width:auto;width:100%}.attempt-header{flex-direction:column;align-items:flex-start;gap:.5rem}.expand-icon{top:1rem;right:1rem}}.notifications-page{max-width:900px;margin:0 auto;padding:2rem}.notifications-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.notifications-header h1{margin:0;font-size:2rem;font-weight:600;color:#212529}.notifications-filters{margin-bottom:1.5rem}.filter-tabs{display:flex;gap:.5rem;border-bottom:2px solid #dee2e6}.filter-tab{background:none;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#6c757d;cursor:pointer;position:relative;transition:color .2s;display:flex;align-items:center;gap:.5rem}.filter-tab:hover{color:#495057}.filter-tab.active{color:#007bff}.filter-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background-color:#007bff}.tab-count{background-color:#e9ecef;color:#495057;padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.filter-tab.active .tab-count{background-color:#007bff;color:#fff}.notifications-list{display:flex;flex-direction:column;gap:.75rem}.notification-card{background-color:#fff;border:1px solid #dee2e6;border-radius:.5rem;padding:1.25rem;cursor:pointer;transition:all .2s}.notification-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#adb5bd}.notification-card.unread{background-color:#f0f7ff;border-color:#b6d4fe}.notification-card.unread:hover{border-color:#6ea8fe}.notification-card-content{display:flex;flex-direction:column;gap:.5rem}.notification-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.notification-card-title{margin:0;font-size:1.0625rem;font-weight:600;color:#212529;flex:1;line-height:1.4}.unread-dot{flex-shrink:0;width:10px;height:10px;background-color:#007bff;border-radius:50%;margin-top:.35rem}.notification-card-message{margin:0;font-size:.9375rem;color:#495057;line-height:1.5}.notification-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem}.notification-card-time{font-size:.8125rem;color:#6c757d}.notification-card-actions{display:flex;gap:.5rem}.action-button{background:none;border:none;color:#007bff;font-size:.8125rem;font-weight:500;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;transition:background-color .2s}.action-button:hover{background-color:#007bff1a}.empty-state{text-align:center;padding:4rem 2rem;color:#6c757d}.empty-state-icon{color:#ced4da;margin-bottom:1rem}.empty-state h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#495057}.empty-state p{margin:0;font-size:1rem;color:#6c757d}.loading-state,.error-state{text-align:center;padding:3rem 2rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid #dee2e6}.page-info{font-size:.9375rem;color:#6c757d}.btn{padding:.5rem 1rem;border:1px solid transparent;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){background-color:#0056b3;border-color:#0056b3}.btn-secondary:hover:not(:disabled){background-color:#545b62;border-color:#545b62}.notification-card:focus{outline:2px solid #007bff;outline-offset:2px}@media(max-width:768px){.notifications-page{padding:1rem}.notifications-header{flex-direction:column;align-items:flex-start;gap:1rem}.notifications-header h1{font-size:1.5rem}.filter-tabs{width:100%}.filter-tab{flex:1;justify-content:center;padding:.75rem .5rem;font-size:.9375rem}.notification-card{padding:1rem}.notification-card-title{font-size:1rem}.notification-card-message{font-size:.875rem}.notification-card-footer{flex-direction:column;align-items:flex-start;gap:.5rem}.pagination{flex-direction:column;gap:.75rem}.pagination .btn{width:100%}}@media(max-width:480px){.notifications-header h1{font-size:1.25rem}.tab-count{font-size:.6875rem}.notification-card{padding:.875rem}.notification-card-title{font-size:.9375rem}.notification-card-message{font-size:.8125rem}}.markdown-reference{min-height:100vh;background:var(--color-background, #ffffff);padding:2rem 1rem}.markdown-reference__container{max-width:1000px;margin:0 auto}.markdown-reference__header{margin-bottom:2rem;text-align:center}.markdown-reference__header h1{font-size:2.5rem;font-weight:700;color:var(--color-text, #212529);margin:0 0 1rem}.markdown-reference__intro{font-size:1.125rem;color:var(--color-text-muted, #6c757d);line-height:1.6;max-width:700px;margin:0 auto}.markdown-reference__tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid var(--color-border, #dee2e6)}.markdown-reference__tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;font-size:1rem;font-weight:500;color:var(--color-text-muted, #6c757d);cursor:pointer;transition:color .2s,border-color .2s;margin-bottom:-2px}.markdown-reference__tab:hover{color:var(--color-text, #212529)}.markdown-reference__tab--active{color:var(--color-primary, #4a90d9);border-bottom-color:var(--color-primary, #4a90d9)}.markdown-reference__content{background:var(--color-surface, #ffffff);border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000000d}.markdown-reference__section{margin-bottom:3rem}.markdown-reference__section:last-child{margin-bottom:0}.markdown-reference__section h2{font-size:1.75rem;font-weight:600;color:var(--color-text, #212529);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border, #dee2e6)}.markdown-reference__description{font-size:1rem;color:var(--color-text-secondary, #495057);margin:0 0 1.5rem;line-height:1.6}.markdown-reference__quick-tips{background:var(--color-info-background, #e7f3ff);border-left:4px solid var(--color-primary, #4a90d9);padding:1.5rem;border-radius:4px;margin-bottom:2rem}.markdown-reference__quick-tips h2{font-size:1.25rem;margin-bottom:1rem;border:none;padding:0}.markdown-reference__quick-tips ul{margin:0;padding-left:1.5rem}.markdown-reference__quick-tips li{margin-bottom:.5rem;line-height:1.6}.markdown-reference__examples{display:flex;flex-direction:column;gap:2rem}.markdown-reference__example{border:1px solid var(--color-border, #dee2e6);border-radius:8px;padding:1.5rem;background:var(--color-surface, #f8f9fa)}.markdown-reference__example-title{font-size:1.25rem;font-weight:600;color:var(--color-text, #212529);margin:0 0 .5rem}.markdown-reference__example-notes{font-size:.875rem;color:var(--color-text-muted, #6c757d);margin:0 0 1rem;font-style:italic}.markdown-reference__example-demo{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}.markdown-reference__label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted, #6c757d);margin-bottom:.5rem}.markdown-reference__example-source{background:var(--color-background, #ffffff);border:1px solid var(--color-border, #dee2e6);border-radius:6px;padding:1rem}.markdown-reference__example-source pre{margin:0;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;white-space:pre-wrap;word-wrap:break-word}.markdown-reference__example-source code{color:var(--color-text, #212529);background:none;padding:0}.markdown-reference__example-output{background:var(--color-background, #ffffff);border:1px solid var(--color-border, #dee2e6);border-radius:6px;padding:1rem}.markdown-reference__rendered{font-size:1rem;line-height:1.6;color:var(--color-text, #212529)}.markdown-reference__rendered h1,.markdown-reference__rendered h2,.markdown-reference__rendered h3,.markdown-reference__rendered h4,.markdown-reference__rendered h5,.markdown-reference__rendered h6,.markdown-reference__rendered p{margin:.5rem 0}.markdown-reference__rendered code{background:var(--color-surface, #f8f9fa);padding:.2rem .4rem;border-radius:3px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875em}.markdown-reference__rendered pre{background:var(--color-surface, #f8f9fa);padding:1rem;border-radius:4px;overflow-x:auto;margin:.5rem 0}.markdown-reference__rendered pre code{background:none;padding:0}.markdown-reference__rendered a{color:var(--color-primary, #4a90d9);text-decoration:underline}.markdown-reference__restrictions{display:flex;flex-direction:column;gap:1.5rem}.markdown-reference__restriction{padding:1rem;background:var(--color-surface, #f8f9fa);border-left:4px solid var(--color-danger, #dc3545);border-radius:4px}.markdown-reference__restriction h3{font-size:1.125rem;font-weight:600;color:var(--color-text, #212529);margin:0 0 .5rem}.markdown-reference__restriction p{font-size:.875rem;color:var(--color-text-secondary, #495057);margin:0 0 .75rem;line-height:1.5}.markdown-reference__example-code{background:var(--color-background, #ffffff);padding:.75rem;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:var(--color-text-muted, #6c757d);border:1px solid var(--color-border, #dee2e6)}.markdown-reference__security-note{margin-top:2rem;padding:1.5rem;background:var(--color-warning-background, #fff3cd);border-left:4px solid var(--color-warning, #ffc107);border-radius:4px;font-size:.875rem;line-height:1.6}.markdown-reference__security-note strong{display:block;margin-bottom:.5rem;font-size:1rem}.markdown-reference__footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border, #dee2e6);text-align:center;color:var(--color-text-muted, #6c757d);font-size:.875rem}.markdown-reference__footer a{color:var(--color-primary, #4a90d9);text-decoration:underline}.markdown-reference__footer a:hover{color:var(--color-primary-dark, #3a7bc8)}@media(max-width:768px){.markdown-reference{padding:1rem .5rem}.markdown-reference__header h1{font-size:2rem}.markdown-reference__intro{font-size:1rem}.markdown-reference__content{padding:1.5rem}.markdown-reference__example-demo{grid-template-columns:1fr}.markdown-reference__tabs{overflow-x:auto}.markdown-reference__tab{white-space:nowrap}}@media(max-width:480px){.markdown-reference__header h1{font-size:1.75rem}.markdown-reference__content{padding:1rem}.markdown-reference__section h2{font-size:1.5rem}}.session-timeout-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.session-timeout-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:420px;width:90%;animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.session-timeout-header{padding:24px 24px 16px;text-align:center;border-bottom:1px solid #e5e7eb}.session-timeout-icon{font-size:48px;margin-bottom:12px}.session-timeout-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#111827}.session-timeout-body{padding:20px 24px;text-align:center}.session-timeout-body p{margin:0 0 12px;color:#374151;line-height:1.5}.session-timeout-body strong{color:#dc2626;font-weight:600}.session-timeout-hint{font-size:.875rem;color:#6b7280}.session-timeout-footer{padding:16px 24px 24px;display:flex;justify-content:center;gap:12px}.session-timeout-footer .btn{padding:10px 24px;font-size:.9375rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s ease;border:none}.session-timeout-footer .btn-primary{background-color:#2563eb;color:#fff}.session-timeout-footer .btn-primary:hover{background-color:#1d4ed8}.session-timeout-footer .btn-primary:focus{outline:2px solid #2563eb;outline-offset:2px}.session-timeout-footer .btn-secondary{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.session-timeout-footer .btn-secondary:hover{background-color:#e5e7eb}.session-timeout-footer .btn-secondary:focus{outline:2px solid #6b7280;outline-offset:2px}@media(prefers-color-scheme:dark){.session-timeout-modal{background:#1f2937}.session-timeout-header{border-bottom-color:#374151}.session-timeout-header h2{color:#f9fafb}.session-timeout-body p{color:#d1d5db}.session-timeout-body strong{color:#f87171}.session-timeout-hint{color:#9ca3af}.session-timeout-footer .btn-secondary{background-color:#374151;color:#f9fafb;border-color:#4b5563}.session-timeout-footer .btn-secondary:hover{background-color:#4b5563}}.admin-layout{display:flex;min-height:100vh;background-color:#f5f5f5}.admin-sidebar{width:250px;background-color:#2c3e50;color:#ecf0f1;display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto}.admin-sidebar-header{padding:1.5rem 1rem;border-bottom:1px solid rgba(255,255,255,.1)}.admin-sidebar-header h1{font-size:1.25rem;margin:0;font-weight:600}.admin-nav{flex:1;padding:1rem 0}.admin-nav ul{list-style:none;padding:0;margin:0}.admin-nav li{margin:0}.admin-nav a{display:flex;align-items:center;padding:.75rem 1rem;color:#ecf0f1;text-decoration:none;transition:background-color .2s}.admin-nav a:hover{background-color:#ffffff1a}.admin-nav a.active{background-color:#3498db;font-weight:600}.nav-icon{margin-right:.75rem;font-size:1.25rem}.nav-label{font-size:.95rem;flex:1}.nav-badge{background-color:#dc3545;color:#fff;border-radius:10px;padding:.125rem .375rem;font-size:.75rem;font-weight:600;line-height:1;min-width:18px;text-align:center;margin-left:auto}.admin-sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.back-to-site{display:block;padding:.5rem;color:#ecf0f1;text-decoration:none;text-align:center;border-radius:4px;transition:background-color .2s}.back-to-site:hover{background-color:#ffffff1a}.admin-main{flex:1;margin-left:250px;display:flex;flex-direction:column}.admin-header{background-color:#fff;padding:1rem 2rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}.admin-breadcrumb{font-size:.875rem;color:#666}.admin-user-info{display:flex;align-items:center;gap:1rem}.user-details{text-align:right}.user-name{font-size:.95rem;font-weight:600;color:#333}.user-role{font-size:.75rem;color:#666}.logout-button{padding:.5rem 1rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.logout-button:hover{background-color:#c0392b}.admin-content{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}@media(max-width:768px){.admin-sidebar{width:200px}.admin-main{margin-left:200px}.nav-label{font-size:.85rem}.admin-header,.admin-content{padding:1rem}}@media(max-width:640px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:relative}.admin-main{margin-left:0}.admin-nav{padding:.5rem 0}.admin-nav a{padding:.5rem 1rem}.user-details{display:none}}.admin-dashboard{max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2rem;margin:0 0 .5rem;color:#333}.dashboard-subtitle{font-size:1rem;color:#666;margin:0}.loading,.error{text-align:center;padding:3rem;font-size:1.125rem;color:#666}.error{color:#e74c3c}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.stat-card.highlight{border-left:4px solid #3498db}.stat-icon{font-size:2.5rem;flex-shrink:0}.stat-label{font-size:.875rem;color:#666;margin-bottom:.25rem}.stat-value{font-size:2rem;font-weight:700;color:#333;line-height:1}.stat-meta{font-size:.75rem;color:#27ae60;margin-top:.25rem}.quick-actions{margin-bottom:2rem}.quick-actions h2{font-size:1.5rem;margin-bottom:1rem;color:#333}.action-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.action-card{background:#fff;border-radius:8px;padding:1.5rem;text-align:center;text-decoration:none;color:#333;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s,background-color .2s}.action-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026;background-color:#f8f9fa}.action-icon{font-size:2.5rem;margin-bottom:.5rem}.action-label{font-size:.95rem;font-weight:600}.recent-activity{margin-bottom:2rem}.recent-activity h2{font-size:1.5rem;margin-bottom:1rem;color:#333}.activity-list{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.activity-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.activity-item:last-child{border-bottom:none}.activity-item:hover{background-color:#f8f9fa}.activity-icon{font-size:1.5rem;flex-shrink:0}.activity-content{flex:1}.activity-text{font-size:.95rem;color:#333;margin-bottom:.25rem}.activity-time{font-size:.75rem;color:#999}@media(max-width:768px){.dashboard-header h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-value{font-size:1.5rem}.action-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.admin-dashboard{padding:0}.stat-card{padding:1rem}.action-grid{grid-template-columns:1fr}}.user-management{display:flex;flex-direction:column;gap:20px}.user-management-filters{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.search-form{display:flex;gap:8px;flex:1;min-width:250px}.search-input{flex:1;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9375rem}.filter-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9375rem;background-color:#fff;cursor:pointer}.bulk-actions{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#eff6ff;border:1px solid #dbeafe;border-radius:6px}.bulk-actions-text{font-weight:500;color:#1e40af}.table-container{overflow-x:auto;border:1px solid #e5e7eb;border-radius:8px;background-color:#fff}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:#f9fafb;border-bottom:1px solid #e5e7eb}.users-table th{padding:12px 16px;text-align:left;font-size:.875rem;font-weight:600;color:#374151;white-space:nowrap}.users-table td{padding:12px 16px;border-top:1px solid #f3f4f6;font-size:.9375rem;color:#111827}.user-row:hover{background-color:#f9fafb}.checkbox-cell input[type=checkbox]{width:16px;height:16px;cursor:pointer}.user-cell{display:flex;align-items:center;gap:12px}.user-cell-info{display:flex;flex-direction:column;gap:2px}.user-id-text{font-family:Monaco,Menlo,monospace;font-size:.6875rem;color:var(--text-secondary);word-break:break-all}.user-avatar-sm{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem;font-weight:600}.role-badge,.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.8125rem;font-weight:500;white-space:nowrap}.actions-cell{width:100px;text-align:right}.btn-icon{background:none;border:none;padding:4px 8px;cursor:pointer;font-size:1.125rem;opacity:.7;transition:opacity .2s}.btn-icon-danger:hover{opacity:1;filter:brightness(.9)}.loading-cell,.empty-cell{text-align:center;padding:40px 16px;color:#6b7280}.pagination{display:flex;justify-content:space-between;align-items:center;padding:16px 0}.pagination-info{font-size:.875rem;color:#6b7280}.btn{padding:8px 16px;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;border:1px solid transparent;transition:all .2s}.btn-sm{padding:6px 12px;font-size:.8125rem}@media(max-width:768px){.user-management-filters{flex-direction:column;align-items:stretch}.search-form{min-width:100%}.table-container{font-size:.875rem}.users-table th,.users-table td{padding:8px 12px}.pagination{flex-direction:column;gap:12px}}@media(prefers-color-scheme:dark){.search-input,.filter-select{background-color:#374151;border-color:#4b5563;color:#f9fafb}.bulk-actions{background-color:#1e3a8a;border-color:#1e40af}.bulk-actions-text{color:#93c5fd}.table-container{background-color:#1f2937;border-color:#374151}.users-table thead{background-color:#111827;border-bottom-color:#374151}.users-table th{color:#9ca3af}.users-table td{border-top-color:#374151;color:#f9fafb}.user-row:hover{background-color:#374151}.loading-cell,.empty-cell,.pagination-info{color:#9ca3af}.btn-secondary{background-color:#374151;color:#f9fafb;border-color:#4b5563}.btn-secondary:hover:not(:disabled){background-color:#4b5563;border-color:#6b7280}}.user-detail-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.user-detail-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:700px;width:90%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.user-detail-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.user-detail-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.user-detail-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.user-detail-close:hover{background-color:#f3f4f6;color:#111827}.user-detail-body{padding:24px;overflow-y:auto;flex:1}.error-message{padding:12px 16px;background-color:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#991b1b;margin-bottom:20px;font-size:.875rem}.success-message{padding:12px 16px;background-color:#d1fae5;border:1px solid #a7f3d0;border-radius:6px;color:#065f46;margin-bottom:20px;font-size:.875rem}.user-info-section{display:flex;flex-direction:column;gap:24px}.user-avatar{display:flex;justify-content:center}.user-avatar img,.avatar-placeholder{width:80px;height:80px;border-radius:50%}.avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:600}.user-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.info-item{display:flex;flex-direction:column;gap:6px}.info-item label{font-size:.875rem;font-weight:500;color:#6b7280}.info-value{color:#111827;font-size:.9375rem}.info-value.code{font-family:Monaco,Menlo,monospace;font-size:.8125rem;color:#4b5563}.role-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9375rem;color:#111827;background-color:#fff;cursor:pointer}.role-select:disabled{opacity:.5;cursor:not-allowed}.role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.8125rem;font-weight:500}.role-user{background-color:#e5e7eb;color:#374151}.role-read_only_admin{background-color:#dbeafe;color:#1e40af}.role-content_moderator{background-color:#fef3c7;color:#92400e}.role-super_admin{background-color:#fce7f3;color:#9f1239}.status-toggle{display:flex;align-items:center;gap:8px;cursor:pointer}.status-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.status-toggle input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.8125rem;font-weight:500}.status-active{background-color:#d1fae5;color:#065f46}.status-inactive{background-color:#fee2e2;color:#991b1b}.user-detail-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background-color:#f9fafb;border-radius:0 0 8px 8px}@media(max-width:640px){.user-info-grid{grid-template-columns:1fr}.user-detail-modal{width:95%;max-height:95vh}}@media(prefers-color-scheme:dark){.user-detail-modal{background:#1f2937}.user-detail-header{border-bottom-color:#374151}.user-detail-header h2{color:#f9fafb}.user-detail-close{color:#9ca3af}.user-detail-close:hover{background-color:#374151;color:#f9fafb}.info-item label{color:#9ca3af}.info-value{color:#f9fafb}.info-value.code{color:#d1d5db}.role-select{background-color:#374151;border-color:#4b5563;color:#f9fafb}.user-detail-footer{background-color:#111827;border-top-color:#374151}.btn-secondary{background-color:#374151;color:#f9fafb;border-color:#4b5563}.btn-secondary:hover:not(:disabled){background-color:#4b5563;border-color:#6b7280}}.confirm-dialog-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:500px;width:90%;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.confirm-dialog-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.confirm-dialog-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.confirm-dialog-close:hover:not(:disabled){background-color:#f3f4f6;color:#111827}.confirm-dialog-close:disabled{opacity:.5;cursor:not-allowed}.confirm-dialog-body{padding:24px}.confirm-dialog-body p{margin:0;color:#4b5563;line-height:1.5}.confirm-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background-color:#f9fafb;border-radius:0 0 8px 8px}.btn{padding:8px 16px;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;border:1px solid transparent;transition:all .2s;min-width:80px}.btn-secondary{background-color:#fff;color:#374151;border-color:#d1d5db}.btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.btn-danger{background-color:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-warning:hover:not(:disabled){background-color:#d97706}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}@media(prefers-color-scheme:dark){.confirm-dialog{background:#1f2937}.confirm-dialog-header{border-bottom-color:#374151}.confirm-dialog-header h2{color:#f9fafb}.confirm-dialog-close{color:#9ca3af}.confirm-dialog-close:hover:not(:disabled){background-color:#374151;color:#f9fafb}.confirm-dialog-body p{color:#d1d5db}.confirm-dialog-footer{background-color:#111827;border-top-color:#374151}.btn-secondary{background-color:#374151;color:#f9fafb;border-color:#4b5563}.btn-secondary:hover:not(:disabled){background-color:#4b5563;border-color:#6b7280}}.users-page{padding:24px;max-width:1400px;margin:0 auto}.users-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.users-page-header h1{margin:0 0 8px;font-size:2rem;font-weight:700;color:#111827}.page-subtitle{margin:0;color:#6b7280;font-size:1rem}.error-state{text-align:center;padding:60px 20px}.error-state h2{margin:0 0 12px;color:#991b1b;font-size:1.5rem}.error-state p{margin:0;color:#6b7280;font-size:1rem}.error-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background-color:#fee2e2;border:1px solid #fecaca;border-radius:8px;margin-bottom:20px;color:#991b1b}.error-icon{font-size:1.25rem}.error-retry{margin-left:auto;padding:6px 12px;background-color:#fff;border:1px solid #dc2626;border-radius:4px;color:#dc2626;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s}.error-retry:hover{background-color:#dc2626;color:#fff}@media(max-width:768px){.users-page{padding:16px}.users-page-header{flex-direction:column;gap:16px}.users-page-header h1{font-size:1.5rem}}@media(prefers-color-scheme:dark){.users-page-header h1{color:#f9fafb}.page-subtitle{color:#9ca3af}.error-state h2{color:#fca5a5}.error-state p{color:#9ca3af}.error-banner{background-color:#7f1d1d;border-color:#991b1b;color:#fecaca}.error-retry{background-color:#374151;border-color:#ef4444;color:#fca5a5}.error-retry:hover{background-color:#ef4444;color:#fff}}.question-management{width:100%}.question-management-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.filter-select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;min-width:150px}.filter-toggle{display:flex;align-items:center;gap:.4rem;font-size:.9rem;cursor:pointer;-webkit-user-select:none;user-select:none}.questions-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 1px 3px #0000001a}.questions-table th{background:#f8f9fa;padding:1rem;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6}.questions-table td{padding:1rem;border-bottom:1px solid #dee2e6}.question-row:hover{background-color:#f8f9fa}.checkbox-cell{width:40px;text-align:center}.question-text{max-width:400px}.question-preview{font-size:.9rem;color:#333;line-height:1.4}.difficulty-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;text-align:center}.difficulty-1{background-color:#d4edda;color:#155724}.difficulty-2{background-color:#d1ecf1;color:#0c5460}.difficulty-3{background-color:#fff3cd;color:#856404}.difficulty-4{background-color:#f8d7da;color:#721c24}.difficulty-5{background-color:#f5c6cb;color:#721c24}.categories-list{display:flex;flex-wrap:wrap;gap:.25rem}.category-tag{display:inline-block;padding:.25rem .5rem;background-color:#e9ecef;border-radius:4px;font-size:.8rem;color:#495057}.text-muted{color:#6c757d;font-style:italic}.actions-cell{width:100px;text-align:center}.btn-icon{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;margin:0 .25rem;opacity:.7;transition:opacity .2s}.btn-icon:hover{opacity:1}.btn-icon-danger:hover{opacity:1;filter:brightness(.8)}.loading-cell,.empty-cell{text-align:center;padding:2rem;color:#6c757d}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.page-info{font-size:.9rem;color:#6c757d}.btn{padding:.5rem 1rem;border:1px solid #dee2e6;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-secondary{background-color:#6c757d;color:#fff;border-color:#6c757d}.table-container{overflow-x:auto}@media(max-width:768px){.question-management-filters{flex-direction:column;align-items:stretch}.filter-select{width:100%}.questions-table{font-size:.85rem}.questions-table th,.questions-table td{padding:.5rem}.question-text{max-width:200px}}.card-picker{border:1px solid var(--border-color, #ddd);border-radius:8px;padding:12px;margin-bottom:12px;background:var(--card-bg, #fff)}.card-picker-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:.9rem}.card-picker-player{font-weight:600}.card-picker-hcp{color:var(--text-muted, #666)}.card-picker-count{margin-left:auto;font-size:.85rem;font-weight:500}.card-picker-count--valid{color:var(--success-color, #28a745)}.card-picker-count--invalid{color:var(--warning-color, #dc3545)}.card-picker-grid{display:flex;flex-direction:column;gap:4px}.card-picker-row{display:flex;align-items:center;gap:2px}.card-picker-suit-label{width:24px;text-align:center;font-size:1.1rem;flex-shrink:0}.card-picker-suit--red .card-picker-suit-label{color:#d00}.card-picker-suit--black .card-picker-suit-label{color:#222}.card-picker-cell{width:32px;height:32px;border:1px solid var(--border-color, #ccc);border-radius:4px;background:var(--card-bg, #fff);cursor:pointer;font-size:.85rem;font-weight:500;display:flex;align-items:center;justify-content:center;transition:background-color .15s,border-color .15s;padding:0;color:inherit}.card-picker-cell:hover:not(:disabled){background:var(--hover-bg, #f0f0f0);border-color:var(--primary-color, #0066cc)}.card-picker-cell--selected{background:var(--primary-color, #0066cc);color:#fff;border-color:var(--primary-color, #0066cc)}.card-picker-suit--red .card-picker-cell--selected{background:#d00;border-color:#d00}.card-picker-cell--selected:hover:not(:disabled){opacity:.85}.card-picker-cell--used{background:var(--disabled-bg, #e9ecef);color:var(--text-muted, #999);cursor:not-allowed;opacity:.4}.modal-content.question-editor{width:min(1200px,calc(100vw - 2rem));max-width:1200px;max-height:90vh;overflow-y:auto}.question-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;font-size:.9rem;color:#333}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{background-color:#e9ecef;cursor:not-allowed;opacity:.7}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.flex-1{flex:1}.flex-2{flex:2}.form-section{padding:1.5rem;background:#f8f9fa;border-radius:6px}.form-section h3{margin:0 0 1rem;font-size:1.1rem;color:#333}.pbn-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1rem}.hand-input-group{padding:1rem;background:#fff;border:1px solid #dee2e6;border-radius:4px}.hand-input-group h4{margin:0 0 .75rem;font-size:1rem;color:#495057;font-weight:600}.suit-inputs{display:flex;flex-direction:column;gap:.5rem}.suit-inputs .form-group{flex-direction:row;align-items:center;gap:.5rem}.suit-inputs .form-group label{font-size:1.25rem;font-weight:400;min-width:24px;text-align:center;margin:0}.suit-inputs .form-group:nth-child(1) label,.suit-inputs .form-group:nth-child(4) label{color:#000}.suit-inputs .form-group:nth-child(2) label,.suit-inputs .form-group:nth-child(3) label{color:#d32f2f}.suit-inputs .form-group input{flex:1;padding:.5rem;font-family:monospace}.answer-group{padding:1rem;background:#fff;border:1px solid #dee2e6;border-radius:4px;margin-bottom:1rem}.answer-group:last-of-type{margin-bottom:.5rem}.categories-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:4px;cursor:pointer;transition:background-color .2s}.checkbox-label:hover{background-color:#0000000d}.checkbox-label input[type=checkbox]{cursor:pointer}.error-message{padding:1rem;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid #dee2e6}.btn-primary{background-color:#007bff;color:#fff;border-color:#007bff}.btn-primary:hover:not(:disabled){background-color:#0056b3;border-color:#004085}.btn-secondary{background-color:#6c757d}.hand-input-mode-toggle{display:flex;gap:4px;margin-bottom:12px}.hand-input-mode-toggle .btn{font-size:.8rem;padding:4px 12px}.pbn-text-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.pbn-text-group{display:flex;flex-direction:column;gap:4px}.pbn-text-group label{font-weight:600;font-size:.85rem}.pbn-text-group input{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:.9rem}.card-picker-grid-container{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.validation-errors{background:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:12px;font-size:.85rem}.validation-errors ul{margin:4px 0 0 16px;padding:0}.validation-errors li{color:#856404}.field-error{color:#dc3545;font-size:.8rem}.btn-outline{background:transparent;border:1px solid #6c757d;color:#6c757d;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.btn-outline:hover:not(:disabled){background:#f8f9fa}.btn-secondary{color:#fff;border-color:#6c757d}.btn-secondary:hover:not(:disabled){background-color:#5a6268;border-color:#545b62}.btn-danger{background-color:#dc3545;color:#fff;border-color:#dc3545}.btn-danger:hover:not(:disabled){background-color:#c82333;border-color:#bd2130}.btn-sm{padding:.375rem .75rem;font-size:.875rem}@media(max-width:768px){.modal-content.question-editor{max-width:95vw;margin:1rem}.form-row,.pbn-grid,.pbn-text-grid,.card-picker-grid-container,.categories-checkboxes{grid-template-columns:1fr}}.conflict-dialog{max-width:900px}.conflict-content{padding:1.5rem 0}.conflict-message{margin-bottom:1.5rem;padding:1rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;color:#856404;font-size:.95rem}.version-comparison{display:grid;grid-template-columns:1fr auto 1fr;gap:1.5rem;align-items:start}.version-info{padding:1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px}.version-info h3{margin:0 0 .75rem;font-size:1rem;color:#333}.version-meta{margin-bottom:1rem;font-size:.85rem;color:#6c757d;line-height:1.6}.version-preview{font-size:.9rem}.version-preview strong{display:block;margin:.75rem 0 .25rem;color:#495057}.version-preview p{margin:0 0 .5rem;padding:.5rem;background:#fff;border:1px solid #dee2e6;border-radius:4px;line-height:1.4}.version-divider{display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:600;color:#6c757d;padding-top:3rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1.5rem;border-top:1px solid #dee2e6}@media(max-width:768px){.conflict-dialog{max-width:95vw;margin:1rem}.version-comparison{grid-template-columns:1fr}.version-divider{padding:0;transform:rotate(90deg);height:2rem}}.questions-page{padding:2rem;max-width:1400px;margin:0 auto}.questions-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.questions-page-header h1{margin:0 0 .5rem;font-size:2rem;color:#333}.page-subtitle{margin:0;color:#6c757d;font-size:1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-primary:hover{background-color:#0056b3;transform:translateY(-1px);box-shadow:0 2px 8px #007bff4d}.error-banner{padding:1rem 1.5rem;margin-bottom:1.5rem;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;font-size:1.5rem;color:#721c24;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s}.error-banner button:hover{opacity:1}@media(max-width:768px){.questions-page{padding:1rem}.questions-page-header{flex-direction:column;align-items:stretch}.questions-page-header h1{font-size:1.5rem}.btn{width:100%}}.category-manager{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.category-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.category-manager-header h3{margin:0;font-size:1.25rem;color:#1f2937}.category-table-container{overflow-x:auto;margin-bottom:1.5rem}.category-table{width:100%;border-collapse:collapse}.category-table th{background:#f9fafb;padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;font-size:.875rem}.category-table td{padding:1rem;border-bottom:1px solid #e5e7eb}.category-table tbody tr:hover{background:#f9fafb}.category-name{font-weight:500;color:#1f2937}.category-description{color:#6b7280;max-width:300px}.category-count{text-align:center}.category-actions{display:flex;gap:.5rem}@media(max-width:768px){.category-manager{padding:1rem}.category-table th,.category-table td{padding:.5rem;font-size:.875rem}.category-description{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-actions{flex-direction:column}}.categories-page{padding:2rem;max-width:1200px;margin:0 auto}.category-form{padding:1.5rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}@media(max-width:768px){.categories-page{padding:1rem}.page-header{flex-direction:column;gap:1rem}.page-header h1{font-size:1.5rem}.btn-primary{width:100%}.modal-content{max-width:100%}}.convention-manager{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.convention-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.convention-manager-header h3{margin:0;font-size:1.25rem;color:#1f2937}.btn-refresh{padding:.5rem 1rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.btn-refresh:hover{background:#e5e7eb}.empty-state{text-align:center;padding:3rem 1rem;color:#6b7280}.convention-table-container{overflow-x:auto;margin-bottom:1.5rem}.convention-table{width:100%;border-collapse:collapse}.convention-table th{background:#f9fafb;padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;font-size:.875rem}.convention-table td{padding:1rem;border-bottom:1px solid #e5e7eb}.convention-table tbody tr:hover{background:#f9fafb}.convention-name{font-weight:500;color:#1f2937;display:flex;align-items:center;gap:.5rem}.default-badge{display:inline-block;padding:.125rem .5rem;background:#fef3c7;color:#92400e;border-radius:4px;font-size:.75rem;font-weight:600}.convention-description{color:#6b7280;max-width:300px}.text-muted{color:#9ca3af;font-style:italic}.convention-status{text-align:center}.status-badge{display:inline-block;padding:.25rem .75rem;background:#f3f4f6;color:#6b7280;border-radius:12px;font-size:.875rem;font-weight:500}.status-badge.status-default{background:#fef3c7;color:#92400e}.convention-count{text-align:center}.count-badge{display:inline-block;padding:.25rem .75rem;background:#f3f4f6;color:#6b7280;border-radius:12px;font-size:.875rem;font-weight:500}.count-badge.has-questions{background:#dbeafe;color:#1e40af}.convention-actions{display:flex;gap:.5rem}.btn-action{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;font-size:.875rem;transition:all .2s}.btn-action:hover{background:#f9fafb}.btn-edit{color:#2563eb;border-color:#2563eb}.btn-edit:hover{background:#eff6ff}.btn-delete{color:#dc2626;border-color:#dc2626}.btn-delete:hover{background:#fef2f2}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding-top:1rem}.btn-page{padding:.5rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.btn-page:hover:not(:disabled){background:#f9fafb;border-color:#2563eb}.btn-page:disabled{opacity:.5;cursor:not-allowed}.page-info{color:#6b7280;font-size:.875rem}@media(max-width:768px){.convention-manager{padding:1rem}.convention-table th,.convention-table td{padding:.5rem;font-size:.875rem}.convention-description{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.convention-actions{flex-direction:column}.convention-name{flex-direction:column;align-items:flex-start}}.conventions-page{padding:2rem;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.page-header h1{margin:0 0 .5rem;color:#1f2937;font-size:1.875rem}.page-description{margin:0;color:#6b7280;font-size:.875rem}.btn-primary{padding:.75rem 1.5rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.error-banner{display:flex;justify-content:space-between;align-items:center;background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:1rem;border-radius:6px;margin-bottom:1.5rem}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#991b1b;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.loading-state{text-align:center;padding:3rem;color:#6b7280}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.25rem;color:#1f2937}.convention-form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem}.form-group input[type=text],.form-group textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-family:inherit}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{resize:vertical;min-height:80px}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer}.checkbox-label span{font-weight:500;color:#374151}.form-help{margin:.5rem 0 0 1.75rem;font-size:.75rem;color:#6b7280}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid #e5e7eb}.btn-secondary{padding:.75rem 1.5rem;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f9fafb}@media(max-width:768px){.conventions-page{padding:1rem}.page-header{flex-direction:column;gap:1rem}.page-header h1{font-size:1.5rem}.btn-primary{width:100%}.modal-content{max-width:100%}}.analytics-dashboard{padding:1rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.dashboard-header h2{margin:0;color:#2c3e50}.refresh-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.5rem 1rem;background:#4a5568;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;transition:background .2s}.refresh-btn:hover:not(:disabled){background:#2d3748}.refresh-btn:disabled{opacity:.7;cursor:not-allowed}.dashboard-loading,.dashboard-error{padding:2rem;text-align:center;border-radius:8px}.dashboard-loading{background:#f8f9fa;color:#6c757d}.dashboard-error{background:#fff5f5;color:#e53e3e;border:1px solid #feb2b2;display:flex;flex-direction:column;align-items:center;gap:1rem}.dashboard-error .refresh-btn{background:#e53e3e}.dashboard-error .refresh-btn:hover{background:#c53030}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.stat-card{display:flex;align-items:center;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{font-size:2.5rem;margin-right:1rem}.stat-content{flex:1}.stat-value{font-size:2rem;font-weight:700;line-height:1.2;color:#2c3e50}.stat-label{font-size:.875rem;color:#6c757d;margin-top:.25rem;text-transform:uppercase;letter-spacing:.5px}.stat-users{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-users .stat-value,.stat-users .stat-label{color:#fff}.stat-active{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.stat-active .stat-value,.stat-active .stat-label{color:#fff}.stat-questions{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.stat-questions .stat-value,.stat-questions .stat-label{color:#fff}.stat-attempts{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.stat-attempts .stat-value,.stat-attempts .stat-label{color:#fff}.stat-feedback{background:linear-gradient(135deg,#fa709a,#fee140);color:#fff}.stat-feedback .stat-value,.stat-feedback .stat-label{color:#fff}.dashboard-footer{text-align:center;padding-top:1rem;border-top:1px solid #e2e8f0}.dashboard-footer small{color:#6c757d;font-size:.75rem}@media(max-width:768px){.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1rem}.stat-icon{font-size:2rem}.stat-value{font-size:1.5rem}}.reports-view{padding:1rem}.reports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.reports-header h2{margin:0;color:#2c3e50}.btn-export{padding:.75rem 1.5rem;background:#4299e1;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.btn-export:hover{background:#3182ce}.report-tabs{display:flex;gap:.5rem;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;color:#6c757d;font-weight:600;cursor:pointer;transition:all .2s}.tab:hover{color:#2c3e50;background:#f8f9fa}.tab.active{color:#4299e1;border-bottom-color:#4299e1}.report-content{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.report-controls{margin-bottom:1.5rem}.report-controls label{display:flex;flex-direction:column;gap:.5rem;font-weight:600;color:#2c3e50}.report-controls select{padding:.5rem;border:1px solid #cbd5e0;border-radius:4px;font-size:1rem;max-width:200px}.report-loading,.report-error{padding:2rem;text-align:center;border-radius:8px}.report-loading{background:#f8f9fa;color:#6c757d}.report-error{background:#fff5f5;color:#e53e3e;border:1px solid #feb2b2}.report-results{margin-top:1.5rem}.report-meta{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:6px;color:#6c757d}.report-meta p{margin:0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-top:1rem}.metric-item{text-align:center;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;box-shadow:0 2px 8px #0000001a}.metric-value{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.metric-label{font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.table-wrapper{overflow-x:auto;margin-top:1rem}.performance-table{width:100%;border-collapse:collapse}.performance-table th{padding:.75rem;text-align:left;background:#f8f9fa;font-weight:600;color:#2c3e50;border-bottom:2px solid #e2e8f0}.performance-table td{padding:.75rem;border-bottom:1px solid #e2e8f0;color:#2c3e50}.performance-table tbody tr:hover{background:#f8f9fa}.question-text{max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#2c3e50}.text-center{text-align:center}.difficulty-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.difficulty-badge.beginner{background:#c6f6d5;color:#22543d}.difficulty-badge.intermediate{background:#feebc8;color:#7c2d12}.difficulty-badge.advanced{background:#fed7d7;color:#742a2a}.success-rate{font-weight:600}.success-rate.high{color:#38a169}.success-rate.medium{color:#d69e2e}.success-rate.low{color:#e53e3e}@media(max-width:768px){.reports-header{flex-direction:column;align-items:flex-start;gap:1rem}.report-tabs{flex-direction:column}.tab{text-align:left;border-left:3px solid transparent;border-bottom:none}.tab.active{border-left-color:#4299e1;border-bottom-color:transparent}.metrics-grid{grid-template-columns:1fr}.metric-value{font-size:2rem}.question-text{max-width:200px}}.analytics-page{max-width:1400px;margin:0 auto;padding:2rem}.page-header{margin-bottom:2rem}.page-header h1{margin:0 0 .5rem;color:#2c3e50;font-size:2rem}.page-description{margin:0;color:#6c757d;font-size:1rem}.dashboard-section{margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.reports-section{padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}@media(max-width:768px){.analytics-page{padding:1rem}.page-header h1{font-size:1.5rem}.dashboard-section,.reports-section{padding:1rem}}.feedback-manager{padding:1.5rem}.feedback-header{margin-bottom:2rem}.feedback-header h2{margin-bottom:1rem}.feedback-stats{display:flex;gap:1rem;flex-wrap:wrap}.stat-card{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:.375rem;padding:1rem;min-width:120px;display:flex;flex-direction:column;align-items:center}.stat-label{font-size:.875rem;color:#6c757d;margin-bottom:.5rem}.stat-value{font-size:1.5rem;font-weight:600;color:#212529}.feedback-filters{display:flex;gap:1.5rem;margin-bottom:1.5rem;padding:1rem;background-color:#f8f9fa;border-radius:.375rem}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-weight:500;color:#495057}.filter-select{padding:.375rem .75rem;border:1px solid #ced4da;border-radius:.25rem;font-size:1rem}.filter-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.feedback-table-container{overflow-x:auto;margin-bottom:1.5rem}.feedback-table{width:100%;border-collapse:collapse;background-color:#fff;box-shadow:0 1px 3px #0000001a}.feedback-table thead{background-color:#e9ecef}.feedback-table th,.feedback-table td{padding:.75rem;text-align:left;border-bottom:1px solid #dee2e6}.feedback-table th{font-weight:600;color:#495057}.feedback-table tbody tr:hover{background-color:#f8f9fa}.question-cell,.comments-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.github-cell{white-space:nowrap;text-align:center}.github-cell a{color:#0969da;text-decoration:none;font-weight:500}.github-cell a:hover{text-decoration:underline}.actions-cell{display:flex;gap:.5rem}.empty-state{text-align:center;padding:2rem;color:#6c757d}.feedback-status-badge,.feedback-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:.25rem;font-size:.875rem;font-weight:500}.feedback-status-badge.status-pending{background-color:#fff3cd;color:#856404}.feedback-status-badge.status-in_review{background-color:#cfe2ff;color:#084298}.feedback-status-badge.status-resolved{background-color:#d1e7dd;color:#0f5132}.feedback-status-badge.status-dismissed,.feedback-type-badge.feedback-type-error_report{background-color:#f8d7da;color:#842029}.feedback-type-badge.feedback-type-suggestion{background-color:#d1e7dd;color:#0f5132}.feedback-type-badge.feedback-type-unclear_question{background-color:#fff3cd;color:#856404}.feedback-type-badge.feedback-type-other{background-color:#e2e3e5;color:#41464b}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem}.page-info{font-size:.875rem;color:#6c757d}.loading-state,.error-state{text-align:center;padding:2rem}.error-message{color:#dc3545;font-weight:500}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px #0000001a;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.modal-header h2{margin:0;font-size:1.25rem}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#212529}.modal-body{padding:1.5rem}.feedback-detail-section{margin-bottom:1.5rem}.feedback-detail-section:last-child{margin-bottom:0}.feedback-detail-section h3{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:#495057}.question-text{padding:1rem;background-color:#f8f9fa;border-radius:.25rem;border-left:3px solid #007bff}.feedback-details-list{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem}.feedback-details-list dt{font-weight:600;color:#6c757d}.feedback-details-list dd{margin:0}.feedback-comments{padding:1rem;background-color:#f8f9fa;border-radius:.25rem;white-space:pre-wrap;word-wrap:break-word}.admin-notes-input{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:.25rem;font-family:inherit;font-size:1rem;resize:vertical}.admin-notes-input:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.admin-notes-input:disabled{background-color:#e9ecef;cursor:not-allowed}.admin-notes-actions{display:flex;justify-content:flex-end;margin-top:.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.section-header h3{margin:0}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #dee2e6}.btn{padding:.5rem 1rem;border:1px solid transparent;border-radius:.25rem;font-size:1rem;font-weight:400;cursor:pointer;transition:all .15s ease-in-out}.btn:disabled{opacity:.65;cursor:not-allowed}.btn-sm{padding:.25rem .5rem;font-size:.875rem}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover:not(:disabled){background-color:#218838}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-warning{background-color:#ffc107;color:#212529}.btn-warning:hover:not(:disabled){background-color:#e0a800}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover:not(:disabled){background-color:#138496}.github-issue-link{display:inline-block;padding:4px 10px;border-radius:4px;background-color:#f1f8ff;border:1px solid #c8e1ff;color:#0366d6;text-decoration:none;font-weight:500}.github-issue-link:hover{background-color:#dbedff}.promote-issue-modal{max-width:700px}.promote-issue-modal .form-group{margin-bottom:16px}.promote-issue-modal .form-group label{display:block;font-weight:600;margin-bottom:4px}.promote-issue-modal .form-control{width:100%;padding:8px 12px;border:1px solid var(--border-color, #dee2e6);border-radius:4px;font-size:.9rem;box-sizing:border-box}.issue-body-input{font-family:SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.85rem;resize:vertical}.labels-list{display:flex;gap:6px;flex-wrap:wrap}.label-badge{display:inline-block;padding:2px 8px;border-radius:12px;background-color:#e1ecf4;color:#0366d6;font-size:.8rem;font-weight:500}@media(max-width:768px){.feedback-stats{justify-content:center}.feedback-filters{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column;align-items:flex-start}.filter-select{width:100%}.actions-cell{flex-direction:column}.modal-content{width:95%}}.feedback-page{padding:2rem;max-width:1400px;margin:0 auto}.feedback-page-header{margin-bottom:2rem}.feedback-page-header h1{margin:0 0 .5rem;font-size:2rem;font-weight:600;color:#212529}.page-description{margin:0;font-size:1rem;color:#6c757d;line-height:1.5}@media(max-width:768px){.feedback-page{padding:1rem}.feedback-page-header h1{font-size:1.5rem}.page-description{font-size:.875rem}}.appeal-queue{padding:.5rem 0}.aq-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem;background:var(--bg-secondary, #f8f9fa);border-radius:8px}.aq-filters{display:flex;align-items:center;gap:.5rem}.aq-filters label{font-weight:600;font-size:.85rem}.aq-filters select{padding:.35rem .75rem;border:1px solid var(--border-color, #dee2e6);border-radius:6px;font-size:.85rem}.aq-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary, #6c757d);font-size:1rem}.aq-list{display:flex;flex-direction:column;gap:1rem}.appeal-card{border:1px solid var(--border-color, #dee2e6);border-radius:10px;padding:1rem 1.25rem;background:var(--bg-card, #fff);transition:box-shadow .15s}.appeal-card:hover{box-shadow:0 2px 8px #00000014}.appeal-card.appeal-approved{border-left:4px solid #198754}.appeal-card.appeal-rejected{border-left:4px solid #dc3545}.appeal-card.appeal-pending{border-left:4px solid #ffc107}.appeal-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.appeal-appellant{font-size:.9rem}.appeal-status-badge{display:inline-block;padding:.15rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.appeal-status-pending{background:#fff3cd;color:#856404}.appeal-status-approved{background:#d1e7dd;color:#0f5132}.appeal-status-rejected{background:#f8d7da;color:#842029}.appeal-date{margin-left:auto;font-size:.8rem;color:var(--text-secondary, #6c757d)}.appeal-reason{margin-bottom:.75rem;font-size:.9rem}.appeal-reason-label{font-weight:600}.appeal-comment-preview{background:var(--bg-secondary, #f8f9fa);border:1px solid var(--border-color, #dee2e6);border-radius:8px;padding:.75rem 1rem;margin-bottom:.75rem}.acp-header{font-size:.85rem;margin-bottom:.25rem}.acp-content{font-size:.9rem;line-height:1.5;margin-bottom:.5rem;word-break:break-word}.acp-meta{font-size:.78rem;color:var(--text-secondary, #6c757d)}.appeal-resolution{margin-bottom:.75rem;padding:.5rem .75rem;background:var(--bg-info, #e8f4fd);border-radius:6px;font-size:.85rem}.appeal-resolution-label{font-weight:600}.appeal-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.appeal-notes-form{width:100%}.appeal-notes-input{width:100%;padding:.5rem;border:1px solid var(--border-color, #dee2e6);border-radius:6px;font-size:.85rem;resize:vertical;margin-bottom:.5rem;font-family:inherit}.appeal-notes-actions{display:flex;gap:.5rem}.aq-pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color, #dee2e6);font-size:.85rem}.aq-pagination button{padding:.3rem .75rem;border:1px solid var(--border-color, #dee2e6);border-radius:6px;background:var(--bg-card, #fff);cursor:pointer;font-size:.85rem}.aq-pagination button:disabled{opacity:.5;cursor:not-allowed}.aq-pagination button:hover:not(:disabled){background:var(--bg-secondary, #f8f9fa)}.user-ban-manager{position:relative}.ban-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.ban-header h2{margin:0;font-size:1.25rem}.ban-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;background:var(--bg-secondary, #f8f9fa);border-radius:8px}.ban-toolbar label{font-weight:600;font-size:.85rem}.ban-toolbar select{padding:.35rem .75rem;border:1px solid var(--border-color, #dee2e6);border-radius:6px;font-size:.85rem}.ban-count{margin-left:auto;font-size:.85rem;color:var(--text-secondary, #6c757d)}.ban-form{background:var(--bg-secondary, #f8f9fa);border:1px solid var(--border-color, #dee2e6);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.ban-form h3{margin:0 0 1rem;font-size:1rem}.ban-form-error{background:#fee2e2;color:#b91c1c;padding:.5rem .75rem;border-radius:6px;margin-bottom:1rem;font-size:.85rem}.ban-form-row{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.ban-form-row label{font-weight:600;font-size:.85rem}.ban-form-row input,.ban-form-row select,.ban-form-row textarea{padding:.5rem .75rem;border:1px solid var(--border-color, #dee2e6);border-radius:6px;font-size:.9rem}.ban-form-row textarea{resize:vertical}.ban-table-wrapper{overflow-x:auto}.ban-table{width:100%;border-collapse:collapse;font-size:.875rem}.ban-table th{text-align:left;padding:.6rem .75rem;border-bottom:2px solid var(--border-color, #dee2e6);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-secondary, #6c757d);white-space:nowrap}.ban-table td{padding:.6rem .75rem;border-bottom:1px solid var(--border-color, #dee2e620);vertical-align:middle}.ban-row:hover{background:var(--bg-hover, #f8f9fa)}.ban-cell-user{min-width:160px}.ban-user-name{font-weight:600}.ban-user-id{font-size:.75rem;color:var(--text-secondary, #6c757d);font-family:monospace}.ban-cell-reason{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ban-empty{text-align:center;padding:2rem!important;color:var(--text-secondary, #6c757d)}.badge-banned{background:#fee2e2;color:#b91c1c}.badge-expired{background:#fef3c7;color:#92400e}.badge-lifted{background:#d1fae5;color:#065f46}.mod-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color, #dee2e6);margin-bottom:1rem}.mod-tab{padding:.75rem 1.25rem;border:none;background:none;cursor:pointer;font-size:.95rem;font-weight:500;color:var(--text-muted, #6c757d);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:.5rem}.mod-tab:hover{color:var(--text-color, #212529)}.mod-tab.active{color:var(--primary-color, #0d6efd);border-bottom-color:var(--primary-color, #0d6efd)}.flag-badge{background:#dc3545;color:#fff;font-size:.75rem;padding:.15rem .5rem;border-radius:10px;font-weight:600}.appeal-count-badge{background:#ffc107;color:#000;font-size:.75rem;padding:.15rem .5rem;border-radius:10px;font-weight:600}.mod-toast{position:fixed;top:1rem;right:1rem;background:#198754;color:#fff;padding:.75rem 1.25rem;border-radius:6px;font-weight:500;z-index:1050;animation:fadeInOut 3s ease-in-out}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-10px)}10%{opacity:1;transform:translateY(0)}85%{opacity:1}to{opacity:0}}.mod-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem}.mod-filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.mod-filters label{font-size:.85rem;font-weight:500;color:var(--text-muted, #6c757d)}.mod-filters select{padding:.35rem .75rem;border:1px solid var(--border-color, #dee2e6);border-radius:4px;font-size:.85rem;background:var(--bg-color, white);color:var(--text-color, #212529)}.mod-bulk-bar{display:flex;align-items:center;gap:.5rem;background:var(--bg-secondary, #f8f9fa);padding:.5rem .75rem;border-radius:6px;border:1px solid var(--border-color, #dee2e6)}.bulk-count{font-size:.85rem;font-weight:600;margin-right:.25rem}.bulk-reason-input{margin-top:.5rem}.bulk-reason-input label{display:block;font-size:.85rem;margin-bottom:.25rem}.bulk-reason-input input{width:100%;padding:.4rem .6rem;border:1px solid var(--border-color, #dee2e6);border-radius:4px;font-size:.85rem}.mod-table-wrapper{overflow-x:auto}.mod-table{width:100%;border-collapse:collapse;font-size:.875rem}.mod-table th{text-align:left;padding:.6rem .5rem;border-bottom:2px solid var(--border-color, #dee2e6);font-weight:600;font-size:.8rem;text-transform:uppercase;color:var(--text-muted, #6c757d);white-space:nowrap}.mod-table td{padding:.6rem .5rem;border-bottom:1px solid var(--border-light, #f0f0f0);vertical-align:top}.mod-row:hover{background:var(--bg-hover, #f8f9fa)}.mod-row.selected{background:var(--bg-selected, #e8f0fe)}.mod-th-checkbox,.mod-cell-checkbox{width:40px;text-align:center}.mod-cell-status{width:80px}.mod-cell-author{min-width:120px;max-width:160px}.author-name{font-weight:500}.mod-cell-content{max-width:300px}.content-preview{word-break:break-word;line-height:1.4}.edited-tag,.moderation-tag{display:inline-block;font-size:.75rem;margin-top:.25rem;padding:.1rem .4rem;border-radius:3px}.edited-tag{background:#fff3cd;color:#856404}.moderation-tag{background:#f8d7da;color:#842029}.mod-cell-question{max-width:180px;font-size:.8rem;color:var(--text-muted, #6c757d)}.mod-cell-stats{white-space:nowrap}.mod-cell-stats span{margin-right:.5rem}.flag-count{color:#dc3545;font-weight:500}.mod-cell-date{white-space:nowrap;font-size:.8rem;color:var(--text-muted, #6c757d)}.mod-cell-actions{white-space:nowrap}.mod-empty{text-align:center;padding:2rem;color:var(--text-muted, #6c757d)}.badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.badge-active{background:#d1e7dd;color:#0f5132}.badge-deleted{background:#f8d7da;color:#842029}.badge-hidden{background:#fff3cd;color:#856404}.btn-sm{padding:.3rem .7rem;font-size:.8rem;border-radius:4px;border:1px solid transparent;cursor:pointer;font-weight:500}.btn-primary{background:#0d6efd;color:#fff;border-color:#0d6efd}.btn-primary:hover{background:#0b5ed7}.btn-secondary{background:#6c757d;color:#fff;border-color:#6c757d}.btn-secondary:hover{background:#5c636a}.btn-danger{background:#dc3545;color:#fff;border-color:#dc3545}.btn-danger:hover{background:#bb2d3b}.btn-warning{background:#ffc107;color:#000;border-color:#ffc107}.btn-warning:hover{background:#ffca2c}.btn-approve{background:#198754;color:#fff;border-color:#198754}.btn-approve:hover{background:#157347}.btn-icon{background:none;border:none;cursor:pointer;padding:.2rem .4rem;font-size:1rem;border-radius:4px}.btn-icon:hover{background:var(--bg-hover, #e9ecef)}.btn-sm:disabled,.btn-icon:disabled{opacity:.5;cursor:not-allowed}.mod-edit-row td{background:var(--bg-secondary, #f8f9fa)}.mod-edit-form{padding:.5rem}.mod-edit-textarea{width:100%;padding:.5rem;border:1px solid var(--border-color, #dee2e6);border-radius:4px;font-family:inherit;font-size:.875rem;resize:vertical}.mod-edit-actions{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.char-count{font-size:.75rem;color:var(--text-muted, #6c757d);margin-left:auto}.mod-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:.5rem 0}.pagination-info{font-size:.85rem;color:var(--text-muted, #6c757d)}.pagination-controls{display:flex;align-items:center;gap:.25rem}.pagination-controls button{padding:.3rem .6rem;border:1px solid var(--border-color, #dee2e6);background:var(--bg-color, white);border-radius:4px;cursor:pointer;font-size:.85rem}.pagination-controls button:hover:not(:disabled){background:var(--bg-hover, #e9ecef)}.pagination-controls button:disabled{opacity:.4;cursor:not-allowed}.pagination-page{padding:0 .5rem;font-size:.85rem}.mod-loading{text-align:center;padding:2rem;color:var(--text-muted, #6c757d)}.mod-error{background:#f8d7da;color:#842029;padding:.75rem 1rem;border-radius:6px;display:flex;justify-content:space-between;align-items:center}.mod-error button{background:#fff;border:1px solid #842029;color:#842029;padding:.3rem .7rem;border-radius:4px;cursor:pointer}.fq-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.fq-filters{display:flex;align-items:center;gap:.5rem}.fq-filters label{font-size:.85rem;font-weight:500;color:var(--text-muted, #6c757d)}.fq-filters select{padding:.35rem .75rem;border:1px solid var(--border-color, #dee2e6);border-radius:4px;font-size:.85rem;background:var(--bg-color, white)}.fq-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted, #6c757d);font-size:1.1rem}.fq-list{display:flex;flex-direction:column;gap:.75rem}.flag-card{border:1px solid var(--border-color, #dee2e6);border-radius:8px;padding:1rem;background:var(--bg-color, white)}.flag-card.flag-pending{border-left:4px solid #ffc107}.flag-card.flag-approved{border-left:4px solid #198754;opacity:.7}.flag-card.flag-rejected{border-left:4px solid #dc3545;opacity:.7}.flag-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.flag-reason{font-weight:600;font-size:.9rem}.flag-status-badge{font-size:.75rem;padding:.15rem .5rem;border-radius:4px;font-weight:500}.flag-status-pending{background:#fff3cd;color:#856404}.flag-status-approved{background:#d1e7dd;color:#0f5132}.flag-status-rejected{background:#f8d7da;color:#842029}.flag-date{font-size:.8rem;color:var(--text-muted, #6c757d);margin-left:auto}.flag-reporter{font-size:.85rem;margin-bottom:.75rem}.flag-description{margin:.25rem 0 0;font-style:italic;color:var(--text-muted, #6c757d)}.flag-comment-preview{background:var(--bg-secondary, #f8f9fa);border-radius:6px;padding:.75rem;margin-bottom:.75rem}.fcp-header{font-size:.85rem;margin-bottom:.35rem}.fcp-content{font-size:.875rem;line-height:1.5;word-break:break-word}.fcp-meta{font-size:.75rem;color:var(--text-muted, #6c757d);margin-top:.35rem}.flag-actions{display:flex;gap:.5rem;flex-wrap:wrap}.flag-notes-form{width:100%}.flag-notes-input{width:100%;padding:.4rem .6rem;border:1px solid var(--border-color, #dee2e6);border-radius:4px;font-family:inherit;font-size:.85rem;resize:vertical;margin-bottom:.5rem}.flag-notes-actions{display:flex;gap:.5rem}.fq-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:.5rem 0;font-size:.85rem}.fq-pagination button{padding:.3rem .7rem;border:1px solid var(--border-color, #dee2e6);background:var(--bg-color, white);border-radius:4px;cursor:pointer}.fq-pagination button:hover:not(:disabled){background:var(--bg-hover, #e9ecef)}.fq-pagination button:disabled{opacity:.4;cursor:not-allowed}.mod-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.mod-dialog{background:var(--bg-color, white);border-radius:12px;padding:1.5rem;width:min(480px,90vw);box-shadow:0 20px 60px #0000004d}.mod-dialog h3{margin:0 0 .75rem}.mod-dialog p{margin:0 0 1rem;font-size:.9rem;color:var(--text-secondary, #6c757d)}.mod-dialog-field{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.mod-dialog-field label{font-weight:600;font-size:.85rem}.mod-dialog-field textarea{padding:.5rem .75rem;border:1px solid var(--border-color, #dee2e6);border-radius:6px;font-size:.9rem;resize:vertical}.mod-dialog-actions{display:flex;gap:.5rem;justify-content:flex-end}.admin-moderation-page{max-width:1400px;margin:0 auto;padding:1.5rem}.admin-moderation-page .page-header{margin-bottom:1.5rem}.admin-moderation-page .page-header h1{font-size:1.5rem;font-weight:600;margin:0 0 .25rem}.page-subtitle{font-size:.9rem;color:var(--text-muted, #6c757d);margin:0}.pending-queue{display:flex;flex-direction:column;gap:1rem}.pq-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.pq-toolbar__left,.pq-toolbar__right{display:flex;align-items:center;gap:.75rem}.pq-count{font-weight:600;font-size:.95rem}.pq-selected-count{font-size:.85rem;color:var(--text-muted, #666)}.pq-filter-select{padding:.3rem .5rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-size:.85rem;background:var(--surface, #fff);color:var(--text, #333)}.pq-loading{padding:2rem;text-align:center;color:var(--text-muted, #666)}.pq-empty{padding:2rem;text-align:center;color:var(--text-muted, #666);border:1px dashed var(--border-color, #ccc);border-radius:6px}.pq-table{width:100%;border-collapse:collapse;font-size:.9rem}.pq-table th{text-align:left;padding:.6rem .75rem;border-bottom:2px solid var(--border-color, #ddd);font-weight:600;white-space:nowrap}.pq-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-color, #eee);vertical-align:middle}.pq-th-check,.pq-td-check{width:2.5rem;text-align:center}.pq-row:hover{background:var(--hover-bg, #f7f7f7)}.pq-row--selected{background:var(--selected-bg, #eef4ff)}.pq-question-link{all:unset;cursor:pointer;color:var(--link-color, #0066cc);text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s}.pq-question-link:hover,.pq-question-link:focus-visible{text-decoration-color:currentColor}.pq-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.1rem .4rem;border-radius:3px;margin-left:.4rem;vertical-align:middle}.pq-badge--ai{background:#e0f0ff;color:#0057a3}.pq-duplicate-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;color:#b45300;background:#fff3cd;padding:.15rem .5rem;border-radius:3px}.pq-duplicate-score{font-weight:400;font-size:.7rem}.pq-difficulty{text-transform:capitalize}.pq-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .75rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-size:.85rem;cursor:pointer;background:var(--surface, #fff);color:var(--text, #333);transition:opacity .15s}.pq-btn:disabled{opacity:.5;cursor:not-allowed}.pq-btn--sm{padding:.25rem .5rem;font-size:.8rem}.pq-btn--approve{background:#d4edda;color:#155724;border-color:#c3e6cb}.pq-btn--approve:hover:not(:disabled){background:#c3e6cb}.pq-btn--reject{background:#f8d7da;color:#721c24;border-color:#f5c6cb}.pq-btn--reject:hover:not(:disabled){background:#f5c6cb}.pq-btn--page{min-width:5rem;justify-content:center}.pq-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding-top:.5rem}.pq-page-info{font-size:.85rem;color:var(--text-muted, #666)}.question-review{display:flex;flex-direction:column;gap:1.25rem}.qr-back{all:unset;cursor:pointer;font-size:.85rem;color:var(--link-color, #0066cc);align-self:flex-start}.qr-back:hover{text-decoration:underline}.qr-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.qr-title{margin:0;font-size:1.3rem}.qr-badges{display:flex;gap:.5rem;align-items:center}.qr-status{font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:10px;text-transform:uppercase;background:#fff8e1;color:#735c0f}.qr-badge{font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:10px}.qr-badge--ai{background:#e8daef;color:#6f42c1}.qr-badge--dup{background:#fff3cd;color:#b45300}.qr-meta,.qr-deal-info{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.875rem}.qr-hands-section{display:flex;flex-direction:column;gap:.5rem}.qr-hands-header{display:flex;align-items:center}.qr-hands-toggle{all:unset;cursor:pointer;font-size:.85rem;color:var(--link-color, #0066cc);font-weight:500}.qr-hands-toggle:hover{text-decoration:underline}.qr-hands{display:flex;flex-wrap:wrap;gap:1.5rem}.qr-hands--all{display:flex;flex-direction:column;align-items:center;gap:.25rem}.qr-hands__row{display:flex;justify-content:center;gap:3rem}.qr-hands__row--top,.qr-hands__row--bottom{justify-content:center}.qr-hands__row--middle{justify-content:center;gap:6rem}.qr-section h3{font-size:1rem;margin:0 0 .5rem}.qr-question-text{margin:0;line-height:1.5}.qr-edit-textarea{width:100%;padding:.6rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-family:inherit;font-size:.9rem;resize:vertical}.qr-inline-input{padding:.4rem .5rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-family:inherit;font-size:.85rem;flex:1}.qr-inline-input--marks{max-width:5rem;flex:0 0 auto}.qr-inline-textarea{width:100%;padding:.4rem .5rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-family:inherit;font-size:.85rem;resize:vertical}.qr-inline-select{padding:.2rem .4rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-size:.85rem}.qr-answers{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.qr-answer{border:1px solid var(--border-color, #e1e4e8);border-radius:6px;padding:.6rem .85rem;background:var(--bg-subtle, #fafbfc)}.qr-answer__header{display:flex;justify-content:space-between;align-items:center}.qr-answer__text{font-weight:600}.qr-answer__marks{font-size:.8rem;font-weight:600;color:var(--primary-color, #2ea44f)}.qr-answer__rationale{margin:.35rem 0 0;font-size:.85rem;color:var(--text-muted, #586069);line-height:1.4}.qr-answer-edit{display:flex;flex-direction:column;gap:.4rem}.qr-answer-edit__row{display:flex;gap:.5rem}.qr-reject-form{display:flex;flex-direction:column;gap:.4rem;padding:1rem;background:#fff5f5;border:1px solid #f5c6cb;border-radius:6px}.qr-reject-form label{font-weight:600;font-size:.9rem}.qr-required{color:#dc3545}.qr-reject-textarea{width:100%;padding:.6rem;border:1px solid #f5c6cb;border-radius:4px;font-family:inherit;font-size:.9rem;resize:vertical}.qr-reject-error{margin:0;font-size:.8rem;color:#dc3545}.qr-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color, #e1e4e8)}.qr-actions__left,.qr-actions__right{display:flex;gap:.5rem;align-items:center}.qr-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem 1rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-size:.85rem;cursor:pointer;background:var(--surface, #fff);color:var(--text, #333);transition:opacity .15s}.qr-btn:disabled{opacity:.5;cursor:not-allowed}.qr-btn--approve{background:#d4edda;color:#155724;border-color:#c3e6cb;font-weight:600}.qr-btn--approve:hover:not(:disabled){background:#c3e6cb}.qr-btn--reject{background:#f8d7da;color:#721c24;border-color:#f5c6cb;font-weight:600}.qr-btn--reject:hover:not(:disabled){background:#f5c6cb}.qr-btn--edit{background:#e2e6ea;color:#333}.qr-btn--edit:hover:not(:disabled){background:#d6dadf}.qr-btn--snapshot{background:#e0f0ff;color:#0057a3;border-color:#b8daff}.qr-btn--snapshot:hover:not(:disabled){background:#cce5ff}.qr-btn--save,.qr-btn--cancel{background:#e2e6ea;color:#333}.qr-status--pending{background:#fff8e1;color:#735c0f}.qr-status--draft{background:#e8eaed;color:#5f6368}.qr-status--approved{background:#d4edda;color:#155724}.qr-status--rejected{background:#f8d7da;color:#721c24}.qr-inline-feedback{margin-top:.35rem}.qr-inline-feedback__toggle{all:unset;cursor:pointer;font-size:.78rem;color:var(--link-color, #6f42c1);font-weight:500}.qr-inline-feedback__toggle:hover{text-decoration:underline}.qr-inline-feedback__input{display:block;width:100%;margin-top:.3rem;padding:.5rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-family:inherit;font-size:.85rem;resize:vertical;transition:border-color .15s}.qr-inline-feedback__input:focus{outline:none;border-color:#6f42c1;box-shadow:0 0 0 2px #6f42c126}.qr-feedback-section{padding:.75rem 0}.qr-feedback-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.qr-feedback-hint{font-size:.82rem;color:var(--text-muted, #586069);font-style:italic}.qr-btn--refine{background:linear-gradient(135deg,#6f42c1,#8b5cf6);color:#fff;border:none;font-weight:600;padding:.55rem 1.25rem;border-radius:6px;cursor:pointer;transition:opacity .15s}.qr-btn--refine:hover:not(:disabled){opacity:.9}.qr-btn--refine:disabled{opacity:.5;cursor:not-allowed}.qr-submission-notes{margin:0;padding:.75rem;background:var(--bg-subtle, #f6f8fa);border-left:3px solid var(--border-color, #ddd);border-radius:4px;font-size:.9rem;line-height:1.5;white-space:pre-wrap}.qr-loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted, #586069);font-size:.9rem}.qr-error{padding:1rem;background:#fff5f5;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-size:.9rem}@media(max-width:768px){.qr-actions{flex-direction:column;align-items:stretch}.qr-actions__left,.qr-actions__right{flex-wrap:wrap}.qr-hands:not(.qr-hands--all){flex-direction:column}.qr-hands__row--middle{gap:2rem}.qr-feedback-actions{flex-direction:column;align-items:stretch}}.sc-backdrop{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000073}.sc-dialog{background:var(--surface, #fff);border-radius:8px;width:90vw;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 8px 30px #0003}.sc-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #e1e4e8)}.sc-header h2{margin:0;font-size:1.15rem}.sc-close{all:unset;cursor:pointer;font-size:1.4rem;line-height:1;color:var(--text-muted, #666)}.sc-close:hover{color:var(--text, #333)}.sc-content{padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.sc-loading,.sc-error,.sc-empty{padding:2rem;text-align:center}.sc-error{color:#dc3545}.sc-row__label{font-size:.95rem;margin:0 0 .5rem}.sc-columns{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.sc-col{padding:.75rem;border:1px solid var(--border-color, #e1e4e8);border-radius:6px;background:var(--bg-subtle, #fafbfc)}.sc-col__heading{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #586069);margin-bottom:.35rem}.sc-col--original{background:#f6f8fa}.sc-col--current{background:#fafbfc}.sc-col p{margin:0;line-height:1.5;white-space:pre-wrap}.sc-changed{background:#fff8c5!important;border-color:#e3b341!important}.sc-answer-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.sc-answer{padding:.4rem .6rem;border:1px solid var(--border-color, #e1e4e8);border-radius:4px;background:#fff}.sc-answer__text{font-weight:600;margin-right:.5rem}.sc-answer__marks{font-size:.8rem;color:var(--primary-color, #2ea44f)}.sc-answer__rationale{margin:.25rem 0 0;font-size:.8rem;color:var(--text-muted, #586069)}.sc-footer{display:flex;justify-content:flex-end;padding:.75rem 1.25rem;border-top:1px solid var(--border-color, #e1e4e8)}.sc-btn{padding:.45rem 1rem;border:1px solid var(--border-color, #ccc);border-radius:4px;background:var(--surface, #fff);cursor:pointer;font-size:.85rem}.sc-btn:hover{background:#f0f0f0}.sc-meta{font-size:.75rem;color:var(--text-muted, #586069);margin:0}@media(max-width:640px){.sc-columns{grid-template-columns:1fr}.sc-dialog{width:95vw}}.pending-review-page{display:flex;flex-direction:column;gap:1.25rem;max-width:1100px;margin:0 auto;padding:1rem}.prp-title{margin:0;font-size:1.4rem}.prp-error{padding:.75rem 1rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-size:.9rem;display:flex;align-items:center;gap:1rem}.prp-btn--back{padding:.4rem .8rem;border:1px solid #721c24;border-radius:4px;background:transparent;color:#721c24;cursor:pointer;font-size:.85rem;white-space:nowrap}.prp-btn--back:hover{background:#721c24;color:#fff}.prp-loading{padding:2rem;text-align:center;color:#6c757d;font-size:1rem}.prp-inline-prompt{display:flex;flex-direction:column;gap:.4rem;padding:1rem;background:#fff5f5;border:1px solid #f5c6cb;border-radius:6px}.prp-inline-prompt label{font-weight:600;font-size:.9rem}.prp-inline-prompt textarea{width:100%;padding:.5rem;border:1px solid #f5c6cb;border-radius:4px;font-family:inherit;font-size:.9rem;resize:vertical}.prp-inline-prompt__actions{display:flex;gap:.5rem;justify-content:flex-end}.prp-inline-prompt__actions button{padding:.4rem .75rem;border:1px solid var(--border-color, #ccc);border-radius:4px;cursor:pointer;font-size:.85rem;background:var(--surface, #fff)}.prp-inline-prompt__actions button:disabled{opacity:.5;cursor:not-allowed}.prp-btn--reject{background:#f8d7da!important;color:#721c24!important;border-color:#f5c6cb!important;font-weight:600}.bulk-generate-form{padding:1rem}.bulk-generate-form h3{margin-bottom:.5rem}.bulk-generate-form .form-description{color:var(--text-secondary, #6b7280);margin-bottom:1.5rem;font-size:.875rem}.bulk-generate-form .form-group{margin-bottom:1rem}.bulk-generate-form .form-group label{display:block;font-weight:600;margin-bottom:.5rem}.bulk-generate-form .checkbox-group{display:flex;flex-wrap:wrap;gap:.75rem}.bulk-generate-form .checkbox-label{display:flex;align-items:center;gap:.25rem;font-weight:400;cursor:pointer}.bulk-generate-form select,.bulk-generate-form input[type=number]{width:100%;max-width:300px;padding:.5rem;border:1px solid var(--border-color, #d1d5db);border-radius:.375rem;font-size:.875rem}.bulk-generate-form .btn{margin-top:1rem}.bulk-generate-form .alert{margin-top:1rem;padding:.75rem 1rem;border-radius:.375rem;font-size:.875rem}.bulk-generate-form .alert-success{background-color:var(--success-bg, #d1fae5);color:var(--success-text, #065f46);border:1px solid var(--success-border, #6ee7b7)}.bulk-generate-form .alert-error{background-color:var(--error-bg, #fee2e2);color:var(--error-text, #991b1b);border:1px solid var(--error-border, #fca5a5)}.bulk-import-form{margin-top:2rem}.bulk-import-form h3{margin-bottom:.5rem}.bulk-import-form .form-description{color:var(--text-secondary, #666);margin-bottom:1rem;font-size:.9rem}.drop-zone{border:2px dashed var(--border-color, #ccc);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:background-color .2s,border-color .2s;margin-bottom:1rem}.drop-zone:hover,.drop-zone.drop-active{background-color:var(--bg-highlight, #f0f4ff);border-color:var(--primary-color, #4a6fa5)}.drop-placeholder .drop-icon{font-size:2rem;display:block;margin-bottom:.5rem}.drop-placeholder p{margin:.25rem 0}.drop-formats{font-size:.8rem;color:var(--text-secondary, #888)}.selected-file{display:flex;align-items:center;justify-content:center;gap:.5rem}.template-downloads{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.template-label{font-size:.85rem;color:var(--text-secondary, #666)}.template-downloads .btn-outline{background:transparent;border:1px solid var(--border-color, #ccc);color:var(--text-primary, #333);padding:4px 10px;border-radius:4px;cursor:pointer;font-size:.8rem}.template-downloads .btn-outline:hover:not(:disabled){background:var(--hover-bg, #f0f0f0)}.selected-file .file-icon{font-size:1.5rem}.selected-file .file-name{font-weight:600}.selected-file .file-size{color:var(--text-secondary, #888);font-size:.85rem}.question-export-form{margin-top:2rem}.question-export-form h3{margin-bottom:.5rem}.question-export-form .form-description{color:var(--text-secondary, #666);margin-bottom:1rem;font-size:.9rem}.filter-group{border:1px solid var(--border-color, #ddd);border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem}.filter-group legend{font-weight:600;font-size:.9rem;padding:0 .25rem}.checkbox-grid{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem}.checkbox-label{display:flex;align-items:center;gap:.35rem;cursor:pointer;font-size:.9rem}.export-preview{margin-bottom:.75rem;font-size:.95rem}.delete-checkbox{margin-bottom:1rem;color:var(--danger-color, #d9534f)}.confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-dialog{background:var(--bg-primary, #fff);border-radius:8px;padding:1.5rem;max-width:420px;width:90%;box-shadow:0 4px 20px #0003}.confirm-dialog h4{margin-top:0;margin-bottom:.75rem}.confirm-actions{display:flex;gap:.75rem;margin-top:1rem}.btn-danger{background-color:var(--danger-color, #d9534f);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.btn-danger:hover{background-color:#c9302c}.btn-secondary{background-color:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, #ddd);padding:.5rem 1rem;border-radius:4px;cursor:pointer}.jobs-status-page{width:100%}.jobs-loading,.jobs-error,.jobs-empty{padding:2rem;text-align:center;color:var(--text-secondary, #6b7280)}.jobs-error{color:var(--error-text, #991b1b)}.jobs-table{width:100%;border-collapse:collapse}.jobs-table th{text-align:left;padding:.75rem;font-weight:600;font-size:.75rem;text-transform:uppercase;color:var(--text-secondary, #6b7280);border-bottom:2px solid var(--border-color, #e5e7eb)}.jobs-table td{padding:.75rem;border-bottom:1px solid var(--border-color, #e5e7eb);font-size:.875rem}.job-row:hover{background-color:var(--hover-bg, #f9fafb)}.progress-cell{display:flex;align-items:center;gap:.5rem}.progress-bar{flex:1;height:.5rem;background-color:var(--border-color, #e5e7eb);border-radius:9999px;overflow:hidden;max-width:120px}.progress-fill{height:100%;background-color:var(--primary, #3b82f6);border-radius:9999px;transition:width .3s ease}.progress-text{font-size:.75rem;color:var(--text-secondary, #6b7280);white-space:nowrap}.jobs-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem}.jobs-pagination button{padding:.375rem .75rem;border:1px solid var(--border-color, #d1d5db);border-radius:.375rem;background:#fff;cursor:pointer;font-size:.875rem}.jobs-pagination button:disabled{opacity:.5;cursor:not-allowed}.job-detail{padding:1rem}.job-detail-loading{padding:2rem;text-align:center;color:var(--text-secondary, #6b7280)}.job-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.job-detail-header h3{margin:0}.job-progress-section{margin-bottom:1.5rem}.progress-bar-large{height:1rem;background-color:var(--border-color, #e5e7eb);border-radius:9999px;overflow:hidden;margin-bottom:.5rem}.progress-bar-large .progress-fill{height:100%;background-color:var(--primary, #3b82f6);border-radius:9999px;transition:width .3s ease}.progress-stats{display:flex;gap:1.5rem;font-size:.875rem;color:var(--text-secondary, #6b7280)}.job-actions{display:flex;gap:.75rem;align-items:center;margin-bottom:1.5rem}.confirm-cancel{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.error-summary{background-color:var(--error-bg, #fee2e2);border:1px solid var(--error-border, #fca5a5);border-radius:.5rem;padding:1rem;margin-bottom:1.5rem}.error-summary h4{margin:0 0 .5rem;color:var(--error-text, #991b1b)}.error-summary ul{margin:0;padding-left:1.5rem;font-size:.875rem}.job-items-section{margin-bottom:1.5rem}.job-items-section h4{margin-bottom:.75rem}.item-states-grid{display:flex;flex-wrap:wrap;gap:.5rem}.item-state{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;background-color:#f3f4f6}.item-pending{background-color:#f3f4f6}.item-processed{background-color:#d1fae5}.item-failed{background-color:#fee2e2}.item-status-dot{width:8px;height:8px;border-radius:50%}.dot-pending{background-color:#9ca3af}.dot-processed{background-color:#10b981}.dot-failed{background-color:#ef4444}.item-error{cursor:help}.job-log-section{margin-bottom:1.5rem}.job-log-section h4{margin-bottom:.75rem}.execution-log{max-height:300px;overflow-y:auto;border:1px solid var(--border-color, #e5e7eb);border-radius:.375rem;font-family:monospace;font-size:.8125rem}.log-entry{display:flex;gap:.75rem;padding:.375rem .75rem;border-bottom:1px solid var(--border-color, #f3f4f6)}.log-entry:last-child{border-bottom:none}.log-time{color:var(--text-secondary, #6b7280);min-width:80px}.log-level{font-weight:600;min-width:50px}.level-info{color:#3b82f6}.level-warning{color:#f59e0b}.level-error{color:#ef4444}.log-message{flex:1}.log-error{background-color:#fef2f2}.job-metadata{border-top:1px solid var(--border-color, #e5e7eb);padding-top:1rem}.job-metadata dl{display:grid;grid-template-columns:auto 1fr;gap:.375rem 1rem;font-size:.875rem}.job-metadata dt{font-weight:600;color:var(--text-secondary, #6b7280)}.job-metadata dd{margin:0}.badge-gray{background-color:#e5e7eb;color:#374151}.badge-blue{background-color:#dbeafe;color:#1e40af}.badge-green{background-color:#d1fae5;color:#065f46}.badge-red{background-color:#fee2e2;color:#991b1b}.badge-amber{background-color:#fef3c7;color:#92400e}.status-badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.btn{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;cursor:pointer}.btn-primary{background-color:#3b82f6;color:#fff}.btn-secondary{background-color:#e5e7eb;color:#374151}.btn-warning{background-color:#f59e0b;color:#fff}.btn-danger{background-color:#ef4444;color:#fff}.btn-text{background:none;color:#3b82f6;padding:.25rem .5rem}.btn:disabled{opacity:.5;cursor:not-allowed}.audit-log h3,.audit-filters{margin-bottom:1rem}.filter-input{padding:.4rem .75rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:.9rem;width:300px}.audit-table{width:100%;border-collapse:collapse;font-size:.9rem}.audit-table th,.audit-table td{padding:.5rem .6rem;text-align:left;border-bottom:1px solid var(--border-color, #eee)}.audit-table th{font-weight:600;font-size:.8rem;color:var(--text-secondary, #666);text-transform:uppercase}.time-cell{white-space:nowrap;font-size:.8rem}.ip-cell{font-family:monospace;font-size:.8rem}.outcome-badge{display:inline-block;padding:.15rem .4rem;border-radius:8px;font-size:.75rem;font-weight:600;color:#fff}.outcome-success{background:#28a745}.outcome-failure{background:#dc3545}.outcome-blocked{background:#d4a017}.settings-editor h3{margin-bottom:1rem}.settings-table{width:100%;border-collapse:collapse;margin-bottom:1rem}.settings-table th,.settings-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-color, #e0e0e0);text-align:left}.settings-table th{font-weight:600;background:var(--table-header-bg, #f5f5f5)}.key-cell{font-family:monospace;font-size:.85rem;white-space:nowrap}.desc-cell{color:var(--text-muted, #666);font-size:.85rem}.value-input{width:100%;min-width:120px;padding:.3rem .5rem;border:1px solid var(--border-color, #ccc);border-radius:4px;font-size:.9rem}tr.dirty .value-input{border-color:var(--primary-color, #007bff);background:var(--input-dirty-bg, #f0f8ff)}.settings-actions{display:flex;align-items:center;gap:1rem}.save-success{color:var(--success-color, #28a745);font-weight:500}.save-error{color:var(--danger-color, #dc3545);font-weight:500}.question-generator{max-width:480px;display:flex;flex-direction:column;gap:1rem}.qg-title{margin:0 0 .25rem;font-size:1.25rem}.qg-field{display:flex;flex-direction:column;gap:.35rem}.qg-field label{font-weight:600;font-size:.875rem}.qg-field select{padding:.5rem;border:1px solid var(--border-color, #ccc);border-radius:4px;background:var(--input-bg, #fff);color:var(--text-color, #333);font-size:.95rem}.qg-field select:disabled{opacity:.6;cursor:not-allowed}.qg-advanced-toggle{background:none;border:none;color:var(--link-color, #0366d6);cursor:pointer;font-size:.875rem;text-align:left;padding:0}.qg-advanced-toggle:hover{text-decoration:underline}.qg-advanced{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;border:1px solid var(--border-color, #ccc);border-radius:4px;background:var(--bg-subtle, #f6f8fa)}.qg-generate-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.25rem;background:var(--primary-color, #2ea44f);color:#fff;font-weight:600;font-size:1rem;border:none;border-radius:6px;cursor:pointer;transition:background .15s}.qg-generate-btn:hover:not(:disabled){background:var(--primary-hover, #2c974b)}.qg-generate-btn:disabled{opacity:.55;cursor:not-allowed}.qg-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:qg-spin .6s linear infinite}@keyframes qg-spin{to{transform:rotate(360deg)}}.qg-error{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;border-radius:6px;font-size:.875rem;border:1px solid #d73a49;background:#ffeef0;color:#86181d}.qg-error--rate-limit{border-color:#e36209;background:#fff8e1;color:#735c0f}.qg-error--service{border-color:#6a737d;background:#f1f8ff;color:#24292e}.qg-error__icon{flex-shrink:0;font-size:1rem}.qg-error__message{line-height:1.4}.generated-question-preview{display:flex;flex-direction:column;gap:1rem}.gqp-rate-limit{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--text-muted, #586069)}.gqp-rate-limit__bar{height:4px;background:var(--border-color, #e1e4e8);border-radius:2px;overflow:hidden}.gqp-rate-limit__fill{height:100%;background:var(--primary-color, #2ea44f);transition:width .3s}.gqp-rate-limit__fill--low{background:#e36209}.gqp-duplicate-badge{display:inline-block;padding:.35rem .7rem;background:#fff8e1;border:1px solid #e36209;border-radius:4px;color:#735c0f;font-size:.8rem}.gqp-header{display:flex;gap:.5rem;align-items:center}.gqp-status{font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:10px;text-transform:uppercase;letter-spacing:.04em}.gqp-status--draft{background:#f1f8ff;color:#0366d6}.gqp-status--pending{background:#fff8e1;color:#735c0f}.gqp-status--approved{background:#dcffe4;color:#22863a}.gqp-status--rejected{background:#ffeef0;color:#d73a49}.gqp-badge--ai{font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:10px;background:#e8daef;color:#6f42c1}.gqp-deal-info{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.875rem}.gqp-hands-section,.gqp-hands-header{margin-bottom:.5rem}.gqp-hands-toggle{background:none;border:none;color:var(--color-primary, #7c3aed);font-size:.85rem;cursor:pointer;padding:.25rem 0;font-weight:500}.gqp-hands-toggle:hover{text-decoration:underline}.gqp-hands{display:flex;flex-wrap:wrap;gap:1.5rem}.gqp-hands--all{flex-direction:column;align-items:center;gap:.25rem}.gqp-hands__row{display:flex;justify-content:center;gap:3rem}.gqp-hands__row--middle{justify-content:space-between;width:100%;max-width:28rem}.gqp-question-text h3{font-size:1rem;margin:0 0 .25rem}.gqp-question-text p{margin:0;line-height:1.5}.gqp-answers h3{font-size:1rem;margin:0 0 .5rem}.gqp-answers__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.gqp-answer{border:1px solid var(--border-color, #e1e4e8);border-radius:6px;padding:.6rem .85rem;background:var(--bg-subtle, #fafbfc)}.gqp-answer__header{display:flex;justify-content:space-between;align-items:center}.gqp-answer__text{font-weight:600}.gqp-answer__marks{font-size:.8rem;font-weight:600;color:var(--primary-color, #2ea44f)}.gqp-answer__rationale{margin:.35rem 0 0;font-size:.85rem;color:var(--text-muted, #586069);line-height:1.4}.gqp-question-text__input{width:100%;padding:.5rem .6rem;border:1px solid var(--border-color, #e1e4e8);border-radius:6px;font-size:.95rem;line-height:1.5;font-family:inherit;resize:vertical;background:var(--bg-default, #fff)}.gqp-question-text__input:focus{outline:none;border-color:var(--primary-color, #2ea44f);box-shadow:0 0 0 2px #2ea44f26}.gqp-answer__header--editable{display:flex;gap:.5rem;align-items:center;flex-wrap:nowrap}.gqp-answer__text-input{flex:1 1 auto;min-width:0;padding:.35rem .5rem;border:1px solid var(--border-color, #e1e4e8);border-radius:4px;font-size:.9rem;font-weight:600;font-family:inherit}.gqp-answer__text-input:focus{outline:none;border-color:var(--primary-color, #2ea44f);box-shadow:0 0 0 2px #2ea44f26}.gqp-answer__marks-label{display:flex;align-items:center;gap:.25rem;font-size:.8rem;font-weight:600;color:var(--primary-color, #2ea44f);white-space:nowrap}.gqp-answer__marks-input{width:3.5rem;padding:.35rem .4rem;border:1px solid var(--border-color, #e1e4e8);border-radius:4px;font-size:.85rem;text-align:center}.gqp-answer__marks-input:focus{outline:none;border-color:var(--primary-color, #2ea44f);box-shadow:0 0 0 2px #2ea44f26}.gqp-answer__reorder{display:flex;flex-direction:column;gap:2px}.gqp-answer__reorder-btn{background:var(--bg-subtle, #f6f8fa);border:1px solid var(--border-color, #e1e4e8);border-radius:3px;padding:0 .35rem;font-size:.75rem;line-height:1.3;cursor:pointer;color:var(--text-muted, #586069)}.gqp-answer__reorder-btn:hover:not(:disabled){background:var(--bg-hover, #e8e8e8);color:var(--text-primary, #24292e)}.gqp-answer__reorder-btn:disabled{opacity:.35;cursor:default}.gqp-answer__delete-btn{background:none;border:1px solid var(--border-color, #e1e4e8);border-radius:3px;padding:0 .4rem;font-size:.8rem;line-height:1.3;cursor:pointer;color:var(--text-muted, #586069);margin-left:.25rem}.gqp-answer__delete-btn:hover{background:#fdd;border-color:#d73a49;color:#d73a49}.gqp-btn--add-answer{margin-top:.5rem;padding:.35rem .75rem;font-size:.85rem;background:var(--bg-subtle, #f6f8fa);border:1px dashed var(--border-color, #e1e4e8);border-radius:4px;cursor:pointer;color:var(--text-muted, #586069)}.gqp-btn--add-answer:hover{background:var(--bg-hover, #e8e8e8);color:var(--text-primary, #24292e);border-style:solid}.gqp-answer__rationale-input{width:100%;margin-top:.35rem;padding:.35rem .5rem;border:1px solid var(--border-color, #e1e4e8);border-radius:4px;font-size:.85rem;font-family:inherit;resize:vertical;color:var(--text-muted, #586069);line-height:1.4}.gqp-answer__rationale-input:focus{outline:none;border-color:var(--primary-color, #2ea44f);box-shadow:0 0 0 2px #2ea44f26}.gqp-feedback-section{margin-top:1.25rem;padding:.75rem 1rem;border:1px solid var(--border-color, #e1e4e8);border-radius:8px;background:var(--bg-subtle, #fafbfc)}.gqp-feedback-section h3{font-size:1rem;margin:0 0 .25rem}.gqp-feedback-hint{font-size:.85rem;color:var(--text-muted, #586069);margin:0}.gqp-feedback-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem}.gqp-inline-feedback{margin-top:.4rem}.gqp-inline-feedback__toggle{background:none;border:none;padding:0;font-size:.8rem;color:var(--primary-color, #6f42c1);cursor:pointer;font-weight:500;transition:color .15s}.gqp-inline-feedback__toggle:hover{color:#8957e5;text-decoration:underline}.gqp-inline-feedback__input{display:block;width:100%;margin-top:.3rem;padding:.4rem .5rem;border:1px solid var(--border-color, #d1d5da);border-radius:5px;font-family:inherit;font-size:.85rem;resize:vertical;box-sizing:border-box;background:var(--bg-color, #fff);color:var(--text-color, #24292e)}.gqp-inline-feedback__input:focus{outline:none;border-color:#6f42c1;box-shadow:0 0 0 2px #6f42c126}.gqp-inline-feedback__input::placeholder{color:var(--text-muted, #959da5);font-size:.82rem}.gqp-btn--refine{background:linear-gradient(135deg,#6f42c1,#8957e5);color:#fff;border:none;border-radius:6px;padding:.45rem 1rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap}.gqp-btn--refine:hover:not(:disabled){opacity:.9}.gqp-btn--refine:disabled{opacity:.5;cursor:not-allowed}.gqp-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted, #586069)}.gqp-empty__text{max-width:320px;margin:0 auto;line-height:1.5}.gqp-skeleton{display:flex;flex-direction:column;gap:1rem}.gqp-skeleton__block{border-radius:4px;background:linear-gradient(90deg,#e1e4e8 25%,#f0f0f0,#e1e4e8 75%);background-size:400% 100%;animation:gqp-shimmer 1.5s ease-in-out infinite}.gqp-skeleton__title{height:1.5rem;width:60%}.gqp-skeleton__hand{height:6rem;width:100%}.gqp-skeleton__text{height:2.5rem;width:90%}.gqp-skeleton__answers{height:8rem;width:100%}@keyframes gqp-shimmer{0%{background-position:-400% 0}to{background-position:400% 0}}.gqp-draft-section{border-top:1px solid var(--border-color, #e1e4e8);padding-top:1rem;margin-top:.5rem}.gqp-draft-section h3{font-size:1rem;margin:0 0 .5rem}.gqp-notes-toolbar{display:flex;gap:.25rem;margin-bottom:.35rem}.gqp-notes-toolbar__btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid var(--border-color, #e1e4e8);border-radius:4px;background:var(--bg-subtle, #fafbfc);cursor:pointer;font-size:.85rem;color:var(--text-color, #24292e);transition:background .15s,border-color .15s}.gqp-notes-toolbar__btn:hover{background:var(--border-color, #e1e4e8);border-color:var(--text-muted, #586069)}.gqp-notes-textarea{width:100%;min-height:5rem;padding:.6rem .75rem;border:1px solid var(--border-color, #e1e4e8);border-radius:6px;font-family:inherit;font-size:.9rem;line-height:1.5;resize:vertical;background:var(--bg-color, #fff);color:var(--text-color, #24292e);box-sizing:border-box}.gqp-notes-textarea:focus{outline:none;border-color:var(--primary-color, #2ea44f);box-shadow:0 0 0 2px #2ea44f26}.gqp-notes-footer{display:flex;justify-content:flex-end;margin-top:.25rem}.gqp-notes-charcount{font-size:.75rem;color:var(--text-muted, #586069)}.gqp-draft-actions{display:flex;gap:.5rem;margin-top:.75rem}.gqp-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:1px solid transparent;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,opacity .15s}.gqp-btn:disabled{opacity:.6;cursor:not-allowed}.gqp-btn--draft{background:#0366d6;color:#fff}.gqp-btn--draft:hover:not(:disabled){background:#0256b9}.gqp-btn--submit{background:var(--primary-color, #2ea44f);color:#fff}.gqp-btn--submit:hover:not(:disabled){background:#269a42}.gqp-btn--resubmit{background:#e36209;color:#fff}.gqp-btn--resubmit:hover:not(:disabled){background:#c95507}.gqp-draft-msg{margin-top:.5rem;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500}.gqp-draft-msg--success{background:#dcffe4;color:#22863a;border:1px solid #c6e6c6}.gqp-draft-msg--error{background:#ffeef0;color:#d73a49;border:1px solid #f5c6cb}.gqp-draft-msg--warning{background:#fff8e1;color:#735c0f;border:1px solid #e6d08c}.gqp-deal-info__label{display:inline-flex;align-items:center;gap:.35rem}.gqp-deal-info__select{padding:.2rem .35rem;border:1px solid var(--color-border, #d1d5db);border-radius:4px;font-size:.875rem;background:var(--color-surface, #fff);color:inherit}.hand-display--editable{min-width:110px}.suit-line--editable{display:flex;align-items:center;gap:.3rem}.gqp-hand-input{width:7rem;padding:.15rem .3rem;border:1px solid var(--color-border, #d1d5db);border-radius:3px;font-family:Consolas,Courier New,monospace;font-size:.875rem;letter-spacing:.05em;background:var(--color-surface, #fff);color:inherit}.gqp-hand-input:focus{outline:2px solid var(--color-primary, #7c3aed);outline-offset:1px;border-color:var(--color-primary, #7c3aed)}.gqp-hand-input::placeholder{color:var(--color-muted, #9ca3af)}.gqp-pbn-errors{background:#ffeef0;color:#d73a49;border:1px solid #f5c6cb;border-radius:6px;padding:.5rem .75rem;margin-bottom:.75rem;font-size:.85rem}.gqp-pbn-errors ul{margin:.25rem 0 0;padding-left:1.25rem}.gqp-pbn-errors li{margin-bottom:.15rem}.generate-question-page{padding:1.5rem;max-width:1100px;margin:0 auto}.gqp-page-title{font-size:1.5rem;margin:0 0 1.25rem}.gqp-layout{display:flex;gap:2rem;align-items:flex-start}.gqp-form-panel{flex:0 0 420px;position:sticky;top:1.5rem}.gqp-preview-panel{flex:1 1 0;min-width:0}@media(max-width:768px){.gqp-layout{flex-direction:column}.gqp-form-panel{flex:none;width:100%;position:static}}.gqp-preview-panel--full{flex:1 1 100%;max-width:800px}.gqp-back-link{display:inline-block;background:none;border:none;color:var(--color-link, #0969da);cursor:pointer;padding:0;margin-bottom:1rem;font-size:.9rem}.gqp-back-link:hover{text-decoration:underline}.gqp-question-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;padding:.75rem 1rem;background:var(--color-surface, #f6f8fa);border:1px solid var(--color-border, #d0d7de);border-radius:6px;font-size:.9rem;color:var(--color-text-secondary, #555)}.gqp-question-meta__item{display:inline-flex;gap:.35rem;align-items:center}.gqp-question-meta__label{font-weight:600;color:var(--color-text-primary, #24292f)}.gqp-loading{padding:2rem;text-align:center;color:var(--color-text-secondary, #666)}.gqp-error{padding:1.5rem;background:var(--color-error-bg, #fef2f2);border:1px solid var(--color-error-border, #fecaca);border-radius:6px;color:var(--color-error, #dc2626);margin-bottom:1rem}.gqp-error .gqp-btn{margin-top:.75rem}.gqp-review-feedback{background:var(--color-warning-bg, #fffbeb);border:1px solid var(--color-warning-border, #fde68a);border-radius:6px;padding:1rem 1.25rem;margin-bottom:1rem}.gqp-review-feedback h3{margin:0 0 .5rem;font-size:.95rem}.gqp-review-feedback__note{margin:0;font-size:.875rem;color:var(--color-text-secondary, #666)}.gqp-confirm-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center}.gqp-confirm-dialog{background:var(--color-bg, #fff);border-radius:8px;padding:1.5rem 2rem;max-width:420px;width:90%;box-shadow:0 4px 24px #0003}.gqp-confirm-dialog h3{margin:0 0 .75rem;font-size:1.1rem}.gqp-confirm-dialog p{margin:0 0 1.25rem;font-size:.9rem;color:var(--color-text-secondary, #555)}.gqp-confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.gqp-btn--secondary{background:var(--color-bg-secondary, #f0f0f0);border:1px solid var(--color-border, #ddd);border-radius:6px;padding:.5rem 1rem;cursor:pointer;font-size:.875rem}.gqp-btn--secondary:hover{background:var(--color-bg-hover, #e8e8e8)}.gqp-btn--danger{background:var(--color-error, #dc2626);color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;cursor:pointer;font-size:.875rem}.gqp-btn--danger:hover{background:#b91c1c}.draft-expiry-warning{display:flex;gap:.75rem;padding:.75rem 1rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:6px;margin-bottom:1rem}.warning-icon{font-size:1.25rem;flex-shrink:0}.warning-content strong{display:block;margin-bottom:.25rem}.expiry-list{margin:.25rem 0 0;padding-left:1.25rem;font-size:.9rem}.days-left{font-weight:600;color:#856404}.expired{font-weight:600;color:#dc3545}.submission-history h3{margin-bottom:1rem}.status-filter{display:flex;gap:.5rem;margin-bottom:1rem}.filter-btn{padding:.35rem .75rem;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--bg-secondary, #f5f5f5);cursor:pointer;font-size:.85rem}.filter-btn.active{background:var(--primary-color, #4a6fa5);color:#fff;border-color:var(--primary-color, #4a6fa5)}.submission-table{width:100%;border-collapse:collapse}.submission-table th,.submission-table td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--border-color, #eee)}.submission-table th{font-weight:600;font-size:.85rem;color:var(--text-secondary, #666)}.question-text{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{display:inline-block;padding:.2rem .5rem;border-radius:10px;color:#fff;font-size:.75rem;font-weight:600;text-transform:capitalize}.feedback-cell .review-notes{font-size:.85rem;color:var(--text-secondary, #666)}.empty-state{text-align:center;color:var(--text-secondary, #888);padding:2rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem}.btn-sm{padding:.25rem .5rem;font-size:.8rem}.changelog-page{max-width:900px;margin:0 auto;padding:2.5rem 1.5rem 4rem}.changelog-page h1{font-size:2.4rem;margin-top:0;margin-bottom:1rem}.changelog-subtitle{color:#0009;font-size:1.1rem;margin-bottom:1.5rem}@media(prefers-color-scheme:dark){.changelog-subtitle{color:#ffffffb3}}.changelog-controls{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-bottom:2rem}.changelog-search-form{display:flex;flex:1 1 260px;gap:.5rem}.changelog-search-input{flex:1;padding:.5rem .75rem;border:1px solid var(--border, #e0e0e0);border-radius:4px;font-size:.95rem;background:transparent;color:inherit}.changelog-search-input:focus{outline:2px solid var(--accent, #0c5dd6);outline-offset:1px}@media(prefers-color-scheme:dark){.changelog-search-input{border-color:var(--border-dark, #333)}}.changelog-search-btn{padding:.5rem 1rem;border:1px solid var(--accent, #0c5dd6);border-radius:4px;background:var(--accent, #0c5dd6);color:#fff;font-size:.9rem;cursor:pointer;white-space:nowrap}.changelog-search-btn:hover{opacity:.85}.changelog-severity-select{padding:.5rem .75rem;border:1px solid var(--border, #e0e0e0);border-radius:4px;font-size:.9rem;background:transparent;color:inherit;cursor:pointer}.changelog-severity-select:focus{outline:2px solid var(--accent, #0c5dd6);outline-offset:1px}@media(prefers-color-scheme:dark){.changelog-severity-select{border-color:var(--border-dark, #333)}}.changelog-clear-btn{padding:.5rem .9rem;border:1px solid var(--border, #e0e0e0);border-radius:4px;background:transparent;font-size:.9rem;color:#0009;cursor:pointer;white-space:nowrap}.changelog-clear-btn:hover{background:#0000000d}@media(prefers-color-scheme:dark){.changelog-clear-btn{border-color:var(--border-dark, #333);color:#fff9}.changelog-clear-btn:hover{background:#ffffff0d}}.changelog-release{border-left:3px solid var(--accent, #0c5dd6);padding-left:1.5rem;margin-bottom:3rem}.changelog-release-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.changelog-release-header h2{font-size:1.6rem;margin:0}.changelog-release-meta{display:flex;gap:.5rem;align-items:center}.changelog-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-size:.85rem;font-weight:600;text-transform:uppercase}.changelog-badge.severity-major{background:#dc2626;color:#fff}.changelog-badge.severity-medium{background:#f59e0b;color:#78350f}.changelog-badge.severity-minor{background:#3b82f6;color:#fff}.changelog-badge.severity-trivial{background:#10b981;color:#fff}.changelog-env{font-size:.85rem;font-weight:500;color:#0009}@media(prefers-color-scheme:dark){.changelog-env{color:#ffffffb3}}.changelog-summary{font-size:1.1rem;margin:1rem 0 1.5rem;font-weight:500}.changelog-category{margin-bottom:1.5rem}.changelog-category h3{font-size:1.1rem;margin:.75rem 0 .5rem;color:var(--accent, #0c5dd6)}@media(prefers-color-scheme:dark){.changelog-category h3{color:#8ab4ff}}.changelog-category ul{margin:0;padding-left:1.5rem}.changelog-category li{margin:.5rem 0}.changelog-pr-link{font-size:.9rem;font-weight:500;text-decoration:none;color:var(--accent, #0c5dd6)}@media(prefers-color-scheme:dark){.changelog-pr-link{color:#8ab4ff}}.changelog-pr-link:hover{text-decoration:underline}.changelog-system-changes{margin-top:1.5rem;border:1px solid var(--border, #e0e0e0);border-radius:6px;padding:.5rem 1rem}@media(prefers-color-scheme:dark){.changelog-system-changes{border-color:var(--border-dark, #333)}}.changelog-system-changes>summary{cursor:pointer;font-size:.9rem;font-weight:600;color:#0000008c;-webkit-user-select:none;user-select:none;padding:.25rem 0}@media(prefers-color-scheme:dark){.changelog-system-changes>summary{color:#ffffff80}}.changelog-system-changes .changelog-category h3{font-size:.95rem;color:#00000080}@media(prefers-color-scheme:dark){.changelog-system-changes .changelog-category h3{color:#ffffff73}}.changelog-system-changes .changelog-category li{font-size:.9rem;color:#0009}@media(prefers-color-scheme:dark){.changelog-system-changes .changelog-category li{color:#ffffff8c}}.changelog-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem}.changelog-pagination button{padding:.5rem 1.25rem;border:1px solid var(--border, #e0e0e0);border-radius:4px;background:transparent;cursor:pointer;font-size:.9rem}.changelog-pagination button:disabled{opacity:.4;cursor:default}.changelog-pagination .page-info{font-size:.9rem;color:#0009}@media(prefers-color-scheme:dark){.changelog-pagination .page-info{color:#ffffffb3}}.changelog-loading,.changelog-empty,.changelog-error{text-align:center;padding:3rem 0;color:#00000080}@media(prefers-color-scheme:dark){.changelog-loading,.changelog-empty,.changelog-error{color:#ffffff80}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f7fa;--bg-tertiary: #e8edf2;--text-primary: #1a202c;--text-secondary: #4a5568;--text-tertiary: #718096;--border-color: #e2e8f0;--accent-primary: #667eea;--accent-secondary: #764ba2;--accent-hover: #5568d3;--success-color: #48bb78;--error-color: #f56565;--warning-color: #ed8936;--card-bg: #ffffff;--card-shadow: rgba(0, 0, 0, .1);--overlay-bg: rgba(0, 0, 0, .5);--suit-red: #d32f2f}[data-theme=dark]{--bg-primary: #1a202c;--bg-secondary: #2d3748;--bg-tertiary: #4a5568;--text-primary: #f7fafc;--text-secondary: #e2e8f0;--text-tertiary: #cbd5e0;--border-color: #4a5568;--accent-primary: #667eea;--accent-secondary: #764ba2;--accent-hover: #5568d3;--success-color: #48bb78;--error-color: #fc8181;--warning-color: #f6ad55;--card-bg: #2d3748;--card-shadow: rgba(0, 0, 0, .3);--overlay-bg: rgba(0, 0, 0, .7);--suit-red: #ef5350}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{width:100%;min-height:100vh}.app{width:100%;min-height:100vh;background-color:var(--bg-primary)}.main-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{width:100%;flex:1;padding:2rem;max-width:1400px;margin:0 auto}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-container{background:#fff;border-radius:16px;padding:3rem;box-shadow:0 20px 60px #0000004d;max-width:400px;width:90%}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:#1a202c;font-size:2rem;margin-bottom:.5rem}.login-header p{color:#4a5568;font-size:.95rem}.login-providers{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.provider-button{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1.5rem;border:2px solid var(--border-color);border-radius:8px;background:var(--card-bg);color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.provider-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px var(--card-shadow);border-color:var(--accent-primary)}.provider-button:disabled{opacity:.6;cursor:not-allowed}.provider-icon{font-size:2rem;display:flex;align-items:center;color:var(--text-primary)}.provider-text{color:var(--text-primary)}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:8px;border-left:4px solid #c33;margin-bottom:1rem;font-size:.9rem}.login-footer{text-align:center;border-top:1px solid #eee;padding-top:1.5rem}.guest-option{color:#666;font-size:.9rem;margin-bottom:1rem}.guest-option a{color:#667eea;text-decoration:none;font-weight:500}.guest-option a:hover{text-decoration:underline}.privacy-note{color:#999;font-size:.8rem;line-height:1.4}.take-quiz-page{max-width:1200px;margin:0 auto;padding:.5rem}.quiz-header{text-align:center;margin-bottom:.75rem;padding:.75rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-radius:8px;color:#fff;box-shadow:0 2px 8px var(--card-shadow)}.quiz-header h1{color:#fff;margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.quiz-meta{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap;font-size:.85rem;opacity:.95}.quiz-meta span{display:flex;align-items:center;gap:.35rem}.quiz-filters{margin-bottom:.5rem;display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap;align-items:center}.quiz-filters label,.convention-filter-label{display:flex;align-items:center;gap:.35rem;font-size:.85rem}.category-select{padding:.4rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.3);background:#ffffff26;color:#fff;font-size:.85rem;cursor:pointer;min-width:140px}.category-select:focus{outline:none;border-color:#fff9;background:#ffffff40}.category-select option{background:var(--bg-secondary);color:var(--text-primary)}.quiz-main-content{display:flex;gap:1rem;align-items:flex-start}.quiz-question-section{flex:1;min-width:0}.quiz-answer-section{flex-shrink:0;width:280px}@media(max-width:768px){.quiz-main-content{flex-direction:column}.quiz-answer-section{width:100%}}.convention-selector{background:var(--card-bg);padding:.75rem;border-radius:8px;margin-bottom:.75rem;border:1px solid var(--border-color);box-shadow:0 1px 4px var(--card-shadow)}.convention-selector label{display:block;font-weight:600;margin-bottom:.35rem;color:var(--text-primary);font-size:.85rem}.convention-selector select{width:100%;padding:.5rem;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all .2s}.convention-selector select:hover{border-color:var(--accent-primary)}.convention-selector select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #667eea1a}.convention-description{margin-top:.5rem;padding:.5rem;background:var(--bg-secondary);border-radius:4px;color:var(--text-secondary);font-size:.8rem;border-left:2px solid var(--accent-primary)}.question-display{background:var(--card-bg);padding:1rem;border-radius:8px;margin-bottom:.75rem;border:1px solid var(--border-color);box-shadow:0 1px 4px var(--card-shadow);width:100%;box-sizing:border-box;overflow:visible;display:block}.question-info{display:flex;gap:1.5rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);flex-wrap:wrap;width:100%}.question-info p{color:var(--text-secondary);font-size:.85rem}.question-info strong{color:var(--text-primary);font-weight:600}.question-text{display:block;font-size:1rem;line-height:1.6;margin-bottom:.75rem;color:var(--text-primary);font-weight:500;background:var(--bg-secondary);padding:.75rem;border-radius:6px;border:1px solid var(--border-color);border-left:3px solid var(--accent-primary);width:100%;max-width:100%;box-sizing:border-box;word-wrap:break-word;overflow-wrap:break-word;white-space:normal}.question-text p{margin:0;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.hands-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-top:.75rem}.hand-display{background:var(--bg-secondary);padding:.75rem;border-radius:6px;border:1px solid var(--border-color)}.player-label{font-weight:700;font-size:.95rem;margin-bottom:.5rem;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px}.hcp-display{font-weight:600;font-size:.85rem;color:var(--text-secondary);text-transform:none;letter-spacing:normal}.suits{display:flex;flex-direction:column;gap:.35rem}.suit-line{display:flex;gap:.5rem;align-items:center;font-family:Courier New,monospace;font-size:.95rem}.suit-symbol{font-size:1.1rem;font-weight:700;width:1.3rem;flex-shrink:0}.suit-red{color:var(--suit-red)}.suit-black{color:var(--text-primary)}.cards{color:var(--text-primary);letter-spacing:.1rem;font-weight:500}.question-actions{display:flex;justify-content:flex-end;margin-bottom:.75rem}.answer-picker{background:var(--card-bg);padding:1rem;border-radius:8px;margin-bottom:.75rem;border:1px solid var(--border-color);box-shadow:0 1px 4px var(--card-shadow)}.answer-picker h3{color:var(--text-primary);margin-bottom:.75rem;font-size:1.1rem;font-weight:600}.answers-list{display:flex;flex-direction:column;gap:.5rem}.answer-option{width:100%;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem;text-align:left;cursor:pointer;transition:all .2s;font-weight:500;position:relative}.answer-option:hover:not(.disabled){transform:translateY(-2px);border-color:var(--accent-primary);box-shadow:0 4px 12px var(--card-shadow);background:var(--card-bg)}.answer-option:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #667eea1a}.answer-option.selected{border-color:var(--accent-primary);background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 0 0 3px #667eea26}.answer-option.disabled{cursor:not-allowed;opacity:.7}.submit-button,.next-button{width:100%;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #667eea4d}.submit-button:hover:not(:disabled),.next-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.submit-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.submit-button:focus,.next-button:focus{outline:none;box-shadow:0 0 0 3px #667eea4d}.quiz-actions{display:flex;gap:1rem;width:100%}.quiz-actions .submit-button{flex:1}.skip-button{flex:0 0 auto;padding:.75rem 1.5rem;background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.skip-button:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.skip-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.skip-button:focus{outline:none;box-shadow:0 0 0 3px #667eea4d}@media(max-width:480px){.quiz-actions{flex-direction:column}.quiz-actions .submit-button,.skip-button{width:100%}}.results{background:var(--card-bg);padding:1rem;border-radius:8px;border:1px solid var(--border-color);box-shadow:0 1px 4px var(--card-shadow)}.results-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.results-icon{font-size:2rem;display:flex;align-items:center;flex-shrink:0}.results-label{font-size:.9rem;font-weight:600;margin:0}.results-success{border-color:var(--success-color);background:linear-gradient(to bottom,var(--card-bg),rgba(72,187,120,.05))}.results-success .results-icon,.results-success .results-label{color:var(--success-color)}.results-success .results-header{border-bottom-color:#48bb784d}.results-warning{border-color:var(--warning-color);background:linear-gradient(to bottom,var(--card-bg),rgba(237,137,54,.05))}.results-warning .results-icon,.results-warning .results-label{color:var(--warning-color)}.results-warning .results-header{border-bottom-color:#ed89364d}.results-error{border-color:var(--error-color);background:linear-gradient(to bottom,var(--card-bg),rgba(245,101,101,.05))}.results-error .results-icon,.results-error .results-label{color:var(--error-color)}.results-error .results-header{border-bottom-color:#f565654d}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.results h3{color:var(--text-primary);margin-bottom:0;font-size:1.2rem;font-weight:600}.results p{margin-bottom:.5rem;color:var(--text-secondary);line-height:1.5;font-size:.95rem}.results strong{color:var(--text-primary);font-weight:600}.submission-error{color:var(--error-color);font-size:.875rem;margin-top:.75rem;padding:.5rem;background:#f565651a;border-radius:4px;border-left:2px solid var(--error-color)}.next-button{margin-top:1rem}.results .result-listed,.results .result-unlisted{font-size:.9rem;padding:.5rem;border-radius:4px;margin-bottom:.5rem}.results .result-listed{background:#48bb781a;color:var(--success-color)}.results .result-unlisted{background:#ed89361a;color:var(--warning-color)}.results .checkmark,.results .info{font-weight:700;margin-right:.25rem}.results .all-answers{margin-top:.75rem}.results .all-answers h4{font-size:1rem;margin-bottom:.5rem;color:var(--text-primary)}.results .all-answers ul{list-style:none;padding:0;margin:0}.results .all-answers li{padding:.5rem;margin-bottom:.35rem;background:var(--bg-secondary);border-radius:4px;font-size:.9rem}.results .answer-rationale{color:var(--text-secondary);font-size:.85rem}.profile-page{max-width:1000px;margin:0 auto;padding:2rem}.profile-header{text-align:center;margin-bottom:2rem}.profile-header h1{color:var(--text-primary);font-size:2rem;font-weight:600}.profile-content{display:flex;flex-direction:column;gap:2rem}.profile-section{background:var(--card-bg);padding:2rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:0 2px 8px var(--card-shadow)}.profile-section h2{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.5rem;font-weight:600}.profile-info{display:flex;flex-direction:column;gap:1rem}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.info-row:last-child{border-bottom:none}.info-label{font-weight:600;color:var(--text-secondary)}.info-value{color:var(--text-primary)}.info-value-mono{font-family:Monaco,Menlo,monospace;font-size:.8125rem;word-break:break-all}.theme-selector{padding:.5rem;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s}.theme-selector:hover{border-color:var(--accent-primary)}.theme-selector:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #667eea1a}.danger-zone{border:2px solid var(--error-color)}.danger-warning{color:var(--text-secondary);margin-bottom:1rem;line-height:1.6}.delete-button,.confirm-delete-button{padding:.75rem 1.5rem;background:var(--error-color);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.delete-button:hover,.confirm-delete-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #f565654d}.cancel-button{padding:.75rem 1.5rem;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.cancel-button:hover{border-color:var(--accent-primary)}.delete-confirm{margin-top:1rem}.confirm-text{color:var(--error-color);font-weight:600;margin-bottom:1rem}.confirm-buttons{display:flex;gap:1rem}.loading{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1.1rem}.error{text-align:center;padding:2rem;color:var(--error-color);background:#f565651a;border-radius:8px;border:1px solid var(--error-color)}.no-questions{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1.1rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}@media(max-width:768px){.app{padding:.5rem}.login-container{padding:2rem}.take-quiz-page{padding:.5rem}.quiz-header{padding:1rem}.quiz-header h1{font-size:1.5rem}.quiz-meta{gap:1rem;font-size:.85rem}.question-display,.answer-picker,.results{padding:1.25rem}.hands-container{grid-template-columns:1fr}.profile-page{padding:1rem}.profile-section{padding:1.25rem}.info-row{flex-direction:column;gap:.25rem}.confirm-buttons{flex-direction:column}}@media(max-width:480px){.quiz-meta,.question-info{flex-direction:column;gap:.5rem}}
