:root{--red: #d2232a;--red-deep: #a51920;--ink: #1c1b1a;--ink-soft: #4c4845;--paper: #f7f3ec;--paper-warm: #efe9df;--white: #fffdf9;--line: rgba(28, 27, 26, .14);--font-display: "Archivo", "Helvetica Neue", sans-serif;--font-body: "Archivo", "Helvetica Neue", sans-serif;--gable: polygon(50% 0%, 100% 26%, 100% 100%, 0% 100%, 0% 26%);--ease: cubic-bezier(.22, .8, .26, .99)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}[hidden]{display:none!important}a{color:inherit}body{font-family:var(--font-body);font-size:16px;line-height:1.55;color:var(--ink);background:radial-gradient(1200px 600px at 85% -5%,rgba(210,35,42,.06),transparent 60%),var(--paper);-webkit-font-smoothing:antialiased;display:flex;flex-direction:column}::selection{background:var(--red);color:var(--white)}img{display:block;max-width:100%}h1,h2{font-family:var(--font-display);font-weight:700;font-stretch:125%;line-height:1.08;letter-spacing:-.02em}h1 em,h2 em{font-style:normal;color:var(--red)}#app{flex:1;display:flex;flex-direction:column;min-height:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.4rem;border-bottom:1px solid var(--line);background:var(--white)}.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;font-weight:800;font-stretch:125%;letter-spacing:.04em;color:var(--ink)}.brand em{font-style:normal;color:var(--red)}.topbar-note{font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}.lobby{flex:1;display:grid;place-items:center;padding:2rem 1.2rem}.lobby-card{max-width:560px;text-align:center;background:var(--white);border:1px solid var(--line);border-radius:18px;padding:2.4rem 2.2rem;box-shadow:0 24px 60px #1c1b1a1a}.lobby-card h1{font-size:clamp(1.6rem,4vw,2.2rem);margin:1.1rem 0 .7rem}.lobby-card p{color:var(--ink-soft)}.lobby-portrait{position:relative;width:132px;margin:0 auto}.lobby-portrait img{width:132px;height:132px;object-fit:cover;border-radius:50%;border:3px solid var(--red)}.lobby-badge{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);background:var(--red);color:var(--white);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.22rem .6rem;border-radius:999px;white-space:nowrap}.lobby-hints{list-style:none;text-align:left;margin:1.3rem auto 1.6rem;max-width:420px;display:grid;gap:.45rem;font-size:.88rem;color:var(--ink-soft)}.lobby-hints a{color:var(--red)}.lobby-error{margin-top:1rem;color:var(--red-deep);font-weight:600}#website{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}.btn-primary{display:inline-block;background:var(--red);color:var(--white);font-family:var(--font-display);font-weight:700;font-stretch:115%;font-size:1rem;letter-spacing:.02em;border:0;border-radius:10px;padding:.9rem 2.2rem;cursor:pointer;text-decoration:none;transition:background .2s var(--ease),transform .2s var(--ease)}.btn-primary:hover{background:var(--red-deep);transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:wait;transform:none}.btn-ghost{background:transparent;border:1px solid var(--line);border-radius:10px;padding:.9rem 1.4rem;font-weight:600;cursor:pointer;color:var(--ink-soft)}.call{flex:1;display:grid;grid-template-columns:1fr 340px;min-height:0}.stage{display:flex;flex-direction:column;min-width:0;min-height:0;padding:1.1rem;gap:1rem;background:var(--ink)}.tiles{flex:1;display:grid;gap:1rem;min-height:0;grid-template-columns:1fr;align-content:center}.tiles.sharing{grid-template-columns:minmax(220px,1fr) 2fr;grid-template-rows:minmax(0,1fr);align-content:stretch}.tile{position:relative;border-radius:14px;overflow:hidden;background:#262422;min-height:0;max-height:100%}.tile-ralph{display:grid;place-items:center;aspect-ratio:4/3;max-height:70vh}.tiles.sharing .tile-ralph{aspect-ratio:auto;max-height:none;height:100%}.tile-ralph img,.tile-ralph video{width:100%;height:100%;object-fit:cover}.tile-ralph figcaption{position:absolute;left:.9rem;bottom:.9rem;display:flex;flex-direction:column;gap:.15rem;background:#1c1b1ab8;color:var(--white);padding:.5rem .85rem;border-radius:9px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.tile-name{font-weight:700;font-size:.92rem}.tile-status{font-size:.76rem;opacity:.85}.tile-status.listening:before{content:"● ";color:#6fcf6f}.tile-status.speaking:before{content:"● ";color:var(--red)}.tile-status.thinking:after{content:"";display:inline-block;width:1.1em;text-align:left;animation:think-dots 1.2s steps(4) infinite}@keyframes think-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.tile-status.thinking:after{content:"…";animation:pulse-dot 1s infinite}.share-topic{margin-left:auto;color:var(--ink);font-size:.8rem;letter-spacing:.04em;text-transform:none;font-weight:800}.pulse-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:14px;pointer-events:none;border:3px solid transparent;transition:border-color .25s}.tile-ralph.speaking .pulse-ring{border-color:var(--red);animation:pulse 1.6s infinite}@keyframes pulse{0%{box-shadow:inset 0 0 #d2232a59}70%{box-shadow:inset 0 0 0 14px #d2232a00}to{box-shadow:inset 0 0 #d2232a00}}.tile-share{background:var(--white);display:flex;flex-direction:column;overflow:hidden}.share-head{display:flex;align-items:center;gap:.5rem;padding:.6rem .9rem;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--line)}.share-dot{width:9px;height:9px;border-radius:50%;background:#4caf50;animation:pulse-dot 1.8s infinite}@keyframes pulse-dot{50%{opacity:.35}}.share-body{flex:1;overflow:auto;padding:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,250px));justify-content:center;align-content:start}.house-card{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--white);box-shadow:0 10px 26px #1c1b1a14;animation:card-in .5s var(--ease)}@keyframes card-in{0%{opacity:0;transform:translateY(16px)}}.house-card img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--paper-warm)}.house-card .hc-noimg{width:100%;aspect-ratio:4/3;display:grid;place-items:center;background:var(--paper-warm)}.house-card .hc-noimg img{width:56px;height:56px;aspect-ratio:auto;opacity:.45}.house-card .hc-body{padding:.75rem .85rem .9rem}.house-card h3{font-size:1.02rem;font-weight:700;font-stretch:120%}.house-card .hc-line{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red)}.house-card .hc-meta{font-size:.84rem;color:var(--ink-soft);margin-top:.25rem}.house-card .hc-price{font-weight:700;margin-top:.3rem}.house-card .hc-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:.55rem;font-size:.8rem;font-weight:700;color:var(--red);text-decoration:none}.house-card .hc-link:hover{text-decoration:underline}.house-card .hc-link svg{width:13px;height:13px;fill:currentColor}.offer-confirm{grid-column:1 / -1;text-align:center;padding:1.4rem;border:2px solid #4caf50;border-radius:12px;background:#f3faf3}.offer-confirm strong{display:block;font-size:1.05rem;margin-bottom:.3rem}.viz{--level: 0;display:flex;align-items:center;gap:4px;height:34px}.viz span{width:5px;border-radius:3px;background:var(--white);height:calc(6px + var(--level) * 26px);transition:height .09s linear}.viz span:nth-child(1),.viz span:nth-child(5){height:calc(5px + var(--level) * 14px)}.viz span:nth-child(2),.viz span:nth-child(4){height:calc(6px + var(--level) * 20px)}.viz-bot{position:absolute;right:.9rem;bottom:.9rem;background:#1c1b1ab8;border-radius:999px;padding:.45rem .7rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.viz-bot span{background:var(--red)}.tile-ralph.speaking .viz-bot span{background:#ff5a60}.viz-user{background:#fffdf91f;border-radius:999px;padding:.45rem .7rem}.viz-user span{background:#fffdf98c}.viz-user.talking span{background:#6fcf6f}.call-timer{font-variant-numeric:tabular-nums;font-weight:700;color:#fffdf9bf;background:#fffdf91f;border-radius:999px;padding:.55rem .9rem;font-size:.9rem}.call-timer.warning{color:var(--white);background:var(--red);animation:pulse-dot 1.4s infinite}.controls{display:flex;justify-content:center;gap:.9rem}.ctl{display:flex;align-items:center;gap:.5rem;border:0;cursor:pointer;border-radius:999px;padding:.7rem 1.3rem;font-weight:700;background:#fffdf91f;color:var(--white);transition:background .2s}.ctl-ico{width:18px;height:18px;fill:currentColor;flex:none}.ctl.muted .ctl-ico{opacity:.45}.ctl:hover{background:#fffdf938}.ctl.muted{background:var(--white);color:var(--ink)}.ctl-end{background:var(--red)}.ctl-end:hover{background:var(--red-deep)}.transcript{display:flex;flex-direction:column;min-height:0;border-left:1px solid var(--line);background:var(--white)}.transcript-head{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--line)}.transcript-toggle{display:none;border:0;background:none;font-size:1rem;cursor:pointer;color:var(--ink-soft)}.transcript-body{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.65rem}.msg{max-width:92%;padding:.55rem .8rem;border-radius:12px;font-size:.9rem;animation:card-in .35s var(--ease)}.msg-user{align-self:flex-end;background:var(--paper-warm);border-bottom-right-radius:4px}.msg-bot{align-self:flex-start;background:#d2232a14;border-bottom-left-radius:4px}.msg-bot:before{content:"Ralph";display:block;font-size:.68rem;font-weight:700;color:var(--red);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.15rem}.chat-form{display:flex;gap:.5rem;padding:.7rem;border-top:1px solid var(--line)}.chat-form input{flex:1;font:inherit;padding:.55rem .7rem;min-width:0;border:1px solid var(--line);border-radius:8px;background:var(--white);color:var(--ink)}.chat-form input:focus{outline:2px solid var(--red);border-color:transparent}.chat-form .btn-small{padding:.55rem .85rem}.pk-points{margin:.5rem 0 0 1.1rem;font-size:.85rem;color:var(--ink-soft)}.pk-points li{margin-bottom:.2rem}.channel-card{grid-column:1 / -1;max-width:560px;justify-self:center;width:100%;text-align:center;border:2px solid var(--red);border-radius:12px;background:var(--white);padding:1.2rem 1.1rem;animation:card-in .5s var(--ease)}.channel-card strong{font-size:1.1rem;font-stretch:120%}.channel-card p{font-size:.85rem;color:var(--ink-soft);margin:.4rem 0 .9rem}.channel-btn{display:block;font-size:1.05rem}.focus-card{grid-column:1 / -1;border:1px solid var(--line);border-radius:12px;background:var(--white);overflow:hidden;max-width:720px;justify-self:center;width:100%;box-shadow:0 10px 26px #1c1b1a14;animation:card-in .5s var(--ease)}.focus-card .fc-grid{display:grid;grid-template-columns:1.2fr 1fr}.focus-card img{width:100%;height:100%;object-fit:cover;min-height:220px;background:var(--paper-warm)}.focus-card .fc-side{padding:1rem 1.1rem;display:flex;flex-direction:column}.focus-card h3{font-size:1.25rem;font-weight:700;font-stretch:120%}.focus-card .hc-line{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red)}.fc-badges{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin:.8rem 0}.fc-badge{border:1px solid var(--line);border-radius:10px;padding:.5rem .6rem;background:var(--paper)}.fc-badge b{display:block;font-size:1.05rem}.fc-badge span{font-size:.72rem;color:var(--ink-soft)}.focus-card .hc-price{font-weight:700;font-size:1.05rem;margin-top:auto}@media(max-width:860px){.focus-card .fc-grid{grid-template-columns:1fr}}.video-card{grid-column:1 / -1;max-width:560px;justify-self:center;width:100%;border:1px solid var(--line);border-radius:12px;background:var(--white);overflow:hidden;box-shadow:0 10px 26px #1c1b1a14;animation:card-in .5s var(--ease)}.video-card .vc-head{padding:.6rem .9rem;font-size:.85rem;font-weight:700;border-bottom:1px solid var(--line)}.video-card .vc-frame{aspect-ratio:16 / 9}.video-card .vc-frame iframe{width:100%;height:100%;display:block;border:0}.video-card .email-hint{padding:.45rem .9rem .6rem;margin:0}.summary-card{grid-column:1 / -1;max-width:560px;justify-self:center;width:100%;border:2px solid var(--red);border-radius:12px;background:var(--white);overflow:hidden;animation:card-in .5s var(--ease)}.summary-card .vc-head{padding:.6rem .9rem;font-size:.85rem;font-weight:700;border-bottom:1px solid var(--line)}.summary-card table{width:100%;border-collapse:collapse;font-size:.85rem}.summary-card td{padding:.4rem .9rem;border-bottom:1px solid var(--line)}.summary-card td:first-child{color:var(--ink-soft);width:42%}.summary-card tr:last-child td{border-bottom:0}.home-card .email-row+.email-row{margin-top:.5rem}.email-card{grid-column:1 / -1;border:1px solid var(--line);border-radius:12px;background:var(--white);padding:1rem 1.1rem;animation:card-in .5s var(--ease);box-shadow:0 10px 26px #1c1b1a14}.email-card label{display:block;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.5rem}.email-row{display:flex;gap:.6rem}.email-row input{flex:1;font:inherit;padding:.65rem .8rem;border:1px solid var(--line);border-radius:8px;background:var(--white);color:var(--ink);min-width:0}.email-row input:focus{outline:2px solid var(--red);border-color:transparent}.btn-small{padding:.65rem 1.1rem;font-size:.9rem;white-space:nowrap}.email-hint{font-size:.78rem;color:var(--ink-soft);margin-top:.5rem}.email-ok{font-size:.95rem;margin:0}@media(max-width:860px){.call{grid-template-columns:1fr;grid-template-rows:1fr auto}.tiles.sharing{grid-template-columns:1fr;grid-template-rows:auto 1fr}.tile-ralph{aspect-ratio:16/10;max-height:34vh}.transcript{border-left:0;border-top:1px solid var(--line);max-height:38vh}.transcript.collapsed .transcript-body{display:none}.transcript-toggle{display:block}.email-row{flex-direction:column}}.share-body{transition:opacity .17s var(--ease),transform .17s var(--ease)}.share-body.stage-out{opacity:0;transform:translateY(10px) scale(.985)}
