:root{color-scheme:dark;--bg: #0f1115;--panel: #171a21;--border: #2a3140;--text: #e8ecf1;--muted: #9aa3b2;--accent: #6ea8fe;--danger: #f87171;--chat-transcript-max: min( calc(100dvh - 14rem) , 580px)}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}html,body,#root{min-height:100%}#root{max-width:720px;margin:0 auto;padding:max(1.25rem,env(safe-area-inset-top,0px)) max(1.25rem,env(safe-area-inset-right,0px)) max(2rem,env(safe-area-inset-bottom,0px)) max(1.25rem,env(safe-area-inset-left,0px))}#root:has(.chat-page){max-width:800px}h1{font-size:1.35rem;margin:0 0 .75rem}h2{font-size:1rem;margin:1rem 0 .5rem;color:var(--muted);font-weight:600}.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:1rem}.row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}label.field{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--muted);min-width:140px;flex:1}input[type=text],input[type=password],input[type=number],select{padding:.45rem .5rem;border-radius:8px;border:1px solid var(--border);background:#0b0d11;color:var(--text)}.choice-row{align-items:flex-start}.choice-field{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:min(100%,17rem)}.choice-field-full{width:100%;min-width:0}.field-caption{display:block;font-size:.85rem;color:var(--muted)}.age-bucket-buttons{display:flex;flex-wrap:wrap;gap:.65rem}.age-bucket-buttons--stretch{width:100%;flex-wrap:nowrap}button.age-bucket-btn{min-height:3rem;min-width:5.75rem;padding:.7rem 1.2rem;font-size:1.05rem;font-weight:600;letter-spacing:.02em;border-radius:12px;border:2px solid var(--border);background:#12151c;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .15s ease,background .15s ease,color .15s ease,box-shadow .15s ease}.age-bucket-buttons--stretch button.age-bucket-btn{flex:1 1 0;min-width:0;width:0}button.age-bucket-btn:hover{border-color:#4a5568;background:#171c26}button.age-bucket-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button.age-bucket-btn.selected{border-color:#4d7cc4;background:#6ea8fe24;color:var(--accent);box-shadow:0 0 0 1px #6ea8fe40}button{padding:.5rem .85rem;border-radius:8px;border:1px solid var(--border);background:#1e2430;color:var(--text);cursor:pointer;font-size:.9rem}button.primary{border-color:#3d5a8a;background:linear-gradient(180deg,#2f4568,#24324a)}button:disabled{opacity:.45;cursor:not-allowed}button.danger{border-color:#7f2d2d;background:#3a1a1a;color:#fecaca}.status{font-size:.85rem;color:var(--muted)}.messages{display:flex;flex-direction:column;gap:.5rem;border:1px solid var(--border);border-radius:10px;min-height:220px;max-height:360px;overflow-y:auto;padding:.65rem;background:#0b0d11;margin:.5rem 0}.msg{display:flex;flex-direction:column;gap:.2rem;max-width:min(85%,22rem);align-self:flex-start;font-size:.92rem;line-height:1.35}.msg.me{align-self:flex-end;text-align:right}.msg .meta{font-size:.72rem;color:var(--muted);text-align:inherit}.msg>div{padding:.5rem .7rem;border-radius:12px;background:#1a222e;border:1px solid var(--border);color:var(--text);word-wrap:break-word}.msg.me>div{background:#6ea8fe1f;border-color:#6ea8fe59;color:var(--accent)}.error{color:var(--danger);font-size:.85rem;margin-top:.35rem}.muted{color:var(--muted)}.small{font-size:.85rem;line-height:1.45}.page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem 1rem;margin-bottom:1rem}.page-header h1{margin:0;flex:1;min-width:0}.page-header-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.5rem .75rem;flex-shrink:0}.blocked-list-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;display:flex;align-items:center;justify-content:center;padding:max(1rem,env(safe-area-inset-top,0px)) max(1rem,env(safe-area-inset-right,0px)) max(1rem,env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-left,0px));background:#0a0c12d1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.blocked-list-card{width:100%;max-width:440px;max-height:min(85vh,520px);display:flex;flex-direction:column;padding:1.25rem 1.2rem;border-radius:16px;border:1px solid var(--border);background:var(--panel);box-shadow:0 20px 50px #00000073}.blocked-list-title{margin:0 0 .75rem;font-size:1.1rem;font-weight:600}.blocked-list-error{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.blocked-list{list-style:none;margin:0 0 .85rem;padding:0;overflow-y:auto;flex:1;min-height:0;border:1px solid var(--border);border-radius:10px;background:#0003}.blocked-list-item{display:flex;align-items:center;justify-content:space-between;gap:.65rem;padding:.5rem .65rem;border-bottom:1px solid var(--border)}.blocked-list-item:last-child{border-bottom:none}.blocked-list-id{font-size:.78rem;word-break:break-all;color:var(--muted);flex:1;min-width:0}button.small-btn{padding:.3rem .55rem;font-size:.8rem;flex-shrink:0}.blocked-list-footer{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;margin-top:auto;padding-top:.35rem}.lang-switcher{display:flex;flex-shrink:0;gap:.2rem;padding:.15rem;border-radius:10px;border:1px solid var(--border);background:#12151c}.lang-btn{min-width:2.6rem;padding:.35rem .5rem;font-size:.78rem;font-weight:600;letter-spacing:.02em;border:none;border-radius:7px;background:transparent;color:var(--muted);cursor:pointer}.lang-btn:hover{color:var(--text);background:#ffffff0d}.lang-btn.active{color:var(--text);background:#2a3148;box-shadow:0 0 0 1px var(--border)}.setup-page section:first-of-type h2{margin-top:0}.setup-panel-heading{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem .75rem;margin-bottom:.5rem}.setup-panel-heading h2{margin:0}.setup-sound-toggle{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.4rem;margin:-.4rem -.4rem -.4rem 0;border-radius:10px;color:var(--muted);transition:color .15s ease,background .15s ease}.setup-sound-toggle:hover{color:var(--text);background:#ffffff0d}.setup-sound-toggle--on{color:var(--accent)}.setup-sound-toggle:focus-within{outline:2px solid var(--accent);outline-offset:2px}.setup-sound-toggle input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;opacity:0}.setup-sound-toggle__icon{display:flex;align-items:center;justify-content:center;min-width:2.75rem;min-height:2.75rem}.setup-sound-toggle__svg{display:block}.pill{font-size:.8rem;padding:.25rem .6rem;border-radius:999px;border:1px solid var(--border);color:var(--muted)}.pill.on{border-color:#2d5a3d;color:#86efac;background:#22c55e14}button.large{padding:.65rem 1.1rem;font-size:1rem}button.ghost{background:transparent;border-color:var(--border)}.actions-panel-actions{margin-top:0}button.btn-block{display:block;width:100%;box-sizing:border-box}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:max(1rem,env(safe-area-inset-top,0px)) max(1rem,env(safe-area-inset-right,0px)) max(1rem,env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-left,0px));background:#0a0c12d1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.search-overlay-card{width:100%;max-width:380px;text-align:center;padding:1.75rem 1.5rem;border-radius:16px;border:1px solid var(--border);background:var(--panel);box-shadow:0 20px 50px #00000073}.search-overlay-title{margin:1rem 0 .35rem;font-size:1.1rem;font-weight:600}.spinner{width:44px;height:44px;margin:0 auto;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent);animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.chat-page{display:flex;flex-direction:column;min-height:calc(100vh - 2.5rem)}.chat-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.chat-header-main{flex:1;min-width:0}.chat-header-title-row{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .75rem}.chat-header-title-row h1{margin:0;line-height:1.25}.chat-header-peer{margin:0;line-height:1.35}.chat-header-peer-compact{display:none;font-weight:600}.chat-header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.chat-header-actions>button:not(.chat-safety-trigger){white-space:nowrap}@media(max-width:520px){.chat-header-peer-full{display:none}.chat-header-peer-compact{display:inline}.chat-header{flex-direction:column;align-items:stretch}.chat-header-actions{width:100%;justify-content:stretch;gap:.35rem}.chat-header-actions>button:not(.chat-safety-trigger){flex:1 1 0;min-width:0;min-height:44px}button.chat-safety-trigger{flex:0 0 auto;width:2.75rem;height:2.75rem;min-width:2.75rem;min-height:2.75rem}:root{--chat-transcript-max: min( calc(100dvh - 12.5rem) , 520px)}}@media(max-width:420px){#root{padding-top:max(.85rem,env(safe-area-inset-top,0px));padding-left:max(.75rem,env(safe-area-inset-left,0px));padding-right:max(.75rem,env(safe-area-inset-right,0px));padding-bottom:max(1.25rem,env(safe-area-inset-bottom,0px))}}button.chat-safety-trigger{flex-shrink:0;width:2.5rem;height:2.5rem;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.35rem;font-weight:800;line-height:1;border:2px solid #8b6914;background:linear-gradient(180deg,#b8860b,#8b6914);color:#1a1508;cursor:pointer;box-shadow:0 2px 8px #00000059}button.chat-safety-trigger:hover{filter:brightness(1.08)}button.chat-safety-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chat-safety-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:max(1rem,env(safe-area-inset-top,0px)) max(1rem,env(safe-area-inset-right,0px)) max(1rem,env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-left,0px));background:#0a0c12d1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.chat-safety-card{width:100%;max-width:360px;padding:1.35rem 1.25rem;border-radius:16px;border:1px solid var(--border);background:var(--panel);box-shadow:0 20px 50px #00000073}.chat-safety-title{margin:0 0 .35rem;font-size:1.1rem;font-weight:600}.chat-safety-peer{margin:0 0 1.1rem}.chat-safety-actions{display:flex;flex-direction:column;gap:.55rem}.chat-safety-actions button{width:100%;justify-content:center}button.chat-safety-cancel{margin-top:.25rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}button.small-btn{font-size:.8rem;padding:.25rem .5rem}.chat-msg-image-wrap{margin-top:.25rem;max-width:min(100%,280px)}.chat-msg-image{display:block;max-width:100%;max-height:220px;border-radius:8px;object-fit:contain}.admin-chat-img{display:block;max-width:min(100%,320px);max-height:240px;margin-top:.35rem;border-radius:8px;object-fit:contain}.chat-body{flex:1;display:flex;flex-direction:column;margin-bottom:0;min-height:0}.chat-body .messages{flex:1 1 auto;min-height:12rem;max-height:var(--chat-transcript-max);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;margin-top:0}.chat-input{flex:1;min-width:120px;padding:.55rem .65rem;border-radius:8px;border:1px solid var(--border);background:#0b0d11;color:var(--text)}.chat-input-row{margin-top:.75rem;align-items:center}.chat-like-heart-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2.75rem;min-width:2.75rem;min-height:2.75rem;padding:0;border-radius:10px;border:1px solid var(--border);background:#1a1f2a;color:var(--muted);cursor:pointer;transition:color .15s ease,border-color .15s ease,background .15s ease}.chat-like-heart-btn:hover:not(:disabled){color:#f472b6;border-color:#f472b673;background:#f472b614}.chat-like-heart-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chat-like-heart-btn--liked{color:#f472b6;border-color:#f472b680;background:#f472b61f}.chat-like-heart-btn:disabled{opacity:1;cursor:default}.chat-like-heart-btn__svg{display:block}button.chat-icon-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2.75rem;min-width:2.75rem;min-height:2.75rem;padding:0;border-radius:10px}.chat-icon-btn__svg{display:block}.chat-send-btn{border-width:1px}.chat-photo-btn--locked{opacity:.55;cursor:pointer}.chat-photo-btn--locked:hover{opacity:.75}.chat-photo-tip{margin:.35rem 0 0;padding:.45rem .55rem;border-radius:8px;border:1px solid var(--border);background:#0003;line-height:1.4}.stats-wrap{margin-top:.75rem;overflow-x:auto}.setup-page:has(.admin-nav) .stats-wrap{max-height:min(calc(100dvh - 12rem),560px);overflow-y:auto;-webkit-overflow-scrolling:touch}.stats-table{width:100%;border-collapse:collapse;font-size:.9rem}.stats-table th,.stats-table td{border:1px solid var(--border);padding:.45rem .55rem;text-align:center}.stats-table thead th{background:#12151c;color:var(--muted);font-weight:600}.stats-table tbody th[scope=row]{text-align:left;background:#12151c;color:var(--text);font-weight:600}.stats-table .stats-sum{font-weight:700;color:var(--accent);background:#6ea8fe0f}code{font-size:.85em;color:var(--muted)}.admin-nav{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem}.admin-nav a{color:var(--accent);text-decoration:none;font-size:.9rem}.admin-nav a:hover{text-decoration:underline}.admin-panel-heading{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem .75rem;margin-bottom:.65rem}.admin-panel-heading h2{margin:0}.admin-reports-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.admin-table .admin-mono{font-size:.72rem}a.admin-room-id-link{font-family:ui-monospace,monospace;color:var(--accent);text-decoration:none}a.admin-room-id-link:hover{text-decoration:underline}.admin-actions{display:flex;flex-wrap:wrap;gap:.35rem;max-width:14rem}.admin-rooms-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:stretch}.admin-rooms-grid>.panel{display:flex;flex-direction:column;min-height:0}@media(max-width:800px){.admin-rooms-grid{grid-template-columns:1fr}}.admin-room-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.admin-rooms-grid .admin-room-list{flex:1 1 auto;min-height:0;max-height:var(--chat-transcript-max);overflow-y:auto;-webkit-overflow-scrolling:touch}button.admin-room-row-btn{display:flex;flex-direction:row;flex-wrap:wrap;align-items:baseline;gap:.35rem;text-align:left;width:100%}.admin-room-row-main{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem}.admin-room-counts{font-size:.78rem}.admin-room-ended{flex-basis:100%;font-size:.72rem}.admin-room-list button.admin-room-active{border-color:var(--accent);color:var(--accent)}.admin-msg-list{list-style:none;margin:0;padding:.5rem .35rem;max-height:var(--chat-transcript-max);overflow-y:auto;display:flex;flex-direction:column;gap:.55rem;flex:1 1 auto;min-height:0;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:10px;background:#0b0d11}.admin-msg-item{display:flex;flex-direction:column;gap:.2rem;max-width:min(88%,20rem);align-self:flex-start;font-size:.92rem;line-height:1.35}.admin-msg-item--right{align-self:flex-end;text-align:right}.admin-msg-meta{text-align:inherit}.admin-msg-item--right .admin-msg-meta code{color:var(--muted)}.admin-msg-body{padding:.45rem .65rem;border-radius:12px;background:#1a222e;border:1px solid var(--border);color:var(--text);word-wrap:break-word}.admin-msg-body--media{padding:.35rem;display:inline-block;max-width:100%}.admin-msg-item--right .admin-msg-body{background:#6ea8fe1f;border-color:#6ea8fe59;color:var(--accent)}.admin-msg-item--right .admin-msg-body--media{text-align:right}
