*{box-sizing:border-box}body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;margin:0;padding:0;background:#fafafa;color:#222}.container{display:flex;flex-wrap:wrap;gap:20px;padding:20px}.left-panel{flex:1 1 260px;max-width:300px;background:#fff;border-radius:10px;padding:16px;border:1px solid #e5e5e5}.left-panel h2{font-size:18px;margin:0 0 10px}.category-select{display:flex;flex-direction:column;gap:10px}.category-row label{display:block;margin-bottom:6px;cursor:pointer;font-size:15px}.grade-select{margin-top:10px;text-align:center}.grade-label{font-weight:700;font-size:14px;margin:6px 0 8px;color:#2b2b2b;display:block;text-align:left}.grade-list{display:grid;grid-template-columns:repeat(3,1fr);justify-content:center;align-items:center;gap:10px 10px;max-width:260px;margin:0 auto;line-height:1.6;font-size:14px}.grade-list label{display:flex;align-items:center;justify-content:flex-start;gap:6px;padding:6px 8px;border-radius:8px;white-space:nowrap;transition:background .15s , outline .15s}.grade-list label:hover{background:#f0f5ff}.grade-list label:has(input:checked) {background:#e7efff;outline:1px solid #c7d8ff;font-weight:600}@media (max-width:640px){.grade-list{grid-template-columns:repeat(2,1fr);max-width:220px;gap:8px 10px;font-size:14px}}.text-selection{margin-top:14px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 8px}.text-button{padding:6px 10px;border:1px solid #c9c9c9;border-radius:8px;background:#f6f7fb!important;color:#000!important;text-align:left;cursor:pointer}.text-button:hover{background:#e1eaff!important;color:#000!important}.right-panel{flex:1 1 640px;min-width:520px}.right-panel h2{font-size:20px;margin:0 0 10px}.section-title{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap}.section-title small{font-size:.9rem;color:#666;font-weight:500}.instruction{margin:6px 0 10px;font-size:14px;color:#444}.current-problem{margin:2px 0 8px;font-size:14px;font-weight:600;color:#2b4a9e}.text-box{border:1px solid #cfcfcf;border-radius:8px;padding:12px;background:#fff;min-height:160px;white-space:pre-wrap}.input-box{width:100%;height:260px;padding:10px;margin-top:10px;border-radius:8px;border:1px solid #8a8a8a;font-size:16px}.controls{margin-top:10px;display:flex;gap:10px}button{padding:8px 16px;border-radius:8px;border:none;background:#3c7cff;color:#fff;cursor:pointer;font-size:15px}button:disabled{background:#b6b6b6}button:hover:not(:disabled) {background:#2b69e8}.results{margin-top:14px;background:#fff;border:1px solid #e5e5e5;padding:12px;border-radius:8px;line-height:1.6;font-size:14px}.val-red{color:#d60000}.val-blue{color:#004fe3}.val-purple{color:#6a1b9a}.diff-wrap{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.diff-box h3{margin:0 0 6px;font-size:15px}.diff{min-height:100px;background:#fff;border:1px solid #e5e5e5;border-radius:8px;padding:10px;line-height:1.8;white-space:pre-wrap;word-break:break-word}.mistake{background:#ffcdcd}.omission{background:#cfe0ff}.extra{background:#e4ccff}.exam-timer-row{display:flex;align-items:center;gap:.75rem;margin:.6rem 0}.timer-label{font-size:13px;color:#444}.exam-timer{font-variant-numeric:tabular-nums;font-weight:800;font-size:1.6rem;letter-spacing:.02em;padding:.25rem .6rem;border-radius:.6rem;background:#f5f5f7;min-width:6ch;text-align:center}.exam-timer.warn{background:#fff4cc}.exam-timer.urgent{background:#ffe1e1}.exam-timer.finished{background:#e6e6e6;color:#666}.locked{opacity:.65;filter:grayscale(.2)}.site-notes{text-align:center;margin-top:22px;font-size:13px}.site-notes p{margin:6px 0}.site-notes small{color:#666}.note-ai{font-size:12px;color:#777}.site-notes .links{margin:16px 0 12px}.site-notes .btn-en{display:inline-block;padding:10px 22px;border-radius:9999px;font-size:15px;font-weight:600;text-decoration:none;color:#0040c1;background:linear-gradient(180deg,#f7faff 0%,#e6efff 100%);border:1px solid #cfdfff;box-shadow:0 1px 3px rgba(0,0,0,.08);transition:all .2s ease}.site-notes .btn-en:hover{background:linear-gradient(180deg,#eaf2ff 0%,#dbe7ff 100%);transform:translateY(-1px);box-shadow:0 3px 5px rgba(0,0,0,.12)}.site-notes .jta{margin:18px auto 8px;max-width:920px;display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}.site-notes .jta-center{text-align:center}.site-notes .jta-side{display:flex;align-items:center;justify-content:center}.side-banner{height:70px;width:auto;object-fit:contain}@media (max-width:640px){.side-banner{height:50px}}.site-notes .jta-logo img{height:70px;width:auto;object-fit:contain;display:block;margin:0 auto}.site-notes .jta-text{font-size:14px;color:#333;line-height:1.7;margin:0}@media (min-width:640px){.site-notes .jta-text{font-size:15px}}@media (max-width:880px){.right-panel{min-width:100%}.diff-wrap{grid-template-columns:1fr}}.terms-wrap{max-width:880px;margin:0 auto;padding:20px 16px 28px}.terms-header{margin-bottom:22px;padding-bottom:10px;border-bottom:1px solid #e5e5e5}.terms-site-title{margin:0;font-size:18px;font-weight:700}.terms-site-title a{color:#222;text-decoration:none}.terms-site-title a:hover{text-decoration:underline}.terms-site-sub{margin:4px 0 0;font-size:14px;color:#666}.terms-main{background:#fff;border-radius:10px;padding:22px 18px 24px;border:1px solid #e5e5e5}.terms-title{font-size:24px;margin:0 0 16px;padding-left:10px;border-left:4px solid #3c7cff}.terms-lead{font-size:15px;background:#f5f7ff;border-radius:8px;padding:14px 18px;margin:12px 0;line-height:1.75}.terms-section{margin-bottom:22px}.terms-section h2{font-size:17px;margin:0 0 6px;padding-left:8px;border-left:3px solid #3c7cff}.terms-section p{margin:0;font-size:15px;line-height:1.9}.terms-date{margin-top:26px;font-size:14px;color:#666;text-align:right}.terms-links{margin-top:18px;display:flex;flex-wrap:wrap;gap:10px}.terms-btn-main,.terms-btn-sub{display:inline-block;padding:8px 16px;border-radius:9999px;font-size:14px;text-decoration:none;cursor:pointer}.terms-btn-main{background:#3c7cff;color:#fff;border:1px solid #2b69e8}.terms-btn-main:hover{background:#2b69e8}.terms-btn-sub{background:#f0f4ff;color:#1f4fb6;border:1px solid #c6d6ff}.terms-btn-sub:hover{background:#e3ecff}.terms-footer{margin-top:18px;font-size:13px;color:#666;text-align:center}.terms-footer p{margin:4px 0}.terms-note{font-size:13px}@media (max-width:640px){.terms-wrap{padding:16px 10px 24px}.terms-main{padding:18px 12px 20px}.terms-title{font-size:20px}.terms-links{flex-direction:column}.terms-btn-main,.terms-btn-sub{width:100%;text-align:center}}.kyosan-banner-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:20px}.kyosan-banner{display:block;padding:10px;text-align:center;background:transparent;border:none;border-radius:0;transition:transform .2s ease}.kyosan-banner:hover{box-shadow:0 2px 8px rgba(0,0,0,.08)}.kyosan-banner img{max-width:100%;height:auto}.kyosan-text-link{list-style:none;padding-left:0;margin-top:15px}.kyosan-text-link li{margin-bottom:8px}.kyosan-text-link a{text-decoration:none;color:#06c}.kyosan-text-link a:hover{text-decoration:underline}.kyosan-text-only{list-style:none;padding-left:0;margin-top:15px;display:flex;flex-wrap:wrap;gap:10px 20px}.kyosan-text-only li{font-size:.95em;color:#333}.top-sponsors{margin:24px auto 16px;padding-top:8px;text-align:center}.top-sponsors-title{font-size:13px;font-weight:500;color:#666;letter-spacing:.04em;margin-bottom:10px}.top-sponsors-grid{display:flex;justify-content:center;gap:48px;flex-wrap:wrap}.top-sponsor{display:flex;align-items:center;justify-content:center}.top-sponsor img{max-height:48px;max-width:200px;width:auto;height:auto}.kyosan-banner-grid{gap:24px}.kyosan-banner{padding:8px}.kyosan-banner img{max-height:60px;max-width:260px;width:auto;height:auto}.kyosan-plan-table{width:100%;border-collapse:collapse;margin:16px 0 8px;font-size:14px}.kyosan-plan-table th,.kyosan-plan-table td{border:1px solid #dde3f5;padding:12px 14px;vertical-align:top}.kyosan-plan-table th{background:#f3f5ff;text-align:left;font-weight:600;white-space:nowrap}.kyosan-plan-table td:nth-child(2) {white-space:nowrap}.terms-note{font-size:13px;color:#555;line-height:1.7;margin-top:12px}.terms-section ol{margin-left:1.2em;padding-left:.5em}.terms-section ol li{margin-bottom:10px;line-height:1.7}.terms-links{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap}.terms-btn-main,.terms-btn-sub{display:inline-block;padding:12px 20px;border-radius:6px;text-decoration:none;font-size:14px}.terms-btn-main{background:#3f51b5;color:#fff}.terms-btn-main:hover{opacity:.9}.terms-btn-sub{background:#eef1ff;color:#3f51b5}.terms-btn-sub:hover{background:#e2e6ff}@media (max-width:640px){.kyosan-plan-table{font-size:13px}.kyosan-plan-table th,.kyosan-plan-table td{padding:9px 8px}.terms-links{flex-direction:column}.terms-btn-main,.terms-btn-sub{text-align:center;width:100%}}.site-notes .links-multi{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}.site-notes .btn-en,.site-notes .btn-quest{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:9999px;font-size:15px;font-weight:600;text-decoration:none;line-height:1;box-shadow:0 1px 3px rgba(0,0,0,.08);transition:transform .15s ease , box-shadow .15s ease , background .15s ease , border-color .15s ease}.site-notes .btn-en{color:#0040c1;background:linear-gradient(180deg,#f7faff 0%,#e6efff 100%);border:1px solid #cfdfff}.site-notes .btn-quest{color:#8a2a00;background:linear-gradient(180deg,#fff3ea 0%,#ffe1cf 100%);border:1px solid #ffd0b6}.site-notes .btn-en:visited{color:#0040c1}.site-notes .btn-quest:visited{color:#8a2a00}.site-notes .btn-en:hover,.site-notes .btn-quest:hover{transform:translateY(-1px);box-shadow:0 3px 6px rgba(0,0,0,.12)}.site-header{position:sticky;top:0;z-index:999;background:rgba(250,250,250,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.08)}.site-header-inner{max-width:1100px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.site-brand{text-decoration:none;color:#222;font-weight:800;font-size:15px;white-space:nowrap}.site-nav{display:flex;align-items:center;gap:10px}.site-nav a{text-decoration:none;color:#222;font-weight:700;font-size:14px;padding:8px 10px;border-radius:9999px}.site-nav a:hover{background:rgba(0,0,0,.06)}.nav-toggle{display:none;width:42px;height:42px;border-radius:12px;border:1px solid rgba(0,0,0,.10);background:#fff;cursor:pointer}.nav-toggle span{display:block;width:20px;height:2px;background:#222;margin:4px auto}@media (max-width:820px){.nav-toggle{display:inline-block}.site-nav{display:none;position:absolute;top:58px;left:14px;right:14px;flex-direction:column;align-items:stretch;gap:6px;padding:10px;background:rgba(255,255,255,.96);border:1px solid rgba(0,0,0,.10);border-radius:14px;box-shadow:0 12px 30px rgba(0,0,0,.12)}.site-nav.is-open{display:flex}.site-nav a{text-align:center}}