.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,var(--header-start),var(--header-mid) 55%,var(--header-end) 100%);color:var(--header-text);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:var(--header-subtext);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:#865494;box-shadow:0 0 8px #865494cc}.status-online .status-dot{background:#45d087;box-shadow:0 0 8px #45d087cc}.status-text{letter-spacing:.08em;text-transform:uppercase;font-size:10px}.presence-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;background:#45d08733;border:1px solid rgba(69,208,135,.4);font-size:11px;font-weight:600;color:#fffffff2;cursor:help;transition:all .2s ease}.presence-badge:hover{background:#45d0874d;border-color:#45d08799}.presence-badge svg{flex-shrink:0}.presence-count{font-variant-numeric:tabular-nums;letter-spacing:.02em}.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}.app--landing .app-main{position:fixed;inset:0;padding-top:90px;overflow-y:auto;-webkit-overflow-scrolling:touch}.banner{padding:12px 16px;border-radius:12px;font-size:14px}.alert-stack{position:absolute;top:0;left:0;right:0;display:grid;gap:8px;z-index:6;pointer-events:none}.alert-stack .banner{pointer-events:auto}.banner-error{background:#e8e5f7;color:#4a2c6e;border:1px solid #c4b5e0}.banner-note{background:#e3e8f7;color:#3d4c7a;border:1px solid #bcc7e6}.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 #d4c7e8;border-top-color:#865494;animation:spin 1s linear infinite}.room-panel{flex:1;display:flex;flex-direction:column;gap:18px;width:100%;max-width:1040px;margin:0 auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.room-hero{background:linear-gradient(120deg,#e8e5f7,#f4f2fc 55%,#ede9f8);border:1px solid var(--line);border-radius:18px;padding:20px;display:grid;gap:16px;box-shadow:0 16px 32px #4a5db81f;flex-shrink:0}.hero-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#86549426;color:#5a3a6e;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(134,84,148,.2);background:#ffffffb3;font-size:12px;color:#5a3a6e}.hero-card{background:#f4f2fc;border:1px dashed rgba(134,84,148,.3);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:#5a3a6e;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{flex-shrink:0;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,#ede9f8,#fafaff);border-color:#8654944d}.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:#fafaff}.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,#f0eef8,#e8e5f2);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;min-height:0;position:relative}.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 54px;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,#f0eef8,#f0eef800);animation:slideDown .3s cubic-bezier(.4,0,.2,1) both}.load-more-button{padding:8px 16px;border-radius:999px;border:1px dashed rgba(134,84,148,.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 #4a5db814}.load-more-button:hover:not(:disabled){background:#f0eef8;color:var(--ink);border-color:#86549480;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)}.typing-indicator-wrapper{position:absolute;left:20px;bottom:calc(100% + 8px);margin:0;width:max-content;pointer-events:none;z-index:5}.typing-indicator{display:inline-block}.typing-bubble{display:inline-flex;align-items:center;padding:12px 16px;background-color:#fff;border:1px solid rgba(0,0,0,.08);border-radius:18px;box-shadow:0 2px 8px #0000000f;animation:bubbleFadeIn .3s ease-out}.typing-dots{display:flex;align-items:center;gap:5px}.typing-dot{width:8px;height:8px;background-color:var(--typing-dot);border-radius:50%;animation:dotBounce 1.4s ease-in-out infinite}.typing-dot:nth-child(1){animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes bubbleFadeIn{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes dotBounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.chat-disabled-banner{padding:12px 20px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;text-align:center;font-weight:600;font-size:14px;border-top:1px solid rgba(217,119,6,.2);box-shadow:0 -2px 12px #d9770626;flex-shrink:0;animation:slideUp .3s cubic-bezier(.4,0,.2,1) both}.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{color:#eeeeed;max-width:75%;padding:10px 14px;border-radius:16px;background:#013ba2;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}.message-link{color:#fff;text-decoration:underline;text-decoration-style:solid;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .2s ease;cursor:pointer;font-weight:500}.message-link:hover{text-decoration-thickness:2px;opacity:.9}.message-link:active{opacity:.8}.message-other .message-link{color:#e8f4ff;text-decoration-color:#fff9}.message-other .message-link:hover{text-decoration-color:#ffffffe6}.input-form{display:flex;gap:10px;padding:12px;border-top:1px solid rgba(134,84,148,.18);background:#ebe8f5;align-items:flex-end;box-shadow:none;flex-shrink:0;position:relative}.input-container{flex:1;min-width:0;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(134,84,148,.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}.button.warning{background:#d97706;color:#fff;box-shadow:0 10px 24px #d9770659}.button.warning:hover{background:#b45309}.button.success{background:#059669;color:#fff;box-shadow:0 10px 24px #05966959}.button.success:hover{background:#047857}@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 12px 42px;gap:12px}.typing-indicator-wrapper{left: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 slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@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}}.attach-button{flex-shrink:0;width:32px;height:32px;padding:6px;background:transparent;border:none;border-radius:50%;color:var(--accent);cursor:pointer;transition:background-color .2s ease,transform .1s ease;display:flex;align-items:center;justify-content:center}.attach-button:hover:not(:disabled){background-color:#c0502e1a}.attach-button:active:not(:disabled){transform:scale(.95)}.attach-button:disabled{opacity:.5;cursor:not-allowed}.attach-button svg{display:block}.message-image-card{margin-top:8px;width:80px;height:80px;border-radius:10px;overflow:hidden;background:linear-gradient(135deg,var(--line) 0%,rgba(0,0,0,.03) 100%);cursor:pointer;transition:all .2s ease;position:relative;border:2px solid var(--line);display:inline-flex}.message-image-card:hover{transform:scale(1.08);box-shadow:0 4px 12px #00000026;border-color:var(--accent)}.image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--accent);opacity:.6;transition:opacity .2s ease}.message-image-card:hover .image-placeholder{opacity:.9}.image-placeholder svg{opacity:.7}.image-placeholder span{font-size:9px;font-weight:500;text-align:center}.message-image{width:100%;height:100%;object-fit:cover;display:block}.image-viewer-backdrop{position:fixed;inset:0;width:100%;height:100%;background:#000000f5;z-index:999998;cursor:zoom-out;-webkit-tap-highlight-color:transparent;touch-action:none}.image-viewer-container{position:fixed;inset:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;z-index:999999;pointer-events:none;-webkit-tap-highlight-color:transparent}.image-viewer-close{position:fixed;top:20px;right:20px;background:#fff;border:none;width:48px;height:48px;border-radius:50%;font-size:32px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:0 4px 16px #0006;transition:transform .15s ease;z-index:1000000;font-weight:300;pointer-events:auto;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.image-viewer-close:hover{transform:scale(1.1)}.image-viewer-close:active{transform:scale(.95)}.image-viewer-image{max-width:90vw;max-height:90vh;width:auto;height:auto;object-fit:contain;pointer-events:auto;display:block;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.camera-button{background:transparent;border:none;color:var(--accent);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;flex-shrink:0}.camera-button:hover:not(:disabled){background:var(--line);transform:scale(1.1)}.camera-button:disabled{opacity:.4;cursor:not-allowed}.upload-progress{position:absolute;bottom:100%;left:0;right:0;height:3px;background:#0000001a;margin-bottom:4px;border-radius:999px;overflow:hidden;display:flex;align-items:center;padding:0 8px}.upload-progress-bar{position:absolute;left:0;top:0;bottom:0;background:var(--accent);transition:width .3s ease;border-radius:999px}.upload-progress-text{position:relative;z-index:1;font-size:11px;color:var(--ink);font-weight:600;margin-left:auto}.image-preview-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}.image-preview-modal{background:var(--paper);border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease;display:flex;flex-direction:column}.image-preview-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}.image-preview-header h3{margin:0;font-size:18px;font-weight:600;color:var(--ink)}.close-button{width:36px;height:36px;padding:6px;background:transparent;border:none;border-radius:8px;color:var(--muted);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#0000000d;color:var(--ink)}.image-preview-content{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;align-items:center;gap:12px}.preview-image{max-width:100%;max-height:400px;border-radius:12px;box-shadow:0 4px 12px #0000001a}.preview-filename{font-size:14px;color:var(--ink);font-weight:500;text-align:center;word-break:break-all}.preview-filesize{font-size:12px;color:var(--muted)}.image-preview-actions{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--line)}.button{flex:1;padding:12px 24px;font-size:15px;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease}.button-secondary{background:#0000000d;color:var(--ink)}.button-secondary:hover{background:#0000001a}.button-primary{background:var(--accent);color:#fff}.button-primary:hover{background:#b85838;transform:translateY(-1px);box-shadow:0 4px 12px #c0502e4d}.button-primary:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999999;padding:20px;animation:fadeIn .2s ease}.confirm-modal{background:var(--paper);border-radius:16px;max-width:400px;width:100%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.confirm-modal-header{padding:20px 20px 16px;border-bottom:1px solid var(--line)}.confirm-modal-header h3{font-family:var(--font-display);font-size:20px;color:var(--ink);margin:0}.confirm-modal-body{padding:20px}.confirm-modal-body p{margin:0;color:var(--muted);font-size:15px;line-height:1.5}.confirm-modal-actions{display:flex;gap:10px;padding:16px 20px 20px;justify-content:flex-end}.confirm-modal-actions .button{min-width:90px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}html{height:100%}:root{color-scheme:light;--font-display: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--ink: #2f261f;--muted: #7a6757;--paper: #fff9f1;--panel: #fffdf8;--line: #e6d5c1;--accent: #7444b4;--accent-strong: #cbbbf0;--shadow: rgba(39, 28, 18, .22);--bg-radial-1: rgba(114, 18, 106, .55);--bg-radial-2: rgba(86, 30, 151, .35);--bg-base-1: #0a0863;--bg-base-2: #280852;--bg-base-3: #a838a8;--header-start: #013ba2;--header-mid: #4a5db8;--header-end: #865494;--header-text: #ffffff;--header-subtext: rgba(255, 255, 255, .85);--typing-dot: #1a110b}[data-theme=sage]{--ink: #26322b;--muted: #6b7b71;--paper: #f7f8f2;--panel: #fdfdf9;--line: #d9e0d2;--accent: #3f7a5a;--accent-strong: #2f6046;--shadow: rgba(22, 33, 26, .22);--bg-radial-1: rgba(196, 219, 192, .55);--bg-radial-2: rgba(171, 196, 182, .35);--bg-base-1: #f1f5ef;--bg-base-2: #dde7d6;--bg-base-3: #cdd8c5;--header-start: #1f2f25;--header-mid: #26382b;--header-end: #2e4132;--header-text: #eef5ee;--header-subtext: rgba(238, 245, 238, .75);--typing-dot: #162019}[data-theme=clay]{--ink: #33241c;--muted: #7b6454;--paper: #fff7f0;--panel: #fffdf9;--line: #e6d0bf;--accent: #c45a3b;--accent-strong: #490350;--shadow: rgba(46, 30, 20, .22);--bg-radial-1: rgba(231, 195, 173, .55);--bg-radial-2: rgba(199, 177, 158, .35);--bg-base-1: #f8eee4;--bg-base-2: #f0d9c7;--bg-base-3: #e3c4b0;--header-start: #2f1f17;--header-mid: #3a261c;--header-end: #432b20;--header-text: #fdf0e5;--header-subtext: rgba(253, 240, 229, .75);--typing-dot: #1a120c}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh;height:100%;background:radial-gradient(circle at 12% 10%,var(--bg-radial-1),transparent 45%),radial-gradient(circle at 82% 14%,var(--bg-radial-2),transparent 45%),linear-gradient(140deg,var(--bg-base-1) 0%,var(--bg-base-2) 45%,var(--bg-base-3) 100%);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}}
