.manual-btn{background:var(--accent);color:#fff;border:none;padding:8px 18px;border-radius:var(--r-pill);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--t-fast);box-shadow:0 2px 8px #6e5ce74d;display:flex;align-items:center;gap:6px;font-family:var(--font);letter-spacing:-.01em}.manual-btn:hover{background:var(--accent-hover);box-shadow:0 4px 14px #6e5ce766;transform:translateY(-1px)}.manual-btn:active{transform:scale(.97);box-shadow:0 1px 4px #6e5ce74d}.tool-nav{display:flex;justify-content:center;gap:8px;margin-bottom:28px;flex-wrap:wrap}.nav-btn{padding:8px 14px;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--r-md);cursor:pointer;transition:all var(--t-fast);font-size:.875rem;font-weight:500;font-family:var(--font);letter-spacing:-.01em;text-align:left;position:relative}.nav-btn:hover{background:var(--accent-light);color:var(--accent)}.nav-btn.active{background:var(--accent-light);color:var(--accent);font-weight:600}.sidebar .nav-btn{width:100%;border-radius:var(--r-md);padding:9px 12px 9px 14px;font-size:.875rem;display:flex;align-items:center;gap:8px}.sidebar .nav-btn.active{background:var(--accent-light);color:var(--accent)}.sidebar .nav-btn.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;border-radius:var(--r-pill);background:var(--accent)}.sub-nav{display:flex;gap:6px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--divider);flex-wrap:wrap}.sub-nav-btn{padding:7px 16px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);border-radius:var(--r-pill);cursor:pointer;font-size:.825rem;font-weight:500;transition:all var(--t-fast);font-family:var(--font);letter-spacing:-.01em}.sub-nav-btn:hover{background:var(--surface-3);border-color:var(--accent);color:var(--accent)}.sub-nav-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #6e5ce740}.generator-content{display:none}.generator-content.active{display:block}.tool-panel h2{color:var(--text-primary);margin-bottom:22px;font-size:1.5rem;font-weight:700;letter-spacing:-.03em;padding-bottom:14px;border-bottom:1px solid var(--divider);line-height:1.2}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:.875rem;color:var(--text-primary);letter-spacing:-.01em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1.5px solid var(--border-strong);border-radius:var(--r-md);font-size:.9rem;font-family:var(--font);color:var(--text-primary);background:var(--surface-1);transition:border-color var(--t-fast),box-shadow var(--t-fast);-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none}.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2386868b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:#6e5ce766}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.form-group textarea{resize:vertical;line-height:1.6}.age-range{display:flex;align-items:center;gap:10px}.age-range input{flex:1;width:auto}.age-range span{color:var(--text-secondary);font-weight:500;font-size:.875rem}.generate-btn,.convert-btn,.copy-btn,.clear-btn{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;padding:10px 22px;border-radius:var(--r-md);cursor:pointer;font-size:.875rem;font-weight:600;font-family:var(--font);transition:all var(--t-fast);letter-spacing:-.01em;margin-right:8px;margin-bottom:8px;box-shadow:0 2px 8px #6e5ce733}.generate-btn:hover,.convert-btn:hover,.copy-btn:hover,.clear-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 14px #6e5ce759}.generate-btn:active,.convert-btn:active,.copy-btn:active,.clear-btn:active{transform:scale(.97);box-shadow:none}.result-area{margin-top:22px}.result-area textarea{width:100%;min-height:150px;resize:vertical;font-family:var(--font-mono);font-size:.875rem;background:var(--surface-3);color:var(--text-primary);border:1.5px solid var(--border-strong);border-radius:var(--r-md);padding:10px 14px;outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast);line-height:1.6}.result-area textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.converter-section{background:var(--surface-3);padding:18px;border-radius:var(--r-lg);margin-bottom:16px;border:1px solid var(--border)}.converter-section h3{color:var(--accent);margin-bottom:14px;font-size:.95rem;font-weight:600;letter-spacing:-.01em}.result-display{background:var(--surface-1);padding:14px;border-radius:var(--r-md);margin-top:12px;border:1.5px solid var(--border-strong);min-height:50px;font-family:var(--font-mono);font-weight:600;font-size:.9rem;color:var(--text-primary);word-break:break-all}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:18px 0}.stat-item{background:var(--surface-3);padding:14px 16px;border-radius:var(--r-md);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.stat-label{font-weight:500;font-size:.875rem;color:var(--text-secondary);letter-spacing:-.01em}.stat-value{font-size:1.1rem;font-weight:700;color:var(--accent);letter-spacing:-.02em}.manual-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000059;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .15s var(--ease)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface-1);backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-radius:var(--r-2xl);border:1px solid var(--border);width:90%;max-width:760px;max-height:82vh;overflow:hidden;box-shadow:var(--shadow-xl);animation:slideUp .2s var(--spring)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid var(--divider);background:var(--surface-3)}.modal-header h2{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-tertiary);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);transition:all var(--t-fast)}.close-btn:hover{color:var(--text-primary);background:#0000000f}.modal-body{padding:20px 24px;overflow-y:auto;max-height:calc(82vh - 65px)}.manual-modal .modal-body{line-height:1.75}.manual-modal .modal-body h3{font-size:1rem;margin-top:20px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--divider);color:var(--text-primary);font-weight:700;letter-spacing:-.02em}.manual-modal .modal-body h4{font-size:.9rem;margin-top:14px;margin-bottom:6px;color:var(--text-secondary);font-weight:600}.manual-modal .modal-body ul{margin:0 0 10px 1.2em;padding-left:.6em}.manual-modal .modal-body li{margin-bottom:5px;font-size:.9rem;color:var(--text-secondary)}.manual-quick-nav{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:14px;padding:10px 14px;border-radius:var(--r-md);background:var(--surface-3);border:1px solid var(--border);font-size:.875rem}.manual-quick-nav span{font-weight:600;color:var(--text-secondary);font-size:.8rem;letter-spacing:-.01em}.manual-quick-nav button{border:1px solid var(--border);background:var(--surface-1);color:var(--accent);border-radius:var(--r-pill);padding:4px 12px;cursor:pointer;font-size:.8rem;font-family:var(--font);font-weight:500;transition:all var(--t-fast);letter-spacing:-.01em}.manual-quick-nav button:hover{background:var(--accent-light);border-color:var(--accent);transform:translateY(-1px)}@media (max-width: 768px){.manual-btn{font-size:.8rem;padding:7px 14px}.stats-grid{grid-template-columns:1fr}.manual-modal .modal-body{padding:16px;font-size:.875rem}.manual-modal .modal-body h3{font-size:.95rem}.manual-quick-nav{gap:5px;padding:8px 10px}.manual-quick-nav button{padding:3px 10px;font-size:.75rem}}.container{width:100%;max-width:100%;margin:0;padding:16px 20px 20px;flex:1;min-height:0;display:flex;flex-direction:column;gap:16px}header{margin-bottom:0;color:var(--text-primary)}header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin-bottom:2px;background:linear-gradient(130deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}header p{font-size:.875rem;color:var(--text-secondary);font-weight:400;letter-spacing:-.01em}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;padding:14px 20px;background:var(--surface-1);backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-radius:var(--r-xl);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.header-text{flex:1}.header-actions{display:flex;align-items:center;gap:8px}.layout-main{display:flex;gap:14px;align-items:stretch;flex:1;min-height:0;width:100%}.sidebar{width:200px;flex-shrink:0;padding:10px 8px;border-radius:var(--r-xl);background:var(--surface-1);backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow-y:auto}.sidebar .tool-nav{flex-direction:column;align-items:stretch;justify-content:flex-start;gap:2px;margin-bottom:0}.sidebar-label{font-size:.7rem;font-weight:600;color:var(--text-tertiary);letter-spacing:.06em;text-transform:uppercase;padding:6px 12px 4px}.tool-content{background:var(--surface-1);backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-radius:var(--r-xl);padding:26px 28px;box-shadow:var(--shadow-sm);border:1px solid var(--border);flex:1;min-height:0;width:auto;display:flex;flex-direction:column;overflow-y:auto}.category-toggle{display:none;padding:9px 16px;border-radius:var(--r-pill);border:none;background:var(--accent);color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow-sm);font-family:var(--font);transition:all var(--t-fast);letter-spacing:-.01em}.category-toggle:hover{background:var(--accent-hover)}.category-toggle:active{transform:scale(.97);opacity:.9}.tool-panel{display:none}.tool-panel.active{display:block}.tool-panel#about-panel{display:none}.tool-panel#about-panel.active{display:block}.about-sub-nav{margin-bottom:20px}.about-content-wrapper{flex:1;min-height:0;overflow:hidden}.about-content{height:100%;max-height:100%;overflow-y:auto;padding-right:8px}.about-content h1,.about-content h2,.about-content h3,.about-content h4{color:var(--text-primary);margin:1.2em 0 .6em;font-weight:700;letter-spacing:-.02em}.about-content h1{font-size:1.8rem}.about-content h2{font-size:1.4rem}.about-content h3{font-size:1.15rem}.about-content p{line-height:1.8;margin:.5em 0;color:var(--text-primary);font-size:.95rem}.about-content strong{color:var(--text-primary);font-weight:700}.about-content ul,.about-content ol{padding-left:1.4em;margin:.5em 0 .5em .2em}.about-content li{margin:.25em 0;line-height:1.7;color:var(--text-secondary);font-size:.95rem}.about-content a{color:var(--accent);text-decoration:none}.about-content a:hover{text-decoration:underline}.about-content code{font-family:var(--font-mono);background:var(--surface-3);padding:2px 6px;border-radius:var(--r-xs);font-size:.875em;color:var(--accent)}.about-content img{max-width:100%;height:auto;display:block;margin:12px auto;border-radius:var(--r-md)}.about-content table{width:100%;border-collapse:collapse;margin:20px 0;table-layout:fixed}.about-content table td{text-align:center;padding:10px;vertical-align:middle;width:33.33%}.about-content table img{max-width:100%;width:auto;height:auto;display:block;margin:0 auto}@media (max-width: 768px){.container{padding:12px;gap:12px}header h1{font-size:1.5rem}.tool-content{padding:18px}.header-content{flex-direction:column;gap:12px;text-align:center;padding:16px}.layout-main{flex-direction:column}.category-toggle{display:inline-flex;align-items:center;gap:6px}.sidebar{display:none;position:fixed;left:0;top:0;bottom:0;width:260px;margin:0;border-radius:0 var(--r-xl) var(--r-xl) 0;z-index:1000;overflow-y:auto}body.sidebar-open .sidebar{display:flex}body.sidebar-open{overflow:hidden}body.sidebar-open:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:999}}.compare-options{display:flex;gap:16px;margin-bottom:18px;flex-wrap:wrap;padding:12px 14px;background:var(--surface-3);border-radius:var(--r-md);border:1px solid var(--border)}.option-group{display:flex;align-items:center}.option-group label{display:flex;align-items:center;gap:7px;font-weight:500;font-size:.875rem;color:var(--text-secondary);cursor:pointer}.option-group input[type=checkbox]{width:auto;margin:0;accent-color:var(--accent)}.compare-container{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.compare-section h3{color:var(--text-primary);margin-bottom:8px;font-size:.9rem;font-weight:600;letter-spacing:-.01em}.compare-section textarea{width:100%;min-height:200px;padding:12px;border:1.5px solid var(--border-strong);border-radius:var(--r-md);font-family:var(--font-mono);font-size:.85rem;resize:vertical;transition:border-color var(--t-fast),box-shadow var(--t-fast);background:var(--surface-1);color:var(--text-primary);outline:none}.compare-section textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.text-info{display:flex;gap:12px;margin-top:6px;font-size:.8rem;color:var(--text-tertiary)}.compare-actions{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}.compare-result{background:var(--surface-3);padding:18px;border-radius:var(--r-lg);border:1px solid var(--border)}.compare-result h3{color:var(--text-primary);margin-bottom:14px;font-size:.95rem;font-weight:700;letter-spacing:-.02em}.result-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:16px}.summary-item{background:var(--surface-1);padding:10px 14px;border-radius:var(--r-md);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.summary-label{font-weight:500;font-size:.825rem;color:var(--text-secondary)}.summary-value{font-weight:700;font-size:.95rem;color:var(--accent)}.diff-display{background:var(--surface-1);border:1.5px solid var(--border-strong);border-radius:var(--r-md);padding:14px;max-height:400px;overflow-y:auto;font-family:var(--font-mono);font-size:.85rem;line-height:1.6}.diff-hint{color:var(--text-tertiary);text-align:center;font-style:italic;font-size:.875rem}.diff-line{padding:2px 6px;margin:1px 0;border-radius:var(--r-xs);white-space:pre-wrap;word-break:break-all}.diff-same{background:transparent;color:var(--text-secondary)}.diff-added{background:#34c7591a;color:#1a7a3a;border-left:3px solid var(--color-success)}.diff-removed{background:#ff3b3014;color:#a8301f;border-left:3px solid var(--color-danger)}.diff-modified{background:#ff9f0a1a;color:#8a5e00;border-left:3px solid var(--color-warning)}.line-number{display:inline-block;width:36px;color:var(--text-tertiary);font-size:.75rem;margin-right:8px;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.compare-container{grid-template-columns:1fr}.compare-options{flex-direction:column;gap:8px}.result-summary{grid-template-columns:1fr}}.regex-container{display:flex;gap:18px;min-height:400px}.regex-input-section{flex:1;display:flex;flex-direction:column;gap:14px}.regex-result-section{flex:1;display:flex;flex-direction:column;border:1.5px solid var(--border-strong);border-radius:var(--r-lg);overflow:hidden;background:var(--surface-1)}.regex-input-wrapper{display:flex;align-items:center;gap:5px;margin-top:5px}.regex-delimiter{font-size:18px;font-weight:600;color:var(--text-tertiary)}#regex-pattern{flex:1;padding:8px 12px;border:1.5px solid var(--border-strong);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:.875rem;outline:none;color:var(--text-primary);background:var(--surface-1);transition:border-color var(--t-fast),box-shadow var(--t-fast)}#regex-pattern:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}#regex-flags{width:72px;padding:8px 10px;border:1.5px solid var(--border-strong);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:.875rem;text-align:center;outline:none;color:var(--text-primary);background:var(--surface-1);transition:border-color var(--t-fast)}#regex-flags:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.regex-flags-help{margin-top:6px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.regex-flags-help span{font-size:.775rem;color:var(--text-tertiary)}.flag-btn{padding:3px 8px;border:1px solid var(--border-strong);background:var(--surface-3);border-radius:var(--r-xs);cursor:pointer;font-family:var(--font-mono);font-size:.775rem;color:var(--text-secondary);transition:all var(--t-fast)}.flag-btn:hover{background:var(--surface-1);border-color:var(--accent)}.flag-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}#test-text{width:100%;padding:12px;border:1.5px solid var(--border-strong);border-radius:var(--r-md);font-family:var(--font-mono);font-size:.875rem;resize:vertical;min-height:200px;outline:none;color:var(--text-primary);background:var(--surface-1);transition:border-color var(--t-fast),box-shadow var(--t-fast)}#test-text:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.regex-actions{display:flex;gap:8px;margin-top:auto;flex-wrap:wrap}.regex-info{padding:12px 16px;background:var(--surface-3);border-bottom:1px solid var(--border);display:flex;gap:16px;flex-wrap:wrap}.info-item{display:flex;align-items:center;gap:6px}.info-label{font-weight:500;font-size:.8rem;color:var(--text-secondary)}.status-valid{color:var(--color-success);font-weight:600;font-size:.875rem}.status-invalid{color:var(--color-danger);font-weight:600;font-size:.875rem}.result-tabs{display:flex;background:var(--surface-3);border-bottom:1px solid var(--border)}.tab-btn{flex:1;padding:10px;border:none;background:transparent;cursor:pointer;font-size:.825rem;font-family:var(--font);font-weight:500;color:var(--text-secondary);transition:all var(--t-fast);border-bottom:2px solid transparent}.tab-btn:hover{background:#00000008;color:var(--text-primary)}.tab-btn.active{background:var(--surface-1);border-bottom-color:var(--accent);color:var(--accent);font-weight:600}.tab-content{flex:1;overflow:hidden}.tab-panel{display:none;height:100%;padding:14px;overflow-y:auto}.tab-panel.active{display:block}.matches-display{margin-bottom:16px}.highlighted-text{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px;font-family:var(--font-mono);font-size:.85rem;line-height:1.6;white-space:pre-wrap;word-break:break-all;min-height:100px;max-height:180px;overflow-y:auto}.regex-match{background:#ffcc004d;border:1px solid rgba(255,204,0,.5);border-radius:3px;padding:1px 3px}.matches-container,.groups-container{max-height:240px;overflow-y:auto}.match-item{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;margin-bottom:6px;font-family:var(--font-mono);font-size:.825rem}.match-index{color:var(--text-secondary);font-weight:600;margin-bottom:4px;font-size:.8rem}.match-text{background:#fc03;padding:3px 6px;border-radius:var(--r-xs);word-break:break-all}.match-position{color:var(--text-tertiary);font-size:.75rem;margin-top:4px}.group-item{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;margin-bottom:6px}.group-header{font-weight:600;color:var(--text-primary);margin-bottom:6px;font-size:.85rem}.group-content{font-family:var(--font-mono);font-size:.825rem}.group-text{background:#32ade61f;padding:3px 6px;border-radius:var(--r-xs);word-break:break-all;margin-bottom:3px}.replace-output{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px;font-family:var(--font-mono);font-size:.875rem;line-height:1.6;white-space:pre-wrap;word-break:break-all;min-height:100px;max-height:280px;overflow-y:auto}.placeholder-text{color:var(--text-tertiary);font-style:italic;text-align:center;margin:20px 0;font-size:.875rem}.help-icon{display:inline-block;margin-left:4px;color:var(--text-tertiary);font-size:.825rem;cursor:help;transition:color var(--t-fast)}.help-icon:hover{color:var(--accent)}@media (max-width: 768px){.regex-container{flex-direction:column}.regex-result-section{min-height:380px}.regex-info{flex-direction:column;gap:8px}.regex-flags-help{justify-content:center}}.json-compare-container{display:flex;flex-direction:column;gap:16px}.json-input-section{background:var(--surface-3);padding:18px;border-radius:var(--r-lg);border:1px solid var(--border)}.json-inputs{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.json-input-group{display:flex;flex-direction:column}.json-input-group label{font-weight:600;font-size:.875rem;margin-bottom:6px;color:var(--text-primary);letter-spacing:-.01em}.json-input-group textarea{width:100%;padding:12px;border:1.5px solid var(--border-strong);border-radius:var(--r-md);font-family:var(--font-mono);font-size:.85rem;resize:vertical;background:var(--surface-1);color:var(--text-primary);transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}.json-input-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.json-actions{display:flex;gap:8px;margin-top:8px}.compare-actions{display:flex;justify-content:center;gap:12px;padding-top:14px;border-top:1px solid var(--divider)}.json-result-section{background:var(--surface-3);padding:18px;border-radius:var(--r-lg);border:1px solid var(--border)}.json-status{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;margin-bottom:18px;padding:14px;background:var(--surface-1);border-radius:var(--r-md);border:1px solid var(--border)}.status-item{display:flex;justify-content:space-between;align-items:center}.status-label{font-weight:500;font-size:.875rem;color:var(--text-secondary)}.differences-container,.structure-container,.summary-container{min-height:180px;padding:14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1)}.differences-display h4,.structure-display h4,.summary-display h4{margin-bottom:14px;color:var(--text-primary);font-weight:700;font-size:.9rem;letter-spacing:-.02em;border-bottom:2px solid var(--accent-light);padding-bottom:8px}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.summary-stats .stat-item{display:flex;flex-direction:column;align-items:center;padding:14px;background:var(--surface-3);border-radius:var(--r-md);border:1px solid var(--border)}.summary-stats .stat-label{font-size:.8rem;color:var(--text-secondary);margin-bottom:4px}.summary-stats .stat-item span:last-child{font-size:1.6rem;font-weight:700;color:var(--accent);letter-spacing:-.03em}.difference-item{padding:10px 12px;margin-bottom:8px;border-left:3px solid var(--color-danger);background:#ff3b300d;border-radius:0 var(--r-sm) var(--r-sm) 0}.difference-added{border-left-color:var(--color-success);background:#34c7590f}.difference-modified{border-left-color:var(--color-warning);background:#ff9f0a0f}.difference-removed{border-left-color:var(--color-danger);background:#ff3b300d}.json-path{font-family:var(--font-mono);font-weight:600;font-size:.875rem;color:var(--text-primary)}.json-value{font-family:var(--font-mono);font-size:.85rem;padding:1px 6px;background:#0000000a;border-radius:var(--r-xs);margin:0 3px}@media (max-width: 768px){.json-inputs,.json-status{grid-template-columns:1fr}.summary-stats{grid-template-columns:repeat(2,1fr)}.compare-actions{flex-direction:column;align-items:center}}.time-convert-section,.date-calc-section,.date-diff-section{background:var(--surface-3);padding:18px;border-radius:var(--r-lg);margin-top:12px;border:1px solid var(--border)}.convert-row,.calc-row,.diff-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.convert-row input,.convert-row select,.calc-row input,.calc-row select,.diff-row input{flex:1;min-width:120px;padding:9px 12px;border:1.5px solid var(--border-strong);border-radius:var(--r-md);font-family:var(--font);font-size:.875rem;color:var(--text-primary);background:var(--surface-1);outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast);-webkit-appearance:none}.convert-row input:focus,.convert-row select:focus,.calc-row input:focus,.calc-row select:focus,.diff-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.convert-arrow{font-size:1rem;font-weight:700;color:var(--accent);margin:0 4px}.time-table{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 16px;margin-top:10px}.table-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--divider)}.table-row:last-child{border-bottom:none}.table-row span{color:var(--text-secondary);font-size:.875rem}.table-row span:last-child{font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.special-dates{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.calc-btn{padding:8px 16px;background:#32ade61f;color:var(--color-info);border:1px solid rgba(50,173,230,.25);border-radius:var(--r-md);cursor:pointer;font-size:.85rem;font-family:var(--font);font-weight:600;transition:all var(--t-fast)}.calc-btn:hover{background:#32ade633}@media (max-width: 768px){.convert-row,.calc-row,.diff-row{flex-direction:column;align-items:stretch}.convert-row input,.convert-row select,.calc-row input,.calc-row select,.diff-row input{width:100%;margin-bottom:8px}.convert-arrow{text-align:center;margin:4px 0}.table-row{flex-direction:column;gap:3px}.special-dates{flex-direction:column}.calc-btn{width:100%}}.log-preview{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-lg);margin-top:14px;overflow:hidden}.log-preview h3{margin:0;padding:12px 16px;background:var(--surface-3);border-bottom:1px solid var(--border);color:var(--text-primary);font-size:.9rem;font-weight:600;letter-spacing:-.01em}.preview-content{padding:14px;max-height:280px;overflow-y:auto;font-family:var(--font-mono);font-size:.8rem;line-height:1.5;background:var(--surface-1);color:var(--text-primary)}.file-info{margin-top:10px;padding:10px 14px;background:#32ade614;border:1px solid rgba(50,173,230,.2);border-radius:var(--r-md);font-size:.85rem;color:var(--color-info)}.stats-overview{background:var(--surface-3);padding:18px;border-radius:var(--r-lg);margin-bottom:18px;border:1px solid var(--border)}.analysis-charts{background:var(--surface-1);padding:18px;border-radius:var(--r-lg);border:1px solid var(--border)}.chart-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:14px}.chart-item{background:var(--surface-3);padding:14px;border-radius:var(--r-md);border:1px solid var(--border)}.chart-item h4{margin:0 0 12px;color:var(--text-primary);font-size:.875rem;font-weight:600;letter-spacing:-.01em}.chart-display{background:var(--surface-1);padding:12px;border-radius:var(--r-sm);min-height:140px;border:1px solid var(--border);font-family:var(--font-mono);font-size:.775rem;color:var(--text-primary)}.filter-options,.search-options{background:var(--surface-3);padding:18px;border-radius:var(--r-lg);margin-bottom:16px;border:1px solid var(--border)}.filter-row,.search-row{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.filter-group,.search-group{display:flex;align-items:center;gap:8px;flex:1;min-width:190px}.checkbox-group{display:flex;gap:14px;flex-wrap:wrap}.checkbox-group label,.search-options-group label{display:flex;align-items:center;gap:5px;font-weight:400;font-size:.875rem;margin:0;color:var(--text-secondary);cursor:pointer}.checkbox-group input[type=checkbox],.search-options-group input[type=checkbox]{accent-color:var(--accent)}.search-options-group{display:flex;gap:18px;flex-wrap:wrap}.filter-actions,.search-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.filtered-results,.search-results{background:var(--surface-1);padding:18px;border-radius:var(--r-lg);border:1px solid var(--border);margin-bottom:16px}.search-summary{background:var(--surface-3);padding:18px;border-radius:var(--r-lg);border:1px solid var(--border)}.log-line{padding:4px 10px;margin:2px 0;border-radius:var(--r-xs);font-family:var(--font-mono);font-size:.8rem;line-height:1.5;word-break:break-all}.log-error{background:#ff3b3012;border-left:3px solid var(--color-danger);color:#a8301f}.log-warning{background:#ff9f0a14;border-left:3px solid var(--color-warning);color:#8a5e00}.log-info{background:#34c75912;border-left:3px solid var(--color-success);color:#1a7a3a}.log-debug{background:#32ade612;border-left:3px solid var(--color-info);color:#1a6699}.log-normal{background:var(--surface-3);border-left:3px solid var(--border-strong);color:var(--text-secondary)}.highlight-match{background:#ffdc0066;padding:1px 3px;border-radius:2px;font-weight:700}.log-timestamp{color:var(--text-tertiary);font-weight:500}.log-level{font-weight:700;padding:1px 6px;border-radius:var(--r-xs);font-size:.7rem;text-transform:uppercase;letter-spacing:.04em}.level-error{background:var(--color-danger);color:#fff}.level-warning{background:var(--color-warning);color:#fff}.level-info{background:var(--color-success);color:#fff}.level-debug{background:var(--color-info);color:#fff}.chart-bar{display:flex;align-items:center;margin-bottom:7px}.chart-label{width:72px;font-size:.775rem;color:var(--text-secondary);flex-shrink:0}.chart-bar-fill{height:18px;background:linear-gradient(90deg,var(--accent),#764ba2);border-radius:var(--r-xs);margin-right:8px;min-width:2px}.chart-value{font-size:.775rem;color:var(--text-secondary);font-weight:600}@media (max-width: 768px){.chart-container{grid-template-columns:1fr}.filter-row,.search-row{flex-direction:column;align-items:stretch}.filter-group,.search-group{min-width:auto;width:100%}.checkbox-group,.search-options-group{flex-direction:column;gap:8px}.filter-actions,.search-actions{flex-direction:column}.filter-actions button,.search-actions button{width:100%}}.image-upload-section{margin-bottom:24px}.upload-area{border:2px dashed var(--border-strong);border-radius:var(--r-xl);padding:40px 24px;text-align:center;background:var(--surface-3);transition:all var(--t-base);cursor:pointer}.upload-area:hover{border-color:var(--accent);background:var(--accent-light)}.upload-area.dragover{border-color:var(--accent);background:var(--accent-light);transform:scale(1.01)}.upload-content{pointer-events:none}.upload-icon{font-size:2.8rem;margin-bottom:12px}.upload-area p{margin:8px 0;color:var(--text-secondary);font-size:.9rem}.upload-hint{font-size:.825rem;color:var(--text-tertiary)}.upload-btn{background:var(--accent);color:#fff;border:none;padding:9px 20px;border-radius:var(--r-md);cursor:pointer;margin-top:14px;pointer-events:all;font-family:var(--font);font-weight:600;font-size:.875rem;transition:all var(--t-fast)}.upload-btn:hover{background:var(--accent-hover)}.size-target-controls{display:flex;align-items:center;gap:10px;margin-top:6px}.size-target-controls input[type=number]{width:90px;padding:6px 10px;border:1.5px solid var(--border-strong);border-radius:var(--r-sm);font-family:var(--font);font-size:.875rem;color:var(--text-primary);background:var(--surface-1);outline:none}.size-target-controls select{padding:6px 10px;border:1.5px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface-1);font-family:var(--font);font-size:.875rem;color:var(--text-primary);outline:none;-webkit-appearance:none}.auto-compress-btn{background:#34c7591a;color:var(--color-success);border:1px solid rgba(52,199,89,.3);padding:6px 12px;border-radius:var(--r-sm);cursor:pointer;font-size:.825rem;font-family:var(--font);font-weight:600;white-space:nowrap;transition:all var(--t-fast)}.auto-compress-btn:hover{background:#34c7592e}.compression-progress{margin:10px 0;padding:12px 14px;background:#32ade60f;border-radius:var(--r-md);border-left:3px solid var(--color-info)}.progress-bar{width:100%;height:6px;background:var(--surface-3);border-radius:var(--r-pill);overflow:hidden;margin:6px 0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#764ba2);transition:width .3s var(--ease);border-radius:var(--r-pill)}.compression-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;margin:10px 0;padding:12px;background:var(--surface-3);border-radius:var(--r-md);border:1px solid var(--border)}.compression-stats .stat-item{text-align:center;display:block;padding:8px;background:var(--surface-1);border-radius:var(--r-sm);border:1px solid var(--border)}.compression-stats .stat-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:2px}.compression-stats .stat-value{display:block;font-size:.875rem;font-weight:700;color:var(--text-primary)}.image-preview-section{background:var(--surface-3);border-radius:var(--r-xl);padding:20px;border:1px solid var(--border)}.preview-container{display:grid;grid-template-columns:1fr 280px 1fr;gap:18px;align-items:start}.original-image,.converted-image{text-align:center}.original-image h3,.converted-image h3{margin-bottom:12px;color:var(--text-primary);font-size:.9rem;font-weight:600}.image-info{border:1px solid var(--border);border-radius:var(--r-md);padding:14px;background:var(--surface-1)}.image-info canvas{max-width:100%;max-height:180px;border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:10px}.image-details{text-align:left;font-size:.85rem}.image-details p{margin:4px 0;color:var(--text-secondary)}.image-details span{font-weight:600;color:var(--text-primary)}.conversion-controls{background:var(--surface-3);border-radius:var(--r-lg);padding:18px;border:1px solid var(--border)}.conversion-controls h3{margin-bottom:18px;text-align:center;color:var(--text-primary);font-size:.95rem;font-weight:700;letter-spacing:-.02em}.conversion-controls .form-group{margin-bottom:16px}.conversion-controls label{display:block;margin-bottom:6px;font-weight:500;font-size:.85rem;color:var(--text-primary)}.conversion-controls select,.conversion-controls input[type=number]{width:100%;padding:8px 12px;border:1.5px solid var(--border-strong);border-radius:var(--r-md);font-family:var(--font);font-size:.875rem;color:var(--text-primary);background:var(--surface-1);outline:none;-webkit-appearance:none;transition:border-color var(--t-fast),box-shadow var(--t-fast)}.conversion-controls select:focus,.conversion-controls input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.conversion-controls input[type=range]{width:100%;margin:8px 0;accent-color:var(--accent)}#quality-value{font-weight:700;color:var(--accent)}.size-controls{margin-top:10px}.size-inputs{display:flex;align-items:center;gap:10px;margin-top:8px}.size-inputs input[type=number]{width:80px;flex:none}.size-inputs span{font-weight:600;color:var(--text-secondary)}.size-inputs label{display:flex;align-items:center;gap:5px;font-size:.85rem;margin:0;color:var(--text-secondary)}.download-btn{background:#34c7591a;color:var(--color-success);border:1px solid rgba(52,199,89,.3);padding:10px 18px;border-radius:var(--r-md);cursor:pointer;margin-top:14px;width:100%;font-family:var(--font);font-weight:600;font-size:.9rem;transition:all var(--t-fast)}.download-btn:hover{background:#34c7592e}@media (max-width: 768px){.preview-container{grid-template-columns:1fr}.conversion-controls{order:-1}}.encoding-section{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}.input-section,.output-section{background:var(--surface-3);border-radius:var(--r-lg);padding:18px;border:1px solid var(--border)}.input-section h3,.output-section h3{margin:0 0 12px;color:var(--text-primary);font-size:.9rem;font-weight:700;letter-spacing:-.02em}.encoding-section textarea{width:100%;min-height:190px;padding:12px;border:1.5px solid var(--border-strong);border-radius:var(--r-md);font-family:var(--font-mono);font-size:.85rem;line-height:1.6;resize:vertical;background:var(--surface-1);color:var(--text-primary);transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}.encoding-section textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.encoding-section textarea[readonly]{background:var(--surface-3);color:var(--text-secondary);cursor:default}.key-section{margin:12px 0;padding:14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md)}.key-section h4{margin:0 0 8px;color:var(--text-primary);font-size:.85rem;font-weight:600;letter-spacing:-.01em}.key-section input,.key-section textarea{width:100%;padding:8px 12px;border:1.5px solid var(--border-strong);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:.85rem;background:var(--surface-1);color:var(--text-primary);transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}.key-section input:focus,.key-section textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-ring)}.key-section input{height:36px}.key-section textarea{min-height:76px;resize:vertical}.encoding-actions,.output-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.encoding-actions button,.output-actions button{padding:8px 16px;border:none;border-radius:var(--r-md);font-size:.85rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--t-fast);min-width:72px;letter-spacing:-.01em}.encoding-actions .generate-btn{background:#34c7591f;color:#1a7a3a;border:1px solid rgba(52,199,89,.3);box-shadow:none}.encoding-actions .generate-btn:hover{background:#34c75933;transform:translateY(-1px)}.encoding-actions .clear-btn{background:#32ade61a;color:var(--color-info);border:1px solid rgba(50,173,230,.25);box-shadow:none}.encoding-actions .clear-btn:hover{background:#32ade62e;transform:translateY(-1px)}.encoding-actions .copy-btn,.output-actions .copy-btn{background:var(--surface-3);color:var(--text-secondary);border:1px solid var(--border-strong);box-shadow:none}.encoding-actions .copy-btn:hover,.output-actions .copy-btn:hover{background:var(--surface-1);color:var(--text-primary);border-color:var(--accent);transform:translateY(-1px)}.output-actions .download-btn{background:#ff9f0a1a;color:#8a5e00;border:1px solid rgba(255,159,10,.3);box-shadow:none;width:auto;margin-top:0;border-radius:var(--r-md)}.output-actions .download-btn:hover{background:#ff9f0a2e;transform:translateY(-1px)}@media (max-width: 768px){.encoding-section{grid-template-columns:1fr;gap:14px}.encoding-actions,.output-actions{justify-content:center}.encoding-actions button,.output-actions button{flex:1;min-width:0}}:root{--accent: #6e5ce7;--accent-hover: #5849cc;--accent-light: rgba(110, 92, 231, .1);--accent-ring: rgba(110, 92, 231, .25);--color-success: #34c759;--color-warning: #ff9f0a;--color-danger: #ff3b30;--color-info: #32ade6;--bg: #f2f2f7;--surface-1: rgba(255, 255, 255, .95);--surface-2: rgba(255, 255, 255, .75);--surface-3: #f8f8fb;--text-primary: #1d1d1f;--text-secondary: #1d1d1f;--text-tertiary: #1d1d1f;--border: rgba(0, 0, 0, .07);--border-strong: rgba(0, 0, 0, .12);--divider: rgba(0, 0, 0, .05);--r-xs: 6px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 20px;--r-2xl: 24px;--r-pill: 999px;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 2px 8px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 32px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.06);--shadow-xl: 0 24px 64px rgba(0,0,0,.12), 0 8px 16px rgba(0,0,0,.06);--ease: cubic-bezier(.4, 0, .2, 1);--spring: cubic-bezier(.34, 1.56, .64, 1);--t-fast: .15s var(--ease);--t-base: .2s var(--ease);--t-slow: .3s var(--ease);--font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-mono: "SF Mono", "Fira Code", "Cascadia Code", "Courier New", monospace}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}html,body{width:100%;height:100%}body{font-family:var(--font);background-color:var(--bg);height:100vh;overflow:hidden;color:var(--text-primary);display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}#root{flex:1;display:flex;flex-direction:column;min-height:0;height:100%}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#00000024;border-radius:var(--r-pill);transition:background var(--t-fast)}::-webkit-scrollbar-thumb:hover{background:#00000042}::selection{background:var(--accent-light);color:var(--text-primary)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.copy-success{background:var(--color-success)!important;color:#fff!important}
