:root{font-family:Segoe UI,system-ui,sans-serif;line-height:1.5;color:#1a1a1a;background:#f6f7f9}*{box-sizing:border-box}body{margin:0}.app{max-width:720px;margin:0 auto;padding:2rem 1.25rem 3rem}header h1{margin:0;font-size:1.75rem}.header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.nav{display:flex;gap:.5rem;flex-wrap:wrap}.nav-btn{background:#eceff3;color:#1a1a1a;border:1px solid #d5dbe3;border-radius:8px;padding:.45rem .75rem;font-size:.9rem}.nav-btn.active{background:#e8eef8;border-color:#2f6fed;color:#1f4fad}.subtitle{margin:.25rem 0 0;color:#5c6570}.progress-wrap{margin:1.25rem 0 1.5rem}.progress-label{font-size:.9rem;color:#5c6570;margin-bottom:.35rem}.progress-track{height:8px;background:#e2e6eb;border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:#2f6fed;transition:width .3s ease}.meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.badge{font-size:.75rem;padding:.2rem .55rem;border-radius:999px;background:#e8eef8;color:#1f4fad}.badge.subtle{background:#eceff3;color:#4a5560}.prompt{font-size:1.15rem;line-height:1.6;margin:0 0 1rem;padding:1rem;background:#fff;border-radius:10px;border:1px solid #e2e6eb}textarea{width:100%;padding:.85rem;border-radius:10px;border:1px solid #cfd6df;font:inherit;resize:vertical;margin-bottom:.75rem}button{font:inherit;cursor:pointer;border:none;border-radius:8px;padding:.65rem 1.1rem}button.primary{background:#2f6fed;color:#fff}button.primary:disabled{opacity:.6;cursor:not-allowed}button.secondary{background:#eceff3;color:#1a1a1a}.feedback{background:#fff;border:1px solid #e2e6eb;border-radius:12px;padding:1.25rem}.score{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.75rem}.score-value{font-size:2rem;font-weight:700}.score.pass .score-value{color:#1a7f4b}.score.fail .score-value{color:#c0392b}.feedback-fr{font-size:1rem;margin:0 0 .75rem}.notes{margin:0 0 .75rem;padding-left:1.2rem;color:#333}.reference,.improved,.feedback-user{margin:.75rem 0;padding:.75rem;background:#f6f7f9;border-radius:8px}.error{color:#c0392b}.complete h2{margin-top:0}.loading{text-align:center;color:#5c6570}.spinner-wrap{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;color:#5c6570}.spinner{width:1.25rem;height:1.25rem;border:2px solid #d5dbe3;border-top-color:#2f6fed;border-radius:50%;animation:spin .7s linear infinite}.spinner-label{font-size:.95rem}@keyframes spin{to{transform:rotate(360deg)}}.feedback.streaming{min-height:6rem}.stream-cursor{color:#2f6fed;animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.history{margin-top:1rem}.history-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.history-header h2{margin:0;font-size:1.25rem}.history-empty{color:#5c6570}.history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85rem}.history-item{background:#fff;border:1px solid #e2e6eb;border-radius:12px;padding:1rem}.history-item-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:.75rem}.history-item-actions{display:flex;align-items:center;gap:.6rem}.history-delete{background:#fdecea;color:#a93226;border:1px solid #f5c6cb;border-radius:8px;padding:.35rem .6rem;font-size:.8rem}.history-delete:disabled{opacity:.6;cursor:not-allowed}.history-id{font-size:.8rem;color:#5c6570;font-weight:600}.history-score{font-size:.85rem;color:#1a7f4b;font-weight:600}.history-en{margin:.5rem 0;font-size:1rem}.history-user,.history-ref,.history-feedback{margin:.5rem 0 0;padding:.65rem;background:#f6f7f9;border-radius:8px;font-size:.95rem}.history-toggle{margin-top:.75rem;background:#eceff3;color:#1a1a1a;font-size:.9rem}.history-attempts{margin-top:.85rem;display:flex;flex-direction:column;gap:.75rem}.history-attempt{padding:.85rem;border:1px solid #e2e6eb;border-radius:10px;background:#fafbfc}.history-attempt-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.history-attempt-label{font-size:.85rem;font-weight:600;color:#4a5560}.history-attempt-score{font-size:.85rem;font-weight:600}.history-attempt-score.pass{color:#1a7f4b}.history-attempt-score.fail{color:#c0392b}.history-notes,.history-improved{margin:.5rem 0 0}
