:root{font-family:Noto Sans JP,system-ui,-apple-system,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#1f1f1f;background-color:#f4f6fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#f4f6fb}a{color:inherit;text-decoration:none}#root{max-width:1100px;margin:0 auto;padding:32px 20px 48px}*{box-sizing:border-box}.app{display:flex;flex-direction:column;gap:24px}.hero{display:flex;gap:24px;justify-content:space-between;align-items:center;background:#f7f7ff;border:1px solid #e5e7ff;border-radius:16px;padding:24px}.eyebrow{text-transform:uppercase;font-weight:600;color:#5b5fc7;margin-bottom:8px;letter-spacing:.1em}h1{margin:0 0 8px;font-size:28px}.subtitle{margin:0;color:#444}.active-type{margin-top:10px;font-weight:600;color:#3f51b5}.view-tabs{display:flex;flex-wrap:wrap;gap:12px}.view-tab{background:#f2f2f2;border:1px solid #d5d5d5;border-radius:12px;padding:10px 18px;font-weight:700}.view-tab.active{background:#1f2a5a;color:#fff;border-color:#1f2a5a}.type-tabs{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.type-tab{background:#f2f2f2;border:1px solid #d5d5d5;border-radius:999px;padding:10px 16px;font-weight:600}.type-tab.active{background:#5b5fc7;color:#fff;border-color:#5b5fc7}.analytics{display:flex;flex-direction:column;gap:20px}.analytics-card h2,.analytics-card h3{margin-top:0}.analytics-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:16px}.analytics-tile{background:#f7f8ff;border:1px solid #d9defc;border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.tile-title{font-weight:700}.tile-stats{display:flex;flex-direction:column;gap:4px;color:#444}.tile-accuracy{font-weight:700;color:#1f2a5a}.file-upload{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;background:#f2f2f2;border:1px solid #d5d5d5;cursor:pointer;font-weight:600}.file-upload input{display:none}.history-table{margin-top:16px;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;background:#fff}.history-row{display:grid;grid-template-columns:minmax(160px,1.2fr) minmax(160px,1fr) repeat(4,minmax(70px,.5fr));gap:8px;padding:10px 14px;border-top:1px solid #eee;font-size:13px}.history-row.header{background:#f6f6f6;font-weight:700;border-top:none}.history-empty{padding:16px;color:#777}.stats{display:grid;grid-template-columns:repeat(3,minmax(72px,1fr));gap:16px;text-align:center}.stat-label{display:block;color:#666;font-size:12px}.stat-value{font-size:20px;font-weight:700}.layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:20px}.card{background:#fff;border:1px solid #e6e6e6;border-radius:16px;padding:24px;box-shadow:0 6px 18px #0000000a}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;color:#555;font-size:14px;gap:12px;flex-wrap:wrap}.badge{background:#edf2ff;color:#3f51b5;padding:4px 10px;border-radius:999px;font-weight:600;margin-right:8px}.meta{font-size:13px;color:#666}.prompt{font-size:20px;font-weight:600;margin:12px 0 20px}.prompt-multiline{white-space:pre-line}.passage{background:#f8fbff;border:1px solid #dbe8ff;border-radius:12px;padding:14px 16px;margin-bottom:14px;color:#333}.meaning{margin:-8px 0 16px;color:#555;font-size:14px}.audio-controls{display:flex;flex-direction:column;gap:10px;align-items:flex-start;margin-bottom:12px}.audio-buttons{display:flex;gap:8px;flex-wrap:wrap}.audio-rate{display:flex;flex-direction:column;gap:8px}.audio-voice{display:flex;flex-direction:column;gap:6px}.audio-voice select{min-width:240px;padding:8px 10px;border-radius:8px;border:1px solid #d5d5d5;background:#fff}.audio-rate input[type=range]{width:220px}.rate-buttons{display:flex;gap:8px;flex-wrap:wrap}.audio-note{margin:0;color:#666;font-size:12px}.answer-area{display:flex;flex-direction:column;gap:10px}.label{font-weight:600;color:#333}.options{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.option{background:#f2f2f2;border:1px solid #d5d5d5;border-radius:12px;padding:12px 16px;font-size:16px}.option.selected{background:#e3e7ff;border-color:#5b5fc7;color:#2f37a6}.picture-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.picture-option{border:1px solid #d5d5d5;background:#fff;border-radius:14px;padding:12px;text-align:left;display:grid;gap:6px}.picture-option.selected{border-color:#5b5fc7;background:#eef0ff}.picture-label{font-weight:700;color:#5b5fc7}.picture-emoji{font-size:28px}.picture-text{font-size:13px;color:#444}.order-answer{padding:12px 14px;border-radius:10px;border:1px dashed #c9c9c9;background:#fafafa;color:#444;min-height:44px}.word-bank{display:flex;flex-wrap:wrap;gap:8px}.word-chip{background:#f2f2f2;border:1px solid #d5d5d5;border-radius:999px;padding:8px 14px}.word-chip.used{opacity:.5;cursor:not-allowed}.order-controls,.button-row{display:flex;flex-wrap:wrap;gap:10px}button{border:none;border-radius:10px;padding:10px 16px;background:#f2f2f2;color:#333;cursor:pointer;font-weight:600}button.primary{background:#5b5fc7;color:#fff}button.ghost{background:#fff;border:1px solid #cfcfcf}.result{margin-top:16px;min-height:28px}.result-good{color:#1b7f3a;font-weight:700}.result-bad{color:#c62828;font-weight:700}.answer-reveal{margin-top:8px;padding:10px 12px;border-radius:10px;background:#fff8e1;border:1px solid #ffe3a3}.tabs{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.tab{background:#f2f2f2;border:1px solid transparent}.tab.active{background:#5b5fc7;color:#fff}.tab-content{min-height:72px;padding:10px 12px;border-radius:12px;background:#f8f9ff;border:1px solid #e3e5ff}.detail-list{margin-top:16px;display:flex;flex-direction:column;gap:12px}.detail-label{font-weight:600;color:#555;display:block;margin-bottom:6px}.grammar-link{margin-top:16px;padding:12px;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:8px}.link-title{font-weight:600;color:#2e7d32;margin:0 0 8px;font-size:14px}.external-link{display:inline-block;color:#1976d2;text-decoration:none;font-weight:500;padding:8px 12px;background:#fff;border:1px solid #90caf9;border-radius:6px;transition:all .2s}.external-link:hover{background:#e3f2fd;border-color:#1976d2;transform:translateY(-1px)}.link-site{color:#666;font-size:12px;font-weight:400;margin-left:4px}.footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.footer-note{color:#777;margin:0;font-size:13px}@media(max-width:900px){.hero{flex-direction:column;align-items:flex-start}.layout{grid-template-columns:1fr}}
