:root{--kb-yellow: #ffbc00;--kb-yellow-dim: #e6a800;--kb-dark: #1a1a1a;--kb-slate: #2d2d2d;--kb-text: #e8e8e8;--kb-muted: #a3a3a3}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:linear-gradient(165deg,var(--kb-dark) 0%,#252525 45%,var(--kb-slate) 100%);min-height:100vh;color:var(--kb-text)}#root{max-width:560px;margin:0 auto;padding:16px 16px 48px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid rgba(255,188,0,.25)}.brand{display:flex;align-items:center;gap:8px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:var(--kb-yellow);color:var(--kb-dark);font-weight:800;font-size:.85rem}.brand-text{font-weight:700;font-size:1rem;letter-spacing:-.02em}.nav{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.nav a{color:var(--kb-muted);text-decoration:none;font-size:.8rem;font-weight:600;padding:6px 10px;border-radius:999px;border:1px solid transparent}.nav a:hover{color:var(--kb-text);border-color:#ffbc0059}.nav a.active{color:var(--kb-dark);background:var(--kb-yellow)}h1{font-size:1.3rem;font-weight:700;margin:0 0 8px}p.sub{color:var(--kb-muted);font-size:.9rem;margin:0 0 20px;line-height:1.5}p.sub a{color:var(--kb-yellow)}.card{background:#fff;color:#0f172a;border-radius:16px;padding:20px;box-shadow:0 20px 50px #0006;margin-bottom:16px}.table-card{overflow-x:auto;padding:12px}.addr{font-family:ui-monospace,monospace;font-size:.8rem;word-break:break-all;background:#f1f5f9;padding:10px;border-radius:8px;margin:12px 0}.member-pill{display:inline-block;margin:0 0 8px;padding:6px 12px;border-radius:999px;background:#ffbc0033;color:#854d0e;font-size:.8rem;font-weight:700}.btn{width:100%;padding:14px 16px;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:10px}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--kb-yellow) 0%,var(--kb-yellow-dim) 100%);color:var(--kb-dark);box-shadow:0 8px 24px #ffbc0040}.btn-secondary{background:#f1f5f9;color:#334155}.btn.btn-text{margin-top:0;padding:6px 10px;width:auto;background:transparent;color:#64748b;font-size:.8rem;font-weight:600;box-shadow:none}.btn.btn-text:hover:enabled{color:#0f172a}.btn.btn-text.danger{color:#b91c1c}.btn.btn-text.danger:hover:enabled{color:#7f1d1d}.cart-panel{margin-top:14px;padding-top:4px;border-top:1px solid #e2e8f0}.cart-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.cart-list{list-style:none;margin:8px 0 0;padding:0;max-height:220px;overflow:auto}.cart-line{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid #f1f5f9;font-size:.85rem}.cart-line:last-child{border-bottom:none}.cart-line-name{font-weight:600;color:#0f172a}.cart-line-meta{font-size:.78rem;color:#64748b;margin-top:2px}.msg{font-size:.88rem;margin-top:12px;line-height:1.45}.msg.ok{color:#059669}.msg.err{color:#dc2626}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;margin-bottom:8px}.badge-yes{background:#d1fae5;color:#065f46}.badge-no{background:#fef3c7;color:#92400e}.consent-block{margin-top:12px}.consent-title{margin:0 0 8px;font-size:.82rem;font-weight:700;color:#475569}.challenge-pre{margin:0 0 14px;padding:12px;max-height:220px;overflow:auto;font-family:ui-monospace,monospace;font-size:.68rem;line-height:1.45;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;color:#0f172a;white-space:pre-wrap;word-break:break-word}.consent-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;font-size:.85rem;line-height:1.45;color:#334155;cursor:pointer}.consent-row input{margin-top:3px;flex-shrink:0}.consent-row--field{flex-direction:column;align-items:stretch;gap:6px;cursor:default}.consent-field-label{font-size:.75rem;font-weight:600;color:#64748b}.link-member-input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e2e8f0;font-size:.85rem;box-sizing:border-box}.btn-row{display:flex;gap:10px;margin-top:14px}.btn-row .btn{margin-top:0;flex:1;min-width:0}.field-label{display:block;font-size:.75rem;font-weight:700;color:#64748b;margin-top:12px;margin-bottom:4px}.field-label:first-of-type{margin-top:0}.field-input{width:100%;padding:10px 12px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.95rem}.field-input.mono{font-family:ui-monospace,monospace;font-size:.8rem}.field-input.small{font-size:.75rem;margin-top:10px}.hint{font-size:.78rem;color:#64748b;margin-top:8px;line-height:1.4}.hint.mono{font-family:ui-monospace,monospace;word-break:break-all}.qr-block{margin-top:16px;text-align:center}.qr-img{width:100%;max-width:280px;height:auto;border-radius:12px;border:1px solid #e2e8f0}.kb-pay-meta-id{margin-top:12px;color:#64748b}.kb-pay-qr-shell{margin-top:20px;padding-top:4px}.kb-pay-qr-brandbar{display:flex;align-items:center;gap:12px;margin-bottom:14px}.kb-pay-qr-mark{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:linear-gradient(145deg,var(--kb-yellow) 0%,var(--kb-yellow-dim) 100%);color:var(--kb-dark);font-weight:800;font-size:.78rem;letter-spacing:-.04em;box-shadow:0 6px 20px #ffbc0059}.kb-pay-qr-brandcopy{display:flex;flex-direction:column;gap:2px}.kb-pay-qr-title{font-size:1.15rem;font-weight:800;color:#0f172a;letter-spacing:-.03em}.kb-pay-qr-sub{font-size:.78rem;font-weight:600;color:#64748b}.kb-pay-qr-card{background:linear-gradient(180deg,#fffef8,#fff 32%);border:1px solid rgba(255,188,0,.45);border-radius:20px;padding:20px 18px 18px;box-shadow:0 0 0 3px #ffbc001f,0 20px 48px #00000014}.kb-pay-qr-amount-block{text-align:center;margin-bottom:10px}.kb-pay-qr-amount-label{display:block;font-size:.72rem;font-weight:700;color:#78716c;letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}.kb-pay-qr-amount-value{margin:0;font-size:1.75rem;font-weight:800;color:#0f172a;letter-spacing:-.03em;line-height:1.2}.kb-pay-qr-currency{display:inline-block;margin-right:6px;font-size:.95rem;font-weight:700;color:#a16207;vertical-align:middle}.kb-pay-qr-items{margin:0 0 16px;padding:10px 12px;font-size:.82rem;line-height:1.45;color:#334155;background:#ffbc0014;border-radius:12px;border:1px solid rgba(255,188,0,.2);text-align:center}.kb-pay-qr-frame{display:inline-block;padding:14px;background:#fff;border-radius:16px;border:3px solid var(--kb-yellow);box-shadow:inset 0 0 0 1px #1a1a1a0f}.kb-pay-qr-img{display:block;width:100%;max-width:240px;height:auto;border-radius:8px}.kb-pay-qr-scan-hint{margin:14px 0 0;font-size:.78rem;color:#64748b;text-align:center;line-height:1.4}.kb-pay-qr-url-label{display:block;margin-top:16px;font-size:.72rem;font-weight:700;color:#64748b}.kb-pay-qr-url{margin-top:6px;background:#f8fafc;border-color:#e2e8f0}.bo-table{width:100%;border-collapse:collapse;font-size:.78rem}.bo-table th,.bo-table td{padding:8px 6px;text-align:left;border-bottom:1px solid #e2e8f0}.bo-table th{color:#64748b;font-weight:700}.bo-table a{color:#2563eb}.bo-section-title{font-size:.95rem;margin:0 0 10px;color:#0f172a}.mono.small{font-size:.72rem}.bo-section-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.bo-count{font-size:.78rem;font-weight:700;color:#64748b;background:#f1f5f9;padding:3px 10px;border-radius:999px}.bo-addr{word-break:break-all;max-width:200px}.kiosk-root{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:linear-gradient(165deg,var(--kb-dark) 0%,#1e1e1e 45%,var(--kb-slate) 100%);color:var(--kb-text);overflow:hidden;z-index:100}.kiosk-header{display:flex;align-items:center;gap:16px;padding:14px 28px;background:#00000059;border-bottom:1.5px solid rgba(255,188,0,.25);flex-shrink:0}.kiosk-logo{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:13px;background:var(--kb-yellow);color:var(--kb-dark);font-weight:900;font-size:1rem;letter-spacing:-.05em;flex-shrink:0}.kiosk-header-info{display:flex;flex-direction:column;gap:2px}.kiosk-title{font-size:1.25rem;font-weight:800;color:var(--kb-text);letter-spacing:-.03em}.kiosk-subtitle{font-size:.82rem;color:var(--kb-muted)}.kiosk-exit-link{margin-left:auto;color:var(--kb-muted);font-size:.78rem;text-decoration:none;padding:6px 12px;border:1px solid rgba(255,188,0,.2);border-radius:8px;transition:all .15s}.kiosk-exit-link:hover{border-color:var(--kb-yellow);color:var(--kb-text)}.kiosk-body{flex:1;display:grid;grid-template-columns:360px 1fr;overflow:hidden}.kiosk-panel{padding:28px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;overflow-y:auto}.kiosk-panel-left{background:#0003;border-right:1px solid rgba(255,188,0,.15)}.kiosk-panel-right{padding:28px 32px}.kiosk-step-badge{display:inline-block;padding:4px 14px;border-radius:999px;background:#ffbc002e;color:var(--kb-yellow);font-size:.72rem;font-weight:800;letter-spacing:.04em;margin-bottom:12px}.kiosk-step-badge--pay{background:#ffbc0040}.kiosk-panel-title{font-size:1.35rem;font-weight:800;color:var(--kb-text);margin-bottom:8px;letter-spacing:-.02em}.kiosk-panel-desc{color:var(--kb-muted);font-size:.88rem;line-height:1.65;margin:0 0 20px}.kiosk-qr-wrap{background:#fff;padding:14px;border-radius:20px;border:3px solid var(--kb-yellow);box-shadow:0 0 0 4px #ffbc001f,0 24px 48px #00000059;display:inline-block;margin-bottom:12px}.kiosk-qr-wrap--pay{box-shadow:0 0 0 6px #ffbc0033,0 32px 64px #0006}.kiosk-qr-img{display:block;width:240px;height:240px;border-radius:10px}.kiosk-qr-placeholder{width:268px;height:268px;border-radius:20px;background:#ffffff0d;border:2px dashed rgba(255,188,0,.25);margin-bottom:12px}.kiosk-qr-caption{margin:0;font-size:.82rem;color:var(--kb-muted);font-weight:600}.kiosk-payment-view{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.kiosk-pay-amount-block{text-align:center;margin:4px 0 8px}.kiosk-pay-item-name{display:block;font-size:1.1rem;font-weight:700;color:var(--kb-text);margin-bottom:4px}.kiosk-pay-amount{display:block;font-size:2.4rem;font-weight:900;color:var(--kb-yellow);letter-spacing:-.04em;line-height:1.1}.kiosk-pay-id{margin:0;font-size:.72rem;font-family:ui-monospace,monospace;color:#a3a3a3b3}.kiosk-reset-btn{margin-top:8px;padding:12px 28px;border:1.5px solid rgba(255,188,0,.35);border-radius:12px;background:transparent;color:var(--kb-muted);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s}.kiosk-reset-btn:hover{border-color:var(--kb-yellow);color:var(--kb-text);background:#ffbc0014}.kiosk-product-view{width:100%;display:flex;flex-direction:column;align-items:center}.kiosk-product-section{width:100%;margin-bottom:16px}.kiosk-product-section-label{font-size:.72rem;font-weight:700;color:var(--kb-muted);letter-spacing:.06em;text-transform:uppercase;text-align:left;margin-bottom:8px}.kiosk-product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;width:100%}.kiosk-product-btn{background:#ffffff0f;border:1.5px solid rgba(255,188,0,.2);border-radius:16px;padding:16px 12px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:6px;align-items:center;text-align:center;min-height:88px;justify-content:center}.kiosk-product-btn:hover:enabled{background:#ffbc001a;border-color:var(--kb-yellow);transform:translateY(-1px);box-shadow:0 8px 24px #0003}.kiosk-product-btn:active:enabled{transform:translateY(0)}.kiosk-product-btn--usdc{border-color:#64b5f64d}.kiosk-product-btn--usdc:hover:enabled{background:#64b5f614;border-color:#64b5f6}.kiosk-product-btn--loading{opacity:.7;background:#ffbc001f;border-color:var(--kb-yellow)}.kiosk-product-btn:disabled{opacity:.45;cursor:not-allowed}.kiosk-product-name{color:var(--kb-text);font-weight:700;font-size:.85rem;line-height:1.35;word-break:keep-all}.kiosk-product-price{color:var(--kb-yellow);font-weight:800;font-size:.95rem;letter-spacing:-.02em}.kiosk-product-btn--usdc .kiosk-product-price{color:#64b5f6}.kiosk-product-hint{font-size:.65rem;font-weight:600;color:var(--kb-muted);margin-top:2px}.kiosk-cart{width:100%;margin-bottom:18px;padding:14px;border-radius:16px;background:#ffbc000f;border:1px solid rgba(255,188,0,.22)}.kiosk-cart-head{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;font-weight:700;color:var(--kb-text);margin-bottom:10px}.kiosk-cart-total{color:var(--kb-yellow);font-variant-numeric:tabular-nums}.kiosk-cart-lines{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.kiosk-cart-line{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:.78rem;color:var(--kb-text)}.kiosk-cart-name{flex:1;text-align:left;line-height:1.35;word-break:keep-all}.kiosk-cart-qty{display:flex;align-items:center;gap:8px;font-weight:700;font-variant-numeric:tabular-nums}.kiosk-qty-btn{width:30px;height:30px;border-radius:10px;border:1px solid rgba(255,188,0,.35);background:#0003;color:var(--kb-text);font-size:1.1rem;line-height:1;cursor:pointer}.kiosk-qty-btn:hover{border-color:var(--kb-yellow);background:#ffbc001f}.kiosk-cart-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;justify-content:flex-end;align-items:center}.kiosk-cart-clear{background:transparent;border:1px solid rgba(255,255,255,.15);color:var(--kb-muted);font-size:.78rem;padding:8px 14px;border-radius:999px;cursor:pointer}.kiosk-cart-clear:hover{color:var(--kb-text);border-color:#ffffff4d}.kiosk-checkout-btn{background:var(--kb-yellow);color:var(--kb-dark);border:none;font-weight:800;font-size:.88rem;padding:12px 22px;border-radius:999px;cursor:pointer;box-shadow:0 6px 20px #ffbc0040}.kiosk-checkout-btn:hover:enabled{filter:brightness(1.05)}.kiosk-checkout-btn:disabled{opacity:.55;cursor:not-allowed}.kiosk-loading{margin-top:16px;color:var(--kb-muted);font-size:.88rem;animation:pulse 1.2s ease-in-out infinite}.kiosk-err{margin-top:12px;color:#f87171;font-size:.85rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}
