*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: #eef2ff;--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--text: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--bg: #f8fafc;--bg-white: #ffffff;--sidebar-width: 240px;--navbar-height: 56px;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-text-size-adjust:100%}.app-layout{display:flex;min-height:100vh}.navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-height);background:var(--bg-white);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;z-index:100;box-shadow:var(--shadow);gap:8px}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;margin:-8px 0 -8px -8px;border-radius:6px;color:var(--text);flex-shrink:0;-webkit-tap-highlight-color:transparent}.menu-toggle svg{width:22px;height:22px;display:block}.menu-toggle:active{background:var(--primary-light)}.navbar-logo{font-size:18px;font-weight:700;color:var(--primary);text-decoration:none;display:flex;align-items:center;gap:8px;flex-shrink:0}.navbar-logo svg{width:28px;height:28px;flex-shrink:0}.navbar-version{font-size:11px;font-weight:500;color:var(--text-secondary);background:var(--bg);padding:1px 6px;border-radius:4px;border:1px solid var(--border);line-height:1.4}.navbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}.navbar-link{color:var(--text-secondary);text-decoration:none;font-size:14px;padding:6px 12px;border-radius:var(--radius);transition:all .2s}.navbar-link:hover{color:var(--primary);background:var(--primary-light)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:85;-webkit-tap-highlight-color:transparent}.sidebar{position:fixed;top:var(--navbar-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-white);border-right:1px solid var(--border);overflow-y:auto;padding:12px 0;z-index:90;-webkit-overflow-scrolling:touch}.sidebar-group{margin-bottom:4px}.sidebar-group-title{padding:8px 20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.sidebar-item{display:block;padding:7px 20px 7px 32px;color:var(--text);text-decoration:none;font-size:14px;transition:all .15s;border-left:3px solid transparent}.sidebar-item:hover{background:var(--primary-light);color:var(--primary)}.sidebar-item.active{background:var(--primary-light);color:var(--primary);font-weight:600;border-left-color:var(--primary)}.main-content{margin-left:var(--sidebar-width);margin-top:var(--navbar-height);padding:24px;flex:1;min-width:0}.tool-page{max-width:1000px;margin:0 auto}.tool-header{margin-bottom:20px}.tool-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}.tool-desc{font-size:14px;color:var(--text-secondary)}.card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:var(--shadow)}.card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:12px}.form-row{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px}.form-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.form-select,.form-input{padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;color:var(--text);background:var(--bg-white);outline:none;transition:border-color .2s;min-height:40px}.form-select:focus,.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-textarea{width:100%;min-height:120px;padding:12px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;color:var(--text);background:var(--bg-white);outline:none;resize:vertical;transition:border-color .2s;line-height:1.5}.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-textarea.output{background:#f1f5f9;min-height:100px}.btn-row{display:flex;gap:8px;margin:16px 0;flex-wrap:wrap}.btn{padding:8px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-outline:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-sm{padding:4px 12px;font-size:12px}.result-area{position:relative}.copy-btn{position:absolute;top:8px;right:8px;padding:4px 10px;font-size:12px;background:var(--primary);color:#fff;border:none;border-radius:4px;cursor:pointer;opacity:.8;transition:opacity .2s;-webkit-tap-highlight-color:transparent}.copy-btn:hover{opacity:1}.error-msg{color:var(--danger);font-size:13px;padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-top:8px}.success-msg{color:var(--success);font-size:13px;padding:8px 12px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;margin-top:8px}.loading{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px}.spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.key-textarea{width:100%;min-height:80px;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:12px;font-family:SF Mono,Fira Code,monospace;color:var(--text);resize:vertical;outline:none}.key-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.hint-text{font-size:11px;font-weight:400;color:var(--text-secondary)}.adjust-msg{display:block;font-size:12px;color:var(--warning);background:#fffbeb;border:1px solid #fde68a;border-radius:4px;padding:4px 8px;margin-top:4px;line-height:1.4}.verify-valid{color:var(--success);font-weight:600}.verify-invalid{color:var(--danger);font-weight:600}@media (max-width: 1024px){:root{--sidebar-width: 210px}.main-content{padding:20px}.tool-page{max-width:100%}}@media (max-width: 768px){:root{--navbar-height: 52px}.menu-toggle{display:flex;align-items:center;justify-content:center}.sidebar-overlay{display:block}.sidebar{width:260px;transform:translate(-100%);transition:transform .25s ease;box-shadow:none}.sidebar.sidebar-open{transform:translate(0);box-shadow:4px 0 16px #00000026}.sidebar-item{padding:10px 20px 10px 32px;font-size:15px}.sidebar-group-title{padding:10px 20px 6px;font-size:11px}.main-content{margin-left:0;padding:16px}.tool-title{font-size:20px}.tool-desc{font-size:13px}.card{padding:16px;margin-bottom:12px}.form-row{flex-direction:column;gap:10px}.form-group{min-width:0}.form-select,.form-input{min-height:44px;font-size:16px}.form-textarea{min-height:100px;font-size:14px}.btn{padding:10px 18px;font-size:14px;min-height:44px}.btn-row{gap:8px;margin:12px 0}.copy-btn{padding:6px 12px;font-size:12px}.key-textarea{min-height:70px;font-size:12px}.navbar{padding:0 12px}.navbar-logo{font-size:16px;gap:6px}.navbar-logo svg{width:24px;height:24px}}@media (max-width: 480px){.main-content{padding:12px}.tool-header{margin-bottom:14px}.tool-title{font-size:18px}.card{padding:14px;border-radius:6px}.card-title{font-size:13px;margin-bottom:10px}.form-textarea{min-height:80px}.btn-row{gap:6px}.btn{padding:10px 14px;font-size:13px;flex:1 1 auto;justify-content:center;min-width:0}.navbar-logo-text{display:none}.navbar-link{padding:6px 8px;font-size:13px}.error-msg,.success-msg{font-size:12px;padding:8px 10px}.sidebar{width:240px}}@media (max-width: 768px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}table th,table td{white-space:nowrap;font-size:13px}}@media (max-width: 480px){canvas{max-width:100%;height:auto!important}}
