:root{--surface:#fff;--surface-subtle:#f8fafc;--surface-hover:#f8fafc;--border-subtle:#e2e8f0;--accent:#578e7e;--accent-strong:#437063;--text-strong:#111827;--text-medium:#475569;--text-muted:#64748b;--text-inverse:#fff}.baekji-bokseup-toast{top:calc(var(--common-header-visible-offset,var(--common-header-offset,0px)) + 12px);background:var(--text-strong);color:var(--text-inverse);opacity:0;pointer-events:none;z-index:9999;border-radius:8px;padding:10px 24px;font-size:.85rem;font-weight:500;transition:opacity .2s;position:fixed;left:50%;translate:-50%}.baekji-bokseup-toast.is-visible{opacity:1}.baekji-bokseup-new .baekji-bokseup-highlight-group{align-items:center;gap:3px;display:inline-flex;position:relative}.baekji-bokseup-new .baekji-bokseup-highlight-btn{cursor:pointer;border:1.5px solid #0000001a;border-radius:5px;width:20px;height:20px;padding:0;transition:transform .15s,box-shadow .15s}.baekji-bokseup-new .baekji-bokseup-highlight-btn:hover{transform:scale(1.15);box-shadow:0 0 0 2px #00000014}.baekji-bokseup-new .baekji-bokseup-highlight-btn--remove{background:var(--surface);color:var(--text-muted);justify-content:center;align-items:center;font-size:.6rem;display:inline-flex}.baekji-bokseup-new [data-tooltip]{position:relative}.baekji-bokseup-new [data-tooltip]:after{content:attr(data-tooltip);background:var(--text-strong);color:var(--text-inverse);white-space:nowrap;pointer-events:none;opacity:0;z-index:50;border-radius:6px;padding:4px 8px;font-size:.7rem;font-weight:500;transition:opacity .15s;position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%)}.baekji-bokseup-new [data-tooltip]:hover:after{opacity:1}.baekji-bokseup-new .baekji-bokseup-form>[data-show-phase]{flex-direction:column;display:none}.baekji-bokseup-new[data-phase=write] .baekji-bokseup-form>[data-show-phase=write],.baekji-bokseup-new[data-phase=review] .baekji-bokseup-form>[data-show-phase=review],.baekji-bokseup-new[data-phase=grade] .baekji-bokseup-form>[data-show-phase=grade]{flex-direction:column;flex:1;display:flex}.baekji-bokseup-new :focus:not(:focus-visible){outline:none}.baekji-bokseup-new{--baekji-bokseup-max-width:100%;--baekji-bokseup-shell-padding-x:clamp(16px, 4vw, 24px);--baekji-bokseup-shell-padding-y:12px;--baekji-bokseup-shell-padding-bottom:12px;--baekji-bokseup-shell-gap:clamp(12px, 2vw, 20px);--baekji-bokseup-content-padding-x:clamp(24px, 4vw, 36px);--baekji-bokseup-content-padding-y:clamp(20px, 3vw, 28px);--baekji-bokseup-content-padding-y-tight:clamp(14px, 2vw, 20px);--baekji-bokseup-content-gap:10px;overscroll-behavior-y:none}@media (width>=1024px){.baekji-bokseup-new{--baekji-bokseup-max-width:min(92%, 900px)}}@media (width>=1440px){.baekji-bokseup-new{--baekji-bokseup-max-width:1000px}}.baekji-bokseup-new .baekji-bokseup-page-shell{gap:var(--baekji-bokseup-shell-gap);width:100%;max-width:var(--baekji-bokseup-max-width);padding:var(--baekji-bokseup-shell-padding-y) var(--baekji-bokseup-shell-padding-x) var(--baekji-bokseup-shell-padding-bottom);flex-direction:column;flex:1;margin:0 auto;display:flex}.baekji-bokseup-new .baekji-bokseup-form{background:var(--surface);flex-direction:column;min-height:78vh;padding-inline:0;display:flex}.baekji-bokseup-new .baekji-bokseup-page-header{border-bottom:1px solid #eef0f3;padding:16px 0 12px}.baekji-bokseup-new .baekji-bokseup-page-header h1{color:#26313f;letter-spacing:0;overflow-wrap:break-word;word-break:keep-all;margin:0;font-size:22px;font-weight:700;line-height:1.3}.baekji-bokseup-new .baekji-bokseup-category-bar{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:10px;min-width:0;display:grid}.baekji-bokseup-new .baekji-bokseup-title-card{box-sizing:border-box;flex-direction:column;align-items:stretch;gap:6px;min-width:0;display:flex}.baekji-bokseup-new .baekji-bokseup-title-card__label{color:#6b7684;letter-spacing:0;padding-inline:0;font-size:13px;font-weight:600;line-height:1.45}.baekji-bokseup-new .baekji-bokseup-title-card__list{flex-flow:wrap;align-items:center;gap:6px;min-width:0;padding-block:2px;padding-inline:0;display:flex}.baekji-bokseup-new .baekji-bokseup-category-chip{box-sizing:border-box;color:#4e5968;letter-spacing:0;text-align:center;white-space:nowrap;appearance:none;cursor:pointer;touch-action:manipulation;background:#fff;border:1px solid #e5e8eb;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;min-height:36px;padding:6px 14px;font-size:14px;font-weight:600;line-height:1.3;text-decoration:none;transition:background-color .14s,border-color .14s,color .14s;display:inline-flex}.baekji-bokseup-new .baekji-bokseup-category-chip--create{color:var(--accent)}.baekji-bokseup-new .baekji-bokseup-category-chip:hover{color:#191f28;background:#f9fafb}.baekji-bokseup-new .baekji-bokseup-category-chip:focus-visible{outline-offset:3px;outline:2px solid #3182f6}.baekji-bokseup-new .baekji-bokseup-category-chip.is-active{color:#1b64da;background:#e8f3ff;border-color:#3182f6;font-weight:700}.baekji-bokseup-new .baekji-bokseup-category-empty{color:var(--text-muted);font-size:14px;font-weight:500;line-height:1.5}.baekji-bokseup-new .baekji-bokseup-editor-field-header{border-bottom:1px solid var(--border-subtle);background:#f3f4f6}.baekji-bokseup-new .baekji-bokseup-header__inner{box-sizing:border-box;width:100%;padding:6px var(--baekji-bokseup-content-padding-x);flex-wrap:wrap;align-items:center;gap:6px 12px;margin:0;display:flex}.baekji-bokseup-new .baekji-bokseup-editor-file-header{box-sizing:border-box;flex:100%;align-items:center;min-width:0;padding:0 0 6px;display:flex;position:relative}.baekji-bokseup-new .baekji-bokseup-editor-file-header:after{content:"";left:calc(var(--baekji-bokseup-content-padding-x) * -1);right:calc(var(--baekji-bokseup-content-padding-x) * -1);background:var(--border-subtle);pointer-events:none;height:1px;position:absolute;bottom:0}.baekji-bokseup-new .baekji-bokseup-header__main{flex:1 1 0;align-items:center;gap:8px 12px;min-width:0;display:flex}.baekji-bokseup-new .baekji-bokseup-header__status{flex:1 1 0;align-items:center;min-width:0;display:none}.baekji-bokseup-new[data-phase=review] .baekji-bokseup-header__status,.baekji-bokseup-new[data-phase=grade] .baekji-bokseup-header__status{display:flex}.baekji-bokseup-new .baekji-bokseup-header__actions{flex-shrink:0;align-items:center;gap:6px;min-height:32px;margin-left:auto;display:flex}.baekji-bokseup-new .baekji-bokseup-header__toolbar{flex-wrap:wrap;flex:1;justify-content:flex-start;align-items:center;gap:1px;min-width:0;min-height:32px;display:none}.baekji-bokseup-new[data-phase=write] .baekji-bokseup-header__toolbar[data-show-phase=write]{display:flex}.baekji-bokseup-new .baekji-bokseup-phase-label{color:var(--text-medium);white-space:nowrap;flex-wrap:nowrap;align-items:center;gap:6px;min-width:0;min-height:32px;font-size:.85rem;font-weight:600;display:flex}.baekji-bokseup-new .baekji-bokseup-header__status>.baekji-bokseup-phase-label[data-show-phase]{display:none}.baekji-bokseup-new[data-phase=review] .baekji-bokseup-header__status>.baekji-bokseup-phase-label[data-show-phase=review],.baekji-bokseup-new[data-phase=grade] .baekji-bokseup-header__status>.baekji-bokseup-phase-label[data-show-phase=grade]{display:flex}.baekji-bokseup-new .baekji-bokseup-timer{font-variant-numeric:tabular-nums;color:var(--accent);letter-spacing:.04em;background:#578e7e14;border-radius:8px;padding:3px 10px;font-family:SF Mono,Fira Code,monospace;font-size:.82rem;font-weight:600}.baekji-bokseup-new .baekji-bokseup-header__actions>[data-show-phase]{display:none}.baekji-bokseup-new[data-phase=write] .baekji-bokseup-header__actions>[data-show-phase=write],.baekji-bokseup-new[data-phase=review] .baekji-bokseup-header__actions>[data-show-phase=review],.baekji-bokseup-new[data-phase=grade] .baekji-bokseup-header__actions>[data-show-phase=grade]{display:inline-flex}.baekji-bokseup-new .baekji-bokseup-title-area{background-image:linear-gradient(var(--border-subtle), var(--border-subtle));background-position:bottom;background-repeat:no-repeat;background-size:100% 1px;border-bottom:none;grid-template-columns:minmax(0,1fr);align-items:stretch;gap:10px;padding:12px 0 14px;display:grid}.baekji-bokseup-new .baekji-bokseup-title-input{box-sizing:border-box;width:100%;min-width:0;color:var(--text-strong);letter-spacing:-.01em;background:0 0;border:none;outline:none;padding:0;font-size:16px;font-weight:700;line-height:1.5}.baekji-bokseup-new .baekji-bokseup-title-input:focus{box-shadow:none;outline:none}.baekji-bokseup-new .baekji-bokseup-title-input::placeholder{color:var(--text-muted);opacity:.7;font-weight:500}@media (width>=48rem){.baekji-bokseup-new .baekji-bokseup-title-area{gap:20px;padding:16px 0 18px}.baekji-bokseup-new .baekji-bokseup-category-bar{gap:20px}.baekji-bokseup-new .baekji-bokseup-title-card{background:#f9fafb;border-radius:16px;gap:10px;padding:12px}.baekji-bokseup-new .baekji-bokseup-title-card__label{color:#333d4b;padding-inline:0;font-size:16px;font-weight:700}.baekji-bokseup-new .baekji-bokseup-title-card__list{flex-flow:column;align-items:flex-start;gap:6px;padding-block:0;padding-inline:0}.baekji-bokseup-new .baekji-bokseup-category-chip{text-align:left;white-space:normal;background:0 0;border:0;border-radius:0;flex-shrink:1;justify-content:flex-start;min-height:30px;padding:4px 0}.baekji-bokseup-new .baekji-bokseup-category-chip:hover{color:#191f28;background:0 0}.baekji-bokseup-new .baekji-bokseup-category-chip.is-active{color:#1b64da;background:0 0;border-color:#0000}.baekji-bokseup-new .baekji-bokseup-title-input{padding-inline:0}}.baekji-bokseup-new .baekji-bokseup-toolbar-btn{min-width:32px;height:32px;color:var(--text-medium);cursor:pointer;background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;padding:0 6px;font-size:.85rem;font-weight:700;transition:background-color .15s,color .15s;display:inline-flex}.baekji-bokseup-new .baekji-bokseup-toolbar-btn:hover{color:var(--text-strong);background:#0000000a}.baekji-bokseup-new .baekji-bokseup-toolbar-btn:active{background:#0000000f}.baekji-bokseup-new .baekji-bokseup-toolbar-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.baekji-bokseup-new .baekji-bokseup-toolbar-btn svg{flex-shrink:0}.baekji-bokseup-new .baekji-bokseup-toolbar-divider{background:var(--border-subtle);flex-shrink:0;width:1px;height:16px;margin:0 4px}.baekji-bokseup-new .baekji-bokseup-toolbar-color-label{cursor:pointer;border-radius:7px;justify-content:center;align-items:center;min-width:32px;height:32px;transition:background-color .15s;display:inline-flex;position:relative}.baekji-bokseup-new .baekji-bokseup-toolbar-color-label:hover{background:#0000000a}.baekji-bokseup-new .baekji-bokseup-toolbar-color-input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.baekji-bokseup-new .baekji-bokseup-toolbar-color-icon{color:red;font-size:.85rem;font-weight:700}.baekji-bokseup-new .baekji-bokseup-toolbar-size-control{background:var(--surface-subtle);border-radius:8px;align-items:center;gap:2px;padding:2px;display:flex}.baekji-bokseup-new .baekji-bokseup-toolbar-size-btn{width:26px;height:26px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:.8rem;font-weight:500;transition:background-color .15s,color .15s;display:flex}.baekji-bokseup-new .baekji-bokseup-toolbar-size-btn:hover{background:var(--surface);color:var(--text-strong);box-shadow:0 1px 2px #0000000f}.baekji-bokseup-new .baekji-bokseup-toolbar-size-display{text-align:center;font-variant-numeric:tabular-nums;min-width:1.5rem;color:var(--text-strong);-webkit-user-select:none;user-select:none;font-size:.75rem;font-weight:700;line-height:26px}.baekji-bokseup-new .baekji-bokseup-editor-area{cursor:text;flex-direction:column;flex:1;min-height:0;padding:0;display:flex}.baekji-bokseup-new [data-editor],.baekji-bokseup-new [data-review-editor]{box-sizing:border-box;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;width:100%;caret-color:var(--accent);min-height:320px;padding:var(--baekji-bokseup-content-padding-y) var(--baekji-bokseup-content-padding-x);color:var(--text-strong);flex:1;font-size:.95rem;line-height:1.85;display:block}.baekji-bokseup-new [data-editor]{background:#f3f4f6}.baekji-bokseup-new [data-editor]:empty:before,.baekji-bokseup-new [data-review-editor]:empty:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none;opacity:.6}.baekji-bokseup-new [data-editor]:focus,.baekji-bokseup-new [data-review-editor]:focus{outline:none}.baekji-bokseup-new .baekji-bokseup-submit{background:var(--accent);color:var(--text-inverse);cursor:pointer;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;padding:5px 14px;font-size:.875rem;font-weight:700;transition:transform .15s,box-shadow .15s,background-color .15s;display:inline-flex;box-shadow:0 1px 3px #578e7e33}.baekji-bokseup-new .baekji-bokseup-submit:hover{background:var(--accent-strong);box-shadow:0 2px 8px #578e7e40}.baekji-bokseup-new .baekji-bokseup-submit:active{transform:scale(.97)}.baekji-bokseup-new .baekji-bokseup-btn--outline{color:var(--accent);border:1px solid var(--accent);box-shadow:none;background:0 0}.baekji-bokseup-new .baekji-bokseup-btn--outline:hover{background:var(--accent);color:var(--text-inverse)}.baekji-bokseup-new .baekji-bokseup-grade-score{padding:var(--baekji-bokseup-content-padding-y) 0 0;justify-content:center;align-items:baseline;gap:4px;display:flex}.baekji-bokseup-new .baekji-bokseup-grade-score__value{color:var(--accent);font-variant-numeric:tabular-nums;font-size:clamp(2.5rem,6vw,3.5rem);font-weight:800;line-height:1}.baekji-bokseup-new .baekji-bokseup-grade-score__unit{color:var(--accent);font-size:1.2rem;font-weight:700}.baekji-bokseup-new .baekji-bokseup-grade-score__label{color:var(--text-muted);margin-left:4px;font-size:.85rem;font-weight:600}.baekji-bokseup-new .baekji-bokseup-grade-diff{gap:var(--baekji-bokseup-shell-gap);padding:var(--baekji-bokseup-shell-gap) 0 var(--baekji-bokseup-content-padding-y);flex-direction:column;display:flex}@media (width>=1024px){.baekji-bokseup-new .baekji-bokseup-grade-diff{flex-direction:row;gap:24px}}.baekji-bokseup-new .baekji-bokseup-grade-diff__panel{flex:1;min-width:0}.baekji-bokseup-new .baekji-bokseup-grade-diff__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-subtle);margin-bottom:8px;padding-bottom:6px;font-size:.75rem;font-weight:700}.baekji-bokseup-new .baekji-bokseup-grade-diff__content{color:var(--text-strong);font-size:.95rem;line-height:1.85}.baekji-bokseup-new .baekji-bokseup-diff--match{color:var(--text-strong)}.baekji-bokseup-new .baekji-bokseup-diff--miss{color:#991b1b;background:#fee2e2;border-radius:2px;padding:0 2px;text-decoration:line-through}.baekji-bokseup-new .baekji-bokseup-diff--wrong{color:#166534;background:#dcfce7;border-radius:2px;padding:0 2px}@media (width<=640px){.baekji-bokseup-new{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;--baekji-bokseup-shell-padding-x:12px;--baekji-bokseup-shell-padding-y:8px;--baekji-bokseup-shell-padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));--baekji-bokseup-shell-gap:12px;--baekji-bokseup-content-padding-x:16px;--baekji-bokseup-content-padding-y:16px;--baekji-bokseup-content-padding-y-tight:12px;--baekji-bokseup-content-gap:8px;min-height:100dvh}.baekji-bokseup-new .baekji-bokseup-header__inner{flex-wrap:wrap;min-height:0}.baekji-bokseup-new .baekji-bokseup-header__main{flex-wrap:wrap;flex:100%;order:2;gap:6px;width:100%}.baekji-bokseup-new .baekji-bokseup-header__status{width:100%}.baekji-bokseup-new .baekji-bokseup-header__actions{flex-wrap:wrap;order:1;justify-content:flex-end;width:100%;margin-left:0}.baekji-bokseup-new .baekji-bokseup-header__toolbar{border-top:1px solid var(--border-subtle);flex-wrap:nowrap;gap:2px;width:100%;min-height:auto;padding:6px 0;overflow-x:auto}.baekji-bokseup-new .baekji-bokseup-header__toolbar::-webkit-scrollbar{display:none}.baekji-bokseup-new .baekji-bokseup-toolbar-btn{min-width:32px;min-height:32px;padding:0 4px;font-size:.8rem}.baekji-bokseup-new .baekji-bokseup-toolbar-color-label{min-width:32px;min-height:32px}.baekji-bokseup-new .baekji-bokseup-toolbar-divider{height:14px;margin:0 2px}.baekji-bokseup-new .baekji-bokseup-highlight-btn{width:22px;height:22px}.baekji-bokseup-new .baekji-bokseup-highlight-group{gap:2px}.baekji-bokseup-new .baekji-bokseup-toolbar-size-control{padding:1px}.baekji-bokseup-new .baekji-bokseup-toolbar-size-btn{width:24px;height:24px}.baekji-bokseup-new .baekji-bokseup-toolbar-size-display{min-width:1.2rem;font-size:.7rem;line-height:24px}.baekji-bokseup-new [data-tooltip]:after{display:none}.baekji-bokseup-new [data-editor],.baekji-bokseup-new [data-review-editor]{min-height:260px;font-size:16px}.baekji-bokseup-new .baekji-bokseup-title-input{font-size:16px}.baekji-bokseup-new .baekji-bokseup-submit{min-height:36px;padding:6px 14px;font-size:.82rem}.baekji-bokseup-new .baekji-bokseup-form{min-height:calc(100dvh - var(--common-header-visible-offset,var(--common-header-offset,52px)) - 24px)}.baekji-bokseup-new .baekji-bokseup-phase-label{white-space:normal;width:100%;font-size:.78rem}.baekji-bokseup-new .baekji-bokseup-grade-diff__content{overflow-wrap:anywhere;word-break:break-word}}
