.sidebar-nav{width:260px;background:#f8f9fa;border-right:1px solid #e0e0e0;height:calc(100vh - 80px);overflow-y:auto;position:fixed;left:0;top:80px;z-index:100}.nav-content{padding:1rem 0}.nav-category{margin-bottom:1.5rem}.nav-category-header{font-size:.75rem;font-weight:700;text-transform:uppercase;color:#666;padding:.5rem 1.5rem;letter-spacing:.5px}.nav-items{list-style:none;padding:0;margin:0}.nav-items li{margin:0}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#333;text-decoration:none;transition:all .2s;border-left:3px solid transparent}.nav-item:hover{background:#e9ecef;color:var(--rouse-red)}.nav-item.active{background:#8b00001a;color:var(--rouse-red);border-left-color:var(--rouse-red);font-weight:600}.nav-icon{font-size:1.2rem;width:24px;text-align:center}.nav-label{font-size:.95rem}@media (max-width: 768px){.sidebar-nav{top:44px;height:calc(100vh - 44px);height:calc(100dvh - 44px);width:100%}.nav-item{padding:1rem 1.5rem;min-height:48px}}.app-layout{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:#f5f5f5;width:100%}:root{--header-height: 80px}.app-header{background:linear-gradient(135deg,var(--rouse-red) 0%,var(--rouse-red-light) 100%);color:#fff;padding:1rem 2rem;position:fixed;top:0;left:0;right:0;width:100%;z-index:200;box-shadow:0 2px 8px #0000001a;padding-top:max(1rem,env(safe-area-inset-top))}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:100%;gap:.75rem}.mobile-menu-button{display:none;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:1.4rem;line-height:1;min-width:44px;min-height:44px;transition:background .2s;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mobile-menu-button:hover{background:#ffffff4d}.logo-container{display:flex;align-items:center;gap:1rem;min-width:0;flex:1;justify-content:center}.logo{height:50px;width:auto;flex-shrink:0}.logo-text{display:flex;flex-direction:column;gap:0}.logo-title-mobile{display:none}.app-header h1{font-size:1.8rem;margin:0;font-weight:700}.subtitle{font-size:.9rem;opacity:.95;margin:0}.user-menu{display:flex;align-items:center;gap:.5rem}.layout-body{display:flex;flex:1;margin-top:var(--header-height);min-height:calc(100vh - var(--header-height));min-height:calc(100dvh - var(--header-height));width:100%;overflow-x:hidden}.sidebar-nav-wrapper{flex-shrink:0}.sidebar-overlay{display:none}.main-content-wrapper{flex:1;margin-left:260px;padding:2rem;min-width:0;width:calc(100% - 260px);background:#fff;min-height:calc(100vh - var(--header-height));min-height:calc(100dvh - var(--header-height))}.app-footer{background:#f8f9fa;padding:1.5rem;text-align:center;color:#666;font-size:.9rem;border-top:1px solid #e0e0e0;margin-left:260px;width:calc(100% - 260px)}@media (max-width: 768px){.mobile-menu-button{display:flex!important;align-items:center;justify-content:center;flex-shrink:0;min-width:40px;min-height:40px;padding:.5rem;font-size:1.25rem}.app-header{padding:.35rem .75rem;padding-top:max(.35rem,env(safe-area-inset-top));min-height:44px;height:44px;display:flex;align-items:center}.app-header .header-content{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;align-items:center;justify-content:space-between;gap:.5rem;width:100%}.logo-container{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;align-items:center;justify-content:flex-start;flex:1;min-width:0;gap:.4rem}.logo-container .logo-text{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;align-items:center;min-width:0}.logo-title-desktop{display:none!important}.logo-title-mobile{display:block!important;font-size:.85rem;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header h1{font-size:.85rem;line-height:1}.subtitle{display:none!important}.logo{height:28px!important;flex-shrink:0}.username{display:none!important}.logout-button{min-width:40px;min-height:40px;padding:.4rem;font-size:.8rem;flex-shrink:0}.layout-body{margin-top:44px;min-height:calc(100vh - 44px);min-height:calc(100dvh - 44px)}.sidebar-nav-wrapper{position:fixed;top:44px;left:0;bottom:0;z-index:150;width:min(280px,85vw);transform:translate(-100%);transition:transform .25s ease-out;pointer-events:none}.sidebar-nav-wrapper.open{transform:translate(0);pointer-events:auto}.sidebar-overlay{display:block;position:fixed;top:44px;left:0;right:0;bottom:0;background:#00000080;z-index:140;opacity:0;pointer-events:none;transition:opacity .25s}.sidebar-overlay.open{opacity:1;pointer-events:all}.main-content-wrapper{margin-left:0;width:100%;padding:1rem;min-height:calc(100dvh - 114px)}.app-footer{margin-left:0;width:100%;padding:1rem;font-size:.8rem}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b0000,brown);padding:2rem}.auth-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:2.5rem;width:100%;max-width:450px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{color:#8b0000;font-size:2rem;margin-bottom:.5rem;font-weight:700}.auth-header p{color:#666;font-size:1rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333;font-size:.95rem}.form-input{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:#8b0000}.form-help{color:#666;font-size:.85rem}.auth-error{background:#fee;color:#c33;padding:1rem;border-radius:8px;border:1px solid #fcc;font-size:.9rem}.auth-button{background:linear-gradient(135deg,#8b0000,brown);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:.5rem}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #8b000066}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-footer{margin-top:2rem;text-align:center;color:#666;font-size:.9rem}@media (max-width: 768px){.auth-container{padding:1rem;align-items:flex-start;padding-top:max(1rem,env(safe-area-inset-top))}.auth-card{padding:1.5rem}.auth-header h1{font-size:1.5rem}.auth-button{min-height:48px;-webkit-tap-highlight-color:transparent}}.link-button{background:none;border:none;color:#8b0000;cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}.link-button:hover{color:brown}.app{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden}:root{--rouse-red: #8B0000;--rouse-red-light: #A52A2A;--rouse-gold: #D4AF37;--rouse-gold-light: #F4D03F}.header{background:linear-gradient(135deg,var(--rouse-red) 0%,var(--rouse-red-light) 100%);color:#fff;padding:2rem}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.logo-container{display:flex;align-items:center;gap:1rem}.logo{height:60px;width:auto}.user-menu{display:flex;align-items:center;gap:1rem}.username{font-size:.95rem}.logout-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .2s}.logout-button:hover{background:#ffffff4d}.header h1{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.subtitle{font-size:1.1rem;opacity:.95}.main-content{padding:2rem}.search-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{display:flex;flex-direction:column;gap:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.label{font-weight:600;color:#333;font-size:.95rem}.required{color:#e74c3c}.input{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.input:focus{outline:none;border-color:var(--rouse-red)}.help-text{color:#666;font-size:.85rem}.selected-items{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.tag{display:inline-flex;align-items:center;gap:.5rem;background:#667eea;color:#fff;padding:.4rem .8rem;border-radius:20px;font-size:.9rem}.tag-remove{background:#ffffff4d;border:none;color:#fff;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s}.tag-remove:hover{background:#ffffff80}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.95rem}.checkbox{width:18px;height:18px;cursor:pointer}.submit-button{background:linear-gradient(135deg,var(--rouse-red) 0%,var(--rouse-red-light) 100%);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:1rem}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #8b000066}.submit-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-top:1rem;border:1px solid #fcc}.results{margin-top:2rem;display:flex;flex-direction:column;gap:2rem}.result-section{background:#f8f9fa;padding:1.5rem;border-radius:12px;border-left:4px solid #667eea}.result-section h2{color:#333;margin-bottom:1rem;font-size:1.5rem}.summary-text{line-height:1.8;color:#444;font-size:1rem}.dna-keywords-section{border-left-color:#e74c3c}.dna-keyword-stats{margin-top:1rem}.dna-stats-label{font-weight:600;color:#333;margin-bottom:.5rem}.dna-stats-list{list-style:none;padding:0;margin:0}.dna-stat-item{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem;padding:.4rem 0;border-bottom:1px solid #eee}.dna-stat-item:last-child{border-bottom:none}.dna-stat-pct{font-weight:700;color:var(--rouse-red);min-width:3.5rem}.dna-stat-keyword{font-style:italic;color:#333}.dna-stat-early,.dna-stat-power{font-size:.85rem;color:#666}.question-list{list-style:decimal;padding-left:1.5rem;display:flex;flex-direction:column;gap:1rem}.question-item{line-height:1.6;color:#444;padding-left:.5rem}.related-topics{display:flex;flex-wrap:wrap;gap:.75rem}.topic-button{background:#fff;border:2px solid var(--rouse-red);color:var(--rouse-red);padding:.6rem 1.2rem;border-radius:20px;cursor:pointer;font-size:.95rem;transition:all .2s;font-weight:500}.topic-button:hover{background:var(--rouse-red);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #8b00004d}.footer{background:#f8f9fa;padding:1.5rem;text-align:center;color:#666;font-size:.9rem}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem}.logo-container{flex-direction:column;text-align:center}.header h1{font-size:1.5rem;text-align:center}.form-row,.checkbox-group{grid-template-columns:1fr}.main-content{padding:1.5rem}}.topic-analysis-page{padding:2rem;width:100%;max-width:100%}@media (max-width: 768px){.topic-analysis-page{padding:1rem}}.topic-analysis-page h1{color:var(--rouse-red);margin-bottom:.5rem}.page-description{color:#666;margin-bottom:2rem}.main-content{padding:0}.home-page{padding:2rem;width:100%;max-width:100%;min-height:100%}.home-page h1{color:var(--rouse-red);margin-bottom:.5rem}.page-subtitle{color:#666;margin-bottom:2rem;font-size:1.1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.quick-actions{margin-bottom:2rem}.quick-actions h2{color:#333;margin-bottom:1rem}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.action-button{padding:1rem 1.5rem;background:#fff;border:2px solid var(--rouse-red);color:var(--rouse-red);border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.action-button:hover{background:var(--rouse-red);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #8b00004d}@media (max-width: 768px){.home-page{padding:1rem 1rem 2rem}.page-subtitle{margin-bottom:1.5rem;font-size:1rem}.quick-actions h2{margin-bottom:.75rem;font-size:1.1rem}.action-buttons{grid-template-columns:1fr;gap:.75rem}.action-button{width:100%;min-height:52px;padding:1rem 1.25rem;font-size:1rem;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}}.recent-activity{background:#f8f9fa;padding:1.5rem;border-radius:12px;border-left:4px solid var(--rouse-red)}.recent-activity h2{color:#333;margin-bottom:.5rem}.recent-activity p{color:#666;margin:0}.page-loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.2rem;color:#666}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin:1rem}.progress-bar-container{width:100%}.progress-bar-label{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem;font-weight:600;color:#333}.progress-bar-value{color:#666;font-weight:500}.progress-bar-value-inline{text-align:right;margin-top:.25rem;font-size:.85rem;color:#666}.progress-bar-track{width:100%;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--rouse-red);border-radius:6px;transition:width .3s ease}.frequency-analyzer-page{padding:2rem;width:100%;max-width:100%}@media (max-width: 768px){.frequency-analyzer-page{padding:1rem}.analyzer-controls{flex-direction:column;align-items:stretch}}.frequency-analyzer-page h1{color:var(--rouse-red);margin-bottom:.5rem}.page-description{color:#666;margin-bottom:2rem;font-size:1rem}.analyzer-controls{display:flex;gap:1rem;margin-bottom:2rem;align-items:flex-end}.form-group{flex:1;display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333}.select-input{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem}.analyze-button{padding:.75rem 2rem;background:var(--rouse-red);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.analyze-button:hover:not(:disabled){background:var(--rouse-red-light);transform:translateY(-2px)}.analyze-button:disabled{opacity:.6;cursor:not-allowed}.analysis-results{display:flex;flex-direction:column;gap:2rem}.progress-summary{background:#f8f9fa;padding:1.5rem;border-radius:12px}.progress-summary h2{color:#333;margin-bottom:1rem}.topic-list{display:flex;flex-direction:column;gap:1rem}.topic-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px}.topic-rank{font-size:1.5rem;font-weight:700;color:var(--rouse-red);min-width:50px}.topic-info{flex:1}.topic-name{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:.25rem}.topic-frequency{font-size:.9rem;color:#666}.study-button{padding:.5rem 1rem;background:var(--rouse-red);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.study-button:hover{background:var(--rouse-red-light)}.study-button.small{padding:.4rem .8rem;font-size:.9rem}.gaps-section,.recommendations-section{background:#fff3cd;padding:1.5rem;border-radius:12px;border-left:4px solid #ffc107}.gaps-section h2,.recommendations-section h2{color:#333;margin-bottom:1rem}.gaps-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.gap-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#fff;border-radius:6px}.gap-topic{flex:1;font-weight:600;color:#333}.gap-frequency{color:#666;font-size:.9rem}.recommendations-list{list-style:disc;padding-left:1.5rem;color:#333}.recommendations-list li{margin-bottom:.5rem}.tossup-practice-page{padding:2rem;width:100%;max-width:100%}.tossup-practice-page h1{color:var(--rouse-red);margin-bottom:.5rem}.page-description{color:#666;margin-bottom:1.5rem}.practice-setup{max-width:700px;margin:2rem auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;border-top:4px solid var(--rouse-red)}.setup-controls{display:flex;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.multi-select-group{flex:1;min-width:260px}.multi-select-group label:first-child{display:block;margin-bottom:.75rem;font-weight:600;color:#333}.practice-setup .checkbox-group{display:flex;flex-wrap:wrap;gap:.5rem 1rem;max-height:180px;overflow-y:auto;padding:.5rem 0}.practice-setup .checkbox-label{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-weight:400;white-space:nowrap;color:#333}.practice-setup .checkbox-label input{cursor:pointer;accent-color:var(--rouse-red)}.form-group{flex:1;min-width:180px}.form-group label{display:block;font-weight:600;margin-bottom:.5rem}.setup-select{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;color:#333;font-size:1rem}.setup-select option{color:#333;background:#fff}.start-button{width:100%;padding:1rem 2rem;background:linear-gradient(135deg,var(--rouse-red) 0%,var(--rouse-red-light) 100%);color:#fff;border:none;border-radius:8px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s}.start-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b000059}.practice-controls-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.speed-control{display:flex;align-items:center;gap:.75rem}.speed-control label{font-weight:600;color:#333}.speed-control input[type=range]{width:120px}.speed-control span{font-weight:600;color:var(--rouse-red);min-width:50px}.score-display{font-weight:700;font-size:1.1rem;color:#333}.practice-area{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.question-display{max-width:900px;margin:0 auto}.question-header{display:flex;gap:.75rem;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap}.category-badge{background:#4a90e2;color:#fff;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:600}.buzz-hint{background:#ffc107;color:#333;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:600}.buzzed-indicator{background:#dc3545;color:#fff;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:700}.marker-legend{font-size:.8rem;color:#666;padding:.3rem .6rem;background:#f5f5f5;border-radius:6px}.question-text-container{min-height:200px;margin-bottom:1.5rem}.question-text{font-size:1.2rem;line-height:1.8;color:#333;white-space:pre-wrap}.cursor{display:inline-block;width:2px;height:1.2rem;background:var(--rouse-red);margin-left:2px;animation:blink 1s infinite;vertical-align:baseline}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.action-buttons-row{display:flex;gap:1rem;margin:1.5rem 0;flex-wrap:wrap}.action-btn{padding:.75rem 1.5rem;border:2px solid;border-radius:8px;font-weight:600;cursor:pointer;font-size:1rem}.answer-btn{background:#28a745;border-color:#28a745;color:#fff}.answer-btn:hover{background:#218838}.skip-btn{background:#6c757d;border-color:#6c757d;color:#fff}.skip-btn:hover{background:#5a6268}.answer-input-section{display:flex;gap:1rem;margin:1.5rem 0;align-items:center}.answer-input{flex:1;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1.1rem}.answer-input:focus{outline:none;border-color:var(--rouse-red)}.submit-answer-btn{padding:1rem 1.5rem;background:var(--rouse-red);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.submit-answer-btn:hover{background:var(--rouse-red-light)}.feedback{padding:1.5rem;border-radius:12px;margin-top:1.5rem}.feedback.correct{background:#d4edda;border:2px solid #28a745}.feedback.incorrect{background:#f8d7da;border:2px solid #dc3545}.feedback.power{background:#fff3cd;border:2px solid #ffc107}.feedback.neg{border-color:#dc3545}.feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:1.1rem;font-weight:700}.feedback.correct .feedback-header{color:#28a745}.feedback.incorrect .feedback-header{color:#dc3545}.feedback.power .feedback-header{color:#856404}.points-badge{font-size:1.2rem}.correct-answer-display{margin-bottom:1rem;padding:.75rem;background:#ffffffb3;border-radius:6px;font-size:1.05rem}.full-question{margin-top:1.5rem;padding:1rem;background:#ffffff80;border-radius:8px}.full-question strong{display:block;margin-bottom:.5rem}.full-question-text{font-size:1rem;line-height:1.6;color:#555}.ai-analysis-section{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.ai-analysis-btn{padding:.6rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:1rem}.ai-analysis-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.ai-analysis-btn:disabled{opacity:.7;cursor:not-allowed}.ai-analysis-result{margin-top:1rem;padding:1rem;background:#fffc;border-radius:8px;border-left:4px solid #667eea;font-size:.95rem;line-height:1.6;color:#333}.ai-analysis-result p{margin:0 0 .75rem}.ai-analysis-result p:last-child{margin-bottom:0}.ai-analysis-result strong{color:#764ba2}.post-reveal-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.power-selection{margin:1rem 0;padding:.75rem;background:#fff9;border-radius:8px}.power-selection p{margin-bottom:.5rem;font-weight:600}.power-yes-btn,.power-no-btn{padding:.5rem 1rem;margin-right:.5rem;border:2px solid;border-radius:6px;font-weight:600;cursor:pointer}.power-yes-btn{background:#ffc107;border-color:#ffc107;color:#333}.power-no-btn{background:#28a745;border-color:#28a745;color:#fff}.post-reveal-actions p{margin-bottom:.75rem;font-weight:600}.right-btn,.wrong-btn{padding:.5rem 1rem;margin-right:.5rem;border:2px solid;border-radius:6px;font-weight:600;cursor:pointer}.right-btn{background:#28a745;border-color:#28a745;color:#fff}.wrong-btn{background:#dc3545;border-color:#dc3545;color:#fff}.next-btn{width:100%;margin-top:1rem;padding:.75rem;background:var(--rouse-red);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.next-btn:hover{background:var(--rouse-red-light)}.loading{text-align:center;padding:2rem;color:#666}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem}@media (max-width: 768px){.tossup-practice-page{padding:1rem}.practice-setup{margin:1rem 0;padding:1.5rem}.setup-controls{flex-direction:column;gap:1.5rem}.multi-select-group{min-width:100%}.practice-setup .checkbox-group{max-height:140px}.start-button{min-height:52px;-webkit-tap-highlight-color:transparent}.practice-controls-bar{flex-direction:column;align-items:stretch}.action-buttons-row{flex-direction:column;gap:.75rem}.action-btn{min-height:48px;-webkit-tap-highlight-color:transparent}.answer-input-section{flex-direction:column}.submit-answer-btn{min-height:48px;width:100%;-webkit-tap-highlight-color:transparent}.question-text{font-size:1.1rem}.right-btn,.wrong-btn,.power-yes-btn,.power-no-btn{min-height:44px;padding:.6rem 1rem;-webkit-tap-highlight-color:transparent}}.admin-container{min-height:100vh;background:#f5f5f5}.admin-header{background:linear-gradient(135deg,#8b0000,brown);color:#fff;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a}.admin-header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.admin-header h1{margin:0;font-size:1.8rem}.admin-main{max-width:1200px;margin:0 auto;padding:2rem}.admin-error{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #fcc}.admin-actions{margin-bottom:2rem}.generate-button{background:linear-gradient(135deg,#8b0000,brown);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s}.generate-button:hover{transform:translateY(-2px)}.generate-form{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.new-keys-section{background:#fff3cd;border:2px solid #ffc107;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.new-keys-section h2{margin-top:0;color:#856404}.warning{color:#856404;font-weight:600;margin-bottom:1rem}.keys-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.new-key-item{display:flex;align-items:center;gap:1rem;background:#fff;padding:.75rem;border-radius:6px}.new-key-item code{flex:1;font-family:monospace;font-size:.9rem;color:#333}.copy-button{background:#8b0000;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem}.copy-button:hover{background:brown}.close-button{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer}.license-keys-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.license-keys-section h2{margin-top:0}.keys-table{width:100%;border-collapse:collapse;margin-top:1rem}.keys-table th{background:#f8f9fa;padding:.75rem;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6}.keys-table td{padding:.75rem;border-bottom:1px solid #dee2e6}.keys-table code{font-family:monospace;font-size:.85rem;background:#f8f9fa;padding:.25rem .5rem;border-radius:4px}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.badge-active{background:#d4edda;color:#155724}.badge-used{background:#d1ecf1;color:#0c5460}.badge-revoked{background:#f8d7da;color:#721c24}.action-buttons{display:flex;gap:.5rem}.action-button{background:#6c757d;color:#fff;border:none;padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-size:.85rem}.action-button:hover{background:#5a6268}.delete-button{background:#dc3545}.delete-button:hover{background:#c82333}.disabled-action{color:#6c757d;font-size:.85rem}*{margin:0;padding:0;box-sizing:border-box}html{height:100%;overflow-x:hidden;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#8b0000,brown);min-height:100%;overflow-x:hidden;padding-bottom:env(safe-area-inset-bottom,0px)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{width:100%;min-height:100%}
