*,:before,:after{box-sizing:border-box}body{color:#1e1e2e;-webkit-font-smoothing:antialiased;background:#f5f6f8;margin:0;font-family:Noto Sans Thai,Segoe UI,system-ui,sans-serif;font-size:15px;line-height:1.5}button{cursor:pointer;font-family:inherit}input,textarea{font-family:inherit}:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app{color:#1e1e2e;background:#f5f6f8;flex-direction:column;width:100%;min-height:100vh;font-family:Noto Sans Thai,Segoe UI,sans-serif;display:flex}.app-header{color:#cdd6f4;background:#1e1e2e;align-items:center;padding:12px 24px;display:flex}.app-header h1{letter-spacing:.03em;margin:0;font-size:1.2rem}.app-header .version{vertical-align:middle;background:#45475a;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:.7em}.app-main{flex:1;grid-template-columns:360px 1fr;align-items:start;gap:16px;padding:16px;display:grid}@media (width<=900px){.app-main{grid-template-columns:1fr}}.left-col{flex-direction:column;gap:12px;display:flex}.scan-form{background:#fff;border-radius:8px;flex-direction:column;gap:12px;padding:16px;display:flex;box-shadow:0 1px 4px #00000014}.form-row{flex-direction:column;gap:4px;display:flex}.form-row label{color:#6c6c8a;text-transform:uppercase;letter-spacing:.04em;flex-direction:column;gap:4px;font-size:.82rem;font-weight:600;display:flex}.form-row input[type=file],.form-row input[type=password],.form-row input[type=date],.form-row textarea{color:#1e1e2e;background:#f9fafc;border:1px solid #cdd6f4;border-radius:6px;padding:7px 10px;font-size:.92rem;transition:border-color .2s}.form-row input:focus,.form-row textarea:focus{border-color:#89b4fa;outline:none}.form-row.two-col{flex-direction:row;gap:10px}.form-row.two-col label{flex:1;min-width:0}.form-row.two-col input{box-sizing:border-box;width:100%}.form-row textarea{resize:vertical;min-height:90px}.filename-hint{color:#89b4fa;font-size:.78rem;font-weight:400}.scan-form button[type=submit]{color:#1e1e2e;cursor:pointer;background:#89b4fa;border:none;border-radius:6px;align-self:flex-end;padding:8px 22px;font-size:.95rem;font-weight:600;transition:background .2s}.scan-form button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.scan-form button[type=submit]:hover:not(:disabled){background:#74c7ec}.error-box{color:#1e1e2e;background:#f38ba8;border-radius:6px;margin-bottom:10px;padding:10px 14px;font-weight:600}.loading-overlay{text-align:center;color:#89b4fa;padding:32px;font-size:1.1rem}.results-panel{flex-direction:column;gap:10px;display:flex}.results-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.badge{color:#cdd6f4;background:#313244;border-radius:4px;padding:2px 8px;font-size:.78rem;font-weight:600}.badge.mode{background:#45475a}.badge.file{color:#a6e3a1;background:#1e1e2e;font-family:monospace}.tx-count{color:#6c6c8a;margin-left:auto;font-size:.82rem}.unmatched-box{background:#fff3cd;border:1px solid #f9e08a;border-radius:6px;padding:10px 14px;font-size:.85rem}.unmatched-box ul{margin:6px 0 0;padding-left:18px}.unmatched-box li{color:#e64553;font-weight:600}.empty{color:#6c6c8a;text-align:center;padding:24px 0;font-style:italic}.table-wrap{overflow-x:auto}.tx-table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;font-size:.85rem;overflow:hidden;box-shadow:0 1px 4px #0000000f}.tx-table th{color:#cdd6f4;text-align:left;text-transform:uppercase;letter-spacing:.05em;background:#1e1e2e;padding:9px 12px;font-size:.75rem}.tx-table td{border-bottom:1px solid #eff1f5;padding:7px 12px}.tx-row{cursor:pointer;transition:background .15s}.tx-row:hover{background:#f0f4ff}.tx-row.ok{background:#80ffaf}.tx-row.ok:hover{background:#5fffa1}.tx-row.miss{background:#fff4f4}.tx-row.miss:hover{background:#ffe5e5}.tx-row.dir-out:not(.ok):not(.miss){background:#fff8f0}.tx-row.dir-out:not(.ok):not(.miss):hover{background:#fed}.tx-row.dir-in:not(.ok):not(.miss){background:#f0fff4}.tx-row.dir-in:not(.ok):not(.miss):hover{background:#dcfce7}.amount{font-family:monospace;font-weight:700}.amount.ok{color:#40a02b}.amount.miss{color:#d20f39}.amount.dir-out{color:#e64553}.amount.dir-in{color:#179299}.td-dir{width:40px;padding-right:4px!important}.dir-badge{letter-spacing:.04em;border-radius:3px;padding:1px 5px;font-size:.65rem;font-weight:700;display:inline-block}.dir-badge.out{color:#c0392b;background:#fce5e5}.dir-badge.in{color:#1a7a50;background:#e0f5ea}.dir-filter{gap:4px;margin-left:auto;display:flex}.dir-filter-btn{color:#4c4f69;cursor:pointer;background:#f5f6f8;border:1px solid #cdd0e0;border-radius:4px;padding:3px 10px;font-size:.78rem}.dir-filter-btn:hover{background:#e0e2f0}.dir-filter-btn.active{color:#cdd6f4;background:#1e1e2e;border-color:#1e1e2e}.td-copy{color:#40a02b;width:18px;font-size:.75rem}.td-date,.td-time{white-space:nowrap;color:#6c6c8a}.td-desc{max-width:360px}.group-manager{background:#fff;border-radius:8px;box-shadow:0 1px 4px #00000014}.toggle-btn{color:#1e1e2e;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;width:100%;padding:11px 16px;font-size:.88rem;font-weight:600}.toggle-btn:hover{background:#f0f4ff}.group-panel{flex-direction:column;gap:8px;padding:0 12px 12px;display:flex}.group-list{flex-wrap:wrap;gap:6px;display:flex}.group-item{border:1px solid #cdd6f4;border-radius:6px;align-items:center;display:flex;overflow:hidden}.group-item.active{background:#eff3ff;border-color:#89b4fa}.group-label{cursor:pointer;padding:4px 10px;font-size:.85rem;font-weight:600}.new-group-row{gap:6px;display:flex}.new-group-row input{border:1px solid #cdd6f4;border-radius:6px;flex:1;padding:6px 10px;font-size:.88rem}.new-group-row button{cursor:pointer;background:#89b4fa;border:none;border-radius:6px;padding:6px 14px;font-size:.88rem;font-weight:600}.group-editor{border-top:1px solid #eff1f5;padding-top:10px}.group-editor-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.item-list{flex-direction:column;gap:4px;max-height:240px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.item-list li{align-items:center;gap:4px;display:flex}.item-list input{border:1px solid #cdd6f4;border-radius:5px;flex:1;padding:5px 8px;font-size:.83rem}.group-editor-actions{justify-content:space-between;margin-top:8px;display:flex}.btn-ghost{cursor:pointer;color:#6c6c8a;background:0 0;border:none;border-radius:4px;padding:3px 7px;font-size:.82rem}.btn-ghost:hover{background:#eff1f5}.btn-ghost.remove{color:#d20f39}.btn-ghost.add{color:#40a02b;font-weight:600}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.debug-panel{border:1px dashed #45475a;border-radius:8px;margin-top:12px;font-size:.82rem;overflow:hidden}.debug-toggle{color:#7f849c;text-align:left;cursor:pointer;letter-spacing:.02em;background:#1e1e2e;border:none;width:100%;padding:8px 12px;font-size:.82rem}.debug-toggle:hover{color:#cdd6f4}.debug-body{color:#cdd6f4;background:#181825;padding:12px}.debug-form{flex-wrap:wrap;align-items:flex-end;gap:8px;margin-bottom:10px;display:flex}.debug-form label{color:#a6adc8;flex-direction:column;gap:3px;font-size:.78rem;display:flex}.debug-form input{color:#cdd6f4;background:#313244;border:1px solid #45475a;border-radius:4px;width:auto;padding:4px 7px;font-size:.82rem}.debug-form input[type=number]{width:60px}.debug-form button{color:#cdd6f4;cursor:pointer;background:#45475a;border:none;border-radius:4px;align-self:flex-end;padding:5px 14px}.debug-form button:disabled{opacity:.5;cursor:not-allowed}.debug-meta{align-items:center;gap:8px;margin-bottom:8px;display:flex}.copy-btn{color:#89b4fa;cursor:pointer;background:#313244;border:1px solid #45475a;border-radius:4px;margin-left:auto;padding:3px 10px;font-size:.78rem}.copy-btn:hover{background:#45475a}.debug-page{margin-bottom:6px}.debug-page-toggle{color:#89b4fa;cursor:pointer;background:0 0;border:none;padding:3px 0;font-size:.82rem}.debug-page-toggle:hover{color:#cdd6f4}.row-count{color:#6c7086;font-size:.78rem}.debug-table{border-collapse:collapse;width:100%;margin-top:4px;font-size:.76rem}.debug-table th{color:#a6adc8;text-align:left;background:#313244;border-bottom:1px solid #45475a;padding:4px 6px}.debug-table td{vertical-align:top;border-bottom:1px solid #1e1e2e;padding:3px 6px}.debug-table tr:hover td{background:#313244}.td-y{color:#6c7086;width:55px;font-family:monospace}.td-row-text{color:#cdd6f4}.td-spans{flex-wrap:wrap;gap:4px;display:flex}.span-chip{white-space:nowrap;background:#313244;border:1px solid #45475a;border-radius:3px;padding:1px 5px}.span-chip em{color:#f38ba8;margin-left:3px;font-size:.72rem;font-style:normal}
