:root{color:#172026;background:#f6f8f4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.app-shell{width:min(100%,920px);min-height:100vh;margin:0 auto;padding:40px 20px}header{margin-bottom:28px}.room-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}header p{margin:0 0 8px;color:#58706f;font-size:.9rem;font-weight:700;text-transform:uppercase}h1{margin:0;font-size:clamp(2.2rem,7vw,4.5rem);line-height:1}h2{margin:0 0 16px;font-size:1rem}.join-form,.status-panel,.panel{border:1px solid #d9e1dc;border-radius:8px;background:#fff;box-shadow:0 20px 50px #17202614}.join-form{display:grid;gap:18px;padding:24px}.auth-shell{width:min(100%,560px)}.auth-form h2{margin-bottom:0}.auth-link{margin:0;color:#58706f;font-weight:700}.auth-link a{color:#185b52}.profile-summary{display:grid;justify-items:end;gap:6px;min-width:160px;color:#58706f}.profile-summary strong{color:#172026}.profile-summary span{border:1px solid #d9e1dc;border-radius:999px;padding:4px 10px;background:#fff;color:#185b52;font-size:.8rem;font-weight:800}.profile-summary button,.profile-action,.secondary-action{border:1px solid #cad6d0;border-radius:6px;padding:8px 12px;color:#172026;background:#fff;font-weight:800}.profile-action{text-decoration:none}.admin-panel{display:grid;gap:18px}.profile-details{display:grid;gap:12px;margin:0}.profile-details div{display:flex;justify-content:space-between;gap:18px;border-bottom:1px solid #e2e9e5;padding-bottom:12px}.profile-details dt{color:#637a77;font-weight:800}.profile-details dd{margin:0;color:#172026;font-weight:800}.text-link{color:#185b52;font-weight:800}label{display:grid;gap:8px;color:#58706f;font-size:.9rem;font-weight:700}input,select{width:100%;border:1px solid #cad6d0;border-radius:6px;padding:13px 14px;color:#172026;background:#fbfcfb}input:read-only{color:#58706f}.join-form button,.admin-form button{border:0;border-radius:6px;padding:14px 18px;color:#fff;background:#185b52;font-weight:800}.button-row{display:flex;flex-wrap:wrap;gap:10px}.button-row button{flex:1 1 140px}.join-form .secondary-button{border:1px solid #cad6d0;color:#172026;background:#fff}.admin-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:18px;margin-top:18px}.admin-form{display:grid;gap:14px}.room-list,.log-list,.admin-chat-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}.log-list,.admin-chat-list{max-height:520px;overflow-y:auto;padding-right:4px}.room-list li,.log-list li,.admin-chat-list li{border:1px solid #e2e9e5;border-radius:6px;padding:12px;background:#fbfcfb}.room-list li,.log-card-header{align-items:center;display:flex;justify-content:space-between;gap:12px}.room-list-details{display:grid;gap:4px;min-width:0}.room-list span,.log-list span,.log-list time{color:#637a77;font-size:.85rem;font-weight:700}.log-card{display:grid;gap:12px}.event-summary{display:flex;flex-wrap:wrap;align-items:center;gap:8px;min-width:0}.event-badge{border:1px solid #cad6d0;border-radius:999px;padding:5px 9px;background:#f1f5f1;color:#172026;font-size:.76rem;line-height:1}.event-label{color:#637a77;font-size:.82rem;font-weight:800}.event-room-join{border-color:#bdd7c7;background:#edf7f1;color:#246444}.event-room-leave{border-color:#d4dad7;background:#f3f6f4;color:#52615d}.event-ptt-start{border-color:#b9d7d2;background:#ecf7f5;color:#185b52}.event-ptt-stop{border-color:#c7d3db;background:#eff4f7;color:#405d70}.event-ptt-busy{border-color:#e2c6af;background:#fbf1ea;color:#8b4d25}.log-room-meta{display:grid;justify-items:end;gap:3px;min-width:120px;text-align:right}.log-room-meta strong{color:#172026;font-size:.9rem}.log-room-meta span{overflow-wrap:anywhere}.room-list-note{text-align:right}.danger-button{border:1px solid #b7473d;border-radius:6px;padding:8px 12px;color:#fff;background:#a93a30;font-weight:800}.danger-button:disabled{border-color:#d6aca7;background:#b9827b}.log-card-message,.admin-chat-message{margin:8px 0;color:#172026}.log-card-message{overflow-wrap:anywhere}.log-card-footer{justify-self:start}.admin-chat-toolbar{display:flex;align-items:end;justify-content:space-between;gap:14px}.admin-chat-toolbar h2{margin:0}.chat-room-filter{min-width:min(100%,220px)}.admin-chat-card{display:grid;gap:10px}.admin-chat-room{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-chat-room strong{color:#172026;font-size:.9rem}.admin-chat-room span{text-align:right;overflow-wrap:anywhere}.admin-chat-message{overflow-wrap:anywhere}.admin-chat-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px 10px}.admin-chat-meta strong{color:#185b52;font-size:.85rem}.admin-chat-list span,.admin-chat-list time{color:#637a77;font-size:.85rem;font-weight:700}.room-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(220px,.8fr);gap:18px;align-items:stretch}.voice-column,.room-sidebar{display:grid;gap:18px;min-width:0}.voice-toolbar{display:flex;justify-content:flex-end}.status-panel{display:grid;gap:16px;padding:22px}.status-panel>div{display:flex;justify-content:space-between;gap:16px}.label{color:#637a77;font-size:.9rem;font-weight:700}.online{color:#19704b}.offline,.error{color:#a93a30}.speaking-state{min-height:80px;align-items:center;border-top:1px solid #e5ece8;padding-top:16px}.speaking-state strong{font-size:clamp(1.4rem,4vw,2.4rem)}.notice,.error{margin:0;border-radius:6px;padding:12px 14px;background:#f1f5f1;font-weight:700}.panel{padding:22px}.participant-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}.participant-list li{display:flex;align-items:center;justify-content:space-between;min-height:44px;border:1px solid #e2e9e5;border-radius:6px;padding:10px 12px;background:#fbfcfb}.participant-list strong{color:#185b52;font-size:.82rem}.chat-panel{display:grid;gap:14px;min-height:360px}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-header h2{margin:0}.chat-header span{color:#637a77;font-size:.82rem;font-weight:800}.chat-list{display:grid;align-content:start;gap:10px;min-height:220px;max-height:340px;margin:0;padding:0;overflow-y:auto;list-style:none}.chat-empty{border:1px dashed #cad6d0;border-radius:6px;padding:14px;color:#637a77;background:#fbfcfb;font-weight:700}.chat-message{display:grid;gap:6px;border:1px solid #e2e9e5;border-radius:6px;padding:10px 12px;background:#fbfcfb}.chat-message.own-message{border-color:#b8d2cb;background:#eef7f4}.chat-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px 10px}.chat-meta strong{color:#185b52;font-size:.9rem}.chat-meta span,.chat-meta time{color:#637a77;font-size:.78rem;font-weight:800}.chat-message p{margin:0;overflow-wrap:anywhere}.chat-form{display:flex;gap:8px}.chat-form input{min-width:0}.chat-form button{border:0;border-radius:6px;padding:0 16px;color:#fff;background:#185b52;font-weight:800}.chat-form button:disabled{background:#91a09b}.audio-settings-panel{display:grid;gap:16px}.audio-settings-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.audio-settings-header h2{margin:0}.audio-status-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.audio-status-grid div{display:grid;gap:5px;border:1px solid #e2e9e5;border-radius:6px;padding:10px 12px;background:#fbfcfb}.audio-status-grid strong{overflow-wrap:anywhere;color:#172026;font-size:.9rem}.audio-device-list{display:grid;gap:10px;min-width:0;margin:0;border:0;padding:0}.audio-device-list legend{margin-bottom:2px;color:#637a77;font-size:.9rem;font-weight:800}.audio-device-option{display:flex;grid-template-columns:none;align-items:center;gap:10px;border:1px solid #e2e9e5;border-radius:6px;padding:10px 12px;background:#fbfcfb;color:#172026}.audio-device-option input{width:auto;margin:0}.audio-device-option span{display:grid;gap:3px;min-width:0}.audio-device-option strong,.audio-device-option small{overflow-wrap:anywhere}.audio-device-option small,.audio-settings-note{color:#637a77;font-size:.82rem;font-weight:700}.audio-settings-actions{display:flex;justify-content:flex-start}.audio-settings-actions button{border:0;border-radius:6px;padding:12px 14px;color:#fff;background:#185b52;font-weight:800}.audio-settings-note{margin:0}.talk-button{min-height:180px;border:0;border-radius:8px;color:#fff;background:#28323a;font-size:clamp(2.4rem,10vw,5.5rem);font-weight:900;letter-spacing:0;touch-action:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none}.talk-button.speaking{background:#c24a35}.talk-button:disabled{background:#91a09b}.webrtc-debug{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:8px 14px;color:#637a77;font-size:.82rem;font-weight:700}@media(max-width:720px){.app-shell{padding:28px 14px}.room-layout{grid-template-columns:1fr}.chat-form{display:grid}.audio-status-grid{grid-template-columns:1fr}.voice-toolbar,.audio-settings-actions{justify-content:stretch}.voice-toolbar button,.audio-settings-actions button{width:100%}.chat-form button{min-height:44px}.admin-grid{grid-template-columns:1fr}.log-list,.admin-chat-list{max-height:420px}.log-card-header{align-items:flex-start;display:grid}.admin-chat-toolbar,.admin-chat-room{align-items:stretch;display:grid}.chat-room-filter{min-width:0}.admin-chat-room span{text-align:left}.log-room-meta{justify-items:start;min-width:0;text-align:left}.room-header{display:grid}.profile-summary{justify-items:start}}
