*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#0f1117;color:#e2e8f0;min-height:100dvh;padding:1.5rem 1rem 3rem}.app{max-width:560px;margin:0 auto}.app-header{text-align:center;margin-bottom:2rem}.app-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:#f8fafc}.subtitle{margin-top:.35rem;font-size:.85rem;color:#64748b;font-family:Courier New,monospace}.app-main{display:flex;flex-direction:column;gap:1.25rem}.card{background:#1e2330;border:1px solid #2d3348;border-radius:12px;padding:1.25rem 1.5rem}.card h2{font-size:1rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem}.card-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card-row h2{margin-bottom:0}.card>h2{margin-bottom:1rem}.badge{display:inline-flex;align-items:center;padding:.2rem .7rem;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.03em}.badge-idle{background:#1e293b;color:#64748b;border:1px solid #334155}.badge-busy{background:#1e3a5f;color:#60a5fa;border:1px solid #1d4ed8;animation:pulse 1.4s ease-in-out infinite}.badge-ok{background:#14532d;color:#4ade80;border:1px solid #16a34a}.badge-warn{background:#431407;color:#fb923c;border:1px solid #c2410c}.badge-error{background:#450a0a;color:#f87171;border:1px solid #b91c1c}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.info-block{background:#151821;border:1px solid #2d3348;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.4rem}.info-row{display:flex;gap:.75rem;font-size:.875rem}.info-label{color:#64748b;min-width:64px}.info-value{color:#e2e8f0;font-family:Courier New,monospace;font-size:.82rem}.error-box{background:#2d0a0a;border:1px solid #7f1d1d;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.82rem;color:#fca5a5}.error-box strong{display:block;margin-bottom:.4rem;color:#f87171}.error-box pre{white-space:pre-wrap;word-break:break-word;font-family:Courier New,monospace;font-size:.78rem;line-height:1.5}.btn-row{display:flex;gap:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.35rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover:not(:disabled){background:#3b82f6}.btn-danger{background:#b91c1c;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.progress-wrap{position:relative;background:#151821;border:1px solid #2d3348;border-radius:999px;height:20px;overflow:hidden;margin-bottom:1rem}.progress-bar{height:100%;background:linear-gradient(90deg,#2563eb,#3b82f6);border-radius:999px;transition:width .15s ease;min-width:4px}.progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:#e2e8f0;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.8)}.steps-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.step-item{display:flex;align-items:flex-start;gap:.875rem;padding:.75rem 1rem;background:#151821;border:1px solid #2d3348;border-radius:8px;transition:border-color .2s}.step-item.step-done{border-color:#16a34a;background:#052e16}.step-number{width:28px;height:28px;border-radius:50%;background:#2d3348;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#94a3b8;flex-shrink:0}.step-item.step-done .step-number{background:#16a34a;color:#fff}.step-body strong{display:block;font-size:.875rem;color:#e2e8f0;margin-bottom:.2rem}.step-body p{font-size:.78rem;color:#64748b;line-height:1.5}.receipt-preview{font-family:Courier New,Courier,monospace;font-size:.78rem;line-height:1.55;color:#a5b4c8;background:#0d1117;border:1px solid #2d3348;border-radius:8px;padding:1rem;overflow-x:auto;white-space:pre}.hint{margin-top:.75rem;font-size:.78rem;color:#475569}.btn-secondary{background:#334155;color:#e2e8f0}.btn-secondary:hover:not(:disabled){background:#475569}.scan-result{margin-bottom:1rem}.services-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.25rem}.service-item{background:#0d1117;border:1px solid #2d3348;border-radius:8px;padding:.65rem .875rem}.service-uuid{font-size:.78rem;color:#94a3b8;margin-bottom:.4rem}.service-uuid code{color:#38bdf8;font-family:Courier New,monospace}.char-row{display:flex;align-items:baseline;gap:.75rem;font-size:.75rem;padding:.2rem 0 .2rem .75rem;border-left:2px solid #1e3a5f;margin-top:.3rem}.char-row code{color:#a5f3fc;font-family:Courier New,monospace;flex-shrink:0}.char-props{color:#64748b;font-size:.7rem}
