@import "https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@600;700;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--serif:"Noto Serif SC", "Source Han Serif SC", "Songti SC", Georgia, serif;--sans:-apple-system, "PingFang SC", "Noto Sans SC", "Segoe UI", sans-serif;--mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;font-family:var(--sans);--bg:#f7f4ec;--surface:#fff;--surface-muted:#f0ece2;--surface-2:#f0ece2;--text:#1c1a17;--muted:#6b6457;--faint:#a89f8d;--border:#e4ddcb;--primary:#c2410c;--primary-contrast:#fff;--danger:#b42318;--success:#087443;--shadow:0 1px 0 #1c1a1708;--shadow-lg:0 8px 32px #1c1a1714;color:var(--text);background:var(--bg);font-weight:400;line-height:1.5}:root[data-theme=dark]{--bg:#1a1714;--surface:#241f1a;--surface-muted:#2e2822;--surface-2:#2e2822;--text:#f0e8db;--muted:#a89f8d;--faint:#6b6457;--border:#3a3128;--primary:#e8704a;--primary-contrast:#1a1714;--danger:#ffb4ab;--success:#77d6a4;--shadow:0 1px 0 #0003;--shadow-lg:0 8px 32px #0000004d}*{box-sizing:border-box}body{background:var(--bg);min-width:320px;min-height:100vh;color:var(--text);background-image:radial-gradient(#1c1a170b 1px,#0000 1px);background-size:14px 14px;margin:0}a{color:inherit}button,input,select,textarea{font:inherit}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid color-mix(in srgb, var(--primary) 45%, transparent);outline-offset:2px}.app-shell{background:var(--bg);height:100vh;color:var(--text);background-image:radial-gradient(#1c1a170b 1px,#0000 1px);background-size:14px 14px;grid-template-columns:208px 1fr;display:grid}.app-main{padding:36px 44px 48px;overflow-y:auto}.app-header{justify-content:space-between;align-items:center;gap:1rem;padding:1rem 0 2rem;display:flex}.brand{gap:.2rem;text-decoration:none;display:grid}.brand-title{letter-spacing:-.04em;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800}.brand-purpose{max-width:44rem;color:var(--muted);margin:0}.preference-controls{flex-wrap:wrap;justify-content:flex-end;gap:.75rem;display:flex}.select-field,.input-field{gap:.35rem;display:grid}.select-field label,.input-field label{letter-spacing:.01em;color:var(--text);font-size:.82rem;font-weight:700}select,input,textarea{border:1px solid var(--border);background:var(--surface);min-height:2.7rem;color:var(--text);border-radius:10px;padding:.6rem .8rem;transition:border-color .15s,box-shadow .15s,background .15s}select:hover,input:hover,textarea:hover{border-color:color-mix(in srgb, var(--primary) 40%, var(--border))}textarea{resize:vertical;width:100%;font-family:var(--mono);line-height:1.6}input::placeholder,textarea::placeholder{color:var(--faint)}input[aria-invalid=true],textarea[aria-invalid=true]{border-color:var(--danger)}.help-text{color:var(--muted);margin:0;font-size:.92rem}.error-text{color:var(--danger);margin:0;font-size:.92rem;font-weight:700}.card{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:14px}.hero,.panel,.tool-card{padding:clamp(1rem,2.5vw,1.5rem)}.hero{margin-bottom:1rem}.hero h1,.panel h2,.tool-page h1{letter-spacing:-.035em;margin:0 0 .5rem}.panel h2,.tool-page h2{font-family:var(--serif);letter-spacing:-.01em;align-items:center;gap:.55rem;font-size:1.15rem;font-weight:700;display:flex}.panel>h2:before,.tool-page section.panel>h2:before{content:"";background:var(--primary);border-radius:2px;flex:none;width:14px;height:3px}.panel h3,.tool-page h3{font-family:var(--serif);letter-spacing:-.005em;font-size:1rem;font-weight:700}.catalog-controls{grid-template-columns:minmax(0,1fr) 16rem;gap:1rem;margin:1rem 0;display:grid}.tool-grid,.panel-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;display:grid}.tool-card{gap:1rem;display:grid}.badge{background:var(--surface-muted);width:fit-content;color:var(--muted);letter-spacing:.01em;border-radius:999px;align-items:center;padding:.25rem .7rem;font-size:.8rem;font-weight:700;display:inline-flex}.button{border:1px solid color-mix(in srgb, var(--primary) 50%, transparent);background:var(--primary);color:var(--primary-contrast);cursor:pointer;border-radius:.65rem;padding:.6rem .95rem;font-weight:700;text-decoration:none;transition:transform .12s,box-shadow .12s,background .12s,border-color .12s,color .12s}.button:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.button:active{box-shadow:none;transform:translateY(0)}.button.secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.button.secondary:hover{border-color:var(--primary);color:var(--primary);box-shadow:none}.button.status-success{background:var(--success);border-color:var(--success);color:var(--primary-contrast)}.button.status-success:hover,.button.status-error:hover{color:var(--primary-contrast);box-shadow:none}.button.status-error{background:var(--danger);border-color:var(--danger);color:#fff}.tool-page{gap:1.25rem;display:grid}.tool-page-header{gap:.65rem;display:grid}.result-list{gap:.6rem;margin-top:1rem;display:grid}.result-row{border:1px solid var(--border);background:var(--surface);border-radius:.65rem;grid-template-columns:minmax(8rem,.7fr) minmax(0,1.3fr) auto;align-items:center;gap:.75rem;padding:.7rem .8rem;transition:border-color .12s,background .12s;display:grid}.result-row:hover{border-color:color-mix(in srgb, var(--primary) 35%, var(--border));background:color-mix(in srgb, var(--primary) 4%, var(--surface))}.result-label{font-weight:700}.result-value{overflow-wrap:anywhere;min-width:0;font-family:var(--mono);color:var(--muted)}.converter-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:1rem;display:grid}.form-stack{gap:1rem;display:grid}.flag-field{border:1px solid var(--border);border-radius:.7rem;margin:0;padding:.85rem}.flag-field legend{padding:0 .25rem;font-size:.82rem;font-weight:700}.flag-options{flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;display:flex}.flag-option{border:1px solid var(--border);background:var(--surface);font-family:var(--mono);border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .7rem;font-weight:600;transition:border-color .12s,background .12s,color .12s;display:inline-flex}.flag-option:hover{border-color:var(--primary);background:color-mix(in srgb, var(--primary) 8%, transparent)}.flag-option input{min-height:auto}.regex-preview{border:1px solid var(--border);background:var(--surface);white-space:pre-wrap;overflow-wrap:anywhere;min-height:10rem;font-family:var(--mono);border-radius:.7rem;margin:.5rem 0 0;padding:.85rem}.regex-highlight{background:color-mix(in srgb, var(--primary) 24%, transparent);box-shadow:0 0 0 1px color-mix(in srgb, var(--primary) 40%, transparent);border-radius:.25rem}.match-list{gap:.75rem;margin-top:1rem;display:grid}.match-card{border:1px solid var(--border);background:var(--surface);border-radius:.7rem;gap:.65rem;padding:.85rem;display:grid}.match-card h4,.match-card dl,.match-card dd,.match-card p{margin:0}.match-card dl{gap:.5rem;display:grid}.match-card dl>div{grid-template-columns:5rem minmax(0,1fr);gap:.5rem;display:grid}.match-card dt{font-weight:700}.match-card code,.group-list code{color:var(--muted);overflow-wrap:anywhere;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.group-list{margin:.4rem 0 0;padding-left:1.25rem}.preset-grid{grid-template-columns:minmax(14rem,20rem) minmax(0,1fr);align-items:start;gap:1rem;display:grid}.preset-controls,.field-grid{grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));gap:1rem;display:grid}.field-editor-header{gap:.35rem;margin-bottom:1rem;display:grid}.toggle-option{align-items:center;gap:.5rem;font-weight:600;display:inline-flex}.result-row-static{grid-template-columns:minmax(9rem,.8fr) minmax(0,1.2fr) auto}.nested-card{box-shadow:none;background:var(--surface);border-radius:.8rem;padding:1rem}.nested-card h3,.nested-card h4{margin:0 0 .5rem}.json-output-card{gap:.75rem;display:grid}.output-card-header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.json-output-card textarea[readonly]{background:var(--surface-muted)}.field-detail-list{gap:.5rem;margin:.5rem 0 0;padding-left:1.25rem;display:grid}.sidebar{background:color-mix(in srgb, var(--surface) 60%, transparent);border-right:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-direction:column;gap:16px;padding:20px 14px 16px;transition:background .3s,border-color .3s;display:flex;overflow-y:auto}.sidebar-logo{align-items:center;gap:8px;padding:0 4px;display:flex}.sidebar-mark{font-family:var(--serif);color:var(--primary);font-size:22px;font-weight:700}.sidebar-title{font-family:var(--serif);letter-spacing:.02em;font-size:18px;font-weight:700}.sidebar-sub{font-family:var(--mono);color:var(--faint);letter-spacing:.15em;margin-top:-8px;padding:0 4px;font-size:10px}.sidebar-nav{flex-direction:column;flex:1;gap:1px;display:flex}.nav-item{color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;width:100%;padding:7px 9px;font-family:inherit;font-size:13.5px;transition:background .12s,color .12s;display:flex}.nav-item:hover{background:color-mix(in srgb, var(--primary) 10%, transparent);color:var(--text)}.nav-item.active{background:var(--text);color:var(--surface)}.nav-item.active .nav-dot{background:var(--primary)!important}.nav-dot{border-radius:2px;flex:none;width:7px;height:7px}.nav-label{flex:1;font-weight:500}.nav-count{font-family:var(--mono);opacity:.7;font-size:11px}.nav-divider{background:var(--border);height:1px;margin:6px 4px}.sidebar-foot{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:12px;display:flex}.sidebar-hint{font-family:var(--mono);color:var(--faint);align-items:center;gap:4px;padding:0 4px;font-size:10.5px;display:flex}.sidebar-hint kbd{font-family:var(--mono);background:var(--surface-2);border:1px solid var(--border);border-radius:3px;padding:1px 5px;font-size:10px}.sidebar-toggles{gap:6px;padding:0 4px;display:flex}.toggle-btn{font-family:var(--mono);color:var(--faint);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;padding:3px 7px;font-size:10.5px;transition:background .12s,color .12s,border-color .12s}.toggle-btn:hover{background:color-mix(in srgb, var(--primary) 10%, transparent);color:var(--text);border-color:var(--primary)}.toggle-btn.on{background:var(--primary);color:#fff;border-color:var(--primary)}.main-area{padding:36px 44px 48px;overflow-y:auto}.hero{max-width:640px;margin-bottom:34px}.hero-title{font-family:var(--serif);letter-spacing:-.01em;margin:0 0 10px;font-size:34px;font-weight:700;line-height:1.15}.hero-em{color:var(--primary);font-style:italic}.hero-sub{color:var(--muted);margin:0 0 20px;font-size:13.5px;line-height:1.7}.search-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;align-items:center;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.search-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 15%, transparent)}.search-icon{color:var(--faint);pointer-events:none;font-size:16px;position:absolute;left:14px}.search-input{background:0 0;border:none;outline:none;flex:1;min-height:auto;padding:13px 16px 13px 38px;font-size:14px}.search-input::placeholder{color:var(--faint)}.search-hint{font-family:var(--mono);color:var(--faint);background:var(--surface-2);border:1px solid var(--border);pointer-events:none;border-radius:4px;padding:2px 5px;font-size:11px;position:absolute;right:12px}.cat-section{margin-bottom:28px}.cat-head{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.cat-title{font-family:var(--serif);align-items:center;gap:8px;margin:0;font-size:16px;font-weight:700;display:flex}.cat-bar{border-radius:2px;width:14px;height:3px}.cat-count{font-family:var(--mono);color:var(--faint);font-size:11px;font-weight:400}.cat-slug{font-family:var(--mono);color:var(--faint);font-size:11px}.tool-rows{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.tool-row{border-bottom:1px solid var(--border);cursor:pointer;color:inherit;grid-template-columns:40px 1fr auto;align-items:center;gap:12px;padding:11px 14px;text-decoration:none;transition:background .1s;display:grid}.tool-row:last-child{border-bottom:none}.tool-row:hover{background:color-mix(in srgb, var(--primary) 8%, transparent)}.tool-row:hover .tool-arrow{opacity:1;transform:translate(3px)}.tool-glyph{width:34px;height:34px;font-family:var(--mono);background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.tool-main{flex-direction:column;gap:1px;min-width:0;display:flex}.tool-title{font-size:13.5px;font-weight:600}.tool-desc{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;line-height:1.5;overflow:hidden}.tool-arrow{font-family:var(--mono);color:var(--faint);opacity:.4;font-size:13px;transition:transform .12s,opacity .12s}.detail-wrap{max-width:960px;padding:36px 44px 48px}.detail-header{flex-direction:column;gap:8px;margin-bottom:28px;display:flex}.detail-back{color:var(--muted);font-size:13px;font-family:var(--mono);align-items:center;gap:6px;width:fit-content;text-decoration:none;transition:color .12s;display:inline-flex}.detail-back:hover{color:var(--primary)}.detail-badge{background:var(--surface-2);color:var(--muted);border-radius:999px;align-items:center;gap:6px;width:fit-content;padding:3px 10px;font-size:12px;font-weight:700;display:inline-flex}.detail-badge-dot{border-radius:2px;width:6px;height:6px}.detail-title{font-family:var(--serif);letter-spacing:-.01em;font-size:28px;font-weight:700}.detail-desc{color:var(--muted);max-width:600px;font-size:13.5px;line-height:1.7}.empty-msg{color:var(--muted);text-align:center;padding:40px 0;font-size:13px}.mobile-menu-btn{z-index:98;border:1px solid var(--border);background:var(--surface);width:40px;height:40px;color:var(--text);cursor:pointer;box-shadow:var(--shadow);border-radius:8px;justify-content:center;align-items:center;transition:background .12s,border-color .12s;display:none;position:fixed;top:14px;left:14px}.mobile-menu-btn:hover{border-color:var(--primary);color:var(--primary)}.sidebar-backdrop{display:none}.sidebar-close-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;transition:color .12s,background .12s;display:none;position:absolute;top:16px;right:14px}.sidebar-close-btn:hover{color:var(--text);background:color-mix(in srgb, var(--primary) 10%, transparent)}@media (width<=1024px){.app-main,.main-area,.detail-wrap{padding:28px 36px}}@media (width<=767px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:100;visibility:hidden;width:min(280px,85vw);transition:transform .25s,visibility 0s .25s;position:fixed;inset:0;transform:translate(-100%)}.app-shell[data-sidebar-open] .sidebar{visibility:visible;transition:transform .25s,visibility;transform:translate(0)}.sidebar-backdrop{z-index:99;opacity:0;pointer-events:none;background:#00000059;transition:opacity .25s;display:block;position:fixed;inset:0}.app-shell[data-sidebar-open] .sidebar-backdrop{opacity:1;pointer-events:auto}.mobile-menu-btn,.sidebar-close-btn{display:flex}.app-main,.main-area,.detail-wrap{padding:60px 16px 32px}.hero-title{font-size:clamp(24px,6vw,34px)}.detail-title{font-size:clamp(22px,5.5vw,28px)}.detail-wrap{max-width:100%}}@media (width<=720px){.app-header,.catalog-controls,.converter-grid,.result-row,.preset-grid{grid-template-columns:1fr}.app-header{display:grid}.preference-controls{justify-content:stretch}.preference-controls>*{flex:10rem;min-width:0}.result-row{align-items:stretch}}
