:root{--bg: #f5f1ea;--bg-gradient-top: #f8ecd8;--bg-gradient-bottom: #e8d5c0;--panel: #ffffff;--panel-shadow: 0 4px 24px rgba(60, 40, 20, .08);--accent: #d4653a;--accent-soft: #f0a372;--text: #2b1d14;--text-muted: #6b5543;--chip-bg: #f5e9da;--chip-border: #dcc8af;--error: #b93e2a;--success: #4a7a3e}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text);background:linear-gradient(180deg,var(--bg-gradient-top) 0%,var(--bg-gradient-bottom) 100%);overscroll-behavior:none;-webkit-user-select:none;user-select:none}.app{display:flex;flex-direction:column;height:100%;max-width:720px;margin:0 auto;padding:16px;gap:16px}.header{display:flex;align-items:baseline;justify-content:space-between;padding:0 8px}.header h1{font-size:20px;font-weight:600;margin:0}.header .state-badge{font-size:12px;font-weight:500;color:var(--text-muted);padding:4px 10px;background:var(--chip-bg);border-radius:999px;text-transform:lowercase}.avatar-wrap{flex:1 1 auto;display:flex;align-items:center;justify-content:center;position:relative;min-height:560px}.avatar-wrap>div{width:100%;height:100%;min-height:560px;display:flex;align-items:center;justify-content:center}.avatar-wrap canvas{display:block;max-width:100%;max-height:100%}.subtitle{flex:0 0 auto;align-self:center;max-width:90%;padding:12px 18px;background:#ffffffeb;border-radius:14px;font-size:15px;line-height:1.4;text-align:center;box-shadow:var(--panel-shadow)}.panel{display:flex;flex-direction:column;gap:12px}.chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.chip{font-size:14px;padding:8px 14px;background:var(--chip-bg);border:1px solid var(--chip-border);border-radius:999px;color:var(--text);cursor:pointer;touch-action:manipulation;transition:transform .12s ease,background .12s ease}.chip:active:not(:disabled){transform:scale(.96);background:#ebd9be}.chip:disabled{opacity:.45;cursor:not-allowed}.ptt-button{align-self:center;width:140px;height:140px;border-radius:50%;border:none;background:radial-gradient(circle at 35% 30%,var(--accent-soft),var(--accent));color:#fff;font-size:16px;font-weight:600;letter-spacing:.5px;cursor:pointer;touch-action:manipulation;box-shadow:0 8px 24px #d4653a59;transition:transform .12s ease,box-shadow .12s ease}.ptt-button:active:not(:disabled){transform:scale(.96);box-shadow:0 4px 14px #d4653a73}.ptt-button[data-active=true]{background:radial-gradient(circle at 35% 30%,#ff7f4d,#a64020);animation:pulse 1.2s ease-in-out infinite}.ptt-button:disabled{opacity:.45;cursor:not-allowed}@keyframes pulse{0%,to{box-shadow:0 8px 24px #d4653a73}50%{box-shadow:0 8px 36px #d4653abf}}.product-card{display:flex;gap:12px;padding:12px;background:var(--panel);border-radius:14px;box-shadow:var(--panel-shadow);align-items:center}.product-card__image{width:96px;height:96px;background:#eadfcf;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.product-card__body{flex:1 1 auto;min-width:0}.product-card__title{font-weight:600;font-size:15px;margin:0 0 4px}.product-card__desc{font-size:13px;color:var(--text-muted);margin:0 0 8px}.product-card__price{font-weight:600}.product-card__old{color:var(--text-muted);text-decoration:line-through;margin-left:8px;font-weight:400;font-size:13px}.product-card__dismiss{background:none;border:0;font-size:20px;color:var(--text-muted);cursor:pointer;padding:4px 8px}
