:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#111827;background-color:#f9fafb}body,html{margin:0;padding:0;min-height:100%}*{box-sizing:border-box}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#1f2937;color:#fff;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.app-header h1{margin:0;font-size:1.25rem}.app-nav{display:flex;gap:.75rem}.app-nav a{color:#d1d5db;text-decoration:none;font-weight:600;padding:.35rem .5rem;border-radius:.35rem}.app-nav a.active{background:#ffffff26;color:#fff}.app-main{flex:1;display:grid;grid-template-columns:minmax(240px,280px) 1fr;gap:1.5rem;padding:1.5rem}.join-panel,.chat-panel{background:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 10px 25px #0f172a14;display:flex;flex-direction:column;gap:1rem}.join-form{display:flex;flex-direction:column;gap:1rem}.join-form label{display:flex;flex-direction:column;font-size:.9rem;color:#4b5563;gap:.35rem}.join-form input,.composer input,.profile-form input,.profile-form select{padding:.6rem .75rem;border-radius:.5rem;border:1px solid #d1d5db;font-size:1rem}.join-form button,.composer button,.profile-form button{padding:.6rem .75rem;border:none;border-radius:.5rem;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.join-form button:hover,.composer button:hover,.profile-form button:hover{background:#1d4ed8}.chat-info{display:flex;justify-content:space-between;font-size:.9rem;color:#4b5563}.messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding:.5rem;background:#f3f4f6;border-radius:.75rem}.message{background:#fff;padding:.75rem;border-radius:.75rem;box-shadow:0 4px 10px #0f172a14}.message header{display:flex;justify-content:space-between;font-size:.85rem;color:#6b7280;margin-bottom:.35rem}.message p{margin:0;white-space:pre-wrap;word-break:break-word}.message-icon-button{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;margin-right:.5rem;padding:0;border:none;background:transparent;cursor:pointer;font-size:1rem;line-height:1}.message-icon-button:disabled{opacity:.65;cursor:not-allowed}.message-icon-button--warning{color:#92400e}.message-icon-spin{display:inline-block;animation:message-spin 1s linear infinite}@keyframes message-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.message-original-collapsible{display:grid;grid-template-rows:0fr;transition:grid-template-rows 1s ease}.message-original-collapsible.is-open{grid-template-rows:1fr}.message-original-inner{overflow:hidden}.message--original{background:#f9fafb;border:1px dashed #9ca3af;box-shadow:none}.message-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:800;color:#374151;text-transform:uppercase}.message-badge-dot{width:10px;height:10px;border-radius:999px;border:2px solid #6b7280}.composer{display:flex;gap:.75rem}.composer input{flex:1;min-width:0}.room-page{flex:1;min-height:0}.room-page .messages{min-height:0}.empty{text-align:center;color:#6b7280}.error{padding:.75rem;border-radius:.75rem;background:#fee2e2;color:#b91c1c;font-size:.9rem}.warning{padding:.75rem;border-radius:.75rem;background:#fef9c3;color:#92400e;font-size:.9rem;border:1px solid #fde68a}.success{padding:.75rem;border-radius:.75rem;background:#dcfce7;color:#15803d;font-size:.9rem}.invite-result{display:flex;flex-direction:column;gap:1rem}.invite-qr{background:#f3f4f6;border-radius:.75rem;padding:1rem;display:flex;justify-content:center}.invite-qr-svg{width:min(260px,80vw)}.invite-qr-svg svg{width:100%;height:auto;display:block}.invite-link-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem}.invite-link{flex:1 1 260px;color:#1d4ed8;word-break:break-all;text-decoration:none;font-weight:700}.invite-link:hover{text-decoration:underline}.invite-link-actions{display:flex;gap:.5rem}.invite-icon-button{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:.75rem;border:1px solid #e5e7eb;background:#f3f4f6;cursor:pointer;color:#111827;position:relative}.invite-copy-toast{position:absolute;left:50%;top:-6px;transform:translate(-50%,-100%);font-size:.7rem;line-height:1;padding:.3rem .45rem;border-radius:.5rem;background:#dcfce7;color:#15803d;border:1px solid rgba(21,128,61,.25);pointer-events:none;white-space:nowrap}.invite-icon-button:hover{background:#e5e7eb}.invite-icon-button:disabled{opacity:.6;cursor:not-allowed}.invite-icon{width:22px;height:22px;display:block}.profile-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:1.5rem;padding:2rem}.profile-card{width:min(480px,100%);background:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 10px 25px #0f172a14;display:flex;flex-direction:column;gap:1rem}.profile-form{display:flex;flex-direction:column;gap:1rem}.profile-form label{display:flex;flex-direction:column;font-size:.9rem;color:#4b5563;gap:.35rem}.session-info{display:flex;flex-direction:column;gap:.75rem}.session-info strong{color:#111827}.session-actions{display:flex;flex-wrap:wrap;gap:.5rem}.profile-name-control{display:flex;gap:.5rem;align-items:center}.ghost-button{background:#e5e7eb;color:#1f2937;border:none;border-radius:.5rem;padding:.55rem .75rem;font-weight:600;cursor:pointer}.ghost-button:hover{background:#d1d5db}.ghost-button.inline{display:inline-flex;margin-left:.5rem;padding:.3rem .6rem;font-size:.85rem}.env-dump{max-height:420px;overflow:auto;background:#0f172a;color:#e2e8f0;padding:1rem;border-radius:.5rem;font-size:.85rem;line-height:1.4}.start-shell{min-height:100vh;display:flex;flex-direction:column}.start-header{position:sticky;top:0;z-index:10;background:#111827;color:#fff;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.start-brand{font-weight:800;letter-spacing:.02em}.start-icon-button{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:.75rem;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#fff;cursor:pointer}.start-icon-button:hover{background:#ffffff24}.start-icon-button--guest{background:#facc15;border:1px solid rgba(17,24,39,.35);color:#111827}.start-icon-button--guest:hover{background:#eab308}.start-icon{width:24px;height:24px;display:block}.start-main{flex:1;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:1.5rem;align-items:center}.start-name{width:min(960px,100%);background:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 10px 25px #0f172a14;display:flex;flex-direction:column;gap:.75rem}.start-title{margin:0;font-size:1.25rem}.start-subtitle{margin:0;color:#6b7280}.start-name-form{display:flex;flex-direction:column;gap:.75rem}.start-name-row{display:flex;align-items:flex-end;flex-wrap:wrap;gap:.75rem}.start-name-label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:#4b5563;flex:1 1 260px}.start-name-label input{padding:.6rem .75rem;border-radius:.5rem;border:1px solid #d1d5db;font-size:1rem}.start-primary-button{padding:.6rem .9rem;border:none;border-radius:.5rem;background:#2563eb;color:#fff;font-weight:700;cursor:pointer;min-width:120px}.start-primary-button:hover{background:#1d4ed8}.start-primary-button:disabled{opacity:.65;cursor:not-allowed}.start-tiles{width:min(960px,100%);display:grid;grid-template-columns:1fr;justify-items:center;gap:1rem}.start-tile{width:clamp(260px,80vw,420px);aspect-ratio:1 / 1;background:#fff;border-radius:.75rem;border:1px solid #e5e7eb;box-shadow:0 10px 25px #0f172a14;padding:1.25rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.35rem;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease}.start-tile:hover{transform:translateY(-2px);box-shadow:0 14px 32px #0f172a1f}.start-tile-title{font-weight:800;color:#111827;font-size:1.1rem}.start-tile-subtitle{color:#6b7280;font-size:.9rem}.start-footer{display:flex;justify-content:space-between;gap:1rem;padding:1rem;border-top:1px solid #e5e7eb;color:#6b7280;background:#f9fafbeb}.start-footer-link{color:inherit;text-decoration:none;font-weight:700}.start-footer-link:hover{text-decoration:underline}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:40}.drawer-backdrop.is-open{opacity:1;pointer-events:auto}.drawer-left,.drawer-top{position:fixed;background:#fff;box-shadow:0 18px 40px #0f172a2e;border:1px solid rgba(15,23,42,.08);z-index:50;transition:transform .18s ease}.drawer-left{top:0;bottom:0;left:0;width:90vw;transform:translate(-102%)}.drawer-left.is-open{transform:translate(0)}.drawer-top{top:0;right:0;width:90vw;max-height:min(70vh,520px);border-bottom-left-radius:.75rem;transform:translateY(-110%)}.drawer-top.is-open{transform:translateY(0)}.drawer-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1rem .75rem;border-bottom:1px solid #e5e7eb}.drawer-title{margin:0;font-size:1.1rem}.drawer-title-link{color:inherit;text-decoration:none;font-weight:800}.drawer-title-link:hover{text-decoration:underline}.drawer-close{width:40px;height:40px;border-radius:.75rem;border:1px solid #e5e7eb;background:#f3f4f6;cursor:pointer;font-size:1.25rem;line-height:1}.drawer-close:hover{background:#e5e7eb}.drawer-content{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.drawer-item{text-align:left;width:100%;padding:.75rem;border-radius:.75rem;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-weight:700;color:#111827}.drawer-item:hover{background:#f3f4f6}.drawer-muted{color:#6b7280;font-size:.9rem}.drawer-strong{font-weight:800;color:#111827}.drawer-profile-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.drawer-profile-meta{display:flex;flex-direction:column;gap:.25rem;min-width:0}.drawer-logout-button{padding:.5rem .75rem;border-radius:.75rem;border:1px solid #dc2626;background:transparent;color:#dc2626;font-weight:800;cursor:pointer;white-space:nowrap}.drawer-logout-button:hover{background:#fee2e2}.drawer-logout-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 960px){.app-main{grid-template-columns:1fr}}@media (min-width: 900px){.start-main{padding:2rem 1.5rem}.start-tiles{grid-template-columns:repeat(2,minmax(280px,1fr));justify-items:stretch}.start-tile{width:100%}.drawer-left{width:min(360px,30vw)}.drawer-top{width:min(420px,30vw)}}.analytics-table{width:100%;border-collapse:collapse;background:#fff;border-radius:.75rem;overflow:hidden;box-shadow:0 10px 25px #0f172a14}.start-name.start-name--wide{width:95%;max-width:none}.analytics-detail-actions{display:flex;align-items:center;gap:.75rem}.analytics-table-wrapper{width:100%;overflow-x:auto}.analytics-table--records{min-width:1400px}.analytics-clickable-row{cursor:pointer}.analytics-clickable-row:hover td{background:#f9fafb}.analytics-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.85rem;white-space:pre-wrap;word-break:break-word}.analytics-table th,.analytics-table td{padding:.75rem;border-bottom:1px solid #e5e7eb;text-align:left;font-size:.9rem}.analytics-table th{background:#f9fafb;color:#374151;font-weight:700}.analytics-table tr:last-child td{border-bottom:none}.analytics-table td.analytics-count,.analytics-table th.analytics-count{text-align:right;font-variant-numeric:tabular-nums}.analytics-groupby{border:1px solid #e5e7eb;border-radius:.75rem;padding:.75rem;margin:0}.analytics-groupby legend{padding:0 .25rem;font-size:.9rem;color:#4b5563;font-weight:700}.analytics-groupby-grid{display:flex;flex-wrap:wrap;gap:.75rem}.analytics-checkbox{display:inline-flex;align-items:center;gap:.35rem;font-size:.9rem;color:#111827}
