:root{--bg:#0d1214;--surface:#171d20;--surface-2:#20282c;--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:32px;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:12px 18px;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(135deg,var(--accent),#5dd5ff);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:24px}.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:12px 14px;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:10px 13px;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(320px,70vw);background:#05090b;color:var(--text);border:1px solid rgba(143,211,255,.28);box-shadow:0 16px 48px rgba(0,0,0,.45);padding:12px 14px;border-radius:14px;line-height:1.35;font-weight:600;font-size:13px;text-transform:none;letter-spacing:0;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{opacity:1;transform:translateX(-50%) translateY(0)}

@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:11px 13px;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:190px;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;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:12px;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:-4px}.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:15px 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;
  }
}

/* === Efika v12: upload modal, bottom upload panel, responsive room player, autoplay polish === */
.room-main-grid-player-only{
  grid-template-columns:1fr!important;
  gap:0!important;
}
.player-panel-head{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:14px!important;
  margin-bottom:4px!important;
}
.open-upload-modal-btn{
  white-space:nowrap!important;
  border-radius:999px!important;
}
.room-now-text{
  min-width:0!important;
}
.room-now-text h2,
#room-now-title{
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
}
.room-upload-bottom{
  padding-top:10px!important;
  padding-bottom:34px!important;
}
.upload-panel-bottom{
  max-width:720px!important;
  margin:0 auto!important;
}
.ajax-upload-form,
.ajax-upload-form *{
  min-width:0;
}
.ajax-upload-form .form-field{
  width:100%!important;
  min-width:0!important;
}
.ajax-upload-form .input-emoji-shell{
  position:relative!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
}
.ajax-upload-form .input-emoji-shell textarea,
.ajax-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;
}
.ajax-upload-form textarea[name="user_comment"],
.ajax-upload-form textarea[name="user_comment"]:focus,
.ajax-upload-form textarea[name="user_comment"]: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;
  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;
}
.ajax-upload-form input[name="mood_tag"],
.ajax-upload-form input[name="mood_tag"]:focus,
.ajax-upload-form input[name="mood_tag"]:active{
  height:58px!important;
  min-height:58px!important;
  max-height:58px!important;
  font-size:16px!important;
  line-height:1.35!important;
}
.ajax-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;
}
.ajax-upload-form .upload-mood-row .emoji-toggle{
  top:6px!important;
}
.efika-modal.hidden{
  display:none!important;
}
.efika-modal{
  position:fixed!important;
  inset:0!important;
  z-index:900!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:18px!important;
}
.efika-modal-backdrop{
  position:absolute!important;
  inset:0!important;
  background:rgba(2,6,8,.72)!important;
  backdrop-filter:blur(10px)!important;
}
.efika-modal-card{
  position:relative!important;
  z-index:1!important;
  width:min(680px,100%)!important;
  max-height:min(88vh,760px)!important;
  overflow-y:auto!important;
  padding:28px!important;
  border-radius:28px!important;
  background:linear-gradient(145deg,rgba(32,40,44,.98),rgba(13,18,20,.98))!important;
  border:1px solid rgba(143,211,255,.18)!important;
  box-shadow:0 28px 90px rgba(0,0,0,.72)!important;
}
.efika-modal-card h2{
  margin:0 48px 18px 0!important;
  font-size:32px!important;
}
.efika-modal-close{
  position:absolute!important;
  top:18px!important;
  right:18px!important;
  width:42px!important;
  height:42px!important;
  border:0!important;
  border-radius:14px!important;
  background:rgba(255,255,255,.08)!important;
  color:var(--text)!important;
  font-size:30px!important;
  line-height:1!important;
  cursor:pointer!important;
}
body.modal-open{
  overflow:hidden!important;
}
.emoji-picker-popup{
  transform:none!important;
}
@media (max-width:980px){
  .room-main-grid,
  .room-main-grid-player-only{
    grid-template-columns:1fr!important;
  }
}
@media (max-width:680px){
  .room-now-layout{
    grid-template-columns:96px minmax(0,1fr)!important;
    gap:14px!important;
    align-items:center!important;
  }
  .player-panel-head{
    align-items:flex-start!important;
  }
  .open-upload-modal-btn{
    padding:10px 12px!important;
    font-size:13px!important;
  }
  .player-panel .track-description{
    max-height:150px!important;
  }
  .efika-modal{
    align-items:flex-end!important;
    padding:10px!important;
  }
  .efika-modal-card{
    width:100%!important;
    max-height:92vh!important;
    padding:22px!important;
    border-radius:24px!important;
  }
}
@media (max-width:460px){
  .player-panel-head{
    flex-direction:column!important;
  }
  .open-upload-modal-btn{
    width:100%!important;
  }
  .room-now-layout{
    grid-template-columns:86px minmax(0,1fr)!important;
    gap:12px!important;
  }
  .track-cover{
    width:86px!important;
    height:86px!important;
    border-radius:18px!important;
  }
  #room-now-title{
    font-size:24px!important;
    line-height:1.15!important;
  }
}

/* === Efika v14: custom radio player, compact upload progress and fixed emoji popup === */
.native-room-audio,
.player-panel audio.native-room-audio{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  opacity:0!important;
  pointer-events:none!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
}
.player-panel{
  position:relative!important;
  overflow:hidden!important;
}
.player-panel-head{
  position:relative!important;
  z-index:2!important;
}
.room-now-layout{
  align-items:center!important;
  gap:20px!important;
}
.room-now-text{
  min-width:0!important;
  max-width:100%!important;
}
#room-now-meta{
  line-height:1.55!important;
}
.now-user-comment{
  display:block!important;
  margin-top:4px!important;
  white-space:pre-wrap!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
  color:#b9d0df!important;
}
.player-panel .track-description,
#room-now-description{
  max-height:168px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding-right:8px!important;
  white-space:pre-wrap!important;
  scrollbar-width:thin!important;
}
.radio-control-row{
  display:flex!important;
  align-items:center!important;
  gap:16px!important;
  margin-top:18px!important;
  padding:18px!important;
  border-radius:24px!important;
  background:linear-gradient(145deg,rgba(8,13,16,.65),rgba(255,255,255,.035))!important;
  border:1px solid rgba(255,255,255,.07)!important;
}
.radio-play-button{
  width:76px!important;
  height:76px!important;
  min-width:76px!important;
  border:0!important;
  border-radius:50%!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  cursor:pointer!important;
  background:#eef4f8!important;
  color:#061014!important;
  box-shadow:0 18px 40px rgba(0,0,0,.36)!important;
  transition:transform .15s ease, filter .15s ease!important;
}
.radio-play-button:hover{
  transform:scale(1.04)!important;
  filter:brightness(1.04)!important;
}
.radio-play-button.is-playing{
  background:linear-gradient(135deg,var(--accent),#5dd5ff)!important;
}
.radio-play-icon{
  font-size:28px!important;
  line-height:1!important;
  transform:translateX(2px)!important;
}
.radio-play-button.is-playing .radio-play-icon{
  font-size:24px!important;
  transform:none!important;
}
.radio-control-copy{
  display:flex!important;
  min-width:0!important;
  flex-direction:column!important;
  gap:4px!important;
}
.radio-control-copy strong{
  font-size:18px!important;
  color:#eaf5ff!important;
}
.radio-control-copy span{
  font-size:13px!important;
  line-height:1.35!important;
}
.radio-control-copy span.hidden{
  display:none!important;
}
.emoji-picker-popup{
  position:fixed!important;
  z-index:1400!important;
  max-width:calc(100vw - 24px)!important;
}
.track-upload-modal-card.upload-progress-state{
  width:min(440px,100%)!important;
  max-height:none!important;
  overflow:visible!important;
  text-align:center!important;
  padding:28px!important;
}
.track-upload-modal-card.upload-progress-state .efika-modal-close{
  display:none!important;
}
.track-upload-modal-card.upload-progress-state .form-field,
.track-upload-modal-card.upload-progress-state .file-form-field,
.track-upload-modal-card.upload-progress-state .selected-file-name,
.track-upload-modal-card.upload-progress-state .ajax-upload-form > .btn{
  display:none!important;
}
.track-upload-modal-card.upload-progress-state .ajax-upload-form{
  gap:18px!important;
}
.track-upload-modal-card.upload-progress-state .upload-progress{
  display:flex!important;
  margin-top:0!important;
}
.track-upload-modal-card.upload-progress-state .form-status{
  display:block!important;
  margin:0!important;
  font-size:17px!important;
  line-height:1.45!important;
  color:#dce8f2!important;
}
.track-upload-modal-card.upload-success-state .upload-progress-head span{
  color:var(--accent-2)!important;
}
@media (min-width:860px){
  .player-panel{
    padding:30px!important;
  }
  .room-now-layout{
    grid-template-columns:152px minmax(0,1fr)!important;
  }
  .player-panel .track-cover,
  .room-now-layout .track-cover{
    width:152px!important;
    height:152px!important;
    border-radius:26px!important;
  }
  #room-now-title{
    font-size:34px!important;
    line-height:1.12!important;
  }
}
@media (max-width:680px){
  .radio-control-row{
    padding:14px!important;
  }
  .radio-play-button{
    width:62px!important;
    height:62px!important;
    min-width:62px!important;
  }
  .radio-play-icon{
    font-size:23px!important;
  }
  .room-now-layout{
    grid-template-columns:96px minmax(0,1fr)!important;
  }
}


/* === Efika v16: stronger room autoplay, slower player ring, clickable player block === */
.efika-global-audio{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  opacity:0!important;
  pointer-events:none!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
}

.room-now-layout[data-audio-toggle-surface],
.radio-control-row[data-audio-toggle-surface],
.now-card-player[data-audio-toggle-surface]{
  cursor:pointer!important;
}

.room-now-layout[data-audio-toggle-surface]:hover .track-cover,
.now-card-player[data-audio-toggle-surface]:hover .track-cover{
  box-shadow:0 0 0 1px rgba(143,211,255,.18), 0 18px 48px rgba(0,0,0,.28)!important;
}

#room-now-title{
  max-width:100%!important;
  font-size:clamp(24px,3.1vw,34px)!important;
}

.radio-control-row{
  position:relative!important;
  isolation:isolate!important;
  justify-content:space-between!important;
  gap:18px!important;
  overflow:visible!important;
  border:0!important;
  background:
    radial-gradient(circle at 88% 50%, rgba(143,211,255,.16), transparent 33%),
    radial-gradient(circle at 16% 0%, rgba(0,196,140,.11), transparent 42%),
    linear-gradient(145deg,rgba(6,10,13,.88),rgba(22,30,34,.82))!important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    inset 0 -1px 0 rgba(0,0,0,.32),
    0 18px 48px rgba(0,0,0,.28)!important;
}

.radio-control-row:before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:-1!important;
  border-radius:inherit!important;
  background-image:
    linear-gradient(115deg,rgba(255,255,255,.035),transparent 28%,rgba(143,211,255,.06) 52%,transparent 78%),
    repeating-linear-gradient(135deg,rgba(255,255,255,.025) 0 1px,transparent 1px 8px)!important;
  opacity:.75!important;
  pointer-events:none!important;
}

.radio-control-copy{
  order:1!important;
  flex:1 1 auto!important;
  min-width:0!important;
}

.radio-control-copy strong{
  font-size:clamp(18px,2.2vw,23px)!important;
  letter-spacing:.01em!important;
}

.radio-play-button{
  order:2!important;
  margin-left:auto!important;
  position:relative!important;
  isolation:isolate!important;
  overflow:visible!important;
  border:0!important;
  outline:0!important;
  background:
    radial-gradient(circle at 35% 28%,#ffffff 0,#e8f5ff 34%,#7fd4ff 100%)!important;
  color:#061014!important;
  box-shadow:
    0 18px 45px rgba(0,0,0,.42),
    0 0 34px rgba(143,211,255,.22),
    inset 0 -10px 18px rgba(3,15,22,.10),
    inset 0 8px 18px rgba(255,255,255,.42)!important;
}

.radio-play-button:before{
  content:""!important;
  position:absolute!important;
  inset:-8px!important;
  border-radius:50%!important;
  padding:3px!important;
  background:
    conic-gradient(from 0deg, transparent 0 26%, rgba(143,211,255,.98) 34%, rgba(0,196,140,.98) 50%, rgba(255,255,255,.86) 62%, transparent 74% 100%)!important;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0)!important;
  -webkit-mask-composite:xor!important;
  mask-composite:exclude!important;
  animation:efika-player-ring 4.8s linear infinite!important;
  opacity:.95!important;
  pointer-events:none!important;
}

.radio-play-button:after{
  content:""!important;
  position:absolute!important;
  inset:-18px!important;
  z-index:-2!important;
  border-radius:50%!important;
  background:
    radial-gradient(circle,rgba(143,211,255,.27),rgba(0,196,140,.11) 42%,transparent 70%)!important;
  animation:efika-player-pulse 3.6s ease-in-out infinite!important;
  pointer-events:none!important;
}

.radio-play-button.is-playing:before{
  animation-duration:2.1s!important;
}

.radio-play-button.is-playing{
  background:
    radial-gradient(circle at 36% 28%,#dff5ff 0,#79d7ff 39%,#00c48c 100%)!important;
}

.radio-play-icon{
  position:relative!important;
  z-index:1!important;
  text-shadow:0 1px 0 rgba(255,255,255,.28)!important;
}

@keyframes efika-player-ring{
  to{transform:rotate(360deg)}
}

@keyframes efika-player-pulse{
  0%,100%{transform:scale(.92);opacity:.55}
  50%{transform:scale(1.08);opacity:.95}
}

.now-card-player{
  grid-template-columns:132px minmax(0,1fr) auto!important;
  gap:18px!important;
  align-items:center!important;
}

.now-card-copy{
  min-width:0!important;
}

.hero-audio-state{
  display:inline-flex!important;
  width:max-content!important;
  margin:8px 0 0!important;
  padding:6px 10px!important;
  border-radius:999px!important;
  background:rgba(143,211,255,.12)!important;
  color:#dff3ff!important;
  font-size:12px!important;
  font-weight:900!important;
  letter-spacing:.05em!important;
}

.hero-radio-play-button{
  width:58px!important;
  height:58px!important;
  min-width:58px!important;
}

.hero-radio-play-button .radio-play-icon{
  font-size:22px!important;
}

.track-upload-modal-card.upload-progress-state .form-status{
  font-weight:900!important;
}

@media (max-width:560px){
  .player-panel{
    padding:18px!important;
    border-radius:24px!important;
  }

  .player-panel-head{
    gap:10px!important;
    margin-bottom:0!important;
  }

  .live-dot{
    padding:7px 10px!important;
    font-size:11px!important;
  }

  .open-upload-modal-btn{
    max-width:210px!important;
    white-space:normal!important;
    text-align:center!important;
    line-height:1.15!important;
  }

  .room-now-layout{
    grid-template-columns:76px minmax(0,1fr)!important;
    gap:10px!important;
    align-items:center!important;
  }

  .player-panel .track-cover,
  .room-now-layout .track-cover,
  .track-cover{
    width:76px!important;
    height:76px!important;
    min-width:76px!important;
    border-radius:17px!important;
    font-size:29px!important;
  }

  #room-now-title{
    font-size:clamp(20px,5.3vw,24px)!important;
    line-height:1.12!important;
    letter-spacing:-.03em!important;
    margin:0 0 7px!important;
  }

  #room-now-meta{
    font-size:13px!important;
    line-height:1.34!important;
  }

  .now-user-comment{
    margin-top:3px!important;
    font-size:13px!important;
    line-height:1.32!important;
  }

  #room-now-description{
    display:none!important;
  }

  .radio-control-row{
    margin-top:14px!important;
    padding:12px!important;
    border-radius:22px!important;
    gap:12px!important;
  }

  .radio-control-copy strong{
    font-size:18px!important;
  }

  .radio-control-copy span{
    font-size:12px!important;
  }

  .radio-play-button{
    width:58px!important;
    height:58px!important;
    min-width:58px!important;
  }

  .radio-play-button:before{
    inset:-7px!important;
  }

  .radio-play-button:after{
    inset:-14px!important;
  }

  .now-card-player{
    grid-template-columns:82px minmax(0,1fr) 54px!important;
    gap:12px!important;
  }

  .hero-radio-play-button{
    width:54px!important;
    height:54px!important;
    min-width:54px!important;
  }
}

@media (max-width:400px){
  .room-now-layout{
    grid-template-columns:66px minmax(0,1fr)!important;
    gap:9px!important;
  }

  .player-panel .track-cover,
  .room-now-layout .track-cover,
  .track-cover{
    width:66px!important;
    height:66px!important;
    min-width:66px!important;
    border-radius:15px!important;
    font-size:25px!important;
  }

  #room-now-title{
    font-size:20px!important;
  }

  .radio-play-button{
    width:54px!important;
    height:54px!important;
    min-width:54px!important;
  }
}

/* === Efika v17: strict now-playing layout, slower player button, cleaner room/player controls === */
:root{
  --player-ring-idle-speed:19.2s;
  --player-ring-live-speed:4.2s;
  --player-pulse-idle-speed:14.4s;
  --player-pulse-live-speed:7.2s;
  --player-button-size:76px;
  --player-button-size-mobile:58px;
}

.player-panel-head{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:14px!important;
}

.now-card-strict{
  justify-content:center!important;
}

.room-now-layout,
.now-card-player{
  display:grid!important;
  grid-template-columns:clamp(104px,15vw,150px) minmax(0,1fr)!important;
  grid-template-areas:
    "poster text"
    "description description"!important;
  align-items:start!important;
  gap:18px 22px!important;
}

.now-card-player{
  grid-template-areas:
    "poster text"
    "description description"
    "controls controls"!important;
}

.room-now-layout .track-cover,
.now-card-player > .track-cover{
  grid-area:poster!important;
  width:clamp(104px,15vw,150px)!important;
  height:clamp(104px,15vw,150px)!important;
  min-width:0!important;
  border-radius:24px!important;
  align-self:start!important;
}

.room-now-text,
.now-card-copy{
  grid-area:text!important;
  min-width:0!important;
  align-self:start!important;
}

#room-now-title,
.now-card-copy h2{
  margin:0 0 12px!important;
  max-width:100%!important;
  font-size:clamp(25px,3.3vw,36px)!important;
  line-height:1.12!important;
  letter-spacing:-.045em!important;
  overflow-wrap:anywhere!important;
}

#room-now-meta,
.now-track-meta,
.now-card-copy p{
  margin:0!important;
  color:var(--muted)!important;
  font-size:clamp(14px,1.65vw,17px)!important;
  line-height:1.45!important;
  overflow-wrap:anywhere!important;
}

.now-user-comment{
  display:block!important;
  margin-top:8px!important;
  color:#dce8f2!important;
  line-height:1.45!important;
}

.room-now-layout .track-description,
.now-card-player .track-description,
#room-now-description{
  grid-area:description!important;
  display:block!important;
  margin:2px 0 0!important;
  padding:0 12px 0 0!important;
  max-height:170px!important;
  min-height:0!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  color:#aeb9c2!important;
  font-size:clamp(15px,1.75vw,17px)!important;
  line-height:1.55!important;
  scrollbar-width:thin!important;
}

.room-now-layout .track-description:empty,
.now-card-player .track-description:empty,
#room-now-description:empty{
  display:none!important;
}

.room-now-layout .track-description::-webkit-scrollbar,
.now-card-player .track-description::-webkit-scrollbar,
#room-now-description::-webkit-scrollbar{
  width:5px!important;
}

.room-now-layout .track-description::-webkit-scrollbar-thumb,
.now-card-player .track-description::-webkit-scrollbar-thumb,
#room-now-description::-webkit-scrollbar-thumb{
  background:rgba(220,232,242,.32)!important;
  border-radius:999px!important;
}

.hero-radio-control{
  grid-area:controls!important;
  width:100%!important;
  margin-top:8px!important;
}

.radio-control-row{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  min-height:112px!important;
  padding:18px 20px!important;
  border:0!important;
  outline:0!important;
}

.radio-control-copy{
  min-width:0!important;
  padding-right:14px!important;
}

.radio-play-button{
  width:var(--player-button-size)!important;
  height:var(--player-button-size)!important;
  min-width:var(--player-button-size)!important;
  border:0!important;
  outline:0!important;
  box-shadow:
    0 22px 48px rgba(0,0,0,.50),
    0 8px 22px rgba(0,196,140,.18),
    0 0 42px rgba(143,211,255,.26),
    inset 0 13px 20px rgba(255,255,255,.56),
    inset 0 -14px 22px rgba(4,20,26,.20)!important;
  background:
    radial-gradient(circle at 32% 24%,#ffffff 0,#eefaff 23%,#91e4ff 48%,#30d8c2 100%)!important;
  transform:translateZ(0)!important;
}

.radio-play-button:hover{
  filter:none!important;
  transform:translateY(-1px)!important;
  box-shadow:
    0 26px 56px rgba(0,0,0,.54),
    0 10px 28px rgba(0,196,140,.24),
    0 0 52px rgba(143,211,255,.34),
    inset 0 14px 22px rgba(255,255,255,.62),
    inset 0 -15px 24px rgba(4,20,26,.20)!important;
}

.radio-play-button:before{
  animation-duration:var(--player-ring-idle-speed)!important;
  opacity:.78!important;
}

.radio-play-button:after{
  animation-duration:var(--player-pulse-idle-speed)!important;
  opacity:.70!important;
}

.radio-play-button.is-playing:before{
  animation-duration:var(--player-ring-live-speed)!important;
  opacity:.92!important;
}

.radio-play-button.is-playing:after{
  animation-duration:var(--player-pulse-live-speed)!important;
  opacity:.82!important;
}

.radio-play-button.is-playing{
  background:
    radial-gradient(circle at 32% 24%,#ffffff 0,#dff8ff 22%,#79d7ff 45%,#00c48c 100%)!important;
}

.hero-radio-play-button{
  width:64px!important;
  height:64px!important;
  min-width:64px!important;
}

@media (max-width:680px){
  .player-panel{
    padding:18px!important;
  }

  .room-now-layout,
  .now-card-player{
    grid-template-columns:88px minmax(0,1fr)!important;
    gap:14px 14px!important;
  }

  .room-now-layout .track-cover,
  .now-card-player > .track-cover,
  .track-cover{
    width:88px!important;
    height:88px!important;
    min-width:88px!important;
    border-radius:18px!important;
  }

  #room-now-title,
  .now-card-copy h2{
    font-size:clamp(22px,6vw,28px)!important;
    line-height:1.12!important;
    margin-bottom:8px!important;
  }

  #room-now-meta,
  .now-track-meta,
  .now-card-copy p{
    font-size:14px!important;
    line-height:1.38!important;
  }

  .room-now-layout .track-description,
  .now-card-player .track-description,
  #room-now-description{
    display:block!important;
    max-height:145px!important;
    font-size:15px!important;
    line-height:1.5!important;
  }

  .radio-control-row{
    min-height:96px!important;
    padding:14px!important;
    gap:12px!important;
  }

  .radio-play-button{
    width:var(--player-button-size-mobile)!important;
    height:var(--player-button-size-mobile)!important;
    min-width:var(--player-button-size-mobile)!important;
  }

  .hero-radio-play-button{
    width:56px!important;
    height:56px!important;
    min-width:56px!important;
  }
}

@media (max-width:420px){
  .room-now-layout,
  .now-card-player{
    grid-template-columns:76px minmax(0,1fr)!important;
    gap:12px 12px!important;
  }

  .room-now-layout .track-cover,
  .now-card-player > .track-cover,
  .track-cover{
    width:76px!important;
    height:76px!important;
    min-width:76px!important;
    border-radius:16px!important;
  }

  #room-now-title,
  .now-card-copy h2{
    font-size:21px!important;
  }

  .room-now-layout .track-description,
  .now-card-player .track-description,
  #room-now-description{
    max-height:132px!important;
  }
}

/* === Efika v18: centered mobile modals, live badge on main player, airtime and metadata tabs === */
.now-card-head{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:14px!important;
  margin:0 0 18px!important;
}

.now-card-strict .now-card-body,
.now-card-player{
  width:100%!important;
}

.track-release-year{
  min-height:18px!important;
  margin:0 0 7px!important;
  color:var(--accent)!important;
  font-size:13px!important;
  line-height:1.2!important;
  font-weight:900!important;
  letter-spacing:.1em!important;
  text-transform:uppercase!important;
}

.track-release-year:empty{
  display:none!important;
}

.now-tabs-shell{
  grid-area:description!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  margin-top:2px!important;
}

.now-tabs{
  display:flex!important;
  flex-direction:column!important;
  gap:10px!important;
  min-width:0!important;
}

.now-tab-list{
  display:flex!important;
  gap:8px!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  padding:1px 0 4px!important;
  scrollbar-width:thin!important;
}

.now-tab-button{
  flex:0 0 auto!important;
  border:1px solid rgba(143,211,255,.16)!important;
  border-radius:999px!important;
  padding:8px 12px!important;
  background:rgba(255,255,255,.055)!important;
  color:#aeb9c2!important;
  font-size:13px!important;
  line-height:1!important;
  font-weight:900!important;
  letter-spacing:.02em!important;
  cursor:pointer!important;
  white-space:nowrap!important;
}

.now-tab-button.is-active{
  background:linear-gradient(135deg,rgba(143,211,255,.22),rgba(0,196,140,.18))!important;
  border-color:rgba(143,211,255,.36)!important;
  color:#eaf7ff!important;
  box-shadow:0 8px 20px rgba(0,0,0,.20)!important;
}

.now-tab-panels{
  min-width:0!important;
}

.now-tab-panel{
  display:none!important;
  max-height:176px!important;
  min-height:74px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding:1px 12px 1px 0!important;
  color:#aeb9c2!important;
  font-size:clamp(15px,1.75vw,17px)!important;
  line-height:1.55!important;
  white-space:pre-wrap!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
  scrollbar-width:thin!important;
}

.now-tab-panel.is-active{
  display:block!important;
}

.now-tab-panel::-webkit-scrollbar,
.now-tab-list::-webkit-scrollbar{
  width:5px!important;
  height:5px!important;
}

.now-tab-panel::-webkit-scrollbar-thumb,
.now-tab-list::-webkit-scrollbar-thumb{
  background:rgba(220,232,242,.32)!important;
  border-radius:999px!important;
}

.radio-control-copy [data-air-time]{
  display:block!important;
  margin-top:4px!important;
  font-variant-numeric:tabular-nums!important;
  color:#a9c4d8!important;
}

.radio-control-copy [data-air-time] + span{
  margin-top:3px!important;
}

@media (max-width:680px){
  .efika-modal{
    align-items:center!important;
    justify-content:center!important;
    min-height:100dvh!important;
    overflow-y:auto!important;
    padding:14px!important;
  }

  .efika-modal-card{
    margin:auto!important;
    max-height:min(92dvh,760px)!important;
  }

  .track-upload-modal-card.upload-progress-state{
    margin:auto!important;
  }

  .now-card-head{
    margin-bottom:14px!important;
  }

  .now-tabs-shell{
    margin-top:0!important;
  }

  .now-tab-button{
    padding:8px 10px!important;
    font-size:12px!important;
  }

  .now-tab-panel{
    max-height:148px!important;
    min-height:72px!important;
    font-size:15px!important;
    line-height:1.5!important;
  }
}

@media (max-width:420px){
  .efika-modal{
    padding:12px!important;
  }

  .efika-modal-card{
    width:min(100%,420px)!important;
    border-radius:22px!important;
  }

  .track-release-year{
    font-size:12px!important;
    margin-bottom:5px!important;
  }

  .now-tab-panel{
    max-height:136px!important;
  }
}

/* === Efika v19: stable tabs, room icons, centered mobile modals, Musify-like mood carousel === */
.efika-modal:not(.hidden){
  position:fixed!important;
  inset:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:100dvh!important;
  padding:clamp(10px,3.5vw,22px)!important;
  overflow:auto!important;
  overscroll-behavior:contain!important;
}

.efika-modal-card{
  margin:auto!important;
  transform:none!important;
}

@media (max-width:680px){
  .efika-modal:not(.hidden){
    align-items:center!important;
    justify-content:center!important;
    padding:calc(12px + env(safe-area-inset-top)) 12px calc(12px + env(safe-area-inset-bottom))!important;
  }
  .efika-modal-card,
  .track-upload-modal-card,
  .track-upload-modal-card.upload-progress-state{
    width:min(100%,440px)!important;
    max-height:min(92dvh,760px)!important;
    margin:auto!important;
  }
}

.room-title-line-with-icon{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:14px!important;
}

.room-title-line-with-icon h1{
  min-width:0!important;
}

.room-title-icon,
.room-control-icon,
.room-card-icon,
.admin-room-icon{
  flex:0 0 auto!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  border-radius:18px!important;
  background:linear-gradient(145deg,rgba(143,211,255,.18),rgba(0,196,140,.13))!important;
  border:1px solid rgba(143,211,255,.20)!important;
  color:#eaf7ff!important;
  font-weight:1000!important;
  box-shadow:0 12px 32px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.18)!important;
}

.room-title-icon img,
.room-control-icon img,
.room-card-icon img,
.admin-room-icon img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
}

.room-title-icon{
  width:58px!important;
  height:58px!important;
  font-size:24px!important;
  border-radius:19px!important;
}

.room-control-icon{
  width:46px!important;
  height:46px!important;
  font-size:19px!important;
  border-radius:16px!important;
}

.radio-control-copy-with-icon{
  display:flex!important;
  align-items:center!important;
  gap:12px!important;
}

.radio-control-texts{
  display:flex!important;
  flex-direction:column!important;
  min-width:0!important;
}

.room-card-top{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
}

.room-card-icon{
  width:58px!important;
  height:58px!important;
  font-size:24px!important;
}

.admin-room-row{
  justify-content:flex-start!important;
}

.admin-row-main{
  flex:1 1 auto!important;
  min-width:0!important;
}

.admin-room-icon{
  width:44px!important;
  height:44px!important;
  border-radius:15px!important;
  font-size:18px!important;
}

.admin-room-icon-large{
  width:74px!important;
  height:74px!important;
  border-radius:22px!important;
  font-size:30px!important;
}

.admin-room-edit-head{
  display:flex!important;
  align-items:center!important;
  gap:16px!important;
  padding:12px!important;
  border:1px solid rgba(255,255,255,.07)!important;
  border-radius:22px!important;
  background:rgba(255,255,255,.035)!important;
}

.admin-room-edit-head p{
  margin:4px 0 0!important;
  line-height:1.35!important;
}

@media (max-width:850px){
  .room-carousel,
  .mood-carousel{
    display:flex!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    gap:14px!important;
    scroll-snap-type:x mandatory!important;
    scroll-padding-inline:28px!important;
    padding:4px 28px 20px!important;
    margin-left:-28px!important;
    margin-right:-28px!important;
    scrollbar-width:thin!important;
  }

  .room-carousel .room-card,
  .mood-carousel .mood-status-card{
    --focus:0;
    scroll-snap-align:center!important;
    flex:0 0 min(78vw,330px)!important;
    min-width:0!important;
    transform:perspective(760px) scaleX(var(--scale-x,.66)) scaleY(var(--scale-y,.94)) translateY(var(--raise,8px))!important;
    transform-origin:center center!important;
    transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease, filter .28s ease!important;
    will-change:transform!important;
    filter:saturate(var(--card-saturate,.78)) brightness(var(--card-brightness,.86))!important;
  }

  .mood-carousel .mood-status-card{
    flex-basis:min(72vw,290px)!important;
  }

  .room-carousel .room-card.is-focus,
  .mood-carousel .mood-status-card.is-focus{
    border-color:rgba(143,211,255,.38)!important;
    box-shadow:0 22px 60px rgba(0,0,0,.44),0 0 34px rgba(143,211,255,.13)!important;
  }

  .room-carousel .room-card-icon,
  .mood-carousel .mood-status-visual{
    transform:scaleX(var(--visual-scale-x,.62))!important;
    transform-origin:center!important;
    transition:transform .28s ease!important;
  }
}

@media (max-width:520px){
  .room-title-line-with-icon{
    align-items:flex-start!important;
  }
  .room-title-icon{
    width:48px!important;
    height:48px!important;
    border-radius:16px!important;
    font-size:20px!important;
  }
  .room-control-icon{
    width:40px!important;
    height:40px!important;
    border-radius:14px!important;
  }
}


/* === Efika v20: room-icon layout refinement, tighter mood carousel, room player cleanup === */
.room-title-head-with-icon{
  display:grid!important;
  grid-template-columns:72px minmax(0,1fr)!important;
  gap:16px!important;
  align-items:center!important;
}

.room-title-copy{
  min-width:0!important;
}

.room-title-copy .eyebrow{
  margin:0 0 8px!important;
}

.room-title-copy h1{
  margin:0!important;
  font-size:clamp(30px,4.8vw,48px)!important;
  line-height:1.03!important;
  letter-spacing:-.05em!important;
}

.room-title-copy .room-inline-description{
  display:block!important;
  margin-top:6px!important;
  color:#d7e2ea!important;
  font-size:clamp(16px,2vw,22px)!important;
  line-height:1.28!important;
  font-weight:800!important;
}

.room-title-head-with-icon .room-title-icon{
  order:0!important;
  width:72px!important;
  height:72px!important;
  border-radius:22px!important;
  font-size:30px!important;
}

.room-card.room-card-compact{
  min-height:0!important;
  justify-content:flex-start!important;
}

.room-card-head{
  display:grid!important;
  grid-template-columns:62px minmax(0,1fr) auto!important;
  gap:14px!important;
  align-items:start!important;
  width:100%!important;
}

.room-card-compact .room-card-icon{
  width:62px!important;
  height:62px!important;
  border-radius:19px!important;
  font-size:26px!important;
  grid-column:1!important;
  grid-row:1 / span 2!important;
  align-self:start!important;
}

.room-card-copy{
  min-width:0!important;
  display:flex!important;
  flex-direction:column!important;
  gap:6px!important;
  justify-content:flex-start!important;
}

.room-card-compact h3{
  margin:2px 0 0!important;
  font-size:clamp(28px,3vw,34px)!important;
  line-height:1.05!important;
}

.room-card-compact p{
  margin:0!important;
  color:var(--muted)!important;
  line-height:1.4!important;
}

.room-card-compact .status{
  align-self:start!important;
  justify-self:end!important;
  margin-top:4px!important;
}

.hero-radio-control .radio-control-copy{
  flex:1 1 auto!important;
  min-width:0!important;
}

.hero-radio-control .radio-control-copy-with-icon{
  display:grid!important;
  grid-template-columns:58px minmax(0,1fr)!important;
  align-items:center!important;
  gap:16px!important;
  width:100%!important;
}

.hero-radio-control .room-control-icon{
  width:58px!important;
  height:58px!important;
  border-radius:19px!important;
  font-size:24px!important;
  justify-self:start!important;
}

#room-radio-control .radio-control-copy-plain{
  display:flex!important;
  align-items:center!important;
  width:100%!important;
  padding-left:0!important;
}

#room-radio-control .radio-control-texts{
  gap:3px!important;
}

@media (max-width:850px){
  .room-carousel,
  .mood-carousel{
    gap:6px!important;
    scroll-padding-inline:18px!important;
    padding:4px 18px 18px!important;
    margin-left:-18px!important;
    margin-right:-18px!important;
  }

  .room-carousel .room-card,
  .mood-carousel .mood-status-card{
    flex:0 0 min(74vw,320px)!important;
    transform:perspective(760px) scaleX(var(--scale-x,.42)) scaleY(var(--scale-y,.92)) translateY(var(--raise,8px))!important;
    filter:saturate(var(--card-saturate,.74)) brightness(var(--card-brightness,.82))!important;
  }

  .mood-carousel .mood-status-card{
    flex-basis:min(64vw,250px)!important;
  }

  .room-carousel .room-card-icon,
  .mood-carousel .mood-status-visual{
    transform:scaleX(var(--visual-scale-x,.44))!important;
  }
}

@media (max-width:640px){
  .room-title-head-with-icon{
    grid-template-columns:60px minmax(0,1fr)!important;
    gap:12px!important;
    align-items:start!important;
  }

  .room-title-head-with-icon .room-title-icon{
    width:60px!important;
    height:60px!important;
    border-radius:19px!important;
    font-size:26px!important;
  }

  .room-card-head{
    grid-template-columns:54px minmax(0,1fr) auto!important;
    gap:11px!important;
  }

  .room-card-compact .room-card-icon{
    width:54px!important;
    height:54px!important;
    border-radius:17px!important;
    font-size:22px!important;
  }

  .room-card-compact h3{
    font-size:clamp(24px,6vw,30px)!important;
  }

  .hero-radio-control .radio-control-copy-with-icon{
    grid-template-columns:52px minmax(0,1fr)!important;
    gap:12px!important;
  }

  .hero-radio-control .room-control-icon{
    width:52px!important;
    height:52px!important;
    border-radius:17px!important;
    font-size:21px!important;
  }
}

/* === Efika v21: compact main hero, sharper room cards, lyric translation UI === */
.topbar{
  padding:10px clamp(16px,4vw,48px)!important;
}

.brand{
  font-size:clamp(40px,7.4vw,62px)!important;
  line-height:1!important;
  color:#8fd3ff!important;
  text-shadow:0 0 26px rgba(143,211,255,.18)!important;
}

.brand span{
  color:#75ccff!important;
}

.hero{
  padding:18px 0 26px!important;
  align-items:start!important;
}

.hero > div:first-child .eyebrow,
.hero > div:first-child h1{
  display:none!important;
}

.hero .lead{
  margin:4px 0 0!important;
  max-width:760px!important;
}

.hero-actions{
  margin-top:22px!important;
}

.room-title-head-with-icon{
  grid-template-columns:76px minmax(0,1fr)!important;
  align-items:center!important;
}

.room-title-name-row{
  display:flex!important;
  align-items:baseline!important;
  gap:16px!important;
  min-width:0!important;
  flex-wrap:nowrap!important;
}

.room-title-name-row h1{
  flex:0 0 auto!important;
  white-space:nowrap!important;
}

.room-title-name-row .room-inline-description{
  display:inline-block!important;
  margin:0!important;
  min-width:0!important;
  line-height:1.2!important;
  vertical-align:baseline!important;
}

.room-card.room-card-compact{
  min-height:150px!important;
  padding:24px!important;
  transform:none!important;
  filter:none!important;
}

.room-card-head{
  grid-template-columns:78px minmax(0,1fr) auto!important;
  align-items:center!important;
  min-height:102px!important;
}

.room-card-compact .room-card-icon{
  width:78px!important;
  height:78px!important;
  border-radius:23px!important;
  font-size:31px!important;
  align-self:center!important;
  transform:none!important;
}

.room-card-copy{
  justify-content:center!important;
  gap:8px!important;
}

.room-card-compact h3,
.room-card-compact p{
  filter:none!important;
  transform:none!important;
  text-shadow:none!important;
}

.room-card-compact .status{
  align-self:center!important;
}

#room-radio-control{
  justify-content:space-between!important;
}

#room-radio-control .radio-control-copy-plain{
  flex:1 1 auto!important;
  width:auto!important;
  justify-content:flex-start!important;
  text-align:left!important;
  padding-left:0!important;
  margin-right:14px!important;
}

#room-radio-control .radio-control-texts{
  align-items:flex-start!important;
  text-align:left!important;
}

.now-tab-panel a{
  color:var(--accent)!important;
  text-decoration:underline!important;
  text-underline-offset:3px!important;
}

.now-tab-panel-lyrics{
  padding-top:0!important;
}

.lyrics-panel-tools{
  position:sticky!important;
  top:0!important;
  z-index:2!important;
  display:flex!important;
  justify-content:flex-end!important;
  padding:0 0 8px!important;
  background:linear-gradient(180deg,rgba(18,24,27,.96),rgba(18,24,27,.72) 70%,rgba(18,24,27,0))!important;
}

.lyrics-translate-toggle{
  border:0!important;
  background:transparent!important;
  color:var(--accent)!important;
  font-weight:900!important;
  font-size:13px!important;
  cursor:pointer!important;
  padding:5px 0 5px 10px!important;
}

.lyrics-translate-toggle:hover{
  color:#dff4ff!important;
}

.lyrics-content{
  display:none!important;
}

.lyrics-content.is-active{
  display:block!important;
}

@media (max-width:850px){
  .hero{
    padding-top:12px!important;
    gap:18px!important;
  }

  .mood-carousel{
    gap:0!important;
    scroll-padding-inline:12px!important;
    padding:4px 12px 18px!important;
    margin-left:-12px!important;
    margin-right:-12px!important;
  }

  .mood-carousel .mood-status-card{
    flex:0 0 min(64vw,240px)!important;
    margin-right:-96px!important;
    transform:perspective(760px) scaleX(var(--scale-x,.34)) scaleY(var(--scale-y,.92)) translateY(var(--raise,8px))!important;
  }

  .mood-carousel .mood-status-card:last-child{
    margin-right:0!important;
  }

  .mood-carousel .mood-status-visual{
    transform:scaleX(var(--visual-scale-x,.36))!important;
  }

  .room-carousel{
    gap:12px!important;
  }

  .room-carousel .room-card{
    flex:0 0 min(78vw,330px)!important;
    transform:none!important;
    filter:none!important;
  }

  .room-carousel .room-card-icon{
    transform:none!important;
  }
}

@media (max-width:640px){
  .brand{
    font-size:40px!important;
  }

  .topbar{
    padding:8px 18px!important;
  }

  .room-title-head-with-icon{
    grid-template-columns:68px minmax(0,1fr)!important;
    align-items:center!important;
  }

  .room-title-head-with-icon .room-title-icon{
    width:68px!important;
    height:68px!important;
    border-radius:22px!important;
  }

  .room-title-name-row{
    gap:10px!important;
  }

  .room-title-name-row h1{
    font-size:clamp(28px,7vw,36px)!important;
  }

  .room-title-name-row .room-inline-description{
    font-size:clamp(15px,4vw,18px)!important;
  }

  .room-card-head{
    grid-template-columns:74px minmax(0,1fr) auto!important;
    min-height:104px!important;
  }

  .room-card-compact .room-card-icon{
    width:74px!important;
    height:74px!important;
    border-radius:22px!important;
  }

  .mood-carousel .mood-status-card{
    flex-basis:min(62vw,220px)!important;
    margin-right:-88px!important;
  }
}

@media (max-width:430px){
  .hero .lead{
    font-size:18px!important;
    line-height:1.35!important;
  }

  .hero-actions .btn{
    padding:11px 16px!important;
  }

  .room-title-head-with-icon{
    grid-template-columns:62px minmax(0,1fr)!important;
  }

  .room-title-head-with-icon .room-title-icon{
    width:62px!important;
    height:62px!important;
    border-radius:20px!important;
  }

  .room-title-name-row{
    flex-wrap:nowrap!important;
  }

  .room-title-name-row .room-inline-description{
    font-size:15px!important;
  }
}

/* === Efika v22: room player text pinned to the left === */
#room-radio-control .radio-control-copy-plain{
  display:block!important;
  flex:1 1 auto!important;
  width:auto!important;
  min-width:0!important;
  text-align:left!important;
  padding-left:0!important;
  padding-right:14px!important;
  margin-right:14px!important;
}

#room-radio-control .radio-control-texts{
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-start!important;
  justify-content:center!important;
  text-align:left!important;
  margin-left:0!important;
}

#room-radio-control #room-audio-state,
#room-radio-control #room-air-time,
#room-radio-control #room-autoplay-note{
  display:block!important;
  width:auto!important;
  text-align:left!important;
}

/* === Efika v23: clean poster area taps, poster preview, guest comment lock, local nav === */
html,
body,
a,
button,
.room-now-layout,
.now-card-player,
.now-tabs-shell,
.now-tab-button,
.track-cover,
.radio-control-row{
  -webkit-tap-highlight-color:transparent!important;
}

.room-now-layout,
.now-card-player{
  cursor:default!important;
  user-select:none!important;
  -webkit-user-select:none!important;
  outline:0!important;
}

.room-now-layout:focus,
.room-now-layout:focus-visible,
.now-card-player:focus,
.now-card-player:focus-visible{
  outline:0!important;
  box-shadow:none!important;
}

.room-now-layout[data-audio-toggle-surface],
.now-card-player[data-audio-toggle-surface]{
  cursor:default!important;
}

.room-now-layout[data-audio-toggle-surface]:hover .track-cover,
.now-card-player[data-audio-toggle-surface]:hover .track-cover{
  box-shadow:none!important;
}

.now-tabs-shell,
.now-tabs,
.now-tab-list,
.now-tab-button{
  user-select:none!important;
  -webkit-user-select:none!important;
}

.now-tab-button:focus,
.now-tab-button:focus-visible,
.now-tab-button:active{
  outline:0!important;
}

.now-tab-panel,
.now-tab-panel *,
.lyrics-content,
.lyrics-content *{
  user-select:text!important;
  -webkit-user-select:text!important;
}

.now-tab-panel::selection,
.lyrics-content::selection{
  background:rgba(143,211,255,.26)!important;
  color:#eaf7ff!important;
}

.track-cover.has-poster,
.room-now-layout .track-cover:has(img),
.now-card-player .track-cover:has(img){
  cursor:zoom-in!important;
}

.poster-modal.hidden{
  display:none!important;
}

.poster-modal{
  position:fixed!important;
  inset:0!important;
  z-index:90!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:clamp(14px,4vw,32px)!important;
}

.poster-modal-backdrop{
  position:absolute!important;
  inset:0!important;
  background:rgba(3,7,9,.78)!important;
  backdrop-filter:blur(10px)!important;
}

.poster-modal-card{
  position:relative!important;
  z-index:1!important;
  width:min(86vw,620px)!important;
  max-height:86vh!important;
  border-radius:28px!important;
  overflow:hidden!important;
  background:linear-gradient(145deg,rgba(32,40,44,.98),rgba(12,17,20,.98))!important;
  border:1px solid rgba(143,211,255,.22)!important;
  box-shadow:0 28px 90px rgba(0,0,0,.68),0 0 60px rgba(143,211,255,.14)!important;
}

.poster-modal-image{
  display:block!important;
  width:100%!important;
  height:auto!important;
  max-height:86vh!important;
  object-fit:contain!important;
  background:#071013!important;
}

.poster-modal-close{
  position:absolute!important;
  top:10px!important;
  right:10px!important;
  z-index:2!important;
  width:40px!important;
  height:40px!important;
  border:0!important;
  border-radius:999px!important;
  background:rgba(5,12,15,.72)!important;
  color:#eaf7ff!important;
  font-size:28px!important;
  line-height:1!important;
  cursor:pointer!important;
  box-shadow:0 10px 26px rgba(0,0,0,.38)!important;
}

body.poster-modal-open{
  overflow:hidden!important;
}

.auth-required-note{
  padding:16px 18px!important;
  border-radius:18px!important;
  background:rgba(143,211,255,.08)!important;
  border:1px solid rgba(143,211,255,.16)!important;
  color:#b9c8d2!important;
  line-height:1.48!important;
}

.auth-required-note a{
  color:var(--accent)!important;
  font-weight:900!important;
  text-decoration:underline!important;
  text-underline-offset:3px!important;
}

#room-radio-control{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
}

#room-radio-control > .radio-control-copy.radio-control-copy-plain{
  display:block!important;
  flex:1 1 auto!important;
  width:auto!important;
  min-width:0!important;
  margin-left:0!important;
  margin-right:auto!important;
  padding-left:0!important;
  padding-right:14px!important;
  text-align:left!important;
  align-self:center!important;
}

#room-radio-control > .radio-control-copy.radio-control-copy-plain .radio-control-texts{
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-start!important;
  justify-content:center!important;
  width:max-content!important;
  max-width:100%!important;
  margin:0!important;
  text-align:left!important;
}

#room-radio-control #room-audio-state,
#room-radio-control #room-air-time,
#room-radio-control #room-autoplay-note{
  display:block!important;
  width:auto!important;
  max-width:100%!important;
  text-align:left!important;
}

.bottom-nav a{
  -webkit-tap-highlight-color:transparent!important;
}


/* === Efika v24: room cards skeleton and adaptive room title description === */
.room-card.room-card-compact{
  min-height:260px!important;
  padding:26px!important;
  overflow:hidden!important;
}

.room-card.room-card-compact .room-card-head{
  display:grid!important;
  grid-template-columns:minmax(86px,102px) minmax(0,1fr) auto!important;
  grid-template-rows:auto minmax(0,1fr)!important;
  grid-template-areas:
    "title title status"
    "icon text text"!important;
  align-items:start!important;
  gap:14px 18px!important;
  width:100%!important;
  min-height:100%!important;
}

.room-card.room-card-compact .room-card-copy{
  display:contents!important;
}

.room-card.room-card-compact h3{
  grid-area:title!important;
  align-self:start!important;
  margin:0!important;
  max-width:100%!important;
  color:#e7f3fb!important;
  font-size:clamp(29px,3vw,38px)!important;
  line-height:1.03!important;
  letter-spacing:-.045em!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  display:-webkit-box!important;
  -webkit-box-orient:vertical!important;
  -webkit-line-clamp:2!important;
}

.room-card.room-card-compact .status{
  grid-area:status!important;
  align-self:start!important;
  justify-self:end!important;
  margin:0!important;
  z-index:1!important;
}

.room-card.room-card-compact .room-card-icon{
  grid-area:icon!important;
  align-self:center!important;
  justify-self:start!important;
  width:96px!important;
  height:96px!important;
  max-width:100%!important;
  border-radius:24px!important;
  font-size:34px!important;
  transform:none!important;
}

.room-card.room-card-compact p{
  grid-area:text!important;
  align-self:start!important;
  margin:0!important;
  max-width:100%!important;
  color:#aeb9c2!important;
  font-size:clamp(16px,1.7vw,19px)!important;
  line-height:1.42!important;
  overflow:hidden!important;
  display:-webkit-box!important;
  -webkit-box-orient:vertical!important;
  -webkit-line-clamp:7!important;
}

.room-title-name-row{
  display:flex!important;
  align-items:baseline!important;
  gap:16px!important;
  min-width:0!important;
  max-width:100%!important;
  flex-wrap:wrap!important;
}

.room-title-name-row h1{
  flex:0 0 auto!important;
  white-space:nowrap!important;
  margin:0!important;
}

.room-title-name-row .room-inline-description{
  flex:1 1 260px!important;
  min-width:min(260px,100%)!important;
  max-width:100%!important;
  margin:0!important;
  display:-webkit-box!important;
  -webkit-box-orient:vertical!important;
  -webkit-line-clamp:2!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  line-height:1.24!important;
}

@media (max-width:850px){
  .room-carousel .room-card.room-card-compact{
    flex:0 0 min(82vw,360px)!important;
    min-height:250px!important;
    transform:none!important;
    filter:none!important;
  }

  .room-card.room-card-compact .room-card-head{
    grid-template-columns:88px minmax(0,1fr) auto!important;
    gap:13px 16px!important;
  }

  .room-card.room-card-compact .room-card-icon{
    width:88px!important;
    height:88px!important;
    border-radius:23px!important;
  }

  .room-card.room-card-compact p{
    -webkit-line-clamp:6!important;
  }
}

@media (max-width:560px){
  .room-card.room-card-compact{
    min-height:228px!important;
    padding:24px!important;
  }

  .room-card.room-card-compact .room-card-head{
    grid-template-columns:78px minmax(0,1fr) auto!important;
    gap:12px 14px!important;
  }

  .room-card.room-card-compact .room-card-icon{
    width:78px!important;
    height:78px!important;
    border-radius:21px!important;
    align-self:center!important;
  }

  .room-card.room-card-compact h3{
    font-size:clamp(26px,7vw,34px)!important;
  }

  .room-card.room-card-compact p{
    font-size:16px!important;
    line-height:1.38!important;
    -webkit-line-clamp:5!important;
  }

  .room-title-name-row{
    gap:8px 12px!important;
  }

  .room-title-name-row .room-inline-description{
    flex-basis:100%!important;
    min-width:0!important;
    -webkit-line-clamp:2!important;
  }
}


/* === Efika v25: lift room card icon and let long room description wrap below icon === */
.room-card.room-card-compact .room-card-head{
  grid-template-rows:auto auto!important;
  align-content:start!important;
  align-items:start!important;
  gap:8px 18px!important;
}

.room-card.room-card-compact .room-card-icon{
  align-self:start!important;
  margin-top:2px!important;
}

.room-card.room-card-compact p{
  align-self:start!important;
}

.room-title-name-row{
  flex-wrap:wrap!important;
  align-items:baseline!important;
}

.room-title-name-row .room-inline-description{
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  display:block!important;
  -webkit-line-clamp:unset!important;
  line-clamp:unset!important;
  word-break:normal!important;
  overflow-wrap:anywhere!important;
}

@media (max-width:760px){
  .room-title-name-row .room-inline-description{
    flex:0 0 calc(100% + 88px)!important;
    width:calc(100% + 88px)!important;
    max-width:calc(100% + 88px)!important;
    margin-left:-88px!important;
    margin-top:8px!important;
    line-height:1.32!important;
  }
}

@media (max-width:640px){
  .room-card.room-card-compact .room-card-head{
    gap:7px 14px!important;
  }

  .room-card.room-card-compact .room-card-icon{
    margin-top:0!important;
  }

  .room-title-name-row .room-inline-description{
    flex-basis:calc(100% + 72px)!important;
    width:calc(100% + 72px)!important;
    max-width:calc(100% + 72px)!important;
    margin-left:-72px!important;
  }
}


/* === Efika v26: lift room header icon and make room cards compact when content fits === */
.room-title-head-with-icon .room-title-icon{
  transform:translateY(-12px)!important;
  align-self:start!important;
}

.room-title-name-row .room-inline-description{
  line-height:1.32!important;
}

.room-card.room-card-compact{
  min-height:210px!important;
  height:auto!important;
}

.room-card.room-card-compact .room-card-head{
  gap:7px 18px!important;
  min-height:0!important;
}

.room-card.room-card-compact .room-card-icon{
  margin-top:-4px!important;
  align-self:start!important;
}

@media (max-width:850px){
  .room-carousel .room-card.room-card-compact{
    flex:0 0 auto!important;
    width:fit-content!important;
    min-width:286px!important;
    max-width:min(74vw,340px)!important;
    min-height:198px!important;
    height:auto!important;
  }

  .room-card.room-card-compact .room-card-head{
    grid-template-columns:82px minmax(142px,1fr) auto!important;
    gap:7px 14px!important;
  }

  .room-card.room-card-compact .room-card-icon{
    width:82px!important;
    height:82px!important;
    margin-top:-4px!important;
  }

  .room-card.room-card-compact p{
    -webkit-line-clamp:5!important;
  }

  .room-title-head-with-icon .room-title-icon{
    transform:translateY(-14px)!important;
  }
}

@media (max-width:760px){
  .room-title-name-row .room-inline-description{
    margin-top:20px!important;
    padding-top:0!important;
  }
}

@media (max-width:640px){
  .room-carousel .room-card.room-card-compact{
    min-width:276px!important;
    max-width:min(72vw,324px)!important;
    min-height:190px!important;
    padding:22px!important;
  }

  .room-card.room-card-compact .room-card-head{
    grid-template-columns:76px minmax(132px,1fr) auto!important;
    gap:6px 12px!important;
  }

  .room-card.room-card-compact .room-card-icon{
    width:76px!important;
    height:76px!important;
    margin-top:-5px!important;
  }

  .room-title-head-with-icon .room-title-icon{
    transform:translateY(-15px)!important;
  }

  .room-title-name-row .room-inline-description{
    margin-top:22px!important;
  }
}

@media (max-width:430px){
  .room-carousel .room-card.room-card-compact{
    min-width:264px!important;
    max-width:min(70vw,306px)!important;
  }

  .room-title-head-with-icon .room-title-icon{
    transform:translateY(-12px)!important;
  }

  .room-title-name-row .room-inline-description{
    margin-top:18px!important;
  }
}

/* === Efika v27: right-side status badges in main player and adaptive room cards === */
#hero-now .now-card-head{
  justify-content:flex-end!important;
}

.room-card.room-card-compact{
  position:relative!important;
}

.room-card.room-card-compact .room-card-head{
  grid-template-columns:minmax(76px,96px) minmax(0,1fr)!important;
  grid-template-areas:
    "title title"
    "icon text"!important;
  padding-right:0!important;
}

.room-card.room-card-compact .status{
  position:absolute!important;
  top:26px!important;
  right:26px!important;
  max-width:calc(100% - 52px)!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  z-index:3!important;
}

.room-card.room-card-compact h3{
  padding-right:76px!important;
}

@media (max-width:640px){
  .room-card.room-card-compact .status{
    top:22px!important;
    right:22px!important;
    max-width:calc(100% - 44px)!important;
  }

  .room-card.room-card-compact h3{
    padding-right:68px!important;
  }
}

@media (max-width:430px){
  .room-card.room-card-compact .room-card-head{
    grid-template-columns:76px minmax(0,1fr)!important;
  }
}

/* === Efika v28: room card description flows around icon instead of being clipped in the right column === */
.room-card.room-card-compact{
  height:auto!important;
  overflow:hidden!important;
}

.room-card.room-card-compact .room-card-head{
  display:grid!important;
  grid-template-columns:1fr!important;
  grid-template-rows:auto auto!important;
  grid-template-areas:
    "title"
    "text"!important;
  align-items:start!important;
  align-content:start!important;
  gap:12px!important;
  min-height:0!important;
  position:relative!important;
  width:100%!important;
}

.room-card.room-card-compact .room-card-copy{
  display:contents!important;
}

.room-card.room-card-compact h3{
  grid-area:title!important;
  padding-right:78px!important;
  max-width:100%!important;
}

.room-card.room-card-compact .status{
  position:absolute!important;
  top:0!important;
  right:0!important;
  max-width:76px!important;
  z-index:4!important;
}

.room-card.room-card-compact .room-card-icon{
  grid-area:text!important;
  align-self:start!important;
  justify-self:start!important;
  position:relative!important;
  z-index:2!important;
  width:96px!important;
  height:96px!important;
  margin:0!important;
  pointer-events:none!important;
}

.room-card.room-card-compact p{
  grid-area:text!important;
  display:block!important;
  margin:0!important;
  max-width:100%!important;
  overflow:visible!important;
  text-overflow:clip!important;
  -webkit-line-clamp:unset!important;
  line-clamp:unset!important;
  -webkit-box-orient:unset!important;
  word-break:normal!important;
  overflow-wrap:anywhere!important;
}

.room-card.room-card-compact p::before{
  content:"";
  float:left;
  width:96px;
  height:96px;
  margin:0 18px 8px 0;
}

.room-card.room-card-compact p::after{
  content:"";
  display:block;
  clear:both;
}

@media (max-width:850px){
  .room-card.room-card-compact .room-card-head{
    grid-template-columns:1fr!important;
    gap:11px!important;
  }

  .room-card.room-card-compact .room-card-icon{
    width:82px!important;
    height:82px!important;
  }

  .room-card.room-card-compact p::before{
    width:82px;
    height:82px;
    margin:0 14px 7px 0;
  }
}

@media (max-width:640px){
  .room-card.room-card-compact h3{
    padding-right:70px!important;
  }

  .room-card.room-card-compact .status{
    max-width:68px!important;
  }

  .room-card.room-card-compact .room-card-icon{
    width:76px!important;
    height:76px!important;
  }

  .room-card.room-card-compact p::before{
    width:76px;
    height:76px;
    margin:0 12px 7px 0;
  }
}

/* === Efika v29: admin moderation, listen modal and block toggle === */
.admin-toolbar{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin:0 0 18px;
}

.admin-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:24px;
  height:24px;
  padding:0 8px;
  border-radius:999px;
  font-size:13px;
  font-weight:900;
  line-height:1;
}

.admin-badge.danger{
  background:var(--danger);
  color:#fff;
  box-shadow:0 0 0 4px rgba(255,95,109,.14);
}

.admin-action-row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.admin-action-row form{
  margin:0;
}

.admin-player-modal.hidden{
  display:none!important;
}

.admin-player-modal{
  position:fixed;
  inset:0;
  z-index:300;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.admin-player-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.68);
  backdrop-filter:blur(8px);
}

.admin-player-card{
  position:relative;
  z-index:1;
  width:min(620px,100%);
  background:linear-gradient(145deg,rgba(32,40,44,.98),rgba(12,18,20,.98));
  border:1px solid rgba(255,255,255,.1);
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:24px;
}

.admin-player-card h2{
  margin:0 42px 16px 0;
  overflow-wrap:anywhere;
}

.admin-player-card audio{
  display:block;
  width:100%;
  margin:0 0 16px;
}

.admin-player-close{
  position:absolute;
  top:16px;
  right:16px;
  width:34px;
  height:34px;
  border:0;
  border-radius:50%;
  background:rgba(255,255,255,.08);
  color:var(--text);
  font-size:24px;
  line-height:1;
  cursor:pointer;
}

.admin-player-controls{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

@media (max-width:640px){
  .admin-player-card{
    padding:20px;
  }
  .admin-player-controls .btn{
    flex:1 1 120px;
  }
}

/* === Efika v30: top tracks, ban voting and adaptive room description === */
.room-title-name-row{
  flex-wrap:wrap!important;
  align-items:baseline!important;
  gap:8px 16px!important;
}
.room-title-name-row .room-inline-description{
  flex:1 1 220px!important;
  min-width:min(220px,100%)!important;
  margin:0!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  display:inline-block!important;
  line-height:1.24!important;
}
.room-title-name-row.description-below .room-inline-description{
  flex:0 0 100%!important;
  min-width:0!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  overflow-wrap:anywhere!important;
  margin-top:8px!important;
}

.top-user-tracks-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.top-track-card{
  background:linear-gradient(145deg,rgba(32,40,44,.94),rgba(18,24,27,.92));
  border:1px solid rgba(255,255,255,.07);
  border-radius:22px;
  padding:14px;
  display:grid;
  grid-template-columns:68px minmax(0,1fr);
  gap:12px;
  align-items:center;
}
.top-track-copy{min-width:0;display:flex;flex-direction:column;gap:5px}
.top-track-copy strong{font-size:16px;line-height:1.22;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top-track-user,.top-track-mood{color:var(--muted);font-size:13px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top-track-reactions{display:flex;gap:10px;font-weight:900;color:#e9f6ff}
.ban-vote-button{
  background:rgba(255,95,109,.16)!important;
  color:#ffbec4!important;
  font-size:15px!important;
  font-weight:900!important;
}
.ban-vote-modal.hidden{display:none!important}
.ban-vote-modal{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:18px}
.ban-vote-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.58);backdrop-filter:blur(8px)}
.ban-vote-card{position:relative;width:min(440px,100%);background:#151d20;border:1px solid rgba(255,255,255,.12);border-radius:24px;box-shadow:var(--shadow);padding:24px}
.ban-vote-card h2{margin:0 0 12px;font-size:24px}
.ban-vote-card p{margin:0;color:#dbe8f0;line-height:1.45}
.ban-vote-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;flex-wrap:wrap}
@media (max-width:850px){.top-user-tracks-grid{display:flex;overflow-x:auto;scroll-snap-type:x proximity;padding-bottom:8px}.top-track-card{flex:0 0 min(82vw,340px);scroll-snap-align:start}}
@media (max-width:520px){.room-title-name-row .room-inline-description{font-size:18px!important;min-width:min(170px,100%)!important}.top-track-card{grid-template-columns:58px minmax(0,1fr)}}


/* === Efika v32: strict room title description wrapping from left edge === */
.room-title-head-with-icon{
  overflow:visible!important;
}

.room-title-copy{
  min-width:0!important;
  overflow:visible!important;
}

.room-title-name-row{
  --room-title-left-offset:0px;
  min-width:0!important;
  max-width:100%!important;
  overflow:visible!important;
  flex-wrap:nowrap!important;
}

.room-title-name-row h1{
  flex:0 0 auto!important;
  white-space:nowrap!important;
}

.room-title-name-row .room-inline-description{
  flex:1 1 auto!important;
  min-width:0!important;
  max-width:100%!important;
  white-space:nowrap!important;
  overflow:visible!important;
  text-overflow:clip!important;
  display:inline-block!important;
  line-height:1.24!important;
}

.room-title-name-row.description-below{
  flex-wrap:wrap!important;
}

.room-title-name-row.description-below .room-inline-description{
  flex:0 0 calc(100% + var(--room-title-left-offset, 0px))!important;
  width:calc(100% + var(--room-title-left-offset, 0px))!important;
  max-width:calc(100% + var(--room-title-left-offset, 0px))!important;
  min-width:0!important;
  margin-left:calc(-1 * var(--room-title-left-offset, 0px))!important;
  margin-top:10px!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  overflow-wrap:anywhere!important;
  word-break:normal!important;
}

@media (max-width:520px){
  .room-title-name-row .room-inline-description{
    min-width:0!important;
    font-size:18px!important;
  }
}

/* === Efika v33: comment reactions and best comments === */
.comment-reactions{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  padding-left:42px!important;
  margin-top:9px!important;
}
.comment-reaction-button{
  border:1px solid rgba(143,211,255,.14)!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.055)!important;
  color:#dce8f2!important;
  min-height:31px!important;
  padding:5px 10px!important;
  font-size:14px!important;
  line-height:1!important;
  font-weight:900!important;
  cursor:pointer!important;
  display:inline-flex!important;
  align-items:center!important;
  gap:2px!important;
  transition:.15s ease!important;
}
.comment-reaction-button:hover{
  transform:translateY(-1px)!important;
  border-color:rgba(143,211,255,.32)!important;
  background:rgba(143,211,255,.11)!important;
}
.comment-reaction-button:disabled{opacity:.62!important;cursor:default!important;transform:none!important}
.best-comments-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.best-comment-card{
  background:linear-gradient(145deg,rgba(32,40,44,.94),rgba(18,24,27,.92));
  border:1px solid rgba(255,255,255,.07);
  border-radius:22px;
  padding:15px;
  min-width:0;
  box-shadow:0 12px 36px rgba(0,0,0,.22);
}
.best-comment-head{
  display:flex;
  align-items:center;
  gap:9px;
  margin-bottom:9px;
  min-width:0;
}
.best-comment-head strong{
  min-width:0;
  color:#cfe9ff;
  font-size:14px;
  font-weight:900;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.best-comment-body{
  color:var(--text);
  font-size:16px;
  font-weight:750;
  line-height:1.36;
  overflow-wrap:anywhere;
  word-break:break-word;
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.best-comment-track{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
  margin-top:10px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.best-comment-reactions{
  display:flex;
  gap:10px;
  margin-top:9px;
  color:#e9f6ff;
  font-size:14px;
  font-weight:900;
}
@media (max-width:850px){
  .comment-reactions{padding-left:0!important}
  .best-comments-grid{display:flex;overflow-x:auto;scroll-snap-type:x proximity;padding-bottom:8px}
  .best-comment-card{flex:0 0 min(82vw,340px);scroll-snap-align:start}
}

/* === Efika v36: user favorites, personal files and standalone track player === */
.profile-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 22px}.profile-tab{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:var(--muted);font-weight:900}.profile-tab:hover,.profile-tab.active{color:#061014;background:linear-gradient(135deg,var(--accent),#5dd5ff);border-color:transparent}.profile-library-panel{display:flex;flex-direction:column;gap:16px}.library-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:8px}.library-panel-head h2{margin:0 0 6px}.library-track-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.library-track-card{display:grid;grid-template-columns:62px minmax(0,1fr);gap:12px;align-items:center;min-width:0;text-align:left;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.045);color:var(--text);border-radius:18px;padding:10px;cursor:pointer}.library-track-card:hover{background:rgba(143,211,255,.09);border-color:rgba(143,211,255,.24);transform:translateY(-1px)}.library-track-card.active{border-color:rgba(143,211,255,.55);box-shadow:0 0 0 1px rgba(143,211,255,.18) inset}.library-track-poster{width:62px;height:62px;border-radius:15px;overflow:hidden;background:linear-gradient(135deg,rgba(143,211,255,.22),rgba(255,255,255,.05));display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--accent);font-weight:900}.library-track-poster img{width:100%;height:100%;object-fit:cover;display:block}.library-track-poster.empty{background:rgba(143,211,255,.1)}.library-track-copy{min-width:0;display:flex;flex-direction:column;gap:4px}.library-track-copy strong{font-size:15px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-track-copy small{color:var(--muted);font-size:13px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-panel-head{position:relative;padding-right:56px}.player-kebab-menu{position:absolute;right:0;top:0;z-index:5}.player-kebab-toggle{width:40px;height:40px;border:1px solid rgba(255,255,255,.1);border-radius:14px;background:rgba(255,255,255,.06);color:var(--text);font-size:24px;line-height:1;cursor:pointer}.player-kebab-toggle:hover{background:rgba(143,211,255,.14)}.player-kebab-dropdown{position:absolute;right:0;top:46px;display:none;min-width:180px;padding:8px;border-radius:16px;background:rgba(14,20,23,.98);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow)}.player-kebab-menu.open .player-kebab-dropdown{display:flex;flex-direction:column;gap:4px}.player-kebab-dropdown button{border:0;border-radius:12px;background:transparent;color:var(--text);padding:10px 12px;text-align:left;cursor:pointer;font-weight:800}.player-kebab-dropdown button:hover{background:rgba(143,211,255,.12)}.standalone-player-section{display:flex;flex-direction:column;gap:18px}.standalone-player-card{position:relative}.standalone-close{position:absolute;right:18px;top:14px;width:38px;height:38px;border-radius:14px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:var(--muted)}.standalone-close:hover{color:var(--text);background:rgba(255,255,255,.14)}.standalone-player-main{display:grid;grid-template-columns:220px minmax(0,1fr);gap:22px;align-items:center}.standalone-poster{width:220px;height:220px;border-radius:28px;overflow:hidden;background:linear-gradient(135deg,rgba(143,211,255,.22),rgba(255,255,255,.04));display:flex;align-items:center;justify-content:center;font-size:74px;color:var(--accent);font-weight:900}.standalone-poster img{width:100%;height:100%;object-fit:cover}.standalone-copy h1{font-size:clamp(30px,5vw,56px);line-height:1;margin:4px 0 8px;letter-spacing:-.055em}.standalone-copy audio{width:100%;margin:16px 0 10px}.standalone-actions{display:flex;gap:10px;flex-wrap:wrap}.playlist-panel{display:flex;flex-direction:column;gap:14px}.playlist-controls{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.playlist-controls .btn.active{background:rgba(143,211,255,.18);color:var(--accent)}.playlist-track-card{font:inherit}.form-status.success{color:var(--accent-2)!important}.form-status.error{color:var(--danger)!important}@media (max-width:850px){.library-track-grid{grid-template-columns:1fr 1fr}.standalone-player-main{grid-template-columns:1fr}.standalone-poster{width:min(70vw,260px);height:min(70vw,260px);margin:0 auto}.library-panel-head{flex-direction:column}.playlist-controls{justify-content:flex-start}}@media (max-width:560px){.library-track-grid{grid-template-columns:1fr}.player-panel-head{padding-right:50px}.player-kebab-toggle{width:38px;height:38px}.standalone-player-card,.playlist-panel{padding:18px}.standalone-copy h1{font-size:32px}.standalone-actions .btn{width:100%}.playlist-controls .btn{flex:1 1 auto}.profile-tabs{gap:8px}.profile-tab{flex:1 1 auto}}

/* === Efika v37: admin autoplay setting, library delete menus and custom file player === */
.library-track-shell{
  position:relative!important;
  min-width:0!important;
}
.library-track-shell .library-track-card{
  width:100%!important;
  padding-right:48px!important;
}
.library-card-menu{
  position:absolute!important;
  top:8px!important;
  right:8px!important;
  z-index:8!important;
}
.library-card-menu-toggle{
  width:34px!important;
  height:34px!important;
  border:1px solid rgba(255,255,255,.1)!important;
  border-radius:12px!important;
  background:rgba(10,15,17,.62)!important;
  color:var(--text)!important;
  font-size:22px!important;
  font-weight:900!important;
  line-height:1!important;
  cursor:pointer!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.library-card-menu-toggle:hover{
  background:rgba(143,211,255,.15)!important;
  border-color:rgba(143,211,255,.28)!important;
}
.library-card-dropdown{
  position:absolute!important;
  right:0!important;
  top:40px!important;
  display:none!important;
  min-width:130px!important;
  padding:8px!important;
  border-radius:15px!important;
  background:rgba(14,20,23,.98)!important;
  border:1px solid rgba(255,255,255,.1)!important;
  box-shadow:var(--shadow)!important;
}
.library-track-shell.menu-open .library-card-dropdown{
  display:flex!important;
  flex-direction:column!important;
  gap:4px!important;
}
.library-card-dropdown button{
  border:0!important;
  border-radius:11px!important;
  background:transparent!important;
  color:#ffb5bd!important;
  padding:10px 12px!important;
  text-align:left!important;
  cursor:pointer!important;
  font-weight:900!important;
}
.library-card-dropdown button:hover{
  background:rgba(255,95,109,.14)!important;
}
.library-card-dropdown button:disabled{
  opacity:.55!important;
  cursor:default!important;
}

.standalone-copy #standalone-audio{
  display:none!important;
}
.file-audio-player{
  margin:16px 0 12px!important;
  display:grid!important;
  grid-template-columns:auto minmax(160px,1fr)!important;
  grid-template-rows:auto auto!important;
  gap:8px 12px!important;
  align-items:center!important;
  width:min(460px,100%)!important;
  padding:10px 12px!important;
  border-radius:16px!important;
  background:rgba(0,0,0,.18)!important;
  border:1px solid rgba(255,255,255,.06)!important;
  box-shadow:inset 0 0 18px rgba(0,0,0,.18)!important;
}
.file-player-controls{
  display:flex!important;
  align-items:center!important;
  gap:5px!important;
  grid-row:1/2!important;
}
.file-player-btn{
  min-width:24px!important;
  height:28px!important;
  border:0!important;
  border-radius:8px!important;
  background:transparent!important;
  color:#dce8f2!important;
  cursor:pointer!important;
  font-size:13px!important;
  font-weight:950!important;
  line-height:1!important;
  padding:0 3px!important;
}
.file-player-btn:hover{
  background:rgba(143,211,255,.14)!important;
  color:var(--accent)!important;
}
.file-player-play{
  min-width:28px!important;
  font-size:15px!important;
}
.file-player-seek{
  grid-column:2/3!important;
  width:100%!important;
  height:12px!important;
  border:0!important;
  border-radius:999px!important;
  background:rgba(0,0,0,.32)!important;
  box-shadow:inset 0 2px 8px rgba(0,0,0,.35)!important;
  overflow:hidden!important;
  padding:0!important;
  cursor:pointer!important;
  display:block!important;
}
.file-player-progress{
  display:block!important;
  width:0%;
  height:100%!important;
  border-radius:999px!important;
  background:linear-gradient(90deg,var(--accent),#5dd5ff)!important;
  box-shadow:0 0 12px rgba(143,211,255,.45)!important;
}
.file-player-time{
  grid-column:1/-1!important;
  display:flex!important;
  justify-content:space-between!important;
  color:var(--muted)!important;
  font-size:12px!important;
  font-weight:800!important;
  padding:0 2px!important;
}
@media (max-width:560px){
  .file-audio-player{
    grid-template-columns:1fr!important;
    width:100%!important;
  }
  .file-player-controls{
    justify-content:center!important;
  }
  .file-player-seek{
    grid-column:1/-1!important;
  }
}

/* === Efika auth v10: пароль, reCAPTCHA, Google OAuth === */
.auth-form{gap:15px}.auth-divider{display:flex;align-items:center;gap:12px;margin:14px 0;color:var(--muted);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.12em}.auth-divider:before,.auth-divider:after{content:"";height:1px;background:rgba(255,255,255,.09);flex:1}.google-auth-btn{width:100%;background:#fff;color:#101619}.captcha-box{display:flex;justify-content:center;padding:4px 0 2px;overflow:hidden}.password-strength{display:flex;flex-direction:column;gap:7px;margin-top:-6px;color:#a9c4d8;font-size:13px}.password-strength b{color:var(--text)}.password-strength-bar{display:block;height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid rgba(255,255,255,.08)}.password-strength-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--danger),var(--warning),var(--accent-2));border-radius:999px;transition:.15s ease}.password-strength[data-score="0"] .password-strength-bar i{width:0}.password-strength[data-score="1"] .password-strength-bar i,.password-strength[data-score="2"] .password-strength-bar i{width:33%}.password-strength[data-score="3"] .password-strength-bar i,.password-strength[data-score="4"] .password-strength-bar i{width:66%}.password-strength[data-score="5"] .password-strength-bar i,.password-strength[data-score="6"] .password-strength-bar i{width:100%}
