:root{--bg: #f4f6f9;--panel: #ffffff;--border: #e2e6ec;--border-strong: #cdd4de;--text: #1c2433;--muted: #6b7588;--accent: #2f6fde;--accent-soft: #eaf1fd;--danger: #d6453d;--ok: #1f9d57;--warn: #c97a12;--shadow: 0 1px 3px rgba(20, 30, 50, .08), 0 4px 16px rgba(20, 30, 50, .06);font-synthesis:none}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Pretendard,-apple-system,Segoe UI,Malgun Gothic,system-ui,sans-serif;color:var(--text);background:var(--bg);font-size:14px;line-height:1.5}button{font:inherit;cursor:pointer}.app{display:grid;grid-template-columns:264px 1fr;grid-template-rows:auto 1fr;grid-template-areas:"header header" "nav    main";height:100%}.app-header{grid-area:header;display:flex;align-items:center;gap:12px;padding:10px 18px;background:var(--panel);border-bottom:1px solid var(--border);z-index:5}.app-header h1{font-size:15px;margin:0;font-weight:700;letter-spacing:-.01em}.mode-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px}.mode-badge.edit{background:#e7f6ee;color:var(--ok)}.mode-badge.view{background:#eef1f6;color:var(--muted)}.app-header .spacer{flex:1}.view-toggle{display:inline-flex;border:1px solid var(--border-strong);border-radius:8px;overflow:hidden}.view-toggle button{border:none;background:#fff;padding:5px 16px;font-weight:600;color:var(--muted)}.view-toggle button+button{border-left:1px solid var(--border-strong)}.view-toggle button.active{background:var(--accent);color:#fff}.nav{grid-area:nav;background:var(--panel);border-right:1px solid var(--border);overflow-y:auto;padding:10px 0 30px}.nav-search{margin:4px 12px 12px;width:calc(100% - 24px);padding:7px 10px;border:1px solid var(--border-strong);border-radius:7px;font:inherit}.nav-group-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:12px 16px 4px}.nav-ccode{padding:6px 16px 2px;font-size:13px;font-weight:700;color:var(--text)}.nav-ccode small{color:var(--muted);font-weight:500;margin-left:6px}.nav-item{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;text-align:left;border:none;background:none;padding:6px 16px 6px 28px;color:var(--text);border-left:3px solid transparent}.nav-item:hover{background:var(--bg)}.nav-item.active{background:var(--accent-soft);border-left-color:var(--accent);font-weight:600}.nav-item .count{font-size:11px;color:var(--muted);background:var(--bg);border-radius:999px;padding:1px 8px}.nav-item.active .count{background:#fff}.lesson-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:4px 16px 10px}.lesson-chip{border:1px solid var(--border-strong);background:#fff;border-radius:7px;padding:7px 4px;font-weight:600;color:var(--text);text-align:center}.lesson-chip:hover{border-color:var(--accent);background:var(--accent-soft)}.lesson-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.main{grid-area:main;overflow:hidden;display:flex;flex-direction:column}.toolbar{display:flex;align-items:center;gap:12px;padding:10px 18px;border-bottom:1px solid var(--border);background:var(--panel)}.toolbar .title{font-weight:700;font-size:14px}.toolbar .sub{color:var(--muted);font-size:12px}.toolbar .spacer{flex:1}.btn{border:1px solid var(--border-strong);background:#fff;border-radius:7px;padding:7px 14px;font-weight:600;color:var(--text)}.btn:hover{border-color:var(--accent)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:disabled{background:#aebfdc;border-color:#aebfdc;cursor:not-allowed}.dirty-dot{color:var(--warn);font-weight:700}.table-wrap{overflow:auto;flex:1}table.grid{border-collapse:separate;border-spacing:0;font-size:13px;width:max-content;min-width:100%}table.grid th,table.grid td{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:0;vertical-align:top}table.grid thead th{position:sticky;top:0;background:#f7f9fc;z-index:2;text-align:left;padding:8px 10px;font-weight:700;white-space:nowrap;border-bottom:2px solid var(--border-strong)}table.grid thead th .col-type{display:block;font-weight:500;font-size:10px;color:var(--muted)}table.grid tbody tr:nth-child(2n){background:#fbfcfe}table.grid tbody tr:hover{background:var(--accent-soft)}@keyframes rowflash{0%,20%{background-color:#ffdf85}to{background-color:transparent}}table.grid tbody tr.flash-row td{animation:rowflash 2.2s ease-out}.rownum{position:sticky;left:0;background:#f7f9fc;color:var(--muted);text-align:right;padding:6px 8px!important;font-variant-numeric:tabular-nums;z-index:1;border-right:2px solid var(--border-strong)!important}.cell{display:block;max-width:340px;max-height:72px;overflow:hidden;padding:6px 10px;white-space:pre-wrap;word-break:break-word;cursor:text;position:relative}.cell.empty{color:#c4cad4}.cell.long:after{content:"⤢";position:absolute;right:4px;bottom:2px;font-size:11px;color:var(--accent);background:linear-gradient(transparent,#fff 60%);padding-left:8px}.cell-input{width:100%;min-width:90px;border:2px solid var(--accent);padding:4px 8px;font:inherit;outline:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141c2c6b;display:flex;align-items:center;justify-content:center;z-index:50;padding:24px}.modal{background:#fff;border-radius:12px;box-shadow:var(--shadow);width:min(760px,100%);max-height:86vh;display:flex;flex-direction:column}.modal header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:10px}.modal header .field{font-weight:700}.modal header .meta{color:var(--muted);font-size:12px}.modal .body{padding:14px 18px;overflow:auto}.modal textarea{width:100%;min-height:320px;border:1px solid var(--border-strong);border-radius:8px;padding:12px;font:inherit;font-family:SF Mono,Consolas,monospace;font-size:13px;resize:vertical}.modal .readonly-text{white-space:pre-wrap;word-break:break-word}.modal footer{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.reader-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden}.reader-bar{display:flex;align-items:center;gap:12px;padding:8px 18px;border-bottom:1px solid var(--border);background:var(--panel)}.reader-bar .reader-title{font-weight:700}.reader-bar .spacer{flex:1}.answers-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.edit-hint{font-size:12px;color:var(--muted);margin-left:12px}.editable{position:relative;border-radius:3px;cursor:pointer;transition:background .1s,box-shadow .1s}.editable:hover{background:#fff6da;box-shadow:inset 0 0 0 1px #f0d28a}.editable.open{background:#fff1c9;box-shadow:inset 0 0 0 1px var(--warn)}div.editable{display:block}.edit-pop{position:absolute;top:-36px;left:0;z-index:30;display:inline-flex;gap:2px;background:#1c2433;border-radius:7px;padding:3px;box-shadow:var(--shadow);white-space:nowrap}.edit-pop:after{content:"";position:absolute;bottom:-5px;left:14px;border:5px solid transparent;border-top-color:#1c2433;border-bottom:0}.edit-pop button{background:transparent;border:none;color:#fff;font-size:12px;font-weight:700;padding:4px 10px;border-radius:5px}.edit-pop button:hover{background:var(--accent)}.reader{overflow-y:auto;padding:32px 0 80px}.reader>*{max-width:760px;margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px}.reader-section{margin-bottom:44px}.reader-section h3{font-size:22px;border-bottom:2px solid var(--text);padding-bottom:8px;margin:0 0 20px}.reader-section h3 .roman{color:var(--accent);margin-right:6px}.reader h4{font-size:16px;margin:28px 0 12px;color:var(--text)}.reader h5{font-size:13px;margin:18px 0 8px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.content-block{margin:24px 0 8px;padding-top:8px}table.vocab{border-collapse:collapse;width:100%;font-size:14px;margin-bottom:8px}table.vocab th,table.vocab td{border:1px solid var(--border-strong);padding:7px 12px;text-align:left}table.vocab th{background:#f7f9fc;font-weight:700}table.vocab td:first-child{font-weight:600;width:40%}blockquote.script,blockquote.passage{margin:0 0 12px;padding:16px 20px;background:#f8fafc;border-left:4px solid var(--accent);border-radius:0 8px 8px 0;line-height:1.75;white-space:pre-wrap;font-size:15px}blockquote.passage{border-left-color:#7c5cd6}.translation{color:var(--muted);font-size:13.5px;line-height:1.7;margin:0 0 12px;padding:0 4px;white-space:pre-wrap}.mk-under{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}.mk-labeling{background:#fff3d6;border-radius:3px;padding:0 2px}.mk-labeling sup{color:var(--warn);font-weight:700;margin-right:1px}.mk-blank{color:var(--accent);font-weight:700;background:#eef3fc;border-radius:3px;padding:0 3px}.quiz-item{margin:16px 0}.quiz-q{margin-bottom:8px;line-height:1.6}.quiz-options{list-style:none;margin:0;padding:0}.quiz-opt{display:flex;gap:8px;padding:6px 10px;border-radius:6px;line-height:1.55}.quiz-opt .opt-mark{color:var(--muted);flex-shrink:0}.quiz-opt .opt-body{flex:1}.quiz-opt.correct{background:#e7f6ee}.quiz-opt.correct .opt-mark{color:var(--ok)}.opt-badge{font-size:11px;font-weight:700;color:var(--ok);border:1px solid var(--ok);border-radius:999px;padding:0 7px;margin-left:8px}.opt-expl{font-size:12.5px;color:var(--muted);margin-top:3px;line-height:1.55}.quiz-tf{display:flex;gap:12px}.tf-opt{border:1px solid var(--border-strong);border-radius:6px;padding:4px 18px;font-weight:700}.tf-opt.correct{background:#e7f6ee;border-color:var(--ok);color:var(--ok)}.tf-expls{margin-top:8px}.dictation-answers{margin:10px 0 0;padding-left:22px;font-size:13.5px;color:var(--text);columns:2}.dictation-answers li{margin-bottom:4px}.warn-note{color:var(--warn);font-size:12.5px;margin:4px 0 8px}.writing-list{padding-left:22px}.writing-list li{margin-bottom:12px}.writing-kor{line-height:1.6}.writing-eng{color:var(--accent);font-size:13.5px;margin-top:2px}.markdown{line-height:1.75}.markdown h1,.markdown h2,.markdown h3{margin:22px 0 10px}.markdown hr{border:0;border-top:1px solid var(--border);margin:16px 0}.markdown code{background:#eef1f6;padding:1px 5px;border-radius:4px;font-size:.9em}.markdown p{margin:8px 0}.center-note{margin:auto;text-align:center;color:var(--muted);padding:48px}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%);background:#1c2433;color:#fff;padding:10px 18px;border-radius:8px;box-shadow:var(--shadow);z-index:80;font-size:13px}.toast.error{background:var(--danger)}
