@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,700&family=Space+Grotesk:wght@400;500;600&display=swap";.app{width:min(1200px,100%);height:min(92vh,900px);display:flex;flex-direction:column;background:var(--paper);border-radius:26px;border:1px solid var(--line);box-shadow:0 28px 60px var(--shadow);overflow:hidden;position:relative;animation:floatIn .6s ease both}.app--landing{overflow:hidden}.app--landing .app-main{overflow-y:auto;-webkit-overflow-scrolling:touch}.app--chat .app-main{overflow:hidden}.app:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 0%,rgba(255,255,255,.5),transparent 45%),radial-gradient(circle at 85% 12%,rgba(255,236,214,.42),transparent 50%);pointer-events:none}.app-header{position:relative;z-index:1;padding:8px 18px 6px;padding-top:calc(6px + env(safe-area-inset-top));background:linear-gradient(120deg,#2c221c,#3d2f27 55%,#473225);color:#fef1dc;display:flex;flex-direction:column;gap:4px}.header-row{display:flex;align-items:center;gap:8px;min-width:0}.header-row--secondary{display:flex;align-items:center;gap:10px}.brand{display:flex;align-items:center;gap:10px;min-width:0}.logo-icon{width:32px;height:32px;flex-shrink:0}.brand-title{font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:.02em;line-height:1;white-space:nowrap}.brand-subtitle{font-size:11px;color:#fef1dcbf;line-height:1.2;white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis}.header-controls{display:flex;align-items:center;gap:8px;flex:1;min-width:0;flex-wrap:nowrap;justify-content:flex-start}.header-controls .button.danger{margin-left:auto}.room-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:#ffffff24;border:1px solid rgba(255,255,255,.3);font-size:11px;white-space:nowrap}.chip-label{text-transform:uppercase;letter-spacing:.18em;font-size:10px;opacity:.7}.chip-value{font-weight:600;max-width:180px;overflow:hidden;text-overflow:ellipsis}.status{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;background:#00000040;font-size:10px}.status-dot{width:8px;height:8px;border-radius:999px;background:#f4a43d;box-shadow:0 0 8px #f4a43dcc}.status-online .status-dot{background:#45d087;box-shadow:0 0 8px #45d087cc}.status-text{letter-spacing:.08em;text-transform:uppercase;font-size:10px}.app-main{position:relative;z-index:1;flex:1;min-height:0;padding:22px 24px calc(18px + var(--keyboard-offset, 0px));display:flex;flex-direction:column;gap:16px;overflow:hidden;overscroll-behavior:contain}.banner{padding:12px 16px;border-radius:12px;font-size:14px}.banner-error{background:#f7e0d4;color:#8a2d1c;border:1px solid #e6b9a3}.banner-note{background:#efe3d4;color:#6e4b2b;border:1px solid #dec2a5}.loading-panel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted)}.loading-spinner{width:44px;height:44px;border-radius:999px;border:3px solid #e6caa7;border-top-color:#c56c2d;animation:spin 1s linear infinite}.room-panel{flex:1;display:flex;flex-direction:column;gap:18px;width:100%;max-width:1040px;margin:0 auto}.room-hero{background:linear-gradient(120deg,#fff3e3,#fffaf4 55%,#f6eee2);border:1px solid var(--line);border-radius:18px;padding:20px;display:grid;gap:16px;box-shadow:0 16px 32px #2f261f1f}.hero-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#c0502e1f;color:#8a3e25;font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase}.hero-text h2{font-family:var(--font-display);font-size:30px}.hero-text p{color:var(--muted);max-width:620px}.hero-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.hero-meta span{padding:6px 10px;border-radius:999px;border:1px solid rgba(92,74,52,.16);background:#ffffffb3;font-size:12px;color:#6f5a47}.hero-card{background:#fff8ee;border:1px dashed rgba(120,84,55,.25);border-radius:16px;padding:16px;display:grid;gap:10px}.hero-card h3{font-family:var(--font-display);font-size:18px}.hero-card ul{list-style:none;display:grid;gap:8px;color:#6f5a47;font-size:14px}.hero-card li{position:relative;padding-left:18px}.hero-card li:before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:50%;background:var(--accent)}@media(min-width:981px){.room-hero{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);align-items:center}}.room-grid{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.room-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:0 16px 32px #2f261f1f;animation:cardIn .6s ease both}.room-card--accent{background:linear-gradient(140deg,#fff4e7,#fffdf8);border-color:#c0502e40}.room-card h3{font-family:var(--font-display);font-size:18px}.room-help{color:var(--muted);font-size:13px}.room-card input{border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-size:14px;background:#fffaf4}.room-card input:focus,.input-wrap:focus-within{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #c0502e2e}.room-card small{font-size:12px;color:var(--muted)}.chat-panel{flex:1;display:flex;flex-direction:column;background:var(--panel);border-radius:18px;border:1px solid var(--line);overflow:hidden;min-height:0;position:relative}.messages-container{flex:1;overflow-y:auto;overflow-x:hidden;background:linear-gradient(180deg,#fff7ec,#f7efe3);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;min-height:0}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:transparent}.messages-container::-webkit-scrollbar-thumb{background:#55402c4d;border-radius:999px}.messages-container::-webkit-scrollbar-thumb:hover{background:#55402c80}.messages-list{display:flex;flex-direction:column;padding:18px 20px;gap:14px;min-height:100%}.load-more-wrapper{display:flex;justify-content:center;padding:16px 20px 0;position:sticky;top:0;z-index:10;background:linear-gradient(180deg,#fff7ec,#fff7ec00)}.load-more-button{padding:8px 16px;border-radius:999px;border:1px dashed rgba(120,84,55,.35);background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #2f261f14}.load-more-button:hover:not(:disabled){background:#fff3e2;color:var(--ink);border-color:#78543780;transform:translateY(-1px);box-shadow:0 4px 12px #2f261f1f}.load-more-button:disabled{cursor:wait;opacity:.6}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;text-align:center;color:var(--muted);min-height:100%}.empty-state-icon{font-size:48px;opacity:.5;animation:floatIcon 3s ease-in-out infinite}.empty-state-title{margin:0;font-size:16px;font-weight:600;color:var(--ink)}.empty-state-subtitle{margin:0;font-size:14px;color:var(--muted)}.message{display:flex;animation:messageIn .3s cubic-bezier(.4,0,.2,1) both}.message-own{justify-content:flex-end}.message-other{justify-content:flex-start}.message-bubble{max-width:75%;padding:10px 14px;border-radius:16px;background:#fff;border:1px solid rgba(92,74,52,.12);box-shadow:0 2px 8px #2f261f14;transition:box-shadow .2s ease}.message-bubble:hover{box-shadow:0 4px 16px #2f261f24}.message-own .message-bubble{background:var(--accent);color:#fff;border-color:transparent;box-shadow:0 2px 12px #c0502e40}.message-own .message-bubble:hover{box-shadow:0 4px 20px #c0502e59}.message-header{display:flex;align-items:center;gap:7px;margin-bottom:6px}.message-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.message-author{font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:10px}.message-time{margin-left:auto;font-size:10px;color:var(--muted);opacity:.8}.message-own .message-time,.message-own .message-author{color:#fffc}.message-content{margin:0;line-height:1.5;word-break:break-word;white-space:pre-wrap;font-size:15px}.input-form{display:flex;gap:10px;padding:12px;border-top:1px solid rgba(92,74,52,.18);background:#f5efe6;align-items:flex-end;box-shadow:0 -6px 16px #2f261f14;flex-shrink:0;position:relative}.input-container{flex:1;min-width:0;background:#fff;border:1px solid rgba(92,74,52,.2);border-radius:20px;padding:8px 14px;box-shadow:inset 0 1px #ffffffb3;transition:border-color .2s ease,box-shadow .2s ease}.input-container:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #c0502e1f}.message-input{width:100%;border:none;padding:0;margin:0;font-family:inherit;font-size:15px;line-height:1.5;background:transparent;resize:none;outline:none;overflow-y:auto;max-height:200px;min-height:24px;display:block;scrollbar-width:thin;scrollbar-color:rgba(85,64,44,.3) transparent}.message-input::placeholder{color:var(--muted);opacity:.7}.message-input::-webkit-scrollbar{width:5px}.message-input::-webkit-scrollbar-thumb{background:#55402c4d;border-radius:999px}.message-input:disabled{opacity:.6;cursor:not-allowed}.send-button{width:46px;height:46px;border-radius:50%;border:none;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #c0502e59;cursor:pointer;flex-shrink:0;transition:all .2s cubic-bezier(.4,0,.2,1)}.send-button:hover:not(:disabled){background:var(--accent-strong);transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #c0502e73}.send-button:active:not(:disabled){transform:translateY(0) scale(.98)}.send-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:0 2px 8px #c0502e33}.button{border:none;border-radius:999px;padding:12px 18px;font-weight:600;font-size:14px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.button.primary{background:var(--accent);color:#fff;box-shadow:0 10px 24px #c0502e59}.button.primary:hover{background:var(--accent-strong);transform:translateY(-1px)}.button.secondary{background:transparent;border:1px solid var(--line);color:var(--ink)}.button.secondary:hover{background:#fff3e2}.button.ghost{background:#ffffff2e;border:1px solid rgba(255,255,255,.25);color:#fff}.button.ghost:hover{background:#ffffff47}.button.danger{background:#b14a37;color:#fff;box-shadow:0 10px 24px #b14a3759}.button.danger:hover{background:#983c2c}@media(max-width:980px){.app{height:var(--app-height, 100vh)}.header-row--secondary{flex-wrap:wrap;gap:6px}.brand-subtitle{white-space:normal}.header-controls{width:100%}.room-grid{grid-template-columns:1fr}.hero-text h2{font-size:26px}.messages-list{padding:14px 16px}.message-bubble{max-width:85%}.input-form{padding:10px}}@media(max-width:720px){.app{height:var(--app-height, 100vh);border-radius:0}.app-header{padding:8px 10px 6px;padding-top:calc(4px + env(safe-area-inset-top));gap:4px}.header-row--secondary{flex-direction:column;align-items:flex-start;gap:4px}.logo-icon{width:24px;height:24px}.brand-title{font-size:16px}.room-chip{padding:3px 8px;font-size:11px}.brand-subtitle{width:100%}.chip-value{max-width:100px}.header-controls{width:100%;justify-content:flex-start;flex-wrap:wrap;row-gap:6px}.status{display:none}.button.ghost,.button.danger{padding:6px 8px;font-size:11px}.app-main{padding:16px 14px calc(14px + var(--keyboard-offset, 0px))}.room-hero{padding:16px}.hero-text h2{font-size:22px}.hero-card,.room-card{padding:14px}.messages-list{padding:12px;gap:12px}.message-bubble{max-width:90%;padding:8px 12px}.message-content{font-size:14px}.input-form{gap:8px;padding:8px}.input-container{padding:6px 12px}.message-input{font-size:16px}.send-button{width:42px;height:42px}.room-card input,.input-area textarea{font-size:16px}.button{width:100%}.button.ghost,.button.danger{width:auto}}@keyframes floatIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes messageIn{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}html{height:100%}:root{color-scheme:light;--font-display: "Fraunces", "Times New Roman", serif;--font-body: "Space Grotesk", "Segoe UI", sans-serif;--ink: #2f261f;--muted: #7a6757;--paper: #fff9f1;--panel: #fffdf8;--line: #e6d5c1;--accent: #c0502e;--accent-strong: #a54426;--shadow: rgba(39, 28, 18, .22)}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh;height:100%;background:radial-gradient(circle at 12% 10%,rgba(236,203,164,.55),transparent 45%),radial-gradient(circle at 82% 14%,rgba(169,197,150,.35),transparent 45%),linear-gradient(140deg,#f9f2e6,#f3e0c7 45%,#e7d0b3);color:var(--ink);font-family:var(--font-body);line-height:1.5;overflow:hidden;-webkit-text-size-adjust:100%}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(90deg,rgba(255,255,255,.18) 0,rgba(255,255,255,.18) 2px,transparent 2px,transparent 24px),linear-gradient(0deg,rgba(255,255,255,.18) 0,rgba(255,255,255,.18) 2px,transparent 2px,transparent 24px);opacity:.35;pointer-events:none}body:after{content:"";position:fixed;inset:0;background:radial-gradient(circle at 90% 90%,rgba(255,255,255,.5),transparent 45%);opacity:.6;pointer-events:none}#root{height:var(--app-height, 100vh);min-height:var(--app-height, 100vh);display:flex;align-items:stretch;justify-content:center;padding:24px;overflow:hidden}@supports (-webkit-touch-callout: none){body,#root{height:var(--app-height, -webkit-fill-available);min-height:var(--app-height, -webkit-fill-available)}}img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}button,input{font:inherit;color:inherit}button:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(max-width:720px){#root{padding:0}}
