:root{color:#1f2520;background:#f7f4ee;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;line-height:1.5;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{cursor:pointer}.app-shell,.auth-shell,.intro-shell{display:grid;min-height:100vh}.app-shell{grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);background:linear-gradient(115deg,rgba(245,117,93,.12),transparent 34%),linear-gradient(305deg,rgba(48,128,132,.16),transparent 40%),#f7f4ee}.auth-shell,.intro-shell{place-items:center;padding:24px;background:linear-gradient(115deg,rgba(228,87,61,.12),transparent 34%),linear-gradient(300deg,rgba(39,79,82,.16),transparent 38%),#f7f4ee}.auth-panel,.intro-panel{display:grid;gap:22px;width:min(100%,430px);border:1px solid rgba(31,37,32,.1);border-radius:8px;padding:28px;background:#fffdf8f0;box-shadow:0 24px 60px #1f25201f}.auth-copy,.intro-copy{display:grid;gap:8px}.auth-copy h1,.intro-copy h1{margin:0;color:#1f2520;font-size:1.8rem;line-height:1.1;letter-spacing:0}.auth-copy p,.intro-copy p{margin:0;color:#6d716b}.auth-toggle{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:5px;border-radius:8px;background:#f1ebe2}.auth-toggle button{min-height:38px;border:0;border-radius:7px;background:transparent;color:#596158}.auth-toggle button.selected{background:#fff;color:#1f2520;box-shadow:0 1px #1f252014}.auth-form{display:grid;gap:14px}.auth-form label{display:grid;gap:6px;color:#485047;font-size:.9rem;font-weight:700}.auth-form input{min-height:48px;border:1px solid rgba(31,37,32,.14);border-radius:8px;padding:0 14px;background:#fff;color:#202620}.auth-error{margin:-2px 0 0;color:#934432;font-size:.86rem;font-weight:700}.auth-notice{margin:-2px 0 0;color:#2f6f58;font-size:.86rem;font-weight:700}.auth-form button,.primary-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;border:0;border-radius:8px;background:#e4573d;color:#fff;font-weight:800}.auth-form button:disabled{opacity:.72;cursor:not-allowed}.auth-form .text-button{min-height:auto;justify-self:start;border:0;padding:0;background:transparent;color:#2f6f58;font-weight:800}.chat-pane{display:grid;grid-template-rows:auto minmax(0,1fr) auto;min-height:100vh;border-right:1px solid rgba(31,37,32,.1)}.topbar{display:grid;grid-template-columns:44px minmax(0,1fr) 40px 40px;align-items:center;gap:14px;padding:22px clamp(18px,4vw,48px);background:#fffdf8bf;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid rgba(31,37,32,.08)}.brand-mark,.icon-button,.message-avatar,.round-action,.composer button{display:inline-grid;place-items:center;border:0}.brand-mark{width:44px;height:44px;border-radius:8px;color:#fffaf4;background:#e4573d;box-shadow:0 12px 24px #c5412b3d}.brand-mark.large{width:54px;height:54px}.topbar h1,.profile-copy h2,.panel-heading h2,.match-title h3{margin:0;letter-spacing:0}.topbar h1{font-size:1.2rem}.topbar p,.profile-copy p,.match-body p{margin:0;color:#6d716b}.icon-button{width:40px;height:40px;border-radius:8px;color:#374036;background:#fff;box-shadow:0 1px #1f252014}.chat-scroll{display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding:28px clamp(18px,4vw,48px)}.assistant-stage{display:grid;grid-template-columns:86px minmax(0,1fr);align-items:center;gap:18px;padding:22px clamp(18px,4vw,48px);border-bottom:1px solid rgba(31,37,32,.08);background:#fffdf885}.assistant-stage h2{margin:0;color:#1f2520;font-size:1.12rem;letter-spacing:0}.assistant-mark{position:relative;display:grid;place-items:center;width:76px;height:76px;color:#fff;border-radius:50%;background:#274f52;overflow:hidden}.assistant-mark.intro{width:104px;height:104px}.assistant-mark span{position:absolute;width:18%;height:44%;border-radius:99px;background:#fff9;transform-origin:center;animation:voiceBar 1.35s ease-in-out infinite}.assistant-mark span:nth-child(1){transform:translate(-22px) scaleY(.55)}.assistant-mark span:nth-child(2){animation-delay:.12s;transform:scaleY(.82)}.assistant-mark span:nth-child(3){animation-delay:.24s;transform:translate(22px) scaleY(.55)}.assistant-mark svg{position:relative;z-index:1}.assistant-mark.awake,.assistant-mark.intro{background:#e4573d}.assistant-mark.speaking span,.assistant-mark.listening span,.assistant-mark.intro span{animation-duration:.78s}.assistant-mark.speaking{box-shadow:0 0 0 8px #e4573d24}.assistant-mark.listening{box-shadow:0 0 0 8px #274f5229}@keyframes voiceBar{0%,to{height:28%;opacity:.52}50%{height:62%;opacity:.88}}.message{display:grid;grid-template-columns:32px minmax(0,auto);gap:10px;max-width:760px;align-items:start}.message.user{align-self:end;grid-template-columns:minmax(0,auto) 32px}.message.user .message-avatar{grid-column:2;grid-row:1}.message.user p{grid-column:1;grid-row:1;background:#274f52;color:#fff}.message-avatar{width:32px;height:32px;border-radius:8px;background:#fff;color:#e4573d;box-shadow:0 8px 18px #1f252014}.message p{margin:0;padding:13px 15px;border-radius:8px;background:#fff;color:#2e342f;box-shadow:0 10px 28px #1f252014}.typing-dots{display:inline-flex;align-items:center;gap:4px;margin-left:7px;vertical-align:middle}.typing-dots span{width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.35;animation:typingPulse 1s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.14s}.typing-dots span:nth-child(3){animation-delay:.28s}@keyframes typingPulse{0%,to{transform:translateY(0);opacity:.28}50%{transform:translateY(-3px);opacity:.85}}.composer-wrap{padding:16px clamp(18px,4vw,48px) 24px;background:#fffdf8db;border-top:1px solid rgba(31,37,32,.08);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.quick-row{display:flex;gap:10px;margin-bottom:10px;min-height:38px}.upload-button,.ghost-button,.voice-button{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 12px;border:1px solid rgba(31,37,32,.12);border-radius:8px;background:#fff;color:#374036}.voice-button{background:#e4573d;color:#fff;border-color:#e4573d}.voice-button.active,.voice-button.listening{background:#274f52;border-color:#274f52}.voice-button.listening{box-shadow:0 0 0 4px #274f5229}.voice-button:disabled{cursor:not-allowed;opacity:.55}.voice-fallback{margin:-2px 0 10px;color:#934432;font-size:.84rem}.upload-button input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.composer{display:grid;grid-template-columns:minmax(0,1fr) 48px;gap:10px}.composer input{width:100%;min-height:52px;border:1px solid rgba(31,37,32,.14);border-radius:8px;padding:0 16px;background:#fff;color:#202620;outline:none}.composer input:focus{border-color:#e4573d;box-shadow:0 0 0 4px #e4573d24}.composer button{width:48px;min-height:52px;border-radius:8px;background:#e4573d;color:#fff}.composer button:disabled{cursor:not-allowed;opacity:.45}.profile-pane{display:grid;align-content:start;gap:18px;padding:clamp(18px,3vw,34px);overflow-y:auto;max-height:100vh}.profile-card,.matches-panel{border:1px solid rgba(31,37,32,.1);border-radius:8px;background:#fffdf8eb;box-shadow:0 22px 50px #1f25201a}.profile-card{overflow:hidden}.photo-frame{aspect-ratio:16 / 10;background:#dfddd4}.photo-frame img,.match-card img{width:100%;height:100%;object-fit:cover;display:block}.photo-placeholder{display:grid;place-items:center;height:100%;color:#687169}.profile-copy{display:grid;gap:8px;padding:18px 18px 4px}.eyebrow{margin:0;color:#e4573d;font-size:.73rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.profile-copy h2,.panel-heading h2{font-size:1.18rem;color:#1f2520}.trait-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;padding:18px}.trait{min-height:78px;padding:12px;background:#f4efe7;border-radius:8px;overflow:hidden}.trait span{display:block;color:#73786f;font-size:.78rem;margin-bottom:5px}.trait strong{display:-webkit-box;overflow:hidden;color:#28312a;font-size:.92rem;line-height:1.25;-webkit-line-clamp:2;-webkit-box-orient:vertical}.matches-panel{padding:18px}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px;color:#274f52}.safety-note{display:flex;align-items:center;gap:8px;padding:10px;margin-bottom:14px;border-radius:8px;background:#eef5f3;color:#42514b;font-size:.84rem}.match-list{display:grid;gap:12px}.matches-locked{display:grid;place-items:center;gap:10px;min-height:190px;padding:22px;border:1px dashed rgba(39,79,82,.24);border-radius:8px;background:#fff;color:#42514b;text-align:center}.matches-locked p{max-width:280px;margin:0}.match-card{display:grid;grid-template-columns:74px minmax(0,1fr) 38px;gap:12px;align-items:center;min-height:104px;padding:10px;border-radius:8px;background:#fff;border:1px solid rgba(31,37,32,.08)}.match-card img{aspect-ratio:1;border-radius:8px}.match-body{min-width:0}.match-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}.match-title h3{font-size:.98rem;color:#1f2520}.match-title span{color:#e4573d;font-weight:800}.match-body p{display:-webkit-box;overflow:hidden;font-size:.86rem;line-height:1.35;-webkit-line-clamp:2;-webkit-box-orient:vertical}.reason-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.reason-row span{padding:4px 7px;border-radius:999px;background:#f6ebe7;color:#934432;font-size:.72rem;font-weight:700}.round-action{width:36px;height:36px;border-radius:50%;background:#274f52;color:#fff}@media(max-width:920px){.app-shell{grid-template-columns:1fr}.chat-pane{min-height:68vh;border-right:0}.profile-pane{max-height:none;padding-top:0}}@media(max-width:560px){.topbar{padding:14px;grid-template-columns:40px minmax(0,1fr) 38px 38px}.brand-mark{width:40px;height:40px}.chat-scroll{padding:18px 14px}.assistant-stage{grid-template-columns:68px minmax(0,1fr);gap:12px;padding:16px 14px}.assistant-mark{width:62px;height:62px}.message,.message.user{max-width:100%}.composer-wrap{padding:12px 14px 16px}.profile-pane{padding:14px}.trait-grid{grid-template-columns:1fr}.match-card{grid-template-columns:64px minmax(0,1fr)}.round-action{display:none}}
