/* focus-room.css — live "focus room" widget (presence + ambient cheers + break chat)
   Standalone; self-mounted by focus-room.js. Matches focus.html teal theme. */
#fr-widget{position:fixed;right:18px;bottom:18px;width:300px;max-width:calc(100vw - 36px);z-index:9000;font-family:inherit;display:none}
#fr-widget.fr-show{display:block;animation:frfade .45s ease}
@keyframes frfade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.fr-card{background:rgba(18,22,28,0.96);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(77,210,160,0.28);border-radius:16px;box-shadow:0 14px 44px rgba(0,0,0,0.5);overflow:hidden}
.fr-head{display:flex;align-items:center;gap:8px;padding:11px 13px;border-bottom:1px solid rgba(255,255,255,0.07);font-size:0.9rem;font-weight:600;color:#e8f5ef}
.fr-dot{width:8px;height:8px;border-radius:50%;background:#4DD2A0;box-shadow:0 0 8px #4DD2A0;animation:frpulse 2s infinite;flex-shrink:0}
@keyframes frpulse{0%,100%{opacity:1}50%{opacity:.3}}
.fr-count{color:#4DD2A0}
.fr-min{margin-left:auto;cursor:pointer;color:#8a9a93;background:none;border:none;font-size:1.05rem;line-height:1;padding:2px 4px}
.fr-min:hover{color:#cfe}
.fr-body{padding:12px 13px}
.fr-cheers{display:flex;gap:7px;flex-wrap:wrap}
.fr-cheer{flex:1 1 64px;background:rgba(77,210,160,0.12);border:1px solid rgba(77,210,160,0.3);color:#bfeede;border-radius:10px;padding:9px 6px;font-size:0.85rem;font-weight:600;cursor:pointer;transition:background .15s,transform .08s}
.fr-cheer:hover{background:rgba(77,210,160,0.22)}
.fr-cheer:active{transform:scale(.93)}
.fr-cheer:disabled{opacity:.45;cursor:default}
.fr-hint{font-size:0.72rem;color:#8a9a93;margin-top:9px;text-align:center;line-height:1.5}
/* incoming cheer toasts */
#fr-toasts{position:fixed;right:18px;bottom:210px;z-index:9001;display:flex;flex-direction:column;gap:8px;align-items:flex-end;pointer-events:none;max-width:calc(100vw - 36px)}
.fr-toast{background:rgba(77,210,160,0.18);border:1px solid rgba(77,210,160,0.4);color:#e3fbf1;padding:8px 13px;border-radius:20px;font-size:0.85rem;font-weight:500;opacity:0;animation:frtoast 4.5s forwards;box-shadow:0 6px 20px rgba(0,0,0,0.3)}
.fr-toast b{color:#4DD2A0}
@keyframes frtoast{6%{opacity:1;transform:translateY(0)}82%{opacity:1}100%{opacity:0;transform:translateY(-8px)}}
/* chat (break) */
.fr-msgs{overflow-y:auto;max-height:300px;min-height:130px;display:flex;flex-direction:column;gap:7px;margin-bottom:9px}
.fr-msgs::-webkit-scrollbar{width:5px}.fr-msgs::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.12);border-radius:3px}
.fr-msg{font-size:0.83rem;line-height:1.5;color:#d6e4dd;word-break:break-word}
.fr-msg b{color:#4DD2A0;font-weight:600;margin-right:5px}
.fr-empty{font-size:0.78rem;color:#8a9a93;text-align:center;padding:14px 4px}
.fr-inrow{display:flex;gap:6px}
.fr-input{flex:1;min-width:0;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:10px;padding:8px 10px;color:#e8f5ef;font-size:0.85rem;font-family:inherit;outline:none}
.fr-input:focus{border-color:rgba(77,210,160,0.5)}
.fr-send{background:#4DD2A0;color:#06140e;border:none;border-radius:10px;padding:0 15px;font-weight:700;cursor:pointer;font-size:0.85rem}
.fr-send:disabled{opacity:.5;cursor:default}
.fr-locked{font-size:0.78rem;color:#8a9a93;text-align:center;padding:8px 4px;line-height:1.5}
.fr-locked a{color:#4DD2A0;text-decoration:underline;cursor:pointer}
@media(max-width:640px){#fr-widget{width:auto;left:12px;right:12px;bottom:12px}#fr-toasts{bottom:200px;right:12px;left:12px;align-items:center}}
