:root{--bg:#0d1214;--surface:#171d20;--surface-2:#024c6d;--text:#dce8f2;--muted:#8f9ba5;--accent:#8fd3ff;--accent-2:#00c48c;--danger:#ff5f6d;--warning:#ffd166;--radius-xl:28px;--radius-md:18px;--shadow:0 18px 60px rgba(0,0,0,.35)}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at 20% 0,#17323c 0,#0d1214 36%,#080b0d 100%);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;min-height:100vh;padding-bottom:110px}a{color:inherit;text-decoration:none}.topbar{position:sticky;top:0;z-index:10;background:rgba(13,18,20,.78);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:space-between;padding:18px clamp(16px,4vw,48px);border-bottom:1px solid rgba(255,255,255,.06)}.brand{font-size:28px;font-weight:900;letter-spacing:-.04em}.brand span,.hero h1 span{color:var(--accent)}.nav{display:flex;align-items:center;gap:18px;color:var(--muted)}.nav a:hover{color:var(--accent)}.user-pill{padding:8px 12px;background:rgba(143,211,255,.12);border-radius:999px;color:var(--accent)}.page{width:min(1180px,calc(100% - 32px));margin:0 auto}.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:stretch;padding:54px 0 34px}.eyebrow{color:var(--accent);font-weight:800;letter-spacing:.16em;font-size:12px}.hero h1,.room-hero h1{font-size:clamp(58px,10vw,118px);line-height:.88;margin:12px 0;letter-spacing:-.08em}.lead{font-size:clamp(20px,3vw,32px);color:#c4d3dd;max-width:820px}.hero-card,.panel,.auth-card,.room-card,.empty-card,.stat{background:linear-gradient(145deg,rgba(32,40,44,.94),rgba(18,24,27,.92));border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-xl);box-shadow:var(--shadow)}.hero-card{padding:10px;min-height:320px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}.hero-card:before{content:"";position:absolute;inset:-40% -10% auto auto;width:260px;height:260px;border-radius:50%;background:rgba(143,211,255,.14);filter:blur(12px)}.live-dot{display:inline-flex;align-items:center;gap:8px;width:max-content;padding:8px 12px;border-radius:999px;background:rgba(0,196,140,.12);color:var(--accent-2);font-weight:800;font-size:12px;letter-spacing:.08em}.live-dot:before{content:"";width:8px;height:8px;background:var(--accent-2);border-radius:50%;box-shadow:0 0 20px var(--accent-2)}.muted{color:var(--muted)}.btn{border:0;border-radius:16px;background:var(--surface-2);color:var(--text);padding:3px 7px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-weight:800}.btn:hover{filter:brightness(1.08)}.btn.primary{background:linear-gradient(165deg, #2196F3, #c3d0dd);color:#061014}.btn.danger{background:rgba(255,95,109,.16);color:#ffb1b8}.btn.small{padding:8px 10px;border-radius:12px;font-size:13px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.section{padding:22px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:22px}.section h2{font-size:32px;margin:0 0 18px}.room-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.room-card,.empty-card{padding:24px;min-height:190px;display:flex;flex-direction:column;justify-content:space-between}.room-card h3{font-size:28px;margin:14px 0 8px}.room-card p{color:var(--muted);line-height:1.5}.status{width:max-content;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.08);color:var(--muted);font-size:12px;font-weight:900}.status.on{background:rgba(0,196,140,.15);color:var(--accent-2)}.split{display:grid;grid-template-columns:1fr 1fr;gap:18px}.panel{padding:10px}.about{font-size:20px;line-height:1.65}.list{display:flex;flex-direction:column;gap:10px}.list-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);padding:7px 7px;border-radius:16px}.list-item span{display:block;color:var(--muted);font-size:13px;margin-top:3px}.room-hero{display:grid;grid-template-columns:1fr .9fr;gap:22px;padding:44px 0 20px}.player-panel audio{width:100%;margin-top:20px}.form{display:flex;flex-direction:column;gap:14px}.form label{display:flex;flex-direction:column;gap:8px;color:#cbd8e0;font-weight:700}.form input,.form textarea,.form select{width:100%;border:1px solid rgba(255,255,255,.1);background:#0e1417;color:var(--text);border-radius:14px;padding:13px 14px;outline:none}.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--accent)}.grid-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.wide{grid-column:1/-1}.auth-card{width:min(520px,100%);margin:70px auto;padding:32px}.reaction-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.reaction-row button{font-size:22px;border:0;border-radius:14px;background:rgba(255,255,255,.08);padding:7px 10px;cursor:pointer}.inline-form{display:grid;grid-template-columns:1fr auto}.mini-player{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:20;width:min(860px,calc(100% - 24px));background:rgba(23,29,32,.95);border:1px solid rgba(255,255,255,.09);box-shadow:var(--shadow);border-radius:24px;padding:12px 16px;display:grid;grid-template-columns:1fr 360px;gap:16px;align-items:center}.mini-player.hidden{display:none}.mini-player span{display:block;color:var(--muted);font-size:13px}.mini-player audio{width:100%}.bottom-nav{display:none}.flash-wrap{padding-top:16px}.flash{padding:12px 16px;border-radius:16px;margin:10px 0;background:rgba(143,211,255,.12);border:1px solid rgba(143,211,255,.2)}.flash.error{background:rgba(255,95,109,.12);border-color:rgba(255,95,109,.25)}.flash.success{background:rgba(0,196,140,.12);border-color:rgba(0,196,140,.25)}.admin-body{background:#0b0f11}.admin-layout{display:grid;grid-template-columns:240px 1fr;gap:0}.admin-menu{min-height:calc(100vh - 72px);background:#101619;border-right:1px solid rgba(255,255,255,.06);padding:18px;display:flex;flex-direction:column;gap:8px}.admin-menu a{padding:12px 14px;border-radius:14px;color:var(--muted)}.admin-menu a:hover{background:rgba(255,255,255,.06);color:var(--text)}.admin-main{padding:26px}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:18px 0}.stat{padding:22px}.stat b{display:block;font-size:36px}.stat span{color:var(--muted)}.admin-row{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.07)}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:12px;border-bottom:1px solid rgba(255,255,255,.07)}.table-wrap{overflow:auto}.switch-row{display:flex!important;flex-direction:row!important;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.06);padding:12px 0}.switch-row small{display:block;color:var(--muted);font-weight:400;margin-top:3px}
@media (max-width: 850px){.now-card-body,.room-now-layout{grid-template-columns:96px 1fr}.track-cover{width:96px;height:96px;border-radius:20px;font-size:34px}body{padding-bottom:150px}.nav{gap:10px;font-size:14px}.hero,.room-hero,.split{grid-template-columns:1fr}.room-grid{display:flex;overflow-x:auto;padding-bottom:8px}.room-card{min-width:280px}.mini-player{bottom:62px;grid-template-columns:1fr}.bottom-nav{position:fixed;display:grid;grid-template-columns:repeat(4,1fr);bottom:0;left:0;right:0;background:rgba(13,18,20,.96);border-top:1px solid rgba(255,255,255,.08);z-index:19}.bottom-nav a{text-align:center;padding:14px 5px;color:var(--muted);font-size:13px}.admin-layout{grid-template-columns:1fr}.admin-menu{min-height:auto;flex-direction:row;overflow-x:auto}.stat-grid{grid-template-columns:repeat(2,1fr)}.grid-form{grid-template-columns:1fr}.inline-form{grid-template-columns:1fr}.hero h1,.room-hero h1{font-size:68px}}

.now-card-body,.room-now-layout{display:grid;grid-template-columns:132px 1fr;gap:18px;align-items:center;position:relative;z-index:1}
.track-cover{width:132px;height:132px;border-radius:24px;background:linear-gradient(145deg,#1f2a2f,#0b0f11);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:44px;font-weight:900;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.track-cover img{width:100%;height:100%;object-fit:cover;display:block}
.track-description{line-height:1.45;max-height:120px;overflow:hidden;margin-top:10px}
.provider-widget{margin-top:18px;overflow:hidden;border-radius:18px;background:rgba(255,255,255,.04)}
.reaction-row button span{font-size:13px;color:var(--accent);font-weight:900}

/* === Efika room UX patch: compact title, player reactions, comment scroll, admin hints === */
.hidden{display:none!important}
.room-title-strip{padding:26px 0 14px;max-width:860px}
.room-title-strip .eyebrow{margin:0 0 8px}
.room-title-strip h1{margin:0;font-size:clamp(30px,5vw,48px);line-height:1.02;letter-spacing:-.045em}
.room-short-description{margin:8px 0 0;color:#c4d3dd;font-size:clamp(16px,2.2vw,21px);line-height:1.35;max-width:760px}
.room-main-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:18px;padding:14px 0 22px}
.player-panel{display:flex;flex-direction:column;gap:16px}
.player-panel audio,.room-audio{width:100%;margin-top:0}
.autoplay-note{font-size:13px;margin:-4px 0 0}
.player-reactions{border-top:1px solid rgba(255,255,255,.07);padding-top:14px}
.player-reactions-title{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:900;margin-bottom:10px}
.player-reactions .reaction-row{margin-bottom:0}
.reaction-row button{color:var(--text)}
.reaction-row button:hover,.emoji-comment-row button:hover{background:rgba(143,211,255,.16);transform:translateY(-1px)}
.emoji-comment-row{display:flex;gap:8px;flex-wrap:wrap;margin:-2px 0 14px}
.emoji-comment-row button{font-size:22px;border:0;border-radius:14px;background:rgba(255,255,255,.08);padding:9px 12px;cursor:pointer;transition:.15s ease}
.live-comments-list{max-height:430px;overflow-y:auto;overscroll-behavior:contain;padding-right:6px;scrollbar-width:thin}
.live-comments-list .list-item{min-height:54px}
.comments-panel{min-height:0}

.settings-form{display:flex;flex-direction:column;gap:18px}
.settings-panel .section-head{align-items:center;margin-bottom:18px}
.feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.feature-card,.settings-row{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.07);border-radius:18px;padding:14px;display:flex;gap:12px}
.feature-card{flex-direction:column;justify-content:space-between;min-height:132px}
.feature-title{display:flex;align-items:center;justify-content:space-between;gap:10px}
.feature-card small,.settings-row small{color:var(--muted);line-height:1.35}
.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.settings-group h2{text-transform:capitalize}
.settings-row{align-items:center;justify-content:space-between;margin:10px 0}
.settings-copy{display:flex;flex-direction:column;gap:5px;min-width:0}
.settings-name{font-weight:900;color:var(--text);word-break:break-word}
.settings-control{display:flex;align-items:center;gap:10px;min-width:210px;justify-content:flex-end}
.settings-control em{font-style:normal;color:var(--accent);font-size:12px;font-weight:900;background:rgba(143,211,255,.1);padding:5px 8px;border-radius:999px}
.settings-control input,.settings-control select,.feature-card select{border:1px solid rgba(255,255,255,.1);background:#0e1417;color:var(--text);border-radius:14px;padding:11px 12px;outline:none;min-width:120px}
.settings-actions{position:sticky;bottom:18px;z-index:5;display:flex;justify-content:flex-end;padding:4px 0}
.tip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:6px;border-radius:50%;background:rgba(143,211,255,.13);color:var(--accent);font-style:normal;font-size:12px;font-weight:900;cursor:help;vertical-align:middle}
.tip:after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 10px);transform:translateX(-50%) translateY(4px);width:min(780px,92vw);background:#05090b;color:var(--text);border:1px solid rgba(143,211,255,.28);box-shadow:0 16px 48px rgba(0,0,0,.45);padding:16px 18px;border-radius:14px;line-height:1.52;font-weight:600;font-size:13px;text-transform:none;letter-spacing:0;white-space:pre-line;opacity:0;pointer-events:none;transition:.15s ease;z-index:50}
.tip:before{content:"";position:absolute;left:50%;bottom:calc(100% + 4px);transform:translateX(-50%);border:6px solid transparent;border-top-color:#05090b;opacity:0;transition:.15s ease;z-index:51}
.tip:hover:after,.tip:hover:before,.tip:focus:after,.tip:focus:before,.tip:focus-visible:after,.tip:focus-visible:before{opacity:1;transform:translateX(-50%) translateY(0)}
.tip:focus{outline:2px solid rgba(143,211,255,.35);outline-offset:2px}

@media (max-width: 980px){.room-main-grid,.settings-grid{grid-template-columns:1fr}.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 600px){.room-title-strip{padding-top:18px}.room-title-strip h1{font-size:34px}.feature-grid{grid-template-columns:1fr}.settings-row{align-items:stretch;flex-direction:column}.settings-control{justify-content:space-between;min-width:0}.live-comments-list{max-height:360px}}

/* === Efika room comments/realtime patch v4 === */
body{padding-bottom:28px}.mini-player{display:none!important}.room-title-strip{padding:22px 0 14px;max-width:none}.room-title-strip .eyebrow{margin:0 0 7px}.room-title-line{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}.room-title-line h1{margin:0;font-size:clamp(34px,4.6vw,48px);line-height:1;letter-spacing:-.055em}.room-inline-description{color:#d7e2ea;font-size:clamp(17px,2vw,22px);font-weight:800;line-height:1.25}.room-short-description{display:none}.comments-panel{min-height:0;overflow:hidden}.live-comment-form{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px}.live-comment-form .btn{min-height:54px}.live-comment-input{min-height:54px;max-height:190px;resize:vertical;font-size:17px!important;line-height:1.45!important;overflow:auto;white-space:pre-wrap}.comment-limit-hint{grid-column:1/-1;color:var(--muted);font-size:12px;line-height:1.35;margin-top:-6px}.live-comments-list{max-height:398px;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding-right:6px;scrollbar-width:thin}.comment-item{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.07);border-radius:16px;padding:10px 13px;overflow:hidden}.comment-head{display:flex;align-items:center;gap:8px;min-width:0;margin-bottom:5px}.comment-head strong{font-size:13px;line-height:1.2;color:#cfe9ff;font-weight:900;letter-spacing:.01em;overflow-wrap:anywhere;word-break:break-word}.comment-history-mark{font-size:11px;color:var(--muted);font-weight:800;background:rgba(143,211,255,.09);border:1px solid rgba(143,211,255,.14);border-radius:999px;padding:3px 7px;white-space:nowrap}.comment-body{font-size:17px;line-height:1.42;color:var(--text);white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.live-comments-list .muted{padding:8px 0;margin:0}.emoji-comment-row{margin-bottom:12px}.emoji-comment-row button{line-height:1}.player-panel audio.room-audio{display:block;max-width:100%}
@media (max-width:850px){body{padding-bottom:72px}.live-comment-form{grid-template-columns:1fr}.live-comment-form .btn{width:100%}.live-comments-list{max-height:340px}.room-title-line{gap:9px}.room-title-line h1{font-size:36px}.room-inline-description{font-size:18px}}

/* === Efika comments stability patch === */
body{padding-bottom:72px}
.room-title-line{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.room-title-line h1{margin:0}
.room-inline-description{color:#d7e5ee;font-size:clamp(18px,2.3vw,22px);font-weight:700;line-height:1.25}
.comments-panel{overflow:hidden;display:flex;flex-direction:column;min-height:0}
.comments-panel h2{margin-bottom:16px}
.live-comment-form{display:grid!important;grid-template-columns:minmax(0,1fr) 126px!important;grid-template-areas:"field send" "hint hint";align-items:stretch;gap:10px 12px;margin-bottom:12px}
.live-comment-input{grid-area:field;width:100%!important;min-width:0!important;height:76px!important;min-height:76px!important;max-height:76px!important;resize:none!important;font-size:17px!important;line-height:1.55!important;padding:12px 14px!important;overflow-y:auto!important;white-space:pre-wrap!important}
.live-comment-form .btn{grid-area:send;width:126px!important;min-width:126px!important;height:76px!important;min-height:76px!important;padding:0 14px!important;align-self:stretch}
.comment-limit-hint{grid-area:hint;display:block;color:#a9c4d8;font-size:12px;line-height:1.35;margin:0}
.live-comments-list{display:flex!important;flex-direction:column!important;gap:10px!important;max-height:386px!important;overflow-y:auto!important;overflow-x:hidden!important;padding:2px 6px 2px 0!important;scrollbar-width:thin}
.comment-item{flex:0 0 auto;display:block;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.075);border-radius:16px;padding:7px 7px;min-height:0;overflow:visible!important}
.comment-head{display:flex;align-items:center;gap:8px;min-width:0;margin:0 0 6px}
.comment-head strong{font-size:13px!important;line-height:1.2;color:#cfe9ff;font-weight:900;letter-spacing:.01em;overflow-wrap:anywhere;word-break:break-word}
.comment-history-mark{font-size:11px;color:var(--muted);font-weight:800;background:rgba(143,211,255,.09);border:1px solid rgba(143,211,255,.14);border-radius:999px;padding:3px 7px;white-space:nowrap}
.comment-body{font-size:17px!important;line-height:1.5!important;color:var(--text);white-space:pre-wrap!important;overflow-wrap:anywhere!important;word-break:break-word!important}
.live-comments-list .muted{padding:8px 0;margin:0}
@media (max-width: 850px){body{padding-bottom:64px}.live-comment-form{grid-template-columns:minmax(0,1fr) 118px!important}.live-comment-form .btn{width:118px!important;min-width:118px!important}.live-comments-list{max-height:340px!important}}
@media (max-width: 520px){.live-comment-form{grid-template-columns:1fr!important;grid-template-areas:"field" "send" "hint"}.live-comment-form .btn{width:100%!important;min-width:0!important;height:54px!important;min-height:54px!important}.live-comment-input{height:86px!important;min-height:86px!important;max-height:86px!important}.room-title-line{display:block}.room-inline-description{display:block;margin-top:4px}}

/* === Efika realtime upload + compact mobile room title patch === */
.room-title-line{display:flex!important;align-items:baseline!important;gap:12px!important;flex-wrap:nowrap!important;min-width:0!important;max-width:100%!important}
.room-title-line h1{flex:0 0 auto!important;white-space:nowrap!important}
.room-inline-description{flex:1 1 auto!important;min-width:0!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;display:inline-block!important;margin-top:0!important;vertical-align:baseline!important}
.form-status{min-height:18px;margin:0;font-size:13px;line-height:1.35}.form-status.success{color:var(--accent-2)}.form-status.error{color:var(--danger)}.ajax-upload-form button:disabled,.live-comment-form button:disabled{opacity:.65;cursor:wait}
@media (max-width:520px){.room-title-line{display:flex!important;flex-wrap:nowrap!important;gap:8px!important}.room-title-line h1{font-size:34px!important;line-height:1!important}.room-inline-description{display:inline-block!important;font-size:18px!important;line-height:1.15!important;margin-top:0!important}}
@media (max-width:420px){.room-title-line h1{font-size:30px!important}.room-inline-description{font-size:16px!important}}

/* === Efika profile, mood statuses and emoji popups patch === */
.nav{position:relative}.nav-menu{position:relative}.nav-menu-toggle{border:0;background:rgba(143,211,255,.12);color:var(--accent);border-radius:999px;padding:8px 12px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;gap:9px}.login-menu-toggle{padding:10px 16px}.user-menu-toggle{padding:6px 12px 6px 7px;color:var(--text)}.nav-dropdown{position:absolute;right:0;top:calc(100% + 10px);min-width:170px;background:#0b1114;border:1px solid rgba(143,211,255,.18);box-shadow:0 18px 50px rgba(0,0,0,.45);border-radius:18px;padding:8px;display:none;z-index:60}.nav-menu.open .nav-dropdown{display:flex;align-items: center;flex-direction:column}.nav-dropdown a{padding:11px 12px;border-radius:12px;color:#dce8f2}.nav-dropdown a:hover{background:rgba(143,211,255,.12);color:var(--accent)}
.avatar{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;overflow:hidden;border-radius:50%;background:linear-gradient(145deg,rgba(143,211,255,.18),rgba(0,196,140,.14));border:1px solid rgba(143,211,255,.35);color:#dff3ff;font-weight:900;text-transform:uppercase}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.avatar-xs{width:30px;height:30px;font-size:13px}.avatar-sm{width:36px;height:36px;font-size:15px}.avatar-xl{width:112px;height:112px;font-size:42px;border-width:2px}.user-menu-name{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.avatar-list-item{display:grid!important;grid-template-columns:auto 1fr;gap:10px;align-items:start}.avatar-list-item>div{min-width:0}.avatar-list-item b,.avatar-list-item span{overflow-wrap:anywhere}
.mood-status-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.mood-status-card{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;background:linear-gradient(145deg,rgba(32,40,44,.94),rgba(18,24,27,.92));border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:10px;min-width:0}.mood-status-card:hover{border-color:rgba(143,211,255,.35);transform:translateY(-1px)}.mood-status-body{display:flex;flex-direction:column;gap:2px;min-width:0}.mood-status-body strong{font-size:13px;color:#cfe9ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mood-status-body em{font-style:normal;font-size:16px;line-height:1.25;color:var(--text);overflow-wrap:anywhere}.mood-section .empty-card{min-height:80px}
.emoji-field-wrap{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:stretch;width:100%}.emoji-field-wrap input,.emoji-field-wrap textarea{min-width:0}.emoji-toggle{border:0;border-radius:14px;background:rgba(255,255,255,.08);color:var(--text);width:48px;min-width:48px;cursor:pointer;font-size:20px}.emoji-toggle:hover{background:rgba(143,211,255,.16)}.field-hint{color:#a9c4d8;font-size:12px;line-height:1.35}.emoji-picker-popup{position:absolute;z-index:120;width:248px;display:grid;grid-template-columns:repeat(6,1fr);gap:6px;padding:10px;background:#080d10;border:1px solid rgba(143,211,255,.25);box-shadow:0 18px 55px rgba(0,0,0,.55);border-radius:18px}.emoji-picker-popup.hidden{display:none}.emoji-picker-popup button{border:0;border-radius:11px;background:rgba(255,255,255,.07);font-size:21px;line-height:1;padding:8px 0;cursor:pointer}.emoji-picker-popup button:hover{background:rgba(143,211,255,.16)}
.live-comment-form{grid-template-columns:minmax(0,1fr) 126px!important;grid-template-areas:"field send" "hint hint"}.live-comment-wrap{grid-area:field;min-width:0}.live-comment-wrap .live-comment-input{width:100%!important;height:76px!important;min-height:76px!important;max-height:76px!important}.live-comment-wrap .emoji-toggle{height:76px}.live-comment-form>.btn{grid-area:send}.comment-head .avatar{margin-right:2px}.comment-head{align-items:center}.comment-body{padding-left:42px}.profile-grid{display:grid;grid-template-columns:.8fr 1.1fr 1.1fr;gap:18px;align-items:start}.profile-preview{display:flex;align-items:center;gap:18px}.profile-preview h3{font-size:28px;margin:0 0 4px}.profile-preview p{margin:0}.profile-form h2{margin-top:0}
@media (max-width:980px){.mood-status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-grid{grid-template-columns:1fr}.topbar{padding:14px 18px}.user-menu-name{max-width:130px}}
@media (max-width:520px){.mood-status-grid{display:flex;overflow-x:auto;padding-bottom:8px}.mood-status-card{min-width:230px}.live-comment-form{grid-template-columns:1fr!important;grid-template-areas:"field" "send" "hint"}.live-comment-form>.btn{width:100%!important;min-width:0!important}.live-comment-wrap .live-comment-input{height:86px!important;min-height:86px!important;max-height:86px!important}.live-comment-wrap .emoji-toggle{height:86px}.comment-body{padding-left:0}.nav-dropdown{right:0px}.brand{font-size:26px}.user-menu-name{max-width:105px}.emoji-picker-popup{width:228px;grid-template-columns:repeat(6,1fr)}}

/* === Efika v8: stable fields, clean file picker, progress and avatar picker === */
.native-file-input{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.form-field{display:flex;flex-direction:column;gap:8px;color:#cbd8e0;font-weight:700;min-width:0}
.form-field>label{display:block;color:#cbd8e0;font-weight:800}
.file-form-field{gap:10px}.file-picker-button{border:1px solid rgba(143,211,255,.26);border-radius:18px;background:linear-gradient(145deg,rgba(143,211,255,.16),rgba(93,213,255,.09));color:#dff3ff;font-weight:900;padding:5px 18px;cursor:pointer;text-align:center;transition:.15s ease}.file-picker-button:hover{transform:translateY(-1px);background:linear-gradient(145deg,rgba(143,211,255,.23),rgba(93,213,255,.13))}.selected-file-name{min-height:20px;color:#a9c4d8;font-size:13px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ajax-upload-form .emoji-field-wrap{display:grid!important;grid-template-columns:minmax(0,1fr) 50px!important;gap:10px!important;align-items:stretch!important;width:100%!important;min-width:0!important}.ajax-upload-form .emoji-field-wrap input,.ajax-upload-form .emoji-field-wrap textarea{display:block!important;width:100%!important;min-width:0!important;margin:0!important}.ajax-upload-form textarea#upload-comment-input{height:92px!important;min-height:92px!important;max-height:92px!important;resize:none!important;font-size:16px!important;line-height:1.55!important;overflow-y:auto!important}.ajax-upload-form input#upload-mood-input{height:54px!important;font-size:16px!important}.ajax-upload-form .emoji-toggle{width:50px!important;min-width:50px!important;height:auto!important;min-height:54px!important;align-self:stretch!important}.upload-textarea-wrap .emoji-toggle{min-height:92px!important}.upload-mood-wrap .emoji-toggle{min-height:54px!important}
.upload-progress{display:flex;flex-direction:column;gap:8px;margin:2px 0 0}.upload-progress-head{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#a9c4d8;font-size:13px;font-weight:800}.upload-progress-head b{color:var(--accent);font-variant-numeric:tabular-nums}.upload-progress-track{height:10px;border-radius:999px;background:rgba(255,255,255,.075);overflow:hidden;border:1px solid rgba(255,255,255,.08)}.upload-progress-track span{display:block;width:0;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),#5dd5ff);transition:width .18s ease}
.comments-panel .live-comment-form{display:grid!important;grid-template-columns:minmax(0,1fr) 126px!important;grid-template-areas:"field send" "hint hint"!important;gap:10px 12px!important;align-items:stretch!important;margin-bottom:12px!important}.comments-panel .live-comment-wrap{grid-area:field!important;display:grid!important;grid-template-columns:minmax(0,1fr) 50px!important;gap:10px!important;width:100%!important;min-width:0!important;align-items:stretch!important}.comments-panel .live-comment-wrap .live-comment-input{display:block!important;width:100%!important;min-width:0!important;height:88px!important;min-height:88px!important;max-height:88px!important;resize:none!important;margin:0!important;font-size:17px!important;line-height:1.55!important;overflow-y:auto!important}.comments-panel .live-comment-wrap .emoji-toggle{width:50px!important;min-width:50px!important;height:88px!important;min-height:88px!important;align-self:stretch!important}.comments-panel .live-comment-form>.btn{grid-area:send!important;width:126px!important;min-width:126px!important;height:88px!important;min-height:88px!important;align-self:stretch!important}.comments-panel .comment-limit-hint{grid-area:hint!important;margin:0!important;color:#a9c4d8!important}.emoji-picker-popup{position:absolute!important;z-index:120!important}.emoji-picker-popup.hidden{display:none!important}
.profile-grid-v8{grid-template-columns:1fr 1fr!important}.profile-main-form{gap:16px}.profile-avatar-block{display:flex;flex-direction:column;gap:8px}.profile-avatar-picker{display:flex!important;flex-direction:row!important;align-items:center!important;gap:18px!important;padding:14px!important;border-radius:22px!important;background:rgba(255,255,255,.04)!important;border:1px solid rgba(143,211,255,.16)!important;cursor:pointer!important;transition:.15s ease}.profile-avatar-picker:hover{border-color:rgba(143,211,255,.35)!important;background:rgba(143,211,255,.08)!important}.profile-avatar-picker strong{display:block;font-size:24px;line-height:1.15;color:var(--text);overflow-wrap:anywhere}.profile-avatar-picker small{display:block;margin-top:4px;color:#a9c4d8;font-size:13px;line-height:1.35}.profile-avatar-picker .avatar-xl{transition:.15s ease}.profile-avatar-picker:hover .avatar-xl{transform:scale(1.03)}
@media (max-width:850px){.profile-grid-v8{grid-template-columns:1fr!important}.ajax-upload-form .emoji-field-wrap{grid-template-columns:minmax(0,1fr) 50px!important}.comments-panel .live-comment-form{grid-template-columns:minmax(0,1fr) 118px!important}.comments-panel .live-comment-form>.btn{width:118px!important;min-width:118px!important}}
@media (max-width:560px){.comments-panel .live-comment-form{grid-template-columns:1fr!important;grid-template-areas:"field" "send" "hint"!important}.comments-panel .live-comment-form>.btn{width:100%!important;min-width:0!important;height:56px!important;min-height:56px!important}.comments-panel .live-comment-wrap .live-comment-input{height:90px!important;min-height:90px!important;max-height:90px!important}.comments-panel .live-comment-wrap .emoji-toggle{height:90px!important;min-height:90px!important}.ajax-upload-form textarea#upload-comment-input{height:96px!important;min-height:96px!important;max-height:96px!important}.profile-avatar-picker{align-items:flex-start!important}.profile-avatar-picker strong{font-size:21px}}

/* === Efika v9: жесткая фиксация полей комментариев и постеры в истории === */
#room-upload-form .emoji-combo{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) 54px!important;
  gap:10px!important;
  align-items:stretch!important;
  width:100%!important;
  min-width:0!important;
}
#room-upload-form .emoji-combo .emoji-toggle{
  width:54px!important;
  min-width:54px!important;
  height:auto!important;
  min-height:58px!important;
  align-self:stretch!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
#room-upload-form #upload-comment-input,
#live-comment-form #live-comment-input{
  box-sizing:border-box!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  margin:0!important;
  flex:0 1 auto!important;
  resize:none!important;
  writing-mode:horizontal-tb!important;
  field-sizing:fixed!important;
  -webkit-appearance:none!important;
  appearance:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  white-space:pre-wrap!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
}
#room-upload-form #upload-comment-input{
  height:96px!important;
  min-height:96px!important;
  max-height:96px!important;
  font-size:16px!important;
  line-height:1.55!important;
}
#room-upload-form .upload-comment-row .emoji-toggle{
  min-height:96px!important;
}
#room-upload-form #upload-mood-input{
  box-sizing:border-box!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  height:58px!important;
  min-height:58px!important;
  margin:0!important;
  font-size:16px!important;
  line-height:1.35!important;
}
#room-upload-form .upload-mood-row .emoji-toggle{
  min-height:58px!important;
}
.comments-panel .live-comment-form-v9{
  display:flex!important;
  flex-direction:column!important;
  gap:10px!important;
  width:100%!important;
  min-width:0!important;
  margin:0 0 14px!important;
}
.comments-panel .live-comment-controls{
  display:grid!important;
  grid-template-columns:58px minmax(220px,1fr) 132px!important;
  grid-template-areas:"emoji field send"!important;
  gap:12px!important;
  align-items:stretch!important;
  width:100%!important;
  min-width:0!important;
}
.comments-panel .live-comment-emoji{
  grid-area:emoji!important;
  width:58px!important;
  min-width:58px!important;
  height:96px!important;
  min-height:96px!important;
  align-self:stretch!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.comments-panel #live-comment-input{
  grid-area:field!important;
  height:96px!important;
  min-height:96px!important;
  max-height:96px!important;
  font-size:17px!important;
  line-height:1.55!important;
}
.comments-panel .live-comment-submit{
  grid-area:send!important;
  width:132px!important;
  min-width:132px!important;
  height:96px!important;
  min-height:96px!important;
  align-self:stretch!important;
  padding:0 14px!important;
}
.comments-panel .comment-limit-hint{
  display:block!important;
  margin:0!important;
  color:#a9c4d8!important;
  font-size:12px!important;
  line-height:1.35!important;
}
.track-list-item{
  display:grid!important;
  grid-template-columns:52px minmax(0,1fr)!important;
  gap:12px!important;
  align-items:center!important;
}
.track-list-item>div{
  min-width:0!important;
}
.track-list-item b,
.track-list-item span:not(.track-thumb){
  overflow-wrap:anywhere!important;
}
.track-thumb{
  width:52px!important;
  height:52px!important;
  border-radius:14px!important;
  overflow:hidden!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex:0 0 52px!important;
  color:var(--accent)!important;
  font-size:22px!important;
  font-weight:900!important;
  background:linear-gradient(145deg,#1f2a2f,#0b0f11)!important;
  border:1px solid rgba(143,211,255,.25)!important;
}
.track-thumb img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
}
.track-thumb-empty{
  background:linear-gradient(145deg,rgba(143,211,255,.14),rgba(0,196,140,.1))!important;
}
@media (max-width:680px){
  .comments-panel .live-comment-controls{
    grid-template-columns:54px minmax(0,1fr) 118px!important;
    gap:10px!important;
  }
  .comments-panel .live-comment-emoji{
    width:54px!important;
    min-width:54px!important;
    height:92px!important;
    min-height:92px!important;
  }
  .comments-panel #live-comment-input{
    height:92px!important;
    min-height:92px!important;
    max-height:92px!important;
  }
  .comments-panel .live-comment-submit{
    width:118px!important;
    min-width:118px!important;
    height:92px!important;
    min-height:92px!important;
  }
}
@media (max-width:460px){
  .comments-panel .live-comment-controls{
    grid-template-columns:54px minmax(0,1fr)!important;
    grid-template-areas:"emoji field" "send send"!important;
  }
  .comments-panel .live-comment-submit{
    width:100%!important;
    min-width:0!important;
    height:56px!important;
    min-height:56px!important;
  }
}

/* === Efika v10: стабильные поля загрузки и попап эмоций над полем === */
#room-upload-form .form-field{
  width:100%!important;
  min-width:0!important;
}
#room-upload-form .input-emoji-shell{
  position:relative!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
}
#room-upload-form .input-emoji-shell textarea,
#room-upload-form .input-emoji-shell input{
  box-sizing:border-box!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  margin:0!important;
  padding-right:72px!important;
  flex:none!important;
  transform:none!important;
  writing-mode:horizontal-tb!important;
  field-sizing:fixed!important;
  -webkit-appearance:none!important;
  appearance:none!important;
}
#room-upload-form #upload-comment-input,
#room-upload-form #upload-comment-input:focus,
#room-upload-form #upload-comment-input:active{
  height:104px!important;
  min-height:104px!important;
  max-height:104px!important;
  resize:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  white-space:pre-wrap!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
  font-size:16px!important;
  line-height:1.55!important;
}
#room-upload-form #upload-mood-input,
#room-upload-form #upload-mood-input:focus,
#room-upload-form #upload-mood-input:active{
  height:58px!important;
  min-height:58px!important;
  max-height:58px!important;
  font-size:16px!important;
  line-height:1.35!important;
}
#room-upload-form .input-emoji-shell .emoji-toggle{
  position:absolute!important;
  right:10px!important;
  top:10px!important;
  z-index:2!important;
  width:46px!important;
  min-width:46px!important;
  max-width:46px!important;
  height:46px!important;
  min-height:46px!important;
  max-height:46px!important;
  padding:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
#room-upload-form .upload-mood-row .emoji-toggle{
  top:6px!important;
}
.emoji-picker-popup{
  position:absolute!important;
  z-index:120!important;
  max-width:calc(100vw - 24px)!important;
}

/* === Efika v11: fixes for player text, live comment emoji button, favicon admin === */
.room-main-grid{
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr)!important;
}
.room-main-grid>.panel,
.room-now-layout,
.room-now-layout>div,
.now-card-body,
.now-card-body>div{
  min-width:0!important;
}
#room-now-title,
#room-now-meta,
.now-user-comment,
.now-card-body h2,
.now-card-body p{
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
}
#room-now-meta,
.now-card-body p{
  line-height:1.45!important;
}
.now-user-comment{
  display:block!important;
  margin-top:4px!important;
  white-space:pre-wrap!important;
  color:#b9c9d6!important;
}
.player-panel .track-description{
  max-height:190px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  white-space:pre-wrap!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
  padding-right:8px!important;
  scrollbar-width:thin!important;
}
#room-upload-form,
#room-upload-form *{
  min-width:0;
}
#room-upload-form .input-emoji-shell{
  inline-size:100%!important;
  max-inline-size:100%!important;
  min-inline-size:0!important;
}
#room-upload-form #upload-comment-input,
#room-upload-form #upload-comment-input:focus,
#room-upload-form #upload-comment-input:active{
  inline-size:100%!important;
  min-inline-size:0!important;
  max-inline-size:100%!important;
  height:104px!important;
  min-height:104px!important;
  max-height:104px!important;
}
.comments-panel .live-comment-controls-v11{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) 132px!important;
  grid-template-areas:"field send" "hint hint"!important;
  gap:10px 12px!important;
  align-items:stretch!important;
  width:100%!important;
  min-width:0!important;
}
.comments-panel .live-comment-shell{
  grid-area:field!important;
  position:relative!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
}
.comments-panel .live-comment-shell #live-comment-input,
.comments-panel .live-comment-shell #live-comment-input:focus,
.comments-panel .live-comment-shell #live-comment-input:active{
  box-sizing:border-box!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  height:96px!important;
  min-height:96px!important;
  max-height:96px!important;
  margin:0!important;
  padding-right:72px!important;
  resize:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  white-space:pre-wrap!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
  font-size:17px!important;
  line-height:1.55!important;
}
.comments-panel .live-comment-shell .live-comment-emoji{
  position:absolute!important;
  right:10px!important;
  top:10px!important;
  z-index:2!important;
  width:46px!important;
  min-width:46px!important;
  max-width:46px!important;
  height:46px!important;
  min-height:46px!important;
  max-height:46px!important;
  padding:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.comments-panel .live-comment-submit{
  grid-area:send!important;
  width:132px!important;
  min-width:132px!important;
  height:96px!important;
  min-height:96px!important;
  align-self:stretch!important;
}
.comments-panel .comment-limit-hint{
  grid-column:1/-1!important;
}
.emoji-picker-popup{
  z-index:500!important;
}
.favicon-admin-panel{
  margin-bottom:18px!important;
}
.favicon-admin-row{
  display:flex!important;
  align-items:center!important;
  gap:16px!important;
  flex-wrap:wrap!important;
}
.favicon-preview{
  width:58px!important;
  height:58px!important;
  border-radius:18px!important;
  background:rgba(143,211,255,.12)!important;
  border:1px solid rgba(143,211,255,.28)!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  color:var(--accent)!important;
  font-weight:900!important;
  font-size:24px!important;
}
.favicon-preview img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
}
.favicon-upload-control{
  display:flex!important;
  flex-direction:column!important;
  gap:7px!important;
  color:var(--text)!important;
  font-weight:800!important;
}
.favicon-upload-control span{
  color:var(--muted)!important;
  font-size:13px!important;
  font-weight:500!important;
  line-height:1.35!important;
}
.favicon-upload-control code{
  color:var(--accent)!important;
}
@media (max-width:680px){
  .comments-panel .live-comment-controls-v11{
    grid-template-columns:minmax(0,1fr) 118px!important;
  }
  .comments-panel .live-comment-submit{
    width:118px!important;
    min-width:118px!important;
  }
}
@media (max-width:460px){
  .comments-panel .live-comment-controls-v11{
    grid-template-columns:1fr!important;
    grid-template-areas:"field" "send" "hint"!important;
  }
  .comments-panel .live-comment-submit{
    width:100%!important;
    min-width:0!important;
    height:56px!important;
    min-height:56px!important;
  }
}

