:root{--bg: #f6f5f1;--surface: #ffffff;--surface-2: #faf9f6;--ink: #1f2328;--ink-soft: #5b626b;--line: #e4e2db;--accent: #c8102e;--accent-soft: #fde7ea;--accent-ink: #8c0a20;--green: #1a7f4b;--green-soft: #e4f5ea;--amber: #9a6b00;--amber-soft: #fbf0d6;--blue: #1d5fb8;--blue-soft: #e6eefb;--radius: 14px;--shadow: 0 1px 2px rgba(16, 18, 22, .06), 0 8px 24px rgba(16, 18, 22, .06);--maxw: 980px;--ja-font: "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", "Noto Sans JP", sans-serif}*{box-sizing:border-box}svg.lucide{vertical-align:-.16em;flex:none}.btn svg.lucide,.app-header nav a svg.lucide{vertical-align:middle}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased}img,svg,video,canvas{max-width:100%}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{line-height:1.25;margin:0 0 .4em}.ja{font-family:var(--ja-font);font-feature-settings:"palt";overflow-wrap:anywhere}ruby rt{font-size:.58em;color:var(--ink-soft);font-weight:400}.ja-target{background:linear-gradient(transparent 60%,var(--accent-soft) 60%);color:inherit;font-weight:700;border-bottom:2px solid var(--accent);padding:0 1px}.app-header{position:sticky;top:0;z-index:20;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}.app-header .bar{max-width:var(--maxw);margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:16px;position:relative}.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--ink)}.brand:hover{text-decoration:none}.brand .logo{width:30px;height:30px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center;font-family:var(--ja-font);font-size:18px}.brand small{display:block;font-size:11px;color:var(--ink-soft);font-weight:600;letter-spacing:.03em}.app-header nav{margin-left:auto;display:flex;gap:6px;align-items:center}.app-header nav a{color:var(--ink-soft);font-weight:600;font-size:14px;padding:7px 12px;border-radius:9px;display:inline-flex;align-items:center;gap:6px}.app-header nav a:hover{background:var(--surface-2);text-decoration:none}.app-header nav a.active{color:var(--accent-ink);background:var(--accent-soft)}.nav-dd{position:relative}.nav-dd-btn{display:inline-flex;align-items:center;gap:6px;border:none;background:transparent;cursor:pointer;font:inherit;font-weight:600;font-size:14px;color:var(--ink-soft);padding:7px 12px;border-radius:9px}.nav-dd-btn:hover{background:var(--surface-2)}.nav-dd-menu{position:absolute;top:100%;left:0;width:max-content;min-width:230px;max-width:min(92vw,420px);margin-top:6px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:6px;z-index:30;display:flex;flex-direction:column;gap:2px}.nav-dd-menu:before{content:"";position:absolute;left:0;right:0;top:-8px;height:8px}.nav-dd-head{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);padding:7px 10px 2px}.nav-dd-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap}.nav-dd-item:hover{background:var(--surface-2);text-decoration:none}.nav-dd-item.active{color:var(--accent-ink);background:var(--accent-soft)}.nav-dd-sep{height:1px;background:var(--line);margin:5px 4px}main{max-width:var(--maxw);margin:0 auto;padding:28px 20px 80px}.app-footer{border-top:1px solid var(--line);color:var(--ink-soft);font-size:13px;text-align:center;padding:24px 20px}.crumbs{font-size:13px;color:var(--ink-soft);margin-bottom:16px}.crumbs a{color:var(--ink-soft)}.crumbs span{color:var(--ink);font-weight:600}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 760px){.grid.cols-2,.grid.cols-4{grid-template-columns:1fr}.app-header nav a{padding:7px 9px}}.badge{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.04em;padding:3px 9px;border-radius:999px;background:var(--accent-soft);color:var(--accent-ink)}.badge.gray{background:var(--surface-2);color:var(--ink-soft);border:1px solid var(--line)}.badge.green{background:var(--green-soft);color:var(--green)}.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font:inherit;font-weight:600;font-size:14px;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:9px 14px;border-radius:10px;transition:.15s}.btn:hover{background:var(--surface-2)}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{background:var(--accent-ink)}.btn.ghost{border-color:transparent;background:transparent}.btn.small{padding:6px 10px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed}.hero{background:linear-gradient(135deg,#fff 0%,var(--surface-2) 100%);border:1px solid var(--line);border-radius:20px;padding:36px 32px;box-shadow:var(--shadow);margin-bottom:28px}.hero h1{font-size:34px;letter-spacing:-.02em}.hero p{color:var(--ink-soft);font-size:16px;max-width:62ch}.hero .ja-big{font-family:var(--ja-font);font-size:20px;color:var(--accent-ink);margin-bottom:6px}.feature-list{display:grid;gap:10px;margin-top:18px}.feature-list .item{display:flex;gap:10px;align-items:flex-start;font-size:14px}.feature-list .item .ic{flex:none}.level-card{display:block;padding:24px;border-radius:18px;transition:.15s}.level-card:hover{text-decoration:none;transform:translateY(-2px);box-shadow:0 10px 30px #1012161a}.level-card .lv{font-size:40px;font-weight:900;color:var(--accent);letter-spacing:-.03em}.level-card h3{font-size:20px;margin:4px 0}.level-card p{color:var(--ink-soft);font-size:14px;margin:0}.level-card .meta{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}.section-tile{display:block;padding:22px;border-radius:16px;transition:.15s}.section-tile:hover{text-decoration:none;transform:translateY(-2px);box-shadow:0 10px 30px #1012161a}.section-tile .ic{font-size:30px}.section-tile h3{margin:10px 0 2px;font-size:18px}.section-tile .ja{color:var(--ink-soft);font-size:14px}.section-tile p{color:var(--ink-soft);font-size:13.5px;margin:8px 0 0}.section-tile .prog{margin-top:14px}.progress{height:8px;background:var(--line);border-radius:999px;overflow:hidden}.progress>i{display:block;height:100%;background:var(--green);border-radius:999px;transition:width .3s}.progress.accent>i{background:var(--accent)}.prog-label{font-size:12px;color:var(--ink-soft);margin-top:5px;display:flex;justify-content:space-between}.study{padding:22px 24px}.study h2{font-size:20px}.note{border-left:3px solid var(--accent);padding:2px 0 2px 16px;margin:18px 0;overflow-x:auto}.note h3{font-size:16px;margin-bottom:6px}.note p{margin:6px 0;font-size:15px}.note ul{margin:6px 0;padding-left:20px}.note li{margin:4px 0}.note code,.inline-code{background:var(--surface-2);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-family:var(--ja-font);font-size:.95em}.note table{border-collapse:collapse;margin:10px 0;width:100%;font-size:14px}.note th,.note td{border:1px solid var(--line);padding:6px 10px;text-align:left}.note th{background:var(--surface-2)}.group-head{margin:30px 0 8px;display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}.group-head h2{font-family:var(--ja-font);font-size:22px;margin:0}.group-head .sub{color:var(--ink-soft);font-weight:600}.instruction{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:12px 16px;margin:10px 0 4px;font-size:14px}.instruction .ja{font-size:15px}.instruction .pt{color:var(--ink-soft);margin-top:4px}.example{margin:10px 0;font-size:14px;border:1px dashed var(--line);border-radius:12px;padding:12px 16px;background:#fff}.example .tag{font-weight:700;color:var(--ink-soft);font-size:12px}.q{padding:18px 20px;margin:14px 0}.q .qnum{flex:none;width:30px;height:30px;border-radius:8px;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:800;font-size:14px}.q .qhead{display:flex;gap:12px;align-items:flex-start}.q .qhead>div{min-width:0}.q .stem{font-size:17px}.q .context{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin:4px 0 12px;font-size:15.5px;white-space:pre-wrap;overflow-wrap:anywhere}.choices{display:grid;gap:8px;margin:12px 0 0}.choice{display:flex;gap:10px;align-items:center;cursor:pointer;border:1px solid var(--line);border-radius:10px;padding:10px 13px;transition:.12s;font-family:var(--ja-font);font-size:15.5px;background:#fff;min-width:0;text-align:left;overflow-wrap:anywhere}.choice:hover{background:var(--surface-2)}.choice .num{flex:none;width:22px;height:22px;border-radius:50%;border:1px solid var(--ink-soft);display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--ink-soft);font-family:Inter,sans-serif}.choice.selected{border-color:var(--accent);background:var(--accent-soft)}.choice.selected .num{background:var(--accent);color:#fff;border-color:var(--accent)}.choice.correct{border-color:var(--green);background:var(--green-soft)}.choice.correct .num{background:var(--green);color:#fff;border-color:var(--green)}.choice.wrong{border-color:var(--accent);background:#fdeef0}.choice.wrong .num{background:var(--accent);color:#fff;border-color:var(--accent)}.q .note-field{margin-top:14px}.q .note-field label{font-size:13px;font-weight:600;color:var(--ink-soft);display:block;margin-bottom:5px}.q textarea{width:100%;min-height:52px;resize:vertical;font:inherit;font-size:14px;border:1px solid var(--line);border-radius:10px;padding:9px 12px;background:var(--surface-2)}.q textarea:focus{outline:2px solid var(--accent-soft);border-color:var(--accent);background:#fff}.q .actions{margin-top:12px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.feedback{margin-top:12px;border-radius:10px;padding:12px 14px;font-size:14px}.feedback.ok{background:var(--green-soft);border:1px solid #bfe3cc}.feedback.no{background:var(--accent-soft);border:1px solid #f5cdd4}.feedback .head{font-weight:700;margin-bottom:4px}.feedback .tr{color:var(--ink-soft);font-style:italic;margin-bottom:4px}.saved-dot{font-size:12px;color:var(--green);font-weight:600}.player{padding:18px 20px}.player .top{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.player .pp{flex:none;width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;background:var(--accent);color:#fff;font-size:20px;display:grid;place-items:center}.player .pp:hover{background:var(--accent-ink)}.player .seek{flex:1;min-width:180px}.player input[type=range]{width:100%;accent-color:var(--accent)}.player .time{font-variant-numeric:tabular-nums;font-size:13px;color:var(--ink-soft);min-width:92px;text-align:right}.player .row2{display:flex;gap:16px;align-items:center;margin-top:12px;flex-wrap:wrap}.player .rates{display:flex;gap:6px}.player .rates button{border:1px solid var(--line);background:#fff;border-radius:8px;padding:4px 9px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink-soft)}.player .rates button.active{background:var(--ink);color:#fff;border-color:var(--ink)}.player .ab{display:flex;gap:6px;align-items:center;font-size:13px;color:var(--ink-soft)}.player .ab .chip{border:1px solid var(--line);border-radius:8px;padding:4px 9px;cursor:pointer;font-weight:600;background:#fff}.player .ab .chip.on{background:var(--blue-soft);border-color:var(--blue);color:var(--blue)}.script{margin-top:16px}.script .ctrl{display:flex;gap:14px;align-items:center;margin-bottom:10px;font-size:13px;color:var(--ink-soft)}.switch{display:inline-flex;align-items:center;gap:7px;cursor:pointer;-webkit-user-select:none;user-select:none}.switch input{accent-color:var(--accent)}.script-item{border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin:10px 0;background:#fff}.script-item .label{display:inline-block;font-family:var(--ja-font);font-weight:800;background:var(--ink);color:#fff;border-radius:7px;padding:2px 10px;font-size:13px;margin-bottom:8px}.script-item .setup{font-size:14px;color:var(--ink-soft);margin-bottom:10px}.script-line{display:grid;grid-template-columns:28px 1fr;gap:8px;margin:6px 0}.script-line .sp{font-weight:700;font-size:12px;color:#fff;background:var(--blue);border-radius:6px;height:22px;display:grid;place-items:center}.script-line .sp.f{background:#b5377e}.script-line .sp.m{background:var(--blue)}.script-line .sp.n{background:var(--ink-soft)}.script-line .ja{font-size:15.5px}.script-line .pt{font-size:13.5px;color:var(--ink-soft)}.script-item .question{margin-top:10px;padding-top:10px;border-top:1px dashed var(--line);font-size:14.5px}.script-item .ans{margin-top:6px;font-size:13px;color:var(--green);font-weight:700}.audio-answer{margin-top:10px;padding-top:10px;border-top:1px dashed var(--line);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.audio-answer .aa-label{font-size:13px;font-weight:600;color:var(--ink-soft)}.opt-row{display:flex;gap:6px}.opt{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:#fff;cursor:pointer;font:inherit;font-size:15px;font-weight:700;color:var(--ink-soft);transition:.12s}.opt:hover{background:var(--surface-2)}.opt.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-ink)}.opt.correct{border-color:var(--green);background:var(--green-soft);color:var(--green)}.opt.wrong{border-color:var(--accent);background:#fdeef0;color:var(--accent-ink)}.aa-result{font-size:13.5px;font-weight:600}.backup-bar{padding:16px 20px;margin-bottom:22px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}.backup-bar .info{font-size:13px;color:var(--ink-soft)}.backup-bar .info b{color:var(--ink)}.backup-bar .spacer{flex:1}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:10px;font-size:14px;box-shadow:var(--shadow);z-index:50}.muted{color:var(--ink-soft)}.section-summary{color:var(--ink-soft);font-size:15px;margin-bottom:4px}.divider{height:1px;background:var(--line);margin:26px 0;border:0}.tablist{display:flex;gap:6px;flex-wrap:wrap;margin:16px 0 6px}.tablist button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 15px;cursor:pointer;font:inherit;font-size:14px;font-weight:600;color:var(--ink-soft)}.tablist button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.stat{padding:18px 16px;text-align:center}.stat .big{font-size:30px;font-weight:900;letter-spacing:-.02em;line-height:1.1}.stat .lbl{font-size:12.5px;color:var(--ink-soft);margin-top:4px}.review-card{padding:20px 22px}.review-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;font-size:13px}.grade-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}.grade{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;border:1px solid var(--line);border-radius:12px;padding:11px 6px;background:#fff;font:inherit;transition:.12s}.grade:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.grade .gl{font-weight:700;font-size:14px}.grade .gi{font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums}.grade.again{border-color:#f3c2c9}.grade.again .gl{color:var(--accent-ink)}.grade.hard{border-color:#f1dca8}.grade.hard .gl{color:var(--amber)}.grade.good{border-color:#bfe3cc}.grade.good .gl{color:var(--green)}.grade.easy{border-color:#bcd2f3}.grade.easy .gl{color:var(--blue)}.grade.recommend{box-shadow:0 0 0 2px var(--accent-soft);border-color:var(--accent)}@media (max-width: 620px){.grade-row{grid-template-columns:repeat(2,1fr)}}.exam-bar{position:sticky;top:64px;z-index:10;padding:12px 16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}.exam-clock{font-size:22px;font-weight:900;font-variant-numeric:tabular-nums;color:var(--ink)}.exam-clock.low{color:var(--accent)}.exam-nav{display:flex;align-items:center;gap:12px;margin-top:16px;flex-wrap:wrap}.exam-dots{display:flex;gap:6px;flex-wrap:wrap;flex:1}.exam-dots .dot{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:#fff;cursor:pointer;font:inherit;font-size:12px;font-weight:700;color:var(--ink-soft)}.exam-dots .dot.done{background:var(--surface-2);color:var(--ink)}.exam-dots .dot.cur{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}.exam-table{width:100%;border-collapse:collapse;font-size:14px}.exam-table th,.exam-table td{padding:8px 12px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}.exam-table th{background:var(--surface-2);font-size:12px;color:var(--ink-soft);position:sticky;top:0}.exam-table td{font-variant-numeric:tabular-nums}.field{display:block;margin:12px 0}.field>span{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:5px}.field input[type=text],.field textarea,.field select{width:100%;font:inherit;font-size:15px;border:1px solid var(--line);border-radius:10px;padding:9px 12px;background:var(--surface-2);font-family:var(--ja-font)}.field textarea{min-height:58px;resize:vertical}.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--accent-soft);border-color:var(--accent);background:#fff}.choice-edit{display:flex;align-items:center;gap:10px;margin:7px 0}.choice-edit input[type=radio]{accent-color:var(--accent);width:18px;height:18px;flex:none}.choice-edit input[type=text]{flex:1;font:inherit;font-size:15px;border:1px solid var(--line);border-radius:10px;padding:8px 12px;background:var(--surface-2);font-family:var(--ja-font);min-width:0}@media (max-width: 760px){.app-header{position:static;-webkit-backdrop-filter:none;backdrop-filter:none}.app-header .bar{padding:10px 16px 12px;align-items:flex-start;flex-direction:column;gap:10px}.brand{font-size:17px}.brand{min-height:44px}.brand .logo{width:34px;height:34px}.app-header nav{margin-left:0;width:100%;flex-wrap:wrap;align-items:stretch;gap:8px}.app-header nav a,.nav-dd-btn{min-height:44px;padding:9px 12px;border-radius:10px}.nav-dd{position:static}.nav-dd-menu{left:16px;right:16px;width:auto;min-width:0;max-width:none;max-height:min(70vh,520px);overflow-y:auto}main{padding:20px 16px 72px}.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:0 4px;margin-bottom:12px}.crumbs a,.crumbs span{min-height:44px;display:inline-flex;align-items:center}.crumbs a{min-width:44px;justify-content:center}.hero{border-radius:16px;padding:24px 22px!important;margin-bottom:22px}.hero h1{font-size:30px;letter-spacing:0}.hero p{font-size:15px}.card{border-radius:12px}.level-card,.section-tile{padding:18px}.study,.q,.review-card,.player,.backup-bar{padding:16px}.group-head{margin-top:24px}.btn{min-height:44px;justify-content:center}.btn.small{min-height:44px;padding:9px 12px}.backup-bar{align-items:stretch;gap:10px}.backup-bar .info,.backup-bar .spacer{flex-basis:100%}.backup-bar .spacer{display:none}.backup-bar .btn{width:100%}.tablist{gap:8px;overflow-x:auto;padding-bottom:2px}.tablist button{min-height:44px;white-space:nowrap}.switch{min-height:44px}.q .qhead{gap:10px}.q .qnum{width:28px;height:28px;border-radius:8px}.q .context{padding:10px 12px;font-size:15px}.choice{align-items:flex-start;min-height:44px;padding:11px 12px}.choice .num{margin-top:1px}.q textarea{min-height:76px}.player .top{display:grid;grid-template-columns:48px 1fr;align-items:center;gap:10px 12px}.player .seek{min-width:0}.player .time{grid-column:1 / -1;min-width:0;text-align:left}.player .row2,.player .rates,.player .ab,.script .ctrl,.audio-answer,.opt-row{gap:8px}.player .rates button,.player .ab .chip,.opt{min-height:44px;min-width:44px}.script-line{grid-template-columns:26px minmax(0,1fr)}.grade-row{gap:8px}.exam-bar{top:0;padding:12px;gap:10px}.exam-clock{width:100%;font-size:24px}.exam-nav{align-items:stretch}.exam-nav>.btn{flex:1 1 130px}.exam-dots{order:3;flex-basis:100%;justify-content:center}.exam-dots .dot{width:44px;height:44px}.exam-table th,.exam-table td{padding:9px 10px}.choice-edit{align-items:flex-start}.choice-edit input[type=radio]{margin-top:10px}.field input[type=text],.field select,.choice-edit input[type=text]{min-height:44px}}@media (max-width: 380px){main{padding-inline:14px}.app-header .bar{padding-inline:14px}.brand small{font-size:10.5px}.app-header nav{gap:6px}.app-header nav a,.nav-dd-btn{font-size:13px;padding-inline:10px}.hero{padding:22px 18px!important}.hero h1{font-size:27px}.hero .ja-big{font-size:18px}.level-card .lv{font-size:34px}.section-tile h3{font-size:17px}.q .qhead{display:grid;grid-template-columns:28px minmax(0,1fr)}.stat .big{font-size:26px}.toast{left:14px;right:14px;transform:none;text-align:center}}
