@import url(https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&family=Sora:wght@300;400;500;600;700&display=swap);.navbar{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#0f0f13bf;border-bottom:1px solid #0000;left:0;padding:0 16px;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}@media (min-width:768px){.navbar{padding:0 24px}}[data-theme=light] .navbar{background:#f4f4f8d9}.navbar.scrolled{background:#0f0f13f7;border-bottom-color:var(--border)}[data-theme=light] .navbar.scrolled{background:#f4f4f8f7}.nav-inner{align-items:center;display:flex;height:60px;justify-content:space-between;margin:0 auto;max-width:1200px}@media (min-width:768px){.nav-inner{height:64px}}.nav-logo{align-items:center;color:var(--text);display:flex;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:1.15rem;font-weight:700;gap:8px;text-decoration:none}@media (min-width:480px){.nav-logo{font-size:1.3rem;gap:10px}}.logo-icon{font-size:1.2rem}@media (min-width:480px){.logo-icon{font-size:1.5rem}}.accent{color:var(--accent)}.nav-right{align-items:center;display:flex;gap:6px}.nav-links{align-items:center;display:none;gap:2px;list-style:none}@media (min-width:860px){.nav-links{display:flex}}.nav-links a{border:1px solid #0000;border-radius:6px;color:var(--muted);font-size:.82rem;font-weight:500;padding:7px 12px;text-decoration:none;transition:all .2s;white-space:nowrap}@media (min-width:1024px){.nav-links a{font-size:.875rem;padding:8px 14px}}.nav-links a:hover{background:var(--surface2);color:var(--text);text-decoration:none}.nav-links a.active{background:#00e5a012;border-color:var(--accent);color:var(--accent)}[data-theme=light] .nav-links a.active{background:#00a8701a}.theme-toggle{align-items:center;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--muted);cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .2s;width:36px}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.hamburger{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:6px}@media (min-width:860px){.hamburger{display:none}}.hamburger span{background:var(--text);border-radius:2px;display:block;height:2px;transition:all .3s;width:22px}.hamburger span.open:first-child{transform:translateY(7px) rotate(45deg)}.hamburger span.open:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger span.open:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{background:var(--surface);border-top:1px solid var(--border);bottom:0;display:flex;flex-direction:column;gap:4px;left:0;overflow-y:auto;padding:12px 16px 24px;position:fixed;right:0;top:60px;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:999}@media (min-width:860px){.mobile-menu{display:none!important}}.mobile-menu.open{transform:translateX(0)}.mobile-menu a{align-items:center;border:1px solid #0000;border-radius:10px;color:var(--muted);display:flex;font-size:1rem;font-weight:500;gap:10px;padding:14px 16px;text-decoration:none;transition:all .2s}.mobile-menu a:hover{background:var(--surface2);color:var(--text);text-decoration:none}.mobile-menu a.active{background:#00e5a00f;border-color:#00e5a04d;color:var(--accent)}[data-theme=light] .mobile-menu a.active{background:#00a87014}.mobile-menu-icon{font-size:1.1rem;text-align:center;width:24px}.mobile-divider{background:var(--border);height:1px;margin:8px 0}.footer{background:var(--surface);border-top:1px solid var(--border);margin-top:60px;padding:40px 16px 0;transition:background .3s,border-color .3s}@media (min-width:480px){.footer{padding:48px 20px 0}}@media (min-width:768px){.footer{margin-top:80px;padding:60px 24px 0}}.footer-inner{grid-gap:28px;display:grid;gap:28px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;padding-bottom:36px}@media (min-width:600px){.footer-inner{gap:32px}}@media (min-width:768px){.footer-inner{gap:40px;grid-template-columns:2fr 1fr 1fr;padding-bottom:48px}}@media (min-width:1024px){.footer-inner{gap:48px}}.footer-brand{grid-column:1/-1}@media (min-width:768px){.footer-brand{grid-column:auto}}.footer-logo{color:var(--text);display:block;font-family:JetBrains Mono,monospace;font-size:1.2rem;font-weight:700;margin-bottom:10px;text-decoration:none}@media (min-width:768px){.footer-logo{font-size:1.3rem;margin-bottom:12px}}.footer-logo span{color:var(--accent)}.footer-brand p{color:var(--muted);font-size:.82rem;line-height:1.7;max-width:320px}@media (min-width:768px){.footer-brand p{font-size:.875rem}}.footer-links h4{color:var(--text);font-size:.75rem;letter-spacing:.08em;margin-bottom:12px;text-transform:uppercase}@media (min-width:768px){.footer-links h4{margin-bottom:16px}}.footer-links ul{display:flex;flex-direction:column;gap:8px;list-style:none}@media (min-width:768px){.footer-links ul{gap:10px}}.footer-links a{color:var(--muted);display:inline-block;font-size:.82rem;text-decoration:none;transition:color .2s}@media (min-width:768px){.footer-links a{font-size:.875rem}}.footer-links a:hover{color:var(--accent);text-decoration:none}.footer-bottom{border-top:1px solid var(--border);color:var(--muted);display:flex;flex-direction:column;font-size:.78rem;gap:8px;margin:0 auto;max-width:1200px;padding:16px 0}@media (min-width:480px){.footer-bottom{align-items:center;flex-direction:row;font-size:.8rem;justify-content:space-between;padding:20px 0}}.footer-bottom a{color:var(--muted);text-decoration:none}.footer-bottom a:hover{color:var(--accent)}.tester-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);margin-bottom:32px;padding:16px}@media (min-width:768px){.tester-wrap{border-radius:16px;margin-bottom:48px;padding:24px}}@media (min-width:1024px){.tester-wrap{padding:28px}}.tester-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px}.tester-stats{display:flex;flex-wrap:wrap;gap:16px}@media (min-width:480px){.tester-stats{gap:24px}}@media (min-width:768px){.tester-stats{gap:32px}}.stat{display:flex;flex-direction:column}.stat-val{color:var(--text);font-family:JetBrains Mono,monospace;font-size:1.3rem;font-weight:700}@media (min-width:480px){.stat-val{font-size:1.5rem}}@media (min-width:768px){.stat-val{font-size:1.6rem}}.stat-val.accent{color:var(--accent)}.stat-label{color:var(--muted);font-size:.68rem;letter-spacing:.07em;text-transform:uppercase}.progress-bar{background:var(--border);border-radius:2px;height:3px;margin-bottom:16px;overflow:hidden}@media (min-width:768px){.progress-bar{height:4px;margin-bottom:20px}}.progress-fill{background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;height:100%;transition:width .3s ease}.os-tabs{display:flex;gap:6px;margin-bottom:16px}@media (min-width:768px){.os-tabs{gap:8px;margin-bottom:20px}}.os-btn{align-items:center;background:#0000;border:1px solid var(--border);border-radius:6px;color:var(--muted);cursor:pointer;display:flex;font-family:Sora,sans-serif;font-size:.78rem;gap:6px;padding:7px 12px;transition:all .2s}@media (min-width:768px){.os-btn{font-size:.82rem;padding:8px 18px}}.os-btn.active{background:#00e5a012;border-color:var(--accent);color:var(--accent)}[data-theme=light] .os-btn.active{background:#00a8701a}.os-btn:hover:not(.active){color:var(--text)}.keyboard-scroll-wrap{-webkit-overflow-scrolling:touch;border-radius:12px;margin:0 -4px;overflow-x:auto;padding:0 4px}.keyboard-scroll-hint{align-items:center;animation:pulse 2s ease-in-out infinite;color:var(--muted);display:flex;font-size:.72rem;gap:6px;margin-bottom:8px}@media (min-width:960px){.keyboard-scroll-hint{display:none}}.keyboard-container{background:var(--bg);border:1px solid var(--border);border-radius:10px;display:inline-block;min-width:-webkit-max-content;min-width:max-content;padding:12px 10px}@media (min-width:768px){.keyboard-container{border-radius:12px;padding:16px 14px}}@media (min-width:1024px){.keyboard-container{padding:20px 16px}}.kb-row{align-items:flex-start;display:flex;gap:3px;margin-bottom:3px}@media (min-width:768px){.kb-row{gap:4px;margin-bottom:4px}}.key-spacer{display:inline-block;flex-shrink:0}.key{align-items:center;background:var(--key-bg);border:1px solid var(--key-border);border-bottom:3px solid var(--border);border-radius:5px;cursor:default;display:inline-flex;flex-shrink:0;height:36px;justify-content:center;overflow:hidden;position:relative;transition:background .15s,border-color .15s,transform .08s;-webkit-user-select:none;user-select:none}@media (min-width:768px){.key{border-radius:6px;height:40px}}.key.mac-key{border-radius:4px}@media (min-width:768px){.key.mac-key{border-radius:5px}}.key.tall{height:75px}@media (min-width:768px){.key.tall{height:84px}}.key-label{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:.62rem;font-weight:500;line-height:1.2;padding:0 2px;pointer-events:none;text-align:center;z-index:1}@media (min-width:768px){.key-label{font-size:.68rem;padding:0 3px}}.key.pressed{background:var(--accent);border-color:var(--accent);border-bottom-color:#00e5a066;transform:translateY(2px)}[data-theme=light] .key.pressed{border-bottom-color:#00a87066}.key.pressed .key-label{color:#0f0f13;font-weight:700}.key.tested{background:var(--key-tested);border-color:#00e5a04d}[data-theme=light] .key.tested{border-color:#00a87066}.key.tested .key-label{color:var(--accent)}.key-glow{background:radial-gradient(circle,#00e5a04d,#0000 70%);inset:0;pointer-events:none;position:absolute}.tester-legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:16px}@media (min-width:768px){.tester-legend{gap:24px;margin-top:20px}}.legend-item{align-items:center;color:var(--muted);display:flex;font-size:.75rem;gap:7px}.legend-dot{border-radius:3px;display:inline-block;flex-shrink:0;height:11px;width:11px}.pressed-dot{background:var(--accent)}.tested-dot{background:var(--key-tested);border:1px solid #00e5a04d}.idle-dot{background:var(--key-bg);border:1px solid var(--key-border)}.touch-notice{background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:8px;color:var(--accent3);display:none;font-size:.8rem;line-height:1.5;margin-bottom:16px;padding:10px 14px}@media (hover:none) and (pointer:coarse){.touch-notice{display:block}}.home{padding-top:60px}@media (min-width:768px){.home{padding-top:64px}}.hero{margin:0 auto;max-width:800px;padding:48px 16px 40px;text-align:center}@media (min-width:480px){.hero{padding:60px 20px 48px}}@media (min-width:768px){.hero{padding:80px 24px 60px}}.hero-badge{font-size:.7rem;margin-bottom:18px}@media (min-width:768px){.hero-badge{font-size:.75rem;margin-bottom:24px}}.hero h1{color:var(--text);font-size:clamp(1.7rem,6vw,3.5rem);margin-bottom:16px}.hero-sub{color:var(--muted);font-size:clamp(.9rem,2.5vw,1.1rem);margin:0 auto 24px;max-width:540px}.hero-hints{animation:pulse 2s ease-in-out infinite;color:var(--muted);font-size:.85rem}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.guide-cards{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr;margin-bottom:40px}@media (min-width:600px){.guide-cards{gap:16px;grid-template-columns:1fr 1fr}}@media (min-width:900px){.guide-cards{gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:64px}}.guide-card{align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);display:flex;gap:14px;padding:18px}@media (min-width:768px){.guide-card{gap:16px;padding:24px}}.guide-card.green{border-color:#00e5a033}.guide-card.teal{border-color:#00b48233}.guide-card.amber{border-color:#f59e0b33}.guide-key-demo{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:700;height:40px;justify-content:center;min-width:40px}@media (min-width:768px){.guide-key-demo{height:44px;min-width:44px}}.pressed-demo{background:var(--accent);color:#0f0f13}.tested-demo{background:var(--key-tested);border:1px solid #00e5a04d;color:var(--accent)}.fn-demo{background:var(--surface2);border:1px solid var(--border);color:var(--muted);font-size:.55rem}.guide-card strong{color:var(--text);display:block;font-size:.9rem;margin-bottom:5px}.guide-card p{color:var(--muted);font-size:.82rem;line-height:1.6;margin:0}.disclaimer{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent3);border-radius:8px;margin:32px auto;max-width:820px;padding:14px 16px}@media (min-width:768px){.disclaimer{margin:48px auto;padding:16px 20px}}.disclaimer p{color:var(--muted);font-size:.82rem;line-height:1.6;margin:0}.disclaimer strong{color:var(--text)}.about-page{padding-top:60px}@media (min-width:768px){.about-page{padding-top:64px}}.about-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:1fr;padding-bottom:48px}@media (min-width:900px){.about-grid{gap:48px;grid-template-columns:1fr 300px;padding-bottom:80px}}@media (min-width:1100px){.about-grid{grid-template-columns:1fr 320px}}.about-section{margin-bottom:36px}@media (min-width:768px){.about-section{margin-bottom:48px}}.about-section h2{border-bottom:1px solid var(--border);color:var(--text);font-size:clamp(1.1rem,3vw,1.4rem);margin-bottom:14px;padding-bottom:10px}.about-section p{color:var(--muted);font-size:clamp(.875rem,2vw,.95rem);line-height:1.8;margin-bottom:12px}.about-section ul{margin:0 0 14px 18px}.about-section li{color:var(--muted);font-size:clamp(.875rem,2vw,.95rem);line-height:1.7;margin-bottom:9px}.about-section li strong{color:var(--text)}.about-section code{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--accent);font-family:JetBrains Mono,monospace;font-size:.82em;padding:2px 6px;word-break:break-all}.user-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-top:16px}@media (min-width:768px){.user-grid{gap:16px}}.user-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;transition:border-color .2s}@media (min-width:768px){.user-card{padding:20px}}.user-card:hover{border-color:#00e5a04d}.user-icon{display:block;font-size:1.3rem;margin-bottom:7px}@media (min-width:768px){.user-icon{font-size:1.5rem;margin-bottom:8px}}.user-card h4{color:var(--text);font-size:.9rem;margin-bottom:5px}.user-card p{color:var(--muted);font-size:.8rem;line-height:1.6;margin:0}.about-sidebar{display:flex;flex-direction:column;gap:16px}@media (min-width:900px){.about-sidebar{align-self:start;position:-webkit-sticky;position:sticky;top:80px}}.sidebar-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}@media (min-width:768px){.sidebar-card{padding:24px}}.sidebar-card h4{color:var(--text);font-size:.95rem;margin-bottom:14px}.fact-list{display:flex;flex-direction:column;gap:10px;list-style:none}.fact-list li{align-items:center;color:var(--muted);display:flex;font-size:.875rem;gap:10px}.fact-list span{flex-shrink:0;font-size:1rem}.accent-card{background:#00e5a00a;border-color:#00e5a040}.accent-card p{color:var(--muted);font-size:.875rem;line-height:1.6;margin-bottom:14px}.sidebar-btn{background:var(--accent);border-radius:8px;color:#0f0f13;display:inline-block;font-size:.875rem;font-weight:600;padding:10px 20px;text-decoration:none;transition:opacity .2s}.sidebar-btn:hover{opacity:.85;text-decoration:none}@media (max-width:899px){.about-sidebar{order:-1}.sidebar-card:last-child{display:none}}.contact-page{padding-top:60px}@media (min-width:768px){.contact-page{padding-top:64px}}.contact-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr;padding-bottom:48px}@media (min-width:900px){.contact-grid{gap:40px;grid-template-columns:1fr 280px;padding-bottom:80px}}@media (min-width:1100px){.contact-grid{gap:48px;grid-template-columns:1fr 300px}}.contact-form-wrap h2{font-size:clamp(1.1rem,3vw,1.4rem);margin-bottom:20px}@media (min-width:768px){.contact-form-wrap h2{margin-bottom:28px}}.contact-form{display:flex;flex-direction:column;gap:16px}@media (min-width:768px){.contact-form{gap:20px}}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr}@media (min-width:600px){.form-row{gap:20px;grid-template-columns:1fr 1fr}}.field{display:flex;flex-direction:column;gap:6px}.field label{color:var(--text);font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.field input,.field select,.field textarea{background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:Sora,sans-serif;font-size:.9rem;outline:none;padding:11px 14px;resize:vertical;transition:border-color .2s;width:100%}@media (min-width:768px){.field input,.field select,.field textarea{padding:12px 16px}}.field input::placeholder,.field textarea::placeholder{color:var(--muted)}.field select{-webkit-appearance:auto;appearance:auto;cursor:pointer}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}.field.error input,.field.error select,.field.error textarea{border-color:#ef4444}.field-error{color:#ef4444;font-size:.75rem}.char-count{color:var(--muted);font-size:.72rem;margin-top:3px;text-align:right}.submit-btn{align-self:flex-start;background:var(--accent);border:none;border-radius:8px;color:#0f0f13;cursor:pointer;font-family:Sora,sans-serif;font-size:.9rem;font-weight:700;padding:13px 24px;transition:opacity .2s;width:100%}@media (min-width:480px){.submit-btn{padding:14px 28px;width:auto}}.submit-btn:hover{opacity:.85}.contact-sidebar{display:flex;flex-direction:column;gap:12px}@media (min-width:768px){.contact-sidebar{gap:16px}}@media (min-width:900px){.contact-sidebar{align-self:start;position:-webkit-sticky;position:sticky;top:80px}}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}@media (min-width:768px){.info-card{padding:20px}}.info-card h4{color:var(--text);font-size:.88rem;margin-bottom:7px}.info-card p{color:var(--muted);font-size:.8rem;line-height:1.7;margin:0}.accent-info{background:#00e5a00a;border-color:#00e5a040}.success-box{background:var(--surface);border:1px solid #00e5a04d;border-radius:16px;margin:80px auto;max-width:480px;padding:36px 24px;text-align:center}@media (min-width:480px){.success-box{margin:100px auto;padding:48px}}.success-icon{align-items:center;background:var(--accent);border-radius:50%;color:#0f0f13;display:flex;font-size:1.6rem;font-weight:700;height:56px;justify-content:center;margin:0 auto 18px;width:56px}@media (min-width:480px){.success-icon{font-size:1.8rem;height:64px;width:64px}}.success-box h2{font-size:clamp(1.2rem,3vw,1.5rem);margin-bottom:10px}.success-box p{color:var(--muted);font-size:.9rem;margin-bottom:20px}.privacy-page{padding-top:60px}@media (min-width:768px){.privacy-page{padding-top:64px}}.privacy-layout{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr;padding-bottom:48px}@media (min-width:900px){.privacy-layout{gap:48px;grid-template-columns:200px 1fr;padding-bottom:80px}}@media (min-width:1100px){.privacy-layout{grid-template-columns:220px 1fr}}.privacy-toc{background:var(--surface);border:1px solid var(--border);border-radius:12px;display:none;padding:20px;position:-webkit-sticky;position:sticky;top:80px}@media (min-width:900px){.privacy-toc{display:block}}.privacy-toc h4{color:var(--text);font-size:.78rem;letter-spacing:.08em;margin-bottom:14px;text-transform:uppercase}.privacy-toc ul{display:flex;flex-direction:column;gap:3px;list-style:none}.privacy-toc a{border-radius:6px;color:var(--muted);display:block;font-size:.8rem;padding:5px 9px;text-decoration:none;transition:all .2s}.privacy-toc a:hover{background:#00e5a012;color:var(--accent);text-decoration:none}.privacy-toc-mobile{-webkit-overflow-scrolling:touch;display:flex;gap:8px;margin-bottom:8px;overflow-x:auto;padding:0 0 12px;scrollbar-width:none}.privacy-toc-mobile::-webkit-scrollbar{display:none}@media (min-width:900px){.privacy-toc-mobile{display:none}}.privacy-toc-mobile a{border:1px solid var(--border);border-radius:20px;color:var(--muted);display:inline-block;flex-shrink:0;font-size:.75rem;padding:6px 12px;text-decoration:none;transition:all .2s;white-space:nowrap}.privacy-toc-mobile a:hover{border-color:var(--accent);color:var(--accent)}.policy-section{border-bottom:1px solid var(--border);margin-bottom:36px;padding-bottom:36px}@media (min-width:768px){.policy-section{margin-bottom:48px;padding-bottom:48px}}.policy-section:last-child{border-bottom:none}.policy-section h2{color:var(--text);font-size:clamp(1.1rem,3vw,1.35rem);margin-bottom:14px}.policy-section h4{color:var(--text);font-size:.92rem;margin:18px 0 7px}.policy-section p{color:var(--muted);font-size:clamp(.875rem,2vw,.93rem);line-height:1.8;margin-bottom:12px}.policy-section ul{margin:0 0 14px 18px}.policy-section li{color:var(--muted);font-size:clamp(.875rem,2vw,.93rem);line-height:1.7;margin-bottom:8px}.policy-section li strong{color:var(--text)}.policy-section a{color:var(--accent)}.highlight-box{background:#00e5a00f;border:1px solid #00e5a040;border-radius:8px;color:var(--text);font-size:clamp(.85rem,2vw,.9rem);line-height:1.6;padding:14px 16px}@media (min-width:768px){.highlight-box{padding:16px 20px}}.highlight-box strong{color:var(--accent);display:block;margin-bottom:5px}.commitment-list{display:flex;flex-direction:column;gap:12px;margin-top:14px}@media (min-width:768px){.commitment-list{gap:16px}}.commitment-item{align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:10px;display:flex;gap:12px;padding:14px 16px}@media (min-width:768px){.commitment-item{gap:16px;padding:20px}}.c-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:26px;justify-content:center;width:26px}@media (min-width:768px){.c-icon{height:28px;width:28px}}.c-icon.green{background:var(--accent);color:#0f0f13}.commitment-item strong{color:var(--text);display:block;font-size:.88rem;margin-bottom:5px}.commitment-item p{color:var(--muted);font-size:.82rem;line-height:1.6;margin:0}.table-scroll{-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:8px;margin:14px 0;overflow-x:auto}.policy-table{border-collapse:collapse;font-size:.82rem;min-width:420px;width:100%}.policy-table th{background:var(--surface2);color:var(--text);font-weight:600;padding:10px 14px;text-align:left;white-space:nowrap}.policy-table td,.policy-table th{border-bottom:1px solid var(--border)}.policy-table td{color:var(--muted);padding:9px 14px}.policy-table tr:last-child td{border-bottom:none}.policy-table tr:hover td{background:var(--surface2)}.mouse-page{padding-top:60px}@media (min-width:768px){.mouse-page{padding-top:64px}}.mouse-tester-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);margin-bottom:16px;padding:16px}@media (min-width:768px){.mouse-tester-wrap{border-radius:16px;margin-bottom:20px;padding:24px}}@media (min-width:1024px){.mouse-tester-wrap{padding:28px}}.mt-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px}@media (min-width:768px){.mt-header{align-items:center;margin-bottom:20px}}.mt-header h2{font-size:clamp(1rem,3vw,1.2rem)}.mt-sub{color:var(--muted);font-size:.8rem;line-height:1.5;margin-top:4px}.reset-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;flex-shrink:0;font-family:Sora,sans-serif;font-size:.8rem;padding:8px 14px;transition:all .2s;white-space:nowrap}@media (min-width:768px){.reset-btn{font-size:.875rem;padding:10px 20px}}.reset-btn:hover{border-color:var(--accent);color:var(--accent)}.mt-progress-bar{background:var(--border);border-radius:2px;height:3px;margin-bottom:16px;overflow:hidden}.mt-progress-fill{background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;height:100%;transition:width .4s ease}.button-indicators{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}@media (min-width:480px){.button-indicators{gap:10px}}@media (min-width:768px){.button-indicators{gap:12px}}.btn-indicator{align-items:center;background:var(--surface2);border:2px solid var(--border);border-radius:10px;display:flex;flex:1 1;flex-direction:column;gap:5px;justify-content:center;max-width:90px;min-width:64px;padding:10px 12px;position:relative;transition:all .15s;-webkit-user-select:none;user-select:none}@media (min-width:480px){.btn-indicator{min-width:72px;padding:12px 14px}}@media (min-width:768px){.btn-indicator{flex:initial;max-width:none;min-width:80px;padding:14px 18px}}.btn-indicator.pressed{background:var(--accent);border-color:var(--accent);transform:scale(.95)}.btn-indicator.tested{background:var(--key-tested);border-color:#00e5a080}.btn-icon{font-size:1.2rem;line-height:1}@media (min-width:480px){.btn-icon{font-size:1.4rem}}.btn-indicator.pressed .btn-icon{filter:brightness(0)}.btn-label{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:.62rem;line-height:1.3;text-align:center;white-space:pre-line}@media (min-width:480px){.btn-label{font-size:.68rem}}.btn-indicator.pressed .btn-label{color:#0f0f13;font-weight:700}.btn-indicator.tested .btn-label{color:var(--accent)}.btn-check{position:absolute;right:7px;top:5px}.btn-check,.btn-scroll-val{color:var(--accent);font-size:.65rem;font-weight:700}.btn-scroll-val{font-family:JetBrains Mono,monospace}.mouse-zone{background:var(--bg);border:2px dashed var(--border);border-radius:10px;cursor:crosshair;height:160px;margin-bottom:16px;overflow:hidden;position:relative;touch-action:none;transition:border-color .2s}@media (min-width:480px){.mouse-zone{height:190px}}@media (min-width:768px){.mouse-zone{border-radius:12px;height:220px}}@media (min-width:1024px){.mouse-zone{height:240px}}.mouse-zone:hover{border-color:var(--accent);border-style:solid}.zone-crosshair{height:0;pointer-events:none;position:absolute;transform:translate(-50%,-50%);width:0}.crosshair-h{height:1px;left:-9px;top:0;width:18px}.crosshair-h,.crosshair-v{background:var(--accent);opacity:.7;position:absolute}.crosshair-v{height:18px;left:0;top:-9px;width:1px}.zone-hint{align-items:center;color:var(--muted);display:flex;flex-direction:column;font-size:.8rem;gap:8px;inset:0;justify-content:center;opacity:.5;pointer-events:none;position:absolute}@media (min-width:768px){.zone-hint{font-size:.85rem}}.zone-icon{font-size:1.6rem}@media (min-width:768px){.zone-icon{font-size:2rem}}.zone-coords{background:var(--surface);border:1px solid var(--border);border-radius:4px;bottom:7px;color:var(--muted);font-family:JetBrains Mono,monospace;font-size:.68rem;padding:3px 8px;position:absolute;right:10px}.mouse-stats{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px}@media (min-width:480px){.mouse-stats{gap:24px}}@media (min-width:768px){.mouse-stats{gap:32px}}.mstat{display:flex;flex-direction:column}.mstat-val{color:var(--text);font-family:JetBrains Mono,monospace;font-size:1.3rem;font-weight:700}@media (min-width:480px){.mstat-val{font-size:1.4rem}}@media (min-width:768px){.mstat-val{font-size:1.5rem}}.mstat-val.accent{color:var(--accent)}.mstat-label{color:var(--muted);font-size:.68rem;letter-spacing:.07em;text-transform:uppercase}.click-log{margin-top:4px}.click-log h4{color:var(--muted);font-size:.78rem;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.log-hint{color:var(--muted);font-size:.72rem;font-weight:400}.log-entries{display:flex;flex-direction:column;gap:4px;max-height:140px;overflow-y:auto}@media (min-width:768px){.log-entries{max-height:160px}}.log-entry{align-items:center;background:var(--surface2);border:1px solid var(--border);border-radius:6px;display:flex;font-size:.75rem;gap:8px;padding:6px 10px}@media (min-width:480px){.log-entry{font-size:.8rem;gap:12px;padding:7px 12px}}.log-entry.btn-0{border-left:3px solid var(--accent)}.log-entry.btn-1{border-left:3px solid var(--accent2)}.log-entry.btn-2{border-left:3px solid var(--accent3)}.log-entry.btn-3,.log-entry.btn-4{border-left:3px solid #60a5fa}.log-dot{background:currentColor;border-radius:50%;flex-shrink:0;height:6px;width:6px}.log-entry.btn-0 .log-dot{color:var(--accent)}.log-entry.btn-1 .log-dot{color:var(--accent2)}.log-entry.btn-2 .log-dot{color:var(--accent3)}.log-entry.btn-3 .log-dot,.log-entry.btn-4 .log-dot{color:#60a5fa}.log-btn{color:var(--text);font-weight:600;min-width:52px}@media (min-width:480px){.log-btn{min-width:64px}}.log-action{color:var(--muted);flex:1 1}.log-time{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:.68rem}.dpi-tester-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);margin-bottom:24px;padding:16px}@media (min-width:768px){.dpi-tester-wrap{border-radius:16px;margin-bottom:32px;padding:24px}}@media (min-width:1024px){.dpi-tester-wrap{margin-bottom:48px;padding:28px}}.dpi-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px}@media (min-width:768px){.dpi-header{margin-bottom:16px}}.dpi-tester-wrap h3{font-size:clamp(.95rem,2.5vw,1.2rem);margin-bottom:6px}.dpi-desc{color:var(--muted);font-size:.82rem;line-height:1.5}.dpi-badge{background:#00e5a01a;border:1px solid #00e5a04d;border-radius:10px;flex-shrink:0;padding:8px 14px;text-align:center}.dpi-badge-val{color:var(--accent);display:block;font-family:JetBrains Mono,monospace;font-size:1.3rem;font-weight:700}@media (min-width:480px){.dpi-badge-val{font-size:1.4rem}}.dpi-badge-label{color:var(--muted);font-size:.65rem;letter-spacing:.06em;text-transform:uppercase}.dpi-zone{align-items:center;background:var(--bg);border:2px dashed var(--border);border-radius:10px;cursor:ew-resize;display:flex;height:80px;justify-content:center;margin-bottom:10px;transition:border-color .2s;-webkit-user-select:none;user-select:none}@media (min-width:768px){.dpi-zone{height:100px}}.dpi-zone.measuring{background:#00e5a00a;border-color:var(--accent);border-style:solid}.dpi-zone.done{border-color:#00e5a066;border-style:solid}.dpi-idle{color:var(--muted);font-size:.82rem}.dpi-arrow{letter-spacing:.04em}.dpi-measuring{align-items:center;display:flex;flex-direction:column;gap:4px}.dpi-dist{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:1.4rem;font-weight:700}@media (min-width:480px){.dpi-dist{font-size:1.6rem}}.dpi-px{font-size:.9rem}.dpi-hint,.dpi-px{color:var(--muted)}.dpi-hint{font-size:.75rem}.dpi-result{align-items:center;display:flex;flex-direction:column;gap:4px}.dpi-value{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:1.6rem;font-weight:700}@media (min-width:480px){.dpi-value{font-size:1.8rem}}.dpi-unit{color:var(--muted);font-size:1rem}.dpi-note{color:var(--muted);font-size:.75rem}.dpi-warning{color:var(--muted);font-size:.78rem;line-height:1.6}.mouse-diagram-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);margin-bottom:32px;padding:16px}@media (min-width:768px){.mouse-diagram-wrap{border-radius:16px;margin-bottom:40px;padding:24px}}@media (min-width:1024px){.mouse-diagram-wrap{margin-bottom:48px;padding:28px}}.mouse-diagram-wrap h3{font-size:clamp(.95rem,2.5vw,1.1rem);margin-bottom:16px}.mouse-diagram{display:flex;justify-content:center}.mouse-body{align-items:center;background:var(--surface2);border:2px solid var(--border);border-radius:70px 70px 44px 44px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;gap:5px;padding:14px 10px 18px;position:relative;width:140px}@media (min-width:480px){.mouse-body{gap:6px;padding:16px 12px 20px;width:160px}}.mb{align-items:center;border-radius:6px;cursor:default;display:flex;font-size:.68rem;font-weight:600;justify-content:space-between;padding:7px 9px;position:relative;transition:all .15s}@media (min-width:480px){.mb{font-size:.72rem;padding:8px 10px}}.left-btn,.right-btn{background:var(--key-bg);border:1px solid var(--key-border);color:var(--muted);width:58px}@media (min-width:480px){.left-btn,.right-btn{width:68px}}.mb-divider{background:var(--border);border-radius:1px;height:24px;width:2px}@media (min-width:480px){.mb-divider{height:28px}}.scroll-btn{background:var(--key-bg);border:2px solid var(--key-border);border-radius:50%;color:var(--muted);flex-direction:column;font-size:.55rem;height:32px;justify-content:center;left:50%;position:absolute;text-align:center;top:52px;transform:translateX(-50%);width:32px}@media (min-width:480px){.scroll-btn{font-size:.6rem;height:36px;top:58px;width:36px}}.mb-num{color:var(--muted);font-size:.58rem;opacity:.6}.tested-btn{background:var(--key-tested);border-color:#00e5a066;color:var(--accent)}.active-btn{background:var(--accent);border-color:var(--accent);color:#0f0f13;transform:scale(.96)}.mouse-bottom{display:flex;gap:5px;margin-top:6px}@media (min-width:480px){.mouse-bottom{gap:6px;margin-top:8px}}.side-btn{background:var(--key-bg);border:1px solid var(--key-border);border-radius:4px;color:var(--muted);font-size:.6rem;padding:5px 7px;width:56px}@media (min-width:480px){.side-btn{font-size:.65rem;padding:6px 8px;width:64px}}.mb-side-label{font-size:.58rem}@media (min-width:480px){.mb-side-label{font-size:.62rem}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f13;--surface:#17171f;--surface2:#1e1e28;--border:#2a2a38;--accent:#00e5a0;--accent2:#7c3aed;--accent3:#f59e0b;--text:#e8e8f0;--muted:#8888a0;--key-bg:#1a1a24;--key-border:#333348;--key-tested:#1a3a2a;--radius:8px;--shadow:0 4px 24px #0006;--nav-h:60px}[data-theme=light]{--bg:#f4f4f8;--surface:#fff;--surface2:#ebebf3;--border:#d0d0e0;--accent:#00a870;--accent2:#6d28d9;--accent3:#d97706;--text:#111118;--muted:#5a5a72;--key-bg:#e8e8f4;--key-border:#c0c0d8;--key-tested:#d0f0e4;--shadow:0 4px 24px #0000001a}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{background:#0f0f13;background:var(--bg);color:#e8e8f0;color:var(--text);font-family:Sora,sans-serif;font-size:15px;line-height:1.7;min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s}img,video{display:block;height:auto;max-width:100%}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0f0f13;background:var(--bg)}::-webkit-scrollbar-thumb{background:#2a2a38;background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00e5a0;background:var(--accent)}a{color:#00e5a0;color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5{font-weight:600;line-height:1.3}.container{margin:0 auto;max-width:1200px;padding:0 16px}@media (min-width:480px){.container{padding:0 20px}}@media (min-width:768px){.container{padding:0 24px}}@media (min-width:1280px){.container{padding:0 32px}}.page-hero{background:linear-gradient(135deg,#17171f,#0f0f13);background:linear-gradient(135deg,var(--surface) 0,var(--bg) 100%);border-bottom:1px solid #2a2a38;border-bottom:1px solid var(--border);margin-bottom:32px;padding:60px 0 40px}@media (min-width:768px){.page-hero{margin-bottom:48px;padding:80px 0 60px}}.page-hero h1{font-size:clamp(1.5rem,5vw,2.8rem);margin-bottom:14px}.page-hero p{color:#8888a0;color:var(--muted);font-size:clamp(.9rem,2.5vw,1.05rem);max-width:560px}.hero-badge{background:#00e5a01a;border:1px solid #00e5a04d;border-radius:20px;color:#00e5a0;color:var(--accent);display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.08em;margin-bottom:16px;padding:5px 14px;text-transform:uppercase}[data-theme=light] .hero-badge{background:#00a8701a;border-color:#00a8704d}.glow-text{color:#00e5a0;color:var(--accent);text-shadow:0 0 40px #00e5a066}[data-theme=light] .glow-text{text-shadow:0 0 20px #00a87040}.article-section{margin:40px auto}@media (min-width:768px){.article-section{margin:64px auto}}.article-content{max-width:820px}.article-content h2{color:#e8e8f0;color:var(--text);font-size:clamp(1.3rem,4vw,1.8rem);margin-bottom:16px}.article-content h3{color:#00e5a0;color:var(--accent);font-size:clamp(1rem,3vw,1.25rem);margin:28px 0 10px}.article-content h4{color:#e8e8f0;color:var(--text);font-size:clamp(.9rem,2vw,1rem);margin:20px 0 8px}.article-content p{color:#8888a0;color:var(--muted);font-size:clamp(.875rem,2vw,.95rem);line-height:1.8;margin-bottom:14px}.article-content ul{margin:0 0 18px 18px}.article-content li{color:#8888a0;color:var(--muted);font-size:clamp(.875rem,2vw,.95rem);line-height:1.7;margin-bottom:8px}.article-content li strong{color:#e8e8f0;color:var(--text)}.article-content code{background:#1e1e28;background:var(--surface2);border:1px solid #2a2a38;border:1px solid var(--border);border-radius:4px;color:#00e5a0;color:var(--accent);font-family:JetBrains Mono,monospace;font-size:.82em;padding:2px 6px;word-break:break-all}.faq-section{margin:40px auto 48px}@media (min-width:768px){.faq-section{margin:64px auto}}.faq-section h2{font-size:clamp(1.3rem,4vw,1.8rem);margin-bottom:20px}.faq-list{display:flex;flex-direction:column;gap:8px}.faq-item{background:#17171f;background:var(--surface);border:1px solid #2a2a38;border:1px solid var(--border);border-radius:10px;cursor:pointer;padding:16px 18px;transition:border-color .2s}@media (min-width:768px){.faq-item{padding:20px 24px}}.faq-item.open,.faq-item:hover{border-color:#00e5a066}.faq-q{align-items:flex-start;color:#e8e8f0;color:var(--text);display:flex;font-size:clamp(.875rem,2vw,.95rem);font-weight:500;gap:12px;justify-content:space-between}.faq-icon{color:#00e5a0;color:var(--accent);flex-shrink:0;font-size:1.2rem;line-height:1.4}.faq-a{border-top:1px solid #2a2a38;border-top:1px solid var(--border);color:#8888a0;color:var(--muted);font-size:.875rem;line-height:1.7;margin-top:12px;padding-top:12px}
/*# sourceMappingURL=main.82180b15.css.map*/