*{box-sizing:border-box;margin:0;padding:0}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;-webkit-tap-highlight-color:transparent}.app{min-height:100vh;background-color:#f5f5f5;display:flex;flex-direction:column}header{background-color:#282c34;color:#fff;padding:12px 16px;text-align:center;position:relative}header h1{font-size:18px;transition:opacity .2s ease}header h1:hover{opacity:.8}header .back-button{position:absolute;left:8px;top:50%;transform:translateY(-50%);padding:10px 12px;font-size:14px;text-decoration:none;color:#fff;background-color:transparent;border:none;cursor:pointer;transition:opacity .2s ease;min-height:44px;display:flex;align-items:center}header .back-button:hover{opacity:.8}header .back-button:active{transform:translateY(-50%) scale(.98)}main{flex:1;max-width:800px;margin:0 auto;padding:20px 16px;width:100%}button{padding:12px 20px;font-size:16px;border:none;border-radius:8px;background-color:#282c34;color:#fff;cursor:pointer;transition:background-color .2s ease;min-height:44px}button:hover{background-color:#404854}button:active{transform:scale(.98)}.flashcard-deck{text-align:center}.flashcard-deck h2{margin-bottom:12px;color:#333;font-size:20px}.deck-list{text-align:center}.deck-list h2{margin-bottom:20px;color:#333;font-size:24px}.deck-grid{display:flex;flex-direction:column;gap:12px;margin-top:16px}.deck-card{background-color:#fff;border:2px solid #ddd;border-radius:8px;padding:20px;cursor:pointer;transition:all .3s ease;text-align:left;min-height:44px}.deck-card:hover{border-color:#282c34;box-shadow:0 4px 12px #0000001a}.deck-card:active{transform:scale(.98)}.deck-card h3{color:#282c34;margin-bottom:8px;font-size:18px}.deck-card p{color:#666;font-size:14px;line-height:1.5}.error{color:#d32f2f;padding:20px;background-color:#ffebee;border-radius:4px;text-align:center}.deck-list-loading,.deck-list-error{text-align:center;padding:40px 16px;color:#666}.mode-selection{text-align:center}.mode-selection h2{margin-bottom:8px;color:#333;font-size:22px}.mode-selection-subtitle{color:#666;font-size:16px;margin-bottom:20px}.mode-options{display:flex;flex-direction:column;gap:12px;margin-top:16px}.mode-option{background-color:#fff;border:2px solid #ddd;border-radius:8px;padding:24px 20px;cursor:pointer;transition:all .3s ease;text-align:center;min-height:44px}.mode-option:hover{border-color:#282c34;box-shadow:0 4px 12px #0000001a}.mode-option:active{transform:scale(.98)}.mode-option h3{color:#282c34;margin-bottom:8px;font-size:20px}.mode-option p{color:#666;font-size:14px}.flashcard{min-height:250px;border-radius:12px}.flashcard-front{text-align:center;font-size:28px}.flashcard-back{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.flashcard-text{font-size:28px;text-align:center;font-weight:500}.flashcard-actions{margin-top:20px;display:flex;flex-direction:column;gap:12px;align-items:stretch}.main-buttons{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:10px}.button-yes,.button-no{padding:16px 20px;font-size:18px;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;min-height:56px}.button-no{background-color:#f44336;color:#fff;grid-column:1;grid-row:1}.button-no:hover{background-color:#da190b}.button-yes{background-color:#4caf50;color:#fff;grid-column:2;grid-row:1}.button-yes:hover{background-color:#45a049}.button-yes:active,.button-no:active{transform:scale(.95)}.button-nav{padding:10px 16px;font-size:14px;background-color:#e0e0e0;color:#333;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease;min-height:44px}.button-nav:hover{background-color:#d0d0d0}.button-finish{padding:14px 24px;font-size:16px;background-color:#282c34;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease;min-height:44px}.button-finish:hover{background-color:#404854}.button-finish:active{transform:scale(.98)}.answer-status{margin-top:8px;padding:10px 16px;background-color:#f5f5f5;border-radius:8px;color:#666;font-size:14px;text-align:center}.results-screen{text-align:center}.results-screen h2{color:#333;margin-bottom:20px;font-size:24px}.results-summary{margin-bottom:24px}.score-display{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px 20px;border-radius:12px;box-shadow:0 4px 12px #0000001a}.score-number{font-size:56px;font-weight:700;margin-bottom:8px}.score-breakdown{font-size:20px;opacity:.9}.failed-cards-section{margin:24px 0;text-align:left}.failed-cards-section h3{color:#333;margin-bottom:12px;font-size:20px}.failed-cards-list{display:flex;flex-direction:column;gap:8px}.failed-card-item{display:flex;align-items:center;padding:16px;background-color:#fff;border:2px solid #ffcdd2;border-radius:8px;gap:10px}.failed-card-front{flex:1;font-size:16px;font-weight:500;color:#333}.failed-card-separator{color:#999;font-size:18px}.failed-card-back{flex:1;font-size:16px;color:#666}.results-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.button-primary,.button-secondary{padding:16px 24px;font-size:16px;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;min-height:48px;width:100%}.button-primary{background-color:#282c34;color:#fff}.button-primary:hover{background-color:#404854}.button-secondary{background-color:#fff;color:#282c34;border:2px solid #282c34}.button-secondary:hover{background-color:#f5f5f5}.button-primary:active,.button-secondary:active{transform:scale(.95)}.user-button{position:absolute;right:16px;top:50%;transform:translateY(-50%)}.sign-in-screen{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 60px)}.sign-in-container{text-align:center;padding:40px 20px}.sign-in-container h2{color:#333;margin-bottom:12px;font-size:24px}.sign-in-container p{color:#666;margin-bottom:24px;font-size:16px}.sign-in-button{width:auto;padding:16px 32px;font-size:18px}.mode-option-smart{border-color:#667eea;background:linear-gradient(135deg,#667eea0d,#764ba20d)}.mode-option-smart:hover{border-color:#764ba2}.smart-review-loading{text-align:center;padding:40px 16px;color:#666;font-size:16px}.smart-review-error{text-align:center;padding:40px 16px;color:#d32f2f;font-size:16px}.smart-review-empty{text-align:center;padding:40px 16px}.smart-review-empty p{color:#333;font-size:18px;margin-bottom:8px}.smart-review-suggestion{color:#666;font-size:14px}.submit-error-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;margin-bottom:16px;background-color:#fff3e0;border:1px solid #ffb74d;border-radius:8px;color:#e65100;font-size:14px}.banner-dismiss{background:none;border:none;color:#e65100;font-size:13px;cursor:pointer;padding:4px 8px;min-height:auto;white-space:nowrap}.banner-dismiss:hover{background-color:#e651001a}@media(min-width:600px){header{padding:16px 20px}header h1{font-size:22px}header .back-button{left:16px;padding:10px 16px}main{padding:32px 24px}.deck-list h2{font-size:28px;margin-bottom:24px}.deck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.deck-card{padding:24px}.deck-card:hover{transform:translateY(-4px)}.mode-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.mode-option{padding:32px 24px}.mode-option:hover{transform:translateY(-4px)}.flashcard-front,.flashcard-text{font-size:32px}.main-buttons{display:flex;justify-content:center;align-items:center;gap:10px}.button-yes,.button-no{min-width:120px}.results-screen h2{font-size:32px;margin-bottom:30px}.score-display{padding:40px}.score-number{font-size:72px}.score-breakdown{font-size:24px}.failed-cards-section{margin:32px 0}.failed-cards-section h3{font-size:24px;margin-bottom:16px}.failed-card-item{padding:20px;gap:15px}.failed-card-front,.failed-card-back{font-size:18px}.results-actions{flex-direction:row;justify-content:center;gap:15px}.button-primary,.button-secondary{width:auto;padding:15px 30px}}@media(min-width:900px){header{padding:20px}header h1{font-size:24px}header .back-button{left:20px}main{padding:40px 20px}.deck-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.deck-card{padding:30px}.mode-options{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.mode-option{padding:40px 30px}.results-summary{margin-bottom:40px}.failed-cards-section{margin:40px 0}}
