:root{color-scheme:light;--bg: #edf2f2;--ink: #303030;--green: #2a9320;--green-soft: #94c999;--green-pale: #ddf5dd;--panel: #ffffff;--sidebar: rgba(15, 15, 15, 1);--sidebar-item: rgba(255, 255, 255, .04);--sidebar-text: #f1f1f1;--sidebar-muted: rgba(255, 255, 255, .38);--line: #303030;--sans: Pretendard, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", Arial, sans-serif;--mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace }:root[data-theme=dark]{color-scheme:dark;--bg: #000000;--ink: #cccccc;--green: #3f9f38;--green-soft: #7fb883;--green-pale: #b8d8b8;--panel: #161616;--sidebar: rgba(0, 0, 0, .93);--sidebar-item: rgba(255, 255, 255, .06);--sidebar-text: #cccccc;--sidebar-muted: rgba(204, 204, 204, .48);--line: #cccccc }*{box-sizing:border-box}[hidden]{display:none!important}html,body{margin:0;min-height:100%;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1;word-break:keep-all}body{overflow-x:hidden}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit;color:inherit}button{border:0;background:none;cursor:pointer}ul,ol{list-style:none;margin:0;padding:0}.app-frame{min-height:100vh}.app-sidebar{position:fixed;inset:0 auto 0 0;width:min(374px,calc(100vw - 18px));height:100vh;z-index:20;overflow:visible;pointer-events:none}.sidebar-toggle{position:absolute;top:0;left:0;width:64px;height:64px;z-index:2;border-radius:999px;background:#2a9320ed;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:0;pointer-events:auto;transition:opacity .14s linear,transform .18s ease}.sidebar-toggle:hover,.btn:hover,.select-label:hover,.sidebar-item:hover,.sidebar-login:hover{opacity:.5}.sidebar-toggle span{display:block;width:18px;height:2px;background:#fff}.sidebar-panel{position:relative;z-index:1;width:min(374px,calc(100vw - 18px));height:100vh;padding:20px;border-radius:0 32px 32px 0;background:var(--sidebar);color:var(--sidebar-text);box-shadow:16px 0 48px #0000002e;overflow-y:auto;opacity:0;visibility:hidden;pointer-events:none;transform:translate(-104%);transition:transform .34s cubic-bezier(.2,.75,.2,1),opacity .2s linear,visibility 0s linear .34s;will-change:transform,opacity}[data-sidebar-open=true] .sidebar-panel{opacity:1;visibility:visible;pointer-events:auto;transform:translate(0);transition-delay:0s,0s,0s}[data-sidebar-open=true] .sidebar-toggle{opacity:0;pointer-events:none;transform:scale(.8)}.sidebar-head{display:grid;grid-template-columns:24px 1fr auto;align-items:center;gap:14px;margin-bottom:20px;height:29px}.sidebar-title{justify-self:start;color:var(--sidebar-text);font-size:17px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-title:hover{opacity:.6}.sidebar-head,.sidebar-search,.sidebar-section,.sidebar-footer-nav{opacity:0;transform:translate(-12px);transition:opacity .22s linear,transform .28s cubic-bezier(.2,.75,.2,1)}[data-sidebar-open=true] .sidebar-head,[data-sidebar-open=true] .sidebar-search,[data-sidebar-open=true] .sidebar-section,[data-sidebar-open=true] .sidebar-footer-nav{opacity:1;transform:translate(0)}[data-sidebar-open=true] .sidebar-head{transition-delay:.07s}[data-sidebar-open=true] .sidebar-search{transition-delay:.11s}[data-sidebar-open=true] .sidebar-section[data-sidebar-favorites-section]{transition-delay:.16s}[data-sidebar-open=true] .sidebar-section:not([data-sidebar-favorites-section]){transition-delay:.23s}[data-sidebar-open=true] .sidebar-footer-nav{transition-delay:.3s}.sidebar-close{width:24px;height:24px;position:relative;display:flex;align-items:center;justify-content:center;color:var(--sidebar-text);padding:0}.sidebar-close span{position:absolute;width:18px;height:2px;border-radius:2px;background:currentColor}.sidebar-close span:first-child{transform:rotate(45deg)}.sidebar-close span:last-child{transform:rotate(-45deg)}.sidebar-login{align-self:center;min-width:69px;min-height:28px;padding:7px 15px;border-radius:999px;background:var(--green);color:var(--green-pale);font-size:14px;font-weight:600;text-align:center}.sidebar-search{width:100%;height:44px;border:0;border-radius:999px;background:#ffffff17;color:var(--sidebar-text);padding:0 20px;outline:0}.sidebar-search::placeholder{color:var(--sidebar-muted)}.sidebar-section{margin-top:22px}.sidebar-section h2{margin:0 0 14px 4px;color:var(--sidebar-text);font-size:15px;font-weight:600;opacity:.5}.sidebar-menu{display:grid;overflow:hidden;border-radius:12px;background:#ffffff06}.sidebar-item{position:relative;min-height:48px;display:grid;grid-template-columns:minmax(0,1fr) 24px;align-items:center;gap:10px;padding:0 16px 0 20px;font-size:15px;font-weight:600;transition:opacity .15s linear}.sidebar-item.is-active{padding-left:28px}.sidebar-item.is-active:before{content:"";position:absolute;left:0;top:2px;bottom:2px;width:8px;border-radius:0 8px 8px 0;background:var(--green)}.sidebar-item.is-coming-soon{cursor:not-allowed;opacity:.42}.sidebar-item.is-coming-soon:hover{opacity:.5}.favorite-toggle{width:24px;height:24px;padding:0;color:#ffffff29;font-size:20px;line-height:24px}.favorite-toggle.is-favorite{color:#ffdc2d}.sidebar-empty{padding:15px 20px;color:var(--sidebar-muted);font-size:14px}.sidebar-footer-nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:22px 4px 10px;color:#ffffff9e;font-size:13px;font-weight:600}.sidebar-footer-nav button{padding:0;color:inherit;font-size:inherit;font-weight:inherit}.app-workspace{min-width:0}.app-topbar{min-height:64px;display:flex;align-items:center;padding:0 16px 0 80px;position:relative;z-index:1}.app-help-btn{margin-left:auto;flex:0 0 auto;width:30px;height:30px;border-radius:999px;border:1.5px solid var(--green, #2a9320);background:transparent;color:var(--green, #2a9320);font-size:16px;font-weight:800;line-height:1;cursor:pointer;transition:background .14s,color .14s}.app-help-btn:hover{background:var(--green, #2a9320);color:#fff}.app-topbar h1{margin:0;max-width:calc(100vw - 152px);font-size:20px;font-weight:600;line-height:24px;color:var(--ink);opacity:1;transform:translate(0);transition:color .18s linear,opacity .2s ease,transform .24s ease}[data-sidebar-open=true] .app-topbar h1{color:var(--ink)}.site-main{min-height:100vh;transition:opacity .2s ease,transform .2s ease}.notice{margin:0 24px 12px;padding:12px 16px;border-radius:12px;background:var(--green-pale);color:var(--green);font-weight:600}.notice-error{color:#b00020}.notice p{margin:0}body[data-layout=auth] .app-topbar{display:none}body[data-layout=auth] .site-main{min-height:100vh;padding-top:0}.auth-layout{min-height:100vh;display:grid;place-items:center;padding:64px 20px}.auth-sheet{width:min(400px,calc(100vw - 40px));min-height:415px;display:grid;align-content:start;gap:14px;padding:28px 32px 32px;border-radius:30px;background:var(--panel);color:#000}:root[data-theme=dark] .auth-sheet{color:var(--ink)}.auth-sheet-compact{min-height:300px}.auth-sheet-tall{min-height:500px}.auth-note{margin:0;font-size:14px;font-weight:500;line-height:1.5;color:#30303099}.auth-note strong{color:var(--green);font-weight:700}.auth-sheet label{display:grid;gap:6px;font-size:15px;font-weight:600}.auth-sheet input:not([type=checkbox]){width:100%;height:40px;padding:0 12px;border:2px solid var(--bg);border-radius:6px;background:var(--panel);color:inherit;outline:none}.auth-check{grid-template-columns:18px auto;align-items:center;justify-content:start;gap:7px!important;margin-top:2px;font-size:14px!important;font-weight:500!important}.auth-check input{width:18px;height:18px;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid #389a2f;border-radius:4px;background:transparent}.auth-check input:checked{background:#389a2f;box-shadow:inset 0 0 0 3px var(--panel)}.global-toast-stack{position:fixed;z-index:1200;left:50%;bottom:24px;display:grid;gap:8px;justify-items:center;pointer-events:none;transform:translate(-50%)}.global-toast{max-width:min(420px,calc(100vw - 40px));padding:10px 16px;border:1px solid rgba(221,245,221,.22);border-radius:999px;background:#2a9320f0;color:var(--green-pale);box-shadow:0 14px 30px #00000029;font-size:14px;font-weight:700;line-height:1.25;opacity:0;transform:translateY(8px);transition:opacity .18s ease,transform .18s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.global-toast.is-visible{opacity:1;transform:translateY(0)}:root[data-theme=dark] .global-toast{border-color:#00000029;background:#9fd4a3f0;color:#000}.auth-primary,.auth-secondary{min-height:44px;display:flex;align-items:center;justify-content:flex-start;padding:13px 19px;border-radius:6px;font-size:15px;font-weight:600}.auth-primary{margin-top:12px;background:#389a2f;color:var(--bg)}.auth-secondary{background:var(--bg);color:#389a2f}.tool-shell{width:100%}body:not([data-page-ready=true]) .tool-body>section{opacity:0;transform:translateY(10px)}body:not([data-page-ready=true]) .app-topbar h1{opacity:0}body[data-page-ready=true] .app-topbar h1{opacity:1}body[data-page-ready=true] .tool-body>section{animation:toolSectionIn .34s cubic-bezier(.2,.75,.2,1) both}body[data-page-ready=true] .tool-body>section:nth-child(2){animation-delay:.07s}body[data-page-ready=true] .tool-body>section:nth-child(3){animation-delay:.14s}body[data-page-leaving=true] .site-main{opacity:0;transform:translateY(4px)}body[data-page-leaving=true] .app-topbar h1{opacity:0}@keyframes toolSectionIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tool-header{display:none}.tool-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.tool-body,.hantool-container{display:flex;align-items:flex-start}.tool-panel{border:0}.tool-body>.tool-panel:not(.hantool-left):not(.hantool-right){padding:36px 32px 32px}.tool-body>.tool-panel:not(.hantool-left):not(.hantool-right):first-child{width:42%;border-radius:20px;background:var(--panel)}.tool-body>.tool-panel:not(.hantool-left):not(.hantool-right):not(:first-child){width:58%;min-height:372px;border-radius:20px;background:var(--green);color:var(--green-pale)}.hantool-left{width:60%;padding:36px 32px 32px;border-radius:20px;background:var(--panel)}.tool-filter-panel{position:sticky;top:0;max-height:100vh}.hantool-right{width:40%;padding:36px;border-radius:20px;background:var(--green)}.hantool-left h2,.hantool-right h2,.tool-panel h2{margin:0 0 16px;font-size:20px;font-weight:600}.hantool-left h2,.tool-body>.tool-panel:not(.hantool-left):not(.hantool-right):first-child h2{color:var(--green)}.hantool-right h2,.tool-body>.tool-panel:not(.hantool-left):not(.hantool-right):not(:first-child) h2{color:var(--green-pale)}textarea{width:100%;height:150px;padding:16px;border:2px solid var(--line);border-radius:8px;resize:none;background:var(--panel);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5;outline:none}.custom-source{display:block;margin-top:32px}.custom-source[hidden]{display:none}.custom-source textarea{border-color:var(--green);background:var(--bg)}.inline-controls{display:flex;align-items:flex-start;flex-wrap:wrap;gap:9px 8px;margin-top:16px}.inline-controls label{color:var(--green);font-weight:600}.tool-panel select{min-height:44px;padding:9px 36px 9px 14px;border:2px solid var(--green);border-radius:999px;background:transparent;color:var(--green);font-weight:600}.tool-panel button:not([class]){display:inline-flex;justify-content:center;align-items:center;min-height:44px;padding:11px 13px;border:2px solid var(--green);border-radius:999px;background:var(--green);color:var(--green-pale);font-weight:600;line-height:1}.hantool-option{display:flex;align-items:center;flex-wrap:wrap;gap:9px 8px;margin-top:60px}.hantool-option .custom-select,.hantool-option .seed-field,.hantool-option .btn{flex:0 0 auto}.btn{opacity:1;transition:opacity linear .15s;-webkit-user-select:none;user-select:none}.btn-r{display:inline-flex;justify-content:center;align-items:center;padding:11px 13px;border:2px solid;border-radius:999px;font-size:16px;font-weight:600;line-height:1}.btn-mw{min-width:96px}.btn-green-light{color:var(--green);background-color:var(--green-pale);border-color:var(--green-pale)}.btn-green{color:var(--ink);background-color:var(--green-soft);border-color:var(--green-soft)}.btn-green-vivid{color:var(--green-pale);background-color:var(--green);border-color:var(--green)}.btn-line-green,.btn-line-green-vivid{color:var(--green);background:none;border-color:var(--green)}.btn-green-ghost{color:var(--green);background:#2a932014;border-color:#2a932052}.custom-select{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.custom-select[data-opened=true]{z-index:1100}.select-label{display:inline-flex;align-items:center;justify-content:space-between;gap:16px;min-height:44px;padding:9px 14px 9px 20px;border:2px solid var(--green);border-radius:999px;background:transparent;color:var(--green);font-size:16px;line-height:1.25;font-weight:600;transition:opacity linear .1s}.select-label:after{content:"";width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid currentColor}.select-dropdown{position:absolute;z-index:1100;left:0;top:calc(100% + 6px);min-width:100%;max-width:calc(100vw - 48px);display:none;flex-direction:column;padding:8px 0;border-radius:16px;background-color:var(--panel);color:var(--ink);font-weight:600;box-shadow:0 14px 30px #0000001f;border:1px solid rgba(10,10,10,.12)}[data-opened=true]>.select-dropdown{display:flex}[data-placement=top]>.select-dropdown{top:auto;bottom:calc(100% + 6px)}.select-dropdown li{padding:9px 20px;line-height:1.25;white-space:nowrap;transition:opacity linear .1s}.select-dropdown li:hover{opacity:.4}.find-jaso-selector>div{margin-bottom:36px}.hangul-picker{display:grid;gap:8px}.hangul-chip-row{display:flex;align-items:center;align-content:center;gap:6px 6px;flex-wrap:wrap}.hangul-chip{display:inline-flex;justify-content:center;align-items:center;padding:6px 7px;border:2px solid var(--green-soft);border-radius:8px;background:transparent;color:var(--green-soft);font-size:17px;font-weight:600;line-height:1;transition:opacity linear .15s}.hangul-chip:hover{opacity:.5}.hangul-chip-group{min-width:auto;border-color:var(--green);color:var(--green)}.hangul-chip[aria-pressed=true]{background:var(--green);border-color:var(--green);color:var(--green-pale)}.hangul-chip-kbd{border-style:dashed;border-color:var(--green-soft);background:var(--green-pale);color:var(--green-soft);font-size:17px;font-weight:600}.hangul-chip-kbd[aria-pressed=true]{border-style:solid;background:var(--green-soft);border-color:var(--green);color:#fff}.hantool-result{margin:0}.hantool-result-display{display:block;min-height:120px;margin:0 0 8px;color:var(--green-pale);white-space:pre-wrap;word-break:break-all;font-size:22px;font-weight:400;line-height:1.4;transition:opacity .15s linear;font-family:var(--sans)}.hantool-result-display:hover{opacity:.7}.hantool-result-display::selection,.hantool-result-display *::selection{background-color:var(--ink)}.hantool-result-count{margin:0;color:var(--green-soft);font-size:15px;font-weight:600}.feature-test .hantool-left{width:58%}.feature-test .hantool-right{width:42%}.feature-test-controls{display:grid;align-content:start;gap:0;padding:0;background:transparent}.feature-control-section{display:grid;gap:18px;padding:24px 26px;border-bottom-width:0;background:var(--panel);border-radius:20px;margin-top:28px}.feature-control-section:first-child{margin-top:0}.feature-control-section:last-of-type{border-bottom-width:1px;border-radius:20px}.feature-control-section h2{color:var(--green);font-size:19px;line-height:1.2;margin-bottom:2px}.feature-file-drop{padding:16px;border:1px dashed rgba(42,147,32,.36);border-radius:10px;background:#2a93200f;color:var(--ink);font-weight:600}.feature-file-drop input{max-width:100%}.feature-file-drop small{color:#3030308a;font-size:14px;font-weight:600}.feature-file-drop.is-dragging{border-color:var(--green);background:var(--green-pale)}.feature-control-grid,.feature-css-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.feature-control-grid label,.feature-control-grid .feature-field,.feature-css-grid label,.feature-control-section>label{display:grid;gap:8px;color:#303030b8;font-size:14px;font-weight:600}.feature-control-grid input,.feature-control-section input{min-height:40px;padding:8px 12px;border:1px solid rgba(10,10,10,.2);border-radius:8px;background:var(--panel);color:var(--ink);outline:0;font-size:14px;font-weight:600}.feature-test .feature-select{display:block;color:var(--ink)}.feature-test .feature-select .select-label{width:100%;min-height:40px;padding:8px 12px;border:1px solid rgba(10,10,10,.2);border-radius:8px;background:var(--panel);color:var(--ink);font-size:14px;font-weight:600}.feature-test .feature-select .select-label:after{border-left-width:5px;border-right-width:5px;border-top-width:6px}.feature-test .feature-select .select-dropdown{border:1px solid rgba(10,10,10,.12);border-radius:10px;background:var(--panel);color:var(--ink);font-size:14px;font-weight:650}.feature-test .feature-select .select-dropdown li{padding:8px 12px}.feature-test textarea{min-height:136px;border-width:1px;border-color:#0a0a0a33;border-radius:8px;color:var(--ink);font-size:14px}.feature-css-grid textarea{height:168px;min-height:168px;border-color:#0a0a0a33;background:var(--panel);font-family:var(--mono);font-size:13px;line-height:1.45}.feature-css-grid button{grid-column:1 / -1;justify-self:start}.feature-list{display:grid;gap:16px;max-height:330px;overflow:auto;padding:12px;border:1px solid rgba(10,10,10,.14);border-radius:10px;background:#2a932009}.feature-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(60px,1fr));gap:5px}.feature-group h3{grid-column:1 / -1;margin:0 0 1px;color:var(--green);font-size:12px;font-weight:900}.feature-item{position:relative;min-height:27px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:5px;padding:5px 8px;border:1px solid rgba(42,147,32,.24);border-radius:8px;color:#303030c2;background:var(--panel);font-size:12px;font-weight:600;line-height:1}.feature-item input[type=checkbox]{position:absolute;inline-size:1px;block-size:1px;opacity:0}.feature-item:has(input[type=checkbox]:checked){border-color:var(--green);background:var(--green);color:var(--green-pale)}.feature-item input[type=number]{width:40px;min-height:22px;padding:2px 5px;border:1px solid rgba(10,10,10,.18);border-radius:6px;background:var(--panel);color:var(--ink);font-size:12px}:root[data-theme=dark] .feature-control-section{border-color:#cccccc2e}:root[data-theme=dark] .feature-file-drop{border-color:#3f9f3870;background:#3f9f381f;color:var(--ink)}:root[data-theme=dark] .feature-file-drop small,:root[data-theme=dark] .feature-control-grid label,:root[data-theme=dark] .feature-control-grid .feature-field,:root[data-theme=dark] .feature-css-grid label,:root[data-theme=dark] .feature-control-section>label{color:#ccccccb8}:root[data-theme=dark] .feature-control-grid input,:root[data-theme=dark] .feature-control-section input,:root[data-theme=dark] .feature-test textarea,:root[data-theme=dark] .feature-test .feature-select .select-label,:root[data-theme=dark] .feature-test .feature-select .select-dropdown,:root[data-theme=dark] .feature-item input[type=number]{border-color:#cccccc3d}:root[data-theme=dark] .feature-list{border-color:#cccccc2e;background:#3f9f3814}:root[data-theme=dark] .feature-item{border-color:#3f9f3857;color:#ccccccc7;background:var(--panel)}:root[data-theme=dark] .feature-item:has(input[type=checkbox]:checked){color:#000;background:var(--green-soft)}.list-compare-tool .hantool-left,.list-compare-tool .hantool-right{width:50%}.list-compare-controls,.list-compare-results{display:grid;align-content:start;gap:0;padding:0;background:transparent}.list-compare-section label,.list-compare-section .feature-field{display:grid;gap:8px;color:#303030b8;font-size:14px;font-weight:600}.list-compare-section textarea,.list-result-section textarea{min-height:146px;border:1px solid rgba(10,10,10,.2);border-radius:8px;background:var(--panel);color:var(--ink);font-family:var(--mono);font-size:13px;line-height:1.45}.list-compare-section small{color:#3030308a;font-size:13px;font-weight:700}.list-compare-section [data-universe-field][hidden]{display:none}.list-compare-settings-grid{grid-template-columns:1fr;gap:12px}.list-compare-field-title{color:var(--green)}.list-compare-section .list-compare-check{min-height:24px;display:inline-grid;grid-template-columns:18px auto;align-items:center;justify-content:start;gap:7px;padding:0;color:#303030b8;font-size:14px;font-weight:500}.list-compare-check input{width:18px;height:18px;min-height:0;padding:0;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid #389a2f;border-radius:4px;background:transparent}.list-compare-check input:checked{background:#389a2f;box-shadow:inset 0 0 0 3px var(--panel)}.list-result-section{display:grid;gap:12px;padding:22px 24px;border-radius:20px;background:var(--green);color:var(--green-pale)}.list-result-section+.list-result-section{margin-top:28px}.list-result-section[hidden]{display:none}.list-result-head{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:8px}.list-result-head h2{display:flex;align-items:center;min-height:23px;margin:0;color:currentColor;font-size:19px;line-height:1}.list-result-head span{display:inline-flex;align-items:center;min-height:23px;color:var(--green-soft);font-size:13px;font-weight:700;line-height:1}.list-result-head .btn{padding:8px 12px;border-width:0;font-size:14px}.list-result-section textarea{min-height:132px;border-color:#ddf5dd47;background:#ddf5dd1f;color:var(--green-pale);resize:vertical}.list-result-section textarea::selection{background:var(--green-pale);color:var(--green)}:root[data-theme=dark] .list-compare-section label,:root[data-theme=dark] .list-compare-section .feature-field,:root[data-theme=dark] .list-compare-section .list-compare-check{color:#ccccccb8}:root[data-theme=dark] .list-compare-section textarea,:root[data-theme=dark] .list-result-section textarea{border-color:#cccccc3d}:root[data-theme=dark] .list-compare-section small{color:#cccccc8f}:root[data-theme=dark] .list-result-section{color:#000;background:var(--green-soft)}:root[data-theme=dark] .list-result-head span{color:#0000008f}:root[data-theme=dark] .list-result-section textarea{background:#0000001a;color:#000}.site-main:has(.font-viewer-tool){min-height:auto;overflow:hidden}.font-viewer-tool{position:relative;display:flex;width:100%;height:calc(100vh - 64px);overflow:hidden}.font-viewer-board{position:relative;flex:1 1 auto;min-width:0;overflow:hidden;background:var(--panel);touch-action:none;outline:none;cursor:grab}.font-viewer-board:active{cursor:grabbing}.font-viewer-board.is-editing{cursor:text}.font-viewer-board.is-editing.is-space{cursor:grab}.font-viewer-board.is-editing.is-space:active{cursor:grabbing}.font-viewer-board.is-dragging:after{content:"";position:absolute;inset:14px;z-index:2;border:2px dashed var(--green);border-radius:18px;background:#2a93200f;pointer-events:none}.font-viewer-canvas,.font-viewer-overlay{position:absolute;inset:0;display:block;width:100%;height:100%}.font-viewer-overlay{pointer-events:none;z-index:2}.fv-hidden-input{position:absolute;top:0;left:0;z-index:3;width:2px;height:18px;margin:0;padding:0;border:0;outline:0;background:transparent;color:transparent;caret-color:transparent;white-space:pre;overflow:hidden;resize:none;opacity:0;pointer-events:none;font:16px/1 var(--mono)}.font-viewer-hint{position:absolute;left:50%;bottom:16px;z-index:4;transform:translate(-50%);padding:6px 14px;border-radius:999px;background:#0a0a0a8c;color:#fff;font-size:12px;font-weight:650;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .25s ease}.font-viewer-board:hover .font-viewer-hint,.font-viewer-board:focus-within .font-viewer-hint{opacity:1}.font-viewer-empty{position:absolute;inset:0;z-index:1;display:grid;align-content:center;justify-items:center;gap:8px;text-align:center;pointer-events:none;padding:24px}.font-viewer-empty strong{font-size:20px;font-weight:700;color:var(--ink);line-height:1.4}.font-viewer-empty span{font-size:14px;font-weight:650;color:#30303080}:root[data-theme=dark] .font-viewer-empty span{color:#cccccc80}.fv-rail{flex:0 0 300px;width:300px;height:100%;overflow-y:auto;overscroll-behavior:contain;background:var(--panel);border-left:1px solid rgba(10,10,10,.1);scrollbar-width:thin;color:var(--ink)}:root[data-theme=dark] .fv-rail{border-left-color:#cccccc29}.fv-section{border-bottom:1px solid rgba(10,10,10,.08)}:root[data-theme=dark] .fv-section{border-bottom-color:#cccccc1f}.fv-section-head{display:flex;align-items:center;justify-content:space-between;height:40px;padding:0 14px;color:var(--green);font-size:13px;font-weight:700;list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none}.fv-section-head::-webkit-details-marker{display:none}.fv-chevron{width:8px;height:8px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:rotate(45deg);transition:transform .15s ease;opacity:.7}.fv-section:not([open]) .fv-chevron{transform:rotate(-45deg)}.fv-section-body{display:grid;gap:12px;padding:12px 14px 16px}.fv-field{display:grid;gap:6px;color:#3030309e;font-size:12px;font-weight:700}:root[data-theme=dark] .fv-field{color:#ccc9}.fv-field small{font-weight:600;opacity:.75}.fv-field-inline{grid-template-columns:1fr auto;align-items:center}.fv-field-row{gap:8px}.fv-range{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px}.fv-range output{color:var(--green);font-size:12px;font-weight:700;white-space:nowrap}.fv-rail textarea,.fv-rail input[type=number]{width:100%;border:1px solid rgba(10,10,10,.18);border-radius:8px;background:var(--panel);color:var(--ink);font:inherit;font-size:13px;font-weight:650;outline:0}.fv-rail textarea{padding:9px 10px;line-height:1.5;resize:vertical;min-height:64px}.fv-rail input[type=number]{height:32px;padding:2px 10px;text-align:left}.fv-field-inline input[type=number]{width:92px}.fv-rail input:focus,.fv-rail textarea:focus{border-color:var(--green)}:root[data-theme=dark] .fv-rail textarea,:root[data-theme=dark] .fv-rail input[type=number]{border-color:#ccc3;background:#000}.fv-rail input[type=range]{width:100%;accent-color:var(--green)}.fv-check{display:grid;grid-template-columns:18px 1fr;gap:9px;align-items:center;color:#303030c7;font-size:13px;font-weight:700;cursor:pointer}:root[data-theme=dark] .fv-check{color:#ccccccc7}.fv-check input{width:18px;height:18px;min-height:0;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--green);border-radius:4px;background:transparent;cursor:pointer}.fv-check input:checked{background:var(--green);box-shadow:inset 0 0 0 3px var(--panel)}.fv-rail .font-compare-select .select-label{width:100%;min-height:36px;padding:7px 12px;border:1px solid rgba(10,10,10,.18);border-radius:8px;background:var(--panel);color:var(--green);font-size:13px;font-weight:700}.fv-rail .font-compare-select .select-dropdown{z-index:20;border-radius:10px;font-size:13px;font-weight:700}:root[data-theme=dark] .fv-rail .font-compare-select .select-label{border-color:#ccc3;background:#000}.fv-upload{position:relative;display:inline-flex;width:100%;min-height:40px;overflow:hidden;cursor:pointer}.fv-upload input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.fv-note{margin:0;color:#30303080;font-size:12px;font-weight:600;line-height:1.45}:root[data-theme=dark] .fv-note{color:#cccccc80}.fv-feature-list{display:grid;gap:14px}.fv-feature-group{display:flex;flex-wrap:wrap;gap:6px 14px}.fv-feature-group-head{width:100%;color:var(--green);font-size:12px;font-weight:800;letter-spacing:.02em}.fv-feature{font-family:var(--mono);font-size:13px}.fv-feature.is-locked{opacity:.55;cursor:not-allowed}.fv-files{display:grid;gap:8px}.fv-files-empty{display:grid;min-height:56px;place-items:center;border-radius:10px;background:#0a0a0a0a;color:#30303080;font-size:13px;font-weight:700}:root[data-theme=dark] .fv-files-empty{background:#ffffff0d;color:#cccccc80}.fv-font{display:grid;gap:14px;padding:12px 14px 18px;border-radius:12px;background:#2a93200d}.fv-font-top{display:grid;grid-template-columns:12px 1fr;align-items:center;gap:11px}.font-file-color{display:inline-block;width:12px;height:28px;flex:0 0 auto;border-radius:999px;background:var(--font-color, var(--green));box-shadow:0 0 0 2px #fff9}.fv-font-name{min-width:0}.fv-font-name strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13.5px;font-weight:700;line-height:1.25}.fv-font-name small{color:#30303080;font-size:11.5px;font-weight:650}:root[data-theme=dark] .fv-font-name small{color:#cccccc80}.fv-font-actions{display:flex;gap:8px}.fv-font-actions .btn{flex:1;min-height:32px;padding:7px 8px;border-width:1.5px;font-size:12px}.fv-adjust{border-top:1px solid var(--green-pale);padding-top:14px}.fv-adjust>summary{display:flex;align-items:center;gap:10px;list-style:none;color:var(--green);font-size:12px;font-weight:700;cursor:pointer;padding-left:3px}.fv-adjust>summary::-webkit-details-marker{display:none}.fv-adjust>summary:before{content:"";width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(-45deg);transition:transform .15s ease;opacity:.8}.fv-adjust[open]>summary:before{transform:rotate(45deg) translate(-2px,-2px)}.fv-adjust-body{display:grid;gap:6px;margin-top:20px}.fv-adjust-row{display:grid;grid-template-columns:1fr 78px;align-items:center;gap:8px;color:#30303099;font-size:12px;font-weight:700}:root[data-theme=dark] .fv-adjust-row{color:#ccc9}.fv-adjust-row input[type=number]{height:27px}.fv-adjust .fv-check{font-size:12px;font-weight:700}.fv-anchor-wrap{display:grid;gap:8px;padding:10px;border:1px solid rgba(42,147,32,.2);border-radius:10px;background:#2a93200a}.fv-anchor-wrap[hidden]{display:none}.fv-anchor-label{color:#3030309e;font-size:12px;font-weight:700}:root[data-theme=dark] .fv-anchor-label{color:#cccccc9e}.fv-anchor{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;width:96px}.fv-anchor button{position:relative;aspect-ratio:1;border:1px solid rgba(42,147,32,.3);border-radius:5px;background:var(--panel);cursor:pointer;padding:0}.fv-anchor button:after{content:"";position:absolute;inset:50%;width:4px;height:4px;margin:-2px 0 0 -2px;border-radius:999px;background:#2a932073}.fv-anchor button[aria-pressed=true]{background:var(--green);border-color:var(--green)}.fv-anchor button[aria-pressed=true]:after{background:#fff}:root[data-theme=dark] .fv-anchor button{background:#000}.fv-print{grid-auto-flow:row}.fv-print .btn{width:100%;min-height:40px}.feature-actions{display:flex;flex-wrap:wrap;gap:8px}.feature-test-preview-panel{position:sticky;top:65px;min-height:360px;max-height:calc(100vh - 104px);overflow:auto}.feature-preview-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.feature-support{color:var(--green-soft);font-family:var(--mono);font-size:12px;line-height:1.35}.feature-preview-wrapper{width:100%;min-height:240px;max-height:420px;overflow:auto}.feature-preview-box{min-height:180px;max-height:320px;overflow:auto;color:var(--green);white-space:pre-wrap;overflow-wrap:anywhere;font-size:28px;line-height:1.45;outline:0}.feature-effective{display:grid;gap:8px;margin:18px 0 0;color:var(--green-pale);line-height:1.4}.feature-effective code{display:block;max-height:96px;overflow:auto;padding:8px 10px;border-radius:10px;background:#ddf5dd26;font-family:var(--mono);font-size:12px;white-space:pre-wrap}.feature-ua{margin-top:18px;color:var(--green-pale);font-size:13px;line-height:1.45}.feature-ua summary{cursor:pointer;font-weight:600}.feature-ua pre{max-height:150px;overflow:auto;margin:10px 0 0;font-family:var(--mono);font-size:11px;white-space:pre-wrap}.unicode-range-tool .hantool-left{width:64%}.unicode-range-tool .hantool-right{width:36%}.unicode-range-left{display:grid;gap:18px}.unicode-range-options{display:grid;gap:10px;justify-items:start}.unicode-source-select .select-label{min-height:44px;border-radius:999px;border-width:2px;border-color:var(--green);color:var(--green);font-weight:600}.unicode-source-select .select-dropdown{border-radius:20px}.unicode-range-help{margin:0;color:#303030a3;font-size:14px;font-weight:650;line-height:1.45}.unicode-range-tool textarea{min-height:320px}.unicode-range-count{margin:0;color:var(--green);font-size:15px;font-weight:600}.unicode-result-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.unicode-result-head h2{margin-bottom:0}.unicode-range-output{min-height:260px;max-height:calc(100vh - 230px);overflow:auto;font-family:var(--mono);font-size:14px;line-height:1.45;word-break:normal}:root[data-theme=dark] .unicode-range-help{color:#ccccccad}.hangul-shape-tool .shape-input-panel{width:34%;display:grid;align-content:start;gap:28px;padding:0;background:transparent}.shape-control-section{display:grid;gap:18px;padding:24px 26px;border-radius:20px;background:var(--panel)}.hangul-shape-tool .shape-result-panel{width:66%;background:var(--panel);border:2px solid var(--green);color:var(--ink)}.hangul-shape-tool .shape-result-panel h2{color:var(--green)}.shape-result-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.shape-result-head h2{margin:0}.shape-result-tools{display:flex;align-items:center;gap:8px}.shape-result-tools[hidden]{display:none}.shape-actions{display:flex;flex-wrap:wrap;gap:8px}.shape-count{margin:0;color:var(--green);font-size:15px;font-weight:600}.shape-edit-section[hidden]{display:none}.shape-edit-section h2{margin-bottom:0;color:var(--green);font-size:18px}.shape-edit-section label{display:grid;gap:8px;color:#303030b8;font-size:14px;font-weight:600}.shape-edit-section textarea{min-height:76px;height:76px;border-width:1px;border-color:#0a0a0a33;font-size:14px}.shape-result{display:grid;gap:28px}.shape-empty{margin:0;color:#30303094;font-size:18px;font-weight:700;line-height:1.45}.shape-result-section{display:grid;gap:10px}.shape-result-section h3{margin:0;color:var(--green);font-size:17px;font-weight:900}.shape-table-scroll{overflow:auto;border:1px solid rgba(42,147,32,.32);border-radius:4px;background:var(--panel)}.shape-matrix-table{width:100%;border-collapse:collapse;font-size:13px;line-height:1.25}.shape-matrix-table th,.shape-matrix-table td{border:1px solid rgba(42,147,32,.18);padding:3px;vertical-align:top;text-align:left}.shape-matrix-table th{position:sticky;top:0;z-index:1;background:#2a932014;color:var(--green);font-weight:900;white-space:nowrap;text-align:left}.shape-matrix-table td.is-empty{background:#2a932006}.shape-group-head{text-align:center!important}.shape-row-group{background:#2a93200f!important}.shape-matrix-char{display:inline-flex;align-items:center;justify-content:center;margin:1px;padding:0;border-radius:5px;color:var(--ink);font-size:14px;line-height:1}.shape-matrix-char:hover{background:#2a932014}.shape-matrix-char.is-selected{color:#b00020;background:#b0002014;opacity:.45}.shape-matrix-char.is-pending-add{color:var(--green);background:#2a93201a;font-weight:600}:root[data-theme=dark] .hangul-shape-tool .shape-result-panel,:root[data-theme=dark] .shape-table-scroll{background:var(--panel)}:root[data-theme=dark] .shape-edit-section label,:root[data-theme=dark] .shape-empty{color:#ccccccb3}.seed-field{display:inline-flex;align-items:center;gap:4px;color:var(--green);font-size:13px;font-weight:600}.seed-field input{width:116px;height:44px;padding:0 13px;border:2px solid var(--green);border-radius:999px;background:transparent;color:var(--green);outline:0;font-weight:600}.page-head,.form-sheet,.table-sheet,.admin-grid a,.tool-row,table,th,td,input,select{border-color:#0a0a0a29}.page-head,.form-sheet,.table-sheet{margin:24px;padding:24px;border-radius:20px;background:var(--panel)}.page-head h1,.form-sheet h1{margin:0 0 10px;font-size:28px}.tool-section,.admin-grid,.table-sheet,.form-sheet{margin:24px}.tool-grid{display:grid;gap:8px}.tool-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center;padding:14px 0;border-bottom:1px solid rgba(10,10,10,.12)}.tool-row em{font-style:normal;color:var(--green);font-weight:600}.tool-row.is-coming-soon{cursor:not-allowed;opacity:.42}.tool-row.is-coming-soon:hover{opacity:.52}.tool-row.is-coming-soon em{color:#3030307a}:root[data-theme=dark] .tool-row.is-coming-soon em{color:#cccccc7a}.form-sheet label,.control-grid label,.stack label{display:grid;gap:6px}.form-sheet input,.form-sheet button,.table-sheet input,.table-sheet select,.admin-inline button,.admin-inline select{min-height:40px;padding:8px 12px;border:1px solid rgba(10,10,10,.2);border-radius:8px;background:var(--panel)}.profile-sheet{margin:0;padding:36px}.profile-sheet h1{margin:0 0 32px}.profile-sheet button.btn{min-height:44px;padding:11px 26px;border:2px solid var(--green);border-radius:999px;background:var(--green);color:var(--green-pale)}.profile-prefs{display:grid;gap:14px;margin:0 0 24px}.profile-prefs-title{margin:0;font-size:15px;font-weight:700}.profile-sheet .pref-check{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;cursor:pointer}.profile-sheet .pref-check input{appearance:none;-webkit-appearance:none;width:20px;height:20px;min-height:0;margin:0;padding:0;border:2px solid var(--green);border-radius:6px;background:var(--panel);cursor:pointer;position:relative;flex:0 0 auto}.profile-sheet .pref-check input:checked{background:var(--green)}.profile-sheet .pref-check input:checked:after{content:"";position:absolute;left:5px;top:1px;width:4px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.admin-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.admin-grid a{padding:18px;border-radius:16px;background:var(--panel)}.table-sheet{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:8px;border:1px solid rgba(10,10,10,.16);text-align:left}.output-box{min-height:132px;margin:8px 0 0;white-space:pre-wrap;word-break:break-all;font-family:var(--sans);font-size:16px;line-height:1.5}.selectable{-webkit-user-select:text!important;user-select:text!important}@media(max-width:768px){.app-topbar{padding-left:80px}.hantool-container,.tool-body{flex-direction:column}.hantool-left,.hantool-right,.tool-body>.tool-panel:not(.hantool-left):not(.hantool-right){width:100%;min-height:auto;padding:30px 26px}.tool-filter-panel{position:static;max-height:none;overflow:visible}.hantool-option{margin-top:42px}.feature-test .hantool-left,.feature-test .hantool-right{width:100%}.feature-test-preview-panel{position:static;max-height:none;overflow:visible}.feature-test-controls{padding:0}.feature-control-grid,.feature-css-grid{grid-template-columns:1fr}.feature-group{grid-template-columns:repeat(auto-fit,minmax(78px,1fr))}.feature-list{max-height:300px}.feature-preview-wrapper,.feature-preview-box{max-height:none}.unicode-range-tool .hantool-left,.unicode-range-tool .hantool-right,.list-compare-tool .hantool-left,.list-compare-tool .hantool-right{width:100%}.list-compare-controls,.list-compare-results{padding:0}.list-result-head{grid-template-columns:minmax(0,1fr) auto}.list-result-head .btn{grid-column:1 / -1;justify-self:start}.hangul-shape-tool .shape-input-panel,.hangul-shape-tool .shape-result-panel{width:100%}.hangul-shape-tool .shape-input-panel{padding:0;background:transparent}.unicode-range-tool textarea{min-height:240px}.admin-grid,.tool-row{grid-template-columns:1fr}}body[data-layout=home] .app-topbar{display:none}.home{background:var(--bg)}.home-hero{position:relative;width:100vw;height:100vh;height:100dvh;background:#0b0b0b;overflow:hidden;touch-action:pan-y;user-select:none}.home-hero-canvas{position:absolute;inset:0;display:block;width:100%;height:100%}.home-hero-recall{position:absolute;right:18px;bottom:18px;z-index:2}.home-recall-btn{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;border:0;border-radius:8px;background:#fffc;color:#303030;cursor:pointer;transition:background .15s ease}.home-recall-btn:hover{background:#fff}.home-toys{position:absolute;right:0;bottom:38px;width:236px;padding:6px;background:#fff;border-radius:14px;box-shadow:0 12px 32px #00000047}.home-toy{display:flex;flex-direction:column;gap:2px;width:100%;padding:10px 12px;text-align:left;border:0;border-radius:10px;background:transparent;cursor:pointer}.home-toy:hover{background:var(--green-pale)}.home-toy strong{font-size:14px;font-weight:700;color:var(--ink)}.home-toy small{font-size:12px;color:#30303099}.home-tools{background:var(--bg)}.home-grid{--tile: 320px;max-width:calc(var(--tile) * 4);margin:0 auto;display:grid;grid-template-columns:repeat(4,var(--tile));justify-content:center;gap:0}.home-tile{position:relative;width:var(--tile);aspect-ratio:1 / 1;display:flex;flex-direction:column;gap:7px;padding:33px 32px;overflow:hidden}.home-tile-title{font-size:18px;font-weight:700;line-height:1.3}.home-tile-desc{margin:0;font-size:15px;font-weight:500;line-height:1.45;opacity:.8}.home-tile--cat{background:var(--green);color:#fff;border-top-left-radius:36px;border-bottom-left-radius:36px}.home-tile--cat.is-solo{border-radius:36px}.home-tile--soft{background:var(--green-soft)}.home-tile--tool{background:var(--panel);color:var(--ink);transition:background .15s ease}.home-tile--tool.is-tail{border-top-right-radius:36px;border-bottom-right-radius:36px}.home-tile--tool:hover{background:var(--green-pale)}.home-tile--tool.is-locked{opacity:.42;cursor:not-allowed}.home-tile--tool.is-locked:hover{background:var(--panel)}.home-support{max-width:1280px;margin:0 auto;padding:64px 24px 40px;display:flex;flex-direction:column;align-items:center;text-align:center}.home-support-title{margin:0 0 16px;font-size:18px;font-weight:700;line-height:1.6}.home-support-lead{margin:0 0 20px;font-size:15px;line-height:1.6}.home-support-prices{margin:0 0 24px;padding:0;list-style:none;display:grid;gap:4px;font-size:15px;line-height:1.6}.home-support-qr{position:relative;width:108px;height:108px;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid rgba(10,10,10,.18);border-radius:12px;background:#fff}.home-support-qr img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}.home-support-qr-ph{font-size:12px;color:#30303080}.home-footer{max-width:1280px;margin:0 auto;padding:32px 24px 48px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.home-footer-copy{margin:0;font-size:13px;color:#30303066}.home-footer-links{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;font-size:15px}.home-footer-links a{opacity:.4;transition:opacity .15s ease}.home-footer-links a:hover{opacity:.85}.home-footer-links span{opacity:.25}.legal-page{max-width:760px;margin:24px auto;padding:24px}.legal-page h1{margin:0 0 16px;font-size:28px}.legal-page-note{color:#3030308c}.legal-page h2{margin:28px 0 10px;font-size:20px}.legal-page h3{margin:20px 0 8px;font-size:16px}.legal-page p{margin:10px 0;line-height:1.75;color:var(--ink)}.legal-page ul,.legal-page ol{margin:10px 0;padding-left:22px;line-height:1.75}.legal-page li{margin:4px 0}.legal-page a{color:var(--green);text-decoration:underline}.legal-page code{font-family:ui-monospace,Menlo,monospace;font-size:.9em;background:#0a0a0a0d;padding:1px 5px;border-radius:5px}.legal-page blockquote{margin:12px 0;padding:6px 16px;border-left:3px solid var(--green);background:#2a93200f;border-radius:0 8px 8px 0}.legal-page hr{border:0;border-top:1px solid rgba(10,10,10,.12);margin:24px 0}.legal-page table{border-collapse:collapse;margin:14px 0}.legal-page th,.legal-page td{border:1px solid rgba(10,10,10,.12);padding:7px 11px}@media(max-width:1295px){.home-grid{grid-template-columns:repeat(3,var(--tile))}}@media(max-width:975px){.home-grid{grid-template-columns:repeat(2,var(--tile))}}@media(max-width:655px){.home-grid{--tile: 100%;grid-template-columns:1fr;max-width:560px}.home-tile{width:auto;aspect-ratio:1.414 / 1}.home-tile--cat,.home-tile--cat.is-solo,.home-tile--tool.is-tail{border-radius:0}.home-grid>.home-tile:first-child{border-top-left-radius:32px;border-top-right-radius:32px}.home-grid>.home-tile:last-child{border-bottom-left-radius:32px;border-bottom-right-radius:32px}}.hangul-typo-tool{gap:0;align-items:stretch;--typo-inspect: var(--sans);--typo-compare: var(--sans) }.typo-left{display:flex;flex-direction:column;gap:20px;flex:0 0 420px;max-width:420px;min-width:0}.typo-card{border-radius:20px}.typo-settings,.typo-inspect-panel{background:var(--panel);color:var(--ink)}.typo-settings{padding:28px 26px}.typo-inspect-panel{flex:1 1 auto;min-width:0;min-height:420px;padding:28px 30px;border:2px solid var(--green)}.typo-results{background:var(--green);color:var(--green-pale);padding:26px;min-height:160px}.typo-settings h2,.typo-inspect-panel h2{margin:0 0 18px;color:var(--green);font-size:20px;font-weight:700}.typo-results h2{margin:0 0 14px;color:#fff;font-size:20px;font-weight:700}.typo-field{display:grid;gap:8px;margin-bottom:20px;font-size:14px;font-weight:600;color:var(--ink)}.typo-field:last-child{margin-bottom:0}.typo-compare-check{margin-bottom:20px}.typo-custom-set{display:grid;gap:12px;margin-bottom:20px;font-size:14px;font-weight:600}.typo-custom-set .typo-note{margin:0;font-size:13px;font-weight:500;line-height:1.6;color:#3030309e}.typo-canvas{display:block;width:100%}.typo-drop{display:grid;gap:6px;cursor:pointer}.typo-drop>span:first-child{font-weight:600}.typo-custom{margin-top:0}.typo-custom textarea{height:120px}.typo-result-list{display:grid;gap:8px}.typo-result-item{margin:0;font-size:14px;line-height:1.5;color:var(--green-pale)}.typo-result-item b{color:#fff;font-weight:700}.typo-result-empty{margin:0;color:#ffffffa6;font-size:14px}.typo-inspect-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:8px}.typo-inspect-head h2{margin:0}.typo-nav{display:flex;align-items:center;gap:10px}.typo-page-info{color:var(--green);font-size:14px;font-weight:700}.typo-nav .btn[disabled]{opacity:.4;pointer-events:none}.typo-grid{display:flex;flex-wrap:wrap;gap:18px 12px;margin-top:20px}.typo-cell{display:flex;flex-direction:column;align-items:center;gap:6px}.typo-glyph{width:1.35em;font-size:44px;line-height:1.18;text-align:center}.typo-glyph-inspect{padding:0;border:0;background:none;color:var(--ink);font-family:var(--typo-inspect);cursor:pointer;border-radius:5px;transition:background .12s ease}.typo-glyph-inspect:hover{background:var(--green-pale)}.typo-glyph-inspect.is-error{background:#ffd7d7;color:#d62b2b}.typo-glyph-compare{color:var(--green);font-family:var(--typo-compare)}.typo-hide-compare .typo-glyph-compare{display:none}.typo-cell-cs .typo-glyph-canvas{width:78px;height:78px;font-size:0;border:1px solid rgba(10,10,10,.12);border-radius:8px;overflow:hidden}.typo-cell-cs .typo-glyph-canvas canvas{display:block;width:100%;height:100%}.typo-cell-cs .typo-glyph-canvas.is-error{border-color:#d62b2b}.typo-cs-caption{max-width:90px;font-size:11px;line-height:1.35;color:#30303099;text-align:center;word-break:break-all}.typo-empty{margin:0;color:#30303094;font-size:16px;font-weight:600}@media(max-width:900px){.hangul-typo-tool{flex-direction:column}.typo-left{flex:1 1 auto;max-width:none;width:100%}}@font-face{font-family:Gwangjang KFA Puncs;src:url(/fonts/gwangjang-bold-kfa-puncs.woff2) format("woff2");font-display:swap}.kfa-tool{background:var(--panel);border-radius:24px;padding:0 18px}.kfa-header{position:sticky;top:0;padding-top:10px;background:var(--panel);border-radius:24px 24px 0 0;padding-left:0;transition:padding-left .3s ease}.kfa-header.is-stuck{padding-left:4em}.kfa-header:after{content:"";display:block;height:10px;background:linear-gradient(var(--panel),rgba(255,255,255,0));pointer-events:none}.kfa-header-inner{display:flex;align-items:center;gap:10px;height:44px}.kfa-search-wrap{flex:0 0 auto;width:290px}.kfa-search{box-sizing:border-box;width:100%;height:44px;padding:0 20px;border:2px solid var(--green);border-radius:999px;background:var(--panel);color:var(--ink);font:inherit;font-size:16px;font-weight:700;outline:none}.kfa-search::placeholder{color:#afafaf;opacity:.7;font-weight:700}.kfa-search-badge{box-sizing:border-box;display:none;flex:0 0 auto;height:44px;padding:0 22px;border:2px solid var(--green);border-radius:999px;background:var(--panel);color:var(--green);font:inherit;font-weight:700;font-size:16px;cursor:pointer;align-items:center}@property --kfa-fade-l{syntax: "<length>"; inherits: false; initial-value: 0px}@property --kfa-fade-r{syntax: "<length>"; inherits: false; initial-value: 0px}.kfa-badges{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:10px;height:44px;overflow-x:auto;scrollbar-width:none;--kfa-fade-l: 0px;--kfa-fade-r: 0px;transition:--kfa-fade-l .25s ease,--kfa-fade-r .25s ease;-webkit-mask-image:linear-gradient(to right,transparent 0,#000 var(--kfa-fade-l),#000 calc(100% - var(--kfa-fade-r)),transparent 100%);mask-image:linear-gradient(to right,transparent 0,#000 var(--kfa-fade-l),#000 calc(100% - var(--kfa-fade-r)),transparent 100%)}.kfa-badges.is-fade-left{--kfa-fade-l: 32px }.kfa-badges.is-fade-right{--kfa-fade-r: 32px }.kfa-badges::-webkit-scrollbar{display:none}.kfa-badge{flex:0 0 auto;height:44px;padding:0 20px;border:0;border-radius:999px;background:var(--bg);color:var(--green);font:inherit;font-weight:600;font-size:16px;white-space:nowrap;cursor:pointer;transition:background .14s,color .14s}.kfa-badge:hover{background:#e2eaea}.kfa-badge.is-active{background:var(--green);color:var(--green-pale)}.kfa-list{padding:14px 0 28px;min-height:50vh}.kfa-cat{margin-bottom:56px}.kfa-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:18px 2px}.kfa-cell{display:flex;flex-direction:column;align-items:stretch;gap:12px;padding:6px 6px 10px;border:0;border-radius:24px;background:none;cursor:pointer;text-align:center}.kfa-cell.is-selected{background:#2a93201a}.kfa-glyph-box{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1 / 1;border:1px solid rgba(10,10,10,.1);border-radius:18px;background:var(--panel);overflow:hidden;transition:border-color .12s}.kfa-cell:hover .kfa-glyph-box{border-color:var(--green)}.kfa-glyph{font-family:"Gwangjang KFA Puncs",var(--sans);font-size:104px;line-height:1;color:var(--ink);font-weight:400;margin-bottom:.18em}.kfa-meta{display:flex;flex-direction:column;gap:6px}.kfa-name,.kfa-cp{font-size:14px;line-height:1.1;color:#afafaf;font-weight:400;word-break:keep-all}.kfa-empty,.kfa-loading{margin:40px 0;color:#30303080;text-align:center}@media(max-width:700px){.kfa-tool{border-radius:18px;padding:0 12px}.kfa-search-wrap{display:block;flex:0 1 auto;width:0;min-width:0;overflow:hidden;opacity:0;transition:width .3s ease,opacity .25s ease}.kfa-search-badge{display:inline-flex}.kfa-search-open .kfa-search-wrap{width:100%;opacity:1}.kfa-search-open .kfa-search-badge,.kfa-search-open .kfa-badges{display:none}.kfa-grid{grid-template-columns:1fr;gap:6px}.kfa-cell{flex-direction:row;align-items:center;gap:16px;padding:8px;text-align:left}.kfa-glyph-box{flex:0 0 auto;width:72px;height:72px}.kfa-glyph{font-size:44px}.kfa-meta{align-items:flex-start;gap:4px}.kfa-name{font-size:16px;color:var(--ink);font-weight:600}.kfa-cp{font-size:14px}}.adm-body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.5;-webkit-font-smoothing:antialiased}.adm-shell{display:grid;grid-template-columns:232px minmax(0,1fr);min-height:100vh}.adm-sidebar{position:sticky;top:0;align-self:start;height:100vh;display:flex;flex-direction:column;gap:6px;padding:18px 14px;background:var(--sidebar);color:var(--sidebar-text)}.adm-sidebar-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.adm-brand{display:flex;flex-direction:column;gap:2px;padding:4px 6px}.adm-brand-mark{font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--green-soft)}.adm-brand-name{font-size:16px;font-weight:800;color:#fff}.adm-navtoggle{display:none;flex-direction:column;gap:4px;padding:8px;background:none;border:0;cursor:pointer}.adm-navtoggle span{width:18px;height:2px;background:var(--sidebar-text)}.adm-nav{display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1 1 auto}.adm-nav-group{display:flex;flex-direction:column;gap:2px;padding:6px 0}.adm-nav-group+.adm-nav-group{margin-top:4px;border-top:1px solid rgba(255,255,255,.08);padding-top:10px}.adm-nav-heading{margin:0 0 4px;padding:0 10px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--sidebar-muted)}.adm-nav-item{display:block;padding:9px 10px;border-radius:9px;font-size:14px;font-weight:600;color:var(--sidebar-text);background:none;border:0;text-align:left;cursor:pointer;transition:background .12s}.adm-nav-item:hover{background:#ffffff0f}.adm-nav-item.is-active{background:var(--green);color:#fff;padding-left:12px}.adm-nav-item.is-disabled{color:var(--sidebar-muted);cursor:default;opacity:.55}.adm-nav-item.is-disabled:hover{background:none}.adm-sidebar-foot{display:flex;flex-direction:column;gap:2px;padding-top:10px;border-top:1px solid rgba(255,255,255,.08)}.adm-foot-link{display:block;width:100%;padding:8px 10px;font:inherit;font-size:13px;color:var(--sidebar-muted);background:none;border:0;text-align:left;cursor:pointer;border-radius:8px}.adm-foot-link:hover{color:var(--sidebar-text);background:#ffffff0f}.adm-main{display:flex;flex-direction:column;min-width:0}.adm-topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 24px;background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid #0a0a0a1a}.adm-topbar h1{margin:0;font-size:20px;font-weight:800}.adm-topbar-actions{display:flex;gap:8px;align-items:center}.adm-content{width:100%;max-width:1040px;padding:20px 24px 56px}.adm-card{background:var(--panel);border-radius:16px;padding:18px 20px;margin-bottom:24px}.adm-card>h2{margin:0 0 14px;font-size:15px;font-weight:800}.adm-card-note{margin:-6px 0 14px;color:#30303094;font-size:13px}.adm-grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}.adm-field{display:grid;gap:6px;margin-bottom:14px}.adm-field>label,.adm-label{font-size:13px;font-weight:700;color:var(--ink)}.adm-field .adm-hint{font-size:12px;color:#30303085;font-weight:500}.adm-input,.adm-textarea,.adm-select-native{width:100%;min-height:40px;padding:9px 12px;border:1px solid #0a0a0a2e;border-radius:9px;background:var(--panel);color:var(--ink);font:inherit;font-size:14px}.adm-input:focus,.adm-textarea:focus,.adm-select-native:focus{outline:none;border-color:var(--green)}.adm-input:disabled{background:#0a0a0a08;color:#30303099}.adm-textarea{height:400px;line-height:1.55;resize:vertical}.adm-textarea-code{font-family:var(--mono);font-size:13px}.adm-check{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none}.adm-check input{appearance:none;-webkit-appearance:none;width:20px;height:20px;margin:0;border:2px solid var(--green);border-radius:6px;background:var(--panel);cursor:pointer;position:relative;flex:0 0 auto}.adm-check input:checked{background:var(--green)}.adm-check input:checked:after{content:"";position:absolute;left:5px;top:1px;width:4px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.adm-actions{display:flex;gap:8px;align-items:center;margin-top:4px}.adm-table-wrap{overflow-x:auto;background:var(--panel)}.adm-table{width:100%;border-collapse:collapse;font-size:14px}.adm-table th,.adm-table td{padding:11px 14px;text-align:left;border:none;vertical-align:middle;white-space:nowrap}.adm-table tr{border-bottom:1px solid #0a0a0a12}.adm-table tr:last-child{border-bottom:none}.adm-table thead tr{border-bottom:none}.adm-table thead th{font-size:12px;font-weight:700;color:#30303099;background:#0a0a0a05}.adm-table tbody tr:last-child td{border-bottom:0}.adm-table tbody tr:hover{background:#2a93200a}.adm-table-fixed{table-layout:fixed}.adm-table td .adm-sub{display:block;font-size:12px;color:#30303085}.adm-table a.adm-rowlink{font-weight:700;color:var(--green)}.adm-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:700;line-height:1.4;white-space:nowrap}.adm-badge-active{background:var(--green-pale);color:var(--green)}.adm-badge-pending{background:#fff3d6;color:#a97400}.adm-badge-suspended{background:#ffe4d6;color:#b8501f}.adm-badge-blocked{background:#ffd9d9;color:#c02626}.adm-badge-muted{background:#0a0a0a0d;color:#30303099}.adm-badge-admin{background:#303030;color:#fff}.adm-filterbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}.adm-filterbar .adm-search{flex:1 1 220px;min-width:160px}.adm-filterbar .custom-select{min-width:130px}.adm-filterbar .adm-date{flex:0 0 auto;width:150px;min-width:0}.adm-select .select-label{width:100%;min-height:40px;padding:8px 12px;border:1px solid #0a0a0a2e;border-radius:9px;background:var(--panel);color:var(--green);font-size:14px;font-weight:700}.adm-select .select-dropdown{border-radius:10px;font-size:14px;font-weight:700}.adm-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:16px}.adm-tile{display:flex;flex-direction:column;gap:4px;padding:16px 18px;background:var(--panel);border:1px solid #0a0a0a14;border-radius:14px}.adm-tile strong{font-size:26px;font-weight:800}.adm-tile span{font-size:13px;color:#30303099;font-weight:600}a.adm-tile:hover{border-color:var(--green)}.adm-notice{margin:0 0 16px;padding:11px 14px;border-radius:10px;background:var(--green-pale);color:var(--green);font-size:14px;font-weight:600}.adm-notice-error{background:#ffd9d9;color:#c02626}.adm-notice-error p{margin:2px 0}.adm-preview{display:inline-flex;align-items:center;justify-content:center;background:#0a0a0a08;border:1px solid #0a0a0a14;border-radius:10px;overflow:hidden}.adm-preview img{display:block;max-width:100%;max-height:100%;object-fit:contain}.adm-preview-icon{width:56px;height:56px}.adm-preview-og{width:200px;height:105px}.adm-muted{color:#30303085;font-size:13px}.adm-checklist{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px 16px}.adm-pager{display:flex;align-items:center;gap:10px;margin-top:16px}.adm-pager-btn{padding:7px 14px;border:1px solid #0a0a0a2e;border-radius:999px;font-size:13px;font-weight:700;color:var(--ink);background:var(--panel)}.adm-pager-btn:hover{border-color:var(--green);color:var(--green)}.adm-pager-btn.is-disabled{opacity:.4;pointer-events:none}.adm-pager-info{font-size:13px;color:#30303099;font-weight:600}@media(max-width:820px){.adm-shell{grid-template-columns:1fr}.adm-sidebar{position:static;height:auto}.adm-navtoggle{display:flex}.adm-shell:not([data-nav-open]) .adm-nav,.adm-shell:not([data-nav-open]) .adm-sidebar-foot{display:none}.adm-grid2{grid-template-columns:1fr}.adm-content{padding:16px 16px 48px}}
