body{margin:0}*{box-sizing:border-box;margin:0;padding:0}body{color:#f0f0f0;background:#0a0a0a;min-height:100vh;font-family:Raleway,sans-serif}.app{flex-direction:column;gap:2.5rem;max-width:820px;margin:0 auto;padding:2.5rem 1.5rem;display:flex}header{text-align:center}.header-title{justify-content:center;align-items:center;gap:.6rem;display:flex}.header-logo{width:auto;height:7.5rem}header h1{letter-spacing:-.5px;font-size:5rem;font-weight:700;line-height:1}header h1 span{color:#33568b}.subtitle{color:#888;text-transform:uppercase;letter-spacing:2.5px;margin-top:.5rem;font-size:1.5rem}main{flex-direction:column;gap:1.25rem;display:flex}.status-bar{color:#999;background:#161616;border:1px solid #2a2a2a;border-radius:8px;padding:.8rem 1rem;font-size:.9rem;font-weight:500}.status-bar.connected{color:#5c5;background:#0d1f12;border-color:#1e4a2a}.status-bar.error{color:#c66;background:#1a0d0d;border-color:#4a1e1e}.connect-btn{color:#fff;letter-spacing:.3px;cursor:pointer;background:#33568b;border:none;border-radius:8px;width:100%;padding:1rem;font-family:inherit;font-size:1rem;font-weight:600;transition:background .15s}.connect-btn:hover{background:#2d4796}.connect-btn.secondary{color:#a05555;background:#1e1e1e;border:1px solid #2a2a2a}.connect-btn.secondary:hover{color:#c06060;background:#251a1a}.keycode-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.content{flex-direction:column;gap:1.5rem;display:flex}.content.disabled{opacity:.35;pointer-events:none}.categories-row{grid-template-columns:1fr 1.6fr;align-items:start;gap:1.5rem;display:grid}.categories-row .keycode-grid{grid-template-columns:1fr}.categories-row .keycode-grid.grid-2{grid-template-columns:1fr 1fr}.category{flex-direction:column;gap:.75rem;display:flex}.category-name{text-transform:uppercase;letter-spacing:2px;color:#777;font-size:.72rem;font-weight:600}.custom-section{background:#0d1520;border:1px solid #2a3a5a;border-radius:10px;flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.custom-hint{color:#7a8aa0;font-size:.82rem}.keycode-btn{color:inherit;cursor:pointer;text-align:left;background:#181818;border:1px solid #2e2e2e;border-radius:8px;flex-direction:column;gap:.3rem;padding:1rem;font-family:inherit;transition:border-color .15s,background .15s;display:flex}.keycode-btn:hover{background:#0d1520;border-color:#33568b}.keycode-btn.active{background:#0a1020;border-color:#33568b}.keycode-label{font-size:.95rem;font-weight:600}.keycode-desc{color:#888;font-size:.8rem}.custom-row{align-items:stretch;gap:.75rem;display:flex}.recorder{color:#7a8aa0;cursor:pointer;background:#111a28;border:1px dashed #3a4a6a;border-radius:8px;flex:1;align-items:center;min-height:64px;padding:1rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:500;transition:border-color .15s,color .15s,background .15s;display:flex}.recorder:hover{color:#aaa;border-color:#33568b}.recorder.recording{color:#33568b;border-style:solid;border-color:#33568b;animation:1s ease-in-out infinite pulse}.recorder.has-combo{color:#f0f0f0;border-style:solid;border-color:#3a3a3a}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.apply-btn{color:#888;cursor:pointer;white-space:nowrap;background:#181818;border:1px solid #2e2e2e;border-radius:8px;padding:1rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:border-color .15s,background .15s,color .15s}.apply-btn:hover:not(:disabled){color:#f0f0f0;background:#0d1520;border-color:#33568b}.apply-btn.active{color:#f0f0f0;background:#0a1020;border-color:#33568b}.apply-btn:disabled{opacity:.3;cursor:not-allowed}footer{text-align:center;color:#666;border-top:1px solid #1a1a1a;padding-top:1.5rem;font-size:.8rem;line-height:1.8}
