@font-face{font-family:MaruBuri;src:url(https://hangeul.pstatic.net/hangeul_static/webfont/MaruBuri/MaruBuri-Regular.woff2)format("woff2");font-weight:400;font-display:swap}@font-face{font-family:NanumSquare;src:url(https://hangeul.pstatic.net/hangeul_static/webfont/NanumSquare/NanumSquareR.woff2)format("woff2");font-weight:400;font-display:swap}@font-face{font-family:NanumBarunGothic;src:url(https://hangeul.pstatic.net/hangeul_static/webfont/NanumBarunGothic/NanumBarunGothic.woff2)format("woff2");font-weight:400;font-display:swap}:root{--primary:#1a1a1a;--primary-hover:#000;--bg-color:#f8f7f2;--panel-bg:#fff;--text-main:#1a1a1a;--text-muted:#555;--border-color:#d1d1d1;--grid-border:#444;--grid-guide:#e0e0e0;--cell-size:16mm;--sidebar-width:280px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-color);color:var(--text-main);height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;overflow:hidden}#app{width:100%;height:100%;display:flex}#controls{width:var(--sidebar-width);background:var(--panel-bg);border-right:1px solid var(--border-color);z-index:10;flex-direction:column;flex-shrink:0;gap:16px;padding:20px 16px;display:flex;overflow-y:auto;box-shadow:2px 0 8px #0000000d}#controls h1{color:var(--text-main);letter-spacing:.05em;margin:0;font-family:Noto Serif KR,serif;font-size:1.3rem;font-weight:700}.header-row{justify-content:space-between;align-items:center;display:flex}#lang-select{border:1px solid var(--border-color);background:var(--bg-color);cursor:pointer;border-radius:6px;width:auto;padding:4px;font-size:.85rem}.control-group{flex-direction:column;gap:6px;display:flex}label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;font-weight:600}.label-row{align-items:center;gap:12px;margin-bottom:2px;display:flex}.outline-btn{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:4px 10px;font-size:.725rem;font-weight:500;line-height:1;transition:all .2s}.outline-btn:hover{color:#374151;background:#f9fafb;border-color:#9ca3af}select,input[type=range]{width:100%}select{border:1px solid var(--border-color);background:#fff;border-radius:6px;outline:none;padding:7px 10px;font-size:.9rem;transition:border-color .2s}select:focus{border-color:var(--primary)}input[type=range]{accent-color:var(--primary)}.checkbox-label{cursor:pointer;color:var(--text-main);text-transform:none;letter-spacing:0;align-items:center;gap:8px;font-size:.875rem;font-weight:400;display:flex}.preset-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.preset-btn{border:1px solid var(--border-color);cursor:pointer;color:var(--text-main);background:#fff;border-radius:6px;padding:6px 4px;font-size:.8rem;font-weight:500;transition:all .15s}.preset-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.textarea-wrapper{flex-direction:column;gap:4px;display:flex}#text-input{border:1px solid var(--border-color);resize:vertical;border-radius:6px;outline:none;width:100%;min-height:90px;max-height:200px;padding:8px 10px;font-family:inherit;font-size:1rem;line-height:1.6;transition:border-color .2s}#text-input:focus{border-color:var(--primary)}.font-drop-zone{border:2px dashed var(--border-color);text-align:center;color:var(--text-muted);background:var(--bg-color);cursor:default;border-radius:6px;margin-top:4px;padding:16px 12px;font-size:.8rem;transition:all .2s}.font-drop-zone.drag-over{border-color:var(--primary);background:var(--primary);color:#fff}.char-count-info{color:var(--text-muted);min-height:1em;font-size:.7rem;line-height:1.5}.row-btn-group{gap:12px;display:flex}.row-btn-block{background:var(--bg-color);border-radius:6px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:6px;display:flex}.row-btn-block>span{color:var(--text-muted);text-transform:none;letter-spacing:0;font-size:.75rem;font-weight:500}.btn-pair{align-items:center;gap:6px;display:flex}.btn-pair>span{text-align:center;min-width:20px;font-size:.95rem;font-weight:600}.icon-btn{border:1px solid var(--border-color);cursor:pointer;width:26px;height:26px;color:var(--text-main);background:#fff;border-radius:4px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;transition:all .15s;display:flex}.icon-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.action-group{margin-top:auto}.primary-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:11px;font-size:.95rem;font-weight:600;transition:background .2s;display:flex}.primary-btn:hover{background:var(--primary-hover)}#preview{background-color:var(--bg-color);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.04'/%3E%3C/svg%3E");flex-direction:column;flex:1;align-items:center;gap:32px;padding:32px;display:flex;overflow-y:auto}.paper{background:#fff;flex-shrink:0;box-shadow:0 4px 16px #0000001a}.paper.A4{width:210mm;min-height:297mm;padding:20mm}.paper.B5{width:176mm;min-height:250mm;padding:15mm}.paper.Letter{width:215.9mm;min-height:279.4mm;padding:20mm}.sheet{width:100%;height:100%;position:relative}.grid-container{flex-direction:column;width:fit-content;margin:0 auto;display:flex}.grid-container.vertical{writing-mode:vertical-rl}.grid-container.no-gap{gap:0}.grid-row{flex-direction:row;display:flex}.cell{width:var(--cell-size);height:var(--cell-size);border:1px solid var(--grid-border);font-size:calc(var(--cell-size) * .7);text-align:center;flex-shrink:0;justify-content:center;align-items:center;margin-top:-1px;margin-left:-1px;line-height:1;display:flex;position:relative}.grid-container{padding:1px 0 0 1px}.cell:before{content:"";pointer-events:none;border-top:.5px dashed var(--grid-guide);width:100%;height:0;position:absolute;top:50%;left:0;transform:translateY(-50%)}.cell:after{content:"";pointer-events:none;border-left:.5px dashed var(--grid-guide);width:0;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.cell-text{z-index:1;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.no-guide .cell:before,.no-guide .cell:after{display:none}.solid-row .cell-text{color:#000}.trace-row .cell-text{color:#00000026}.empty-row .cell-text{visibility:hidden}.empty-hint{color:#9ca3af;text-align:center;pointer-events:none;z-index:10;background:#fffc;border-radius:8px;width:80%;padding:20px;font-size:1.1rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@media print{@page{size:auto;margin:0!important}body{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#fff;overflow:visible}#app{width:100%;height:auto;display:block}.no-print{display:none!important}#preview{width:100%;margin:0;padding:0;display:block;overflow:visible}.paper-scaler{width:auto!important;height:auto!important;margin:0!important;padding:0!important;display:block!important;transform:none!important}.paper{box-shadow:none!important;page-break-after:always!important;page-break-inside:avoid!important;margin:0 auto!important;transform:none!important}.paper.A4{width:210mm;min-height:297mm;padding:20mm}.paper.B5{width:176mm;min-height:250mm;padding:15mm}.paper.Letter{width:215.9mm;min-height:279.4mm;padding:20mm}.paper:last-child{page-break-after:auto!important}.grid-container{margin:0 auto}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:440px;padding:24px;animation:.25s ease-out modalIn;box-shadow:0 20px 40px #0003}@keyframes modalIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{color:var(--text-main);font-family:Noto Serif KR,serif;font-size:1.15rem}.close-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:4px;font-size:1.8rem;line-height:1}.close-btn:hover{color:var(--text-main)}@media screen and (width<=768px){body{flex-direction:column;height:auto;overflow:auto}#app{flex-direction:column;height:auto}#controls{border-right:none;border-bottom:1px solid var(--border-color);flex-shrink:0;gap:12px;width:100%;padding:16px;overflow-y:visible;box-shadow:0 2px 8px #0000000d}#controls h1{font-size:1.15rem}#text-input{min-height:70px}#preview{gap:16px;min-height:50vh;padding:16px}.paper{box-shadow:0 2px 8px #00000014}.paper .sheet{overflow:visible}.grid-container{transform-origin:0 0}.action-group{margin-top:0}.modal-content{border-radius:12px;width:95%;padding:20px}.preset-grid{gap:6px}.preset-btn{padding:10px 4px;font-size:.85rem}}
