:root{--bg:#faf7f2;--surface:#fff;--border:#e8e0d5;--text:#1a1209;--text-2:#6b5c45;--accent:#c84b11;--accent-light:#fde8df;--accent-hover:#a83a0a;--green:#1a7a4a;--green-light:#d4f0e3;--red:#b91c1c;--red-light:#fee2e2;--yellow:#92400e;--yellow-light:#fef3c7;--radius:12px;--radius-sm:8px;--shadow:0 1px 4px #00000014;--shadow-md:0 4px 16px #0000001f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--bg);color:var(--text);min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.5}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font:inherit;border-radius:var(--radius-sm);border:none;padding:.6rem 1.2rem;transition:background .15s,opacity .15s}button:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{font:inherit;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);outline:none;width:100%;padding:.6rem .8rem;transition:border-color .15s}input:focus,textarea:focus,select:focus{border-color:var(--accent)}label{color:var(--text-2);margin-bottom:.3rem;font-size:.875rem;font-weight:500;display:block}.field{flex-direction:column;gap:.25rem;display:flex}.field-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.btn{white-space:nowrap;justify-content:center;align-items:center;gap:.4rem;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{color:var(--accent);border:1.5px solid var(--accent);background:0 0;font-weight:500}.btn-secondary:hover:not(:disabled){background:var(--accent-light)}.btn-ghost{color:var(--text-2);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--red);color:#fff;font-weight:600}.btn-danger:hover:not(:disabled){background:#991b1b}.btn-green{background:var(--green);color:#fff;font-weight:600}.btn-green:hover:not(:disabled){background:#155e3c}.btn-sm{padding:.4rem .8rem;font-size:.875rem}.btn-full{width:100%}.page{flex:1;max-width:480px;margin:0 auto;padding:1.5rem 1rem}.center{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:80dvh;display:flex}.card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.topbar{z-index:10;background:var(--surface);border-bottom:1.5px solid var(--border);align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex;position:sticky;top:0}.topbar-title{flex:1;font-size:1rem;font-weight:700}.topbar-back{color:var(--text-2);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:.35rem .5rem;font-size:1rem}.topbar-back:hover{background:var(--border)}.badge{border-radius:99px;padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-active{background:var(--yellow-light);color:var(--yellow)}.badge-deal{background:var(--green-light);color:var(--green)}.badge-no_deal{background:var(--red-light);color:var(--red)}.badge-expired{background:var(--border);color:var(--text-2)}.bubble-user{background:var(--accent);color:#fff;word-break:break-word;border-radius:18px 18px 4px;align-self:flex-end;max-width:80%;padding:.65rem 1rem}.bubble-ai{background:var(--surface);border:1.5px solid var(--border);color:var(--text);word-break:break-word;border-radius:18px 18px 18px 4px;align-self:flex-start;max-width:80%;padding:.65rem 1rem}.bubble-system{background:var(--border);color:var(--text-2);text-align:center;border-radius:8px;align-self:center;padding:.4rem .75rem;font-size:.8rem}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:1.25rem;height:1.25rem;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.divider{border:none;border-top:1.5px solid var(--border);margin:1rem 0}.error-msg{color:var(--red);background:var(--red-light);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.875rem}.success-msg{color:var(--green);background:var(--green-light);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.875rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-2)}.text-bold{font-weight:700}.gap-stack{flex-direction:column;gap:.75rem;display:flex}.flex-row{flex-direction:row;align-items:center;gap:.5rem;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.login-logo{margin-bottom:.25rem;font-size:2.5rem}.login-box{width:100%;max-width:360px}.login-divider{color:var(--text-2);align-items:center;gap:.75rem;font-size:.875rem;display:flex}.login-divider:before,.login-divider:after{content:"";border-top:1.5px solid var(--border);flex:1}.session-card{cursor:pointer;align-items:flex-start;gap:.75rem;display:flex}.session-card:hover{background:var(--bg)}.session-card-icon{flex-shrink:0;padding-top:.1rem;font-size:1.5rem}.session-card-body{flex:1;min-width:0}.session-card-title{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.session-card-meta{color:var(--text-2);flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.2rem;font-size:.8rem;display:flex}.wizard-steps{align-items:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.step-dot{background:var(--border);border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .2s}.step-dot.active{background:var(--accent);border-radius:4px;width:20px}.step-dot.done{background:var(--green)}.product-card-select{cursor:pointer;border:2px solid var(--border);border-radius:var(--radius);padding:1rem;transition:border-color .15s}.product-card-select.selected{border-color:var(--accent);background:var(--accent-light)}.difficulty-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;padding:.6rem 1rem;font-size:.875rem;transition:all .15s}.difficulty-btn.selected{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:600}.persona-card{cursor:pointer;border:2px solid var(--border);border-radius:var(--radius);padding:.85rem;transition:border-color .15s}.persona-card.selected{border-color:var(--accent);background:var(--accent-light)}.arena-wrap{flex-direction:column;max-width:480px;height:100dvh;margin:0 auto;display:flex;overflow:hidden}.arena-header{background:var(--surface);border-bottom:1.5px solid var(--border);padding:.6rem 1rem}.arena-persona{font-size:.9rem;font-weight:700}.arena-turn{color:var(--text-2);font-size:.8rem}.state-bar{background:var(--accent-light);border-bottom:1.5px solid var(--border);grid-template-columns:1fr 1fr;gap:.4rem;padding:.6rem 1rem;display:grid}.state-cell{text-align:center}.state-cell-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-2);font-size:.6rem;font-weight:600}.state-cell-value{color:var(--text);font-size:.85rem;font-weight:700}.state-cell-value.highlight{color:var(--accent)}.arena-messages{flex-direction:column;flex:1;gap:.75rem;padding:1rem;display:flex;overflow-y:auto}.arena-suggestions{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:.4rem;padding:.5rem 1rem;display:flex;overflow-x:auto}.suggestion-chip{background:var(--bg);border:1.5px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:99px;flex-shrink:0;padding:.35rem .85rem;font-size:.8rem;transition:all .15s}.suggestion-chip:hover{border-color:var(--accent);background:var(--accent-light)}.arena-input-bar{background:var(--surface);border-top:1.5px solid var(--border);flex-shrink:0;align-items:flex-end;gap:.5rem;padding:.6rem 1rem;display:flex}.arena-input-bar textarea{resize:none;flex:1;min-height:40px;max-height:100px;padding:.5rem .75rem;font-size:.9rem}.arena-action-btns{background:var(--surface);flex-shrink:0;gap:.4rem;padding:.4rem 1rem .65rem;display:flex}.score-ring{flex-direction:column;align-items:center;gap:.25rem;padding:1.5rem 0;display:flex}.score-number{color:var(--accent);font-size:3.5rem;font-weight:800;line-height:1}.score-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;font-weight:600}.score-bar-track{background:var(--border);border-radius:99px;height:8px}.score-bar-fill{background:var(--accent);border-radius:99px;height:8px;transition:width .5s}.action-item{align-items:flex-start;gap:.75rem;display:flex}.action-num{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:.75rem;font-weight:700;display:flex}.key-display{background:var(--bg);border-radius:var(--radius-sm);letter-spacing:.05em;border:1.5px solid var(--border);padding:.35rem .75rem;font-family:monospace;font-size:.875rem}.guide-step{border-bottom:1px solid var(--border);align-items:flex-start;gap:.75rem;padding:.75rem 0;display:flex}.guide-step:last-child{border-bottom:none}.guide-step-num{background:var(--accent-light);color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:1.75rem;height:1.75rem;font-size:.875rem;font-weight:700;display:flex}
