*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Inter,Arial,sans-serif;background:radial-gradient(circle at top left,rgba(98,84,255,.22),transparent 30%),linear-gradient(180deg,#09111f,#0b1220 60%,#0d1628);color:#eef2ff;min-height:100vh}a{text-decoration:none;color:inherit}button,input,textarea,select{font:inherit}.hidden{display:none!important}.panel{background:rgba(16,22,40,.9);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(14px);box-shadow:0 18px 45px rgba(0,0,0,.28)}.input{width:100%;background:#0a1020;color:#fff;border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:14px 16px;outline:none}.textarea{min-height:120px;resize:vertical}.code{min-height:140px}.input:focus{border-color:#7b6dff;box-shadow:0 0 0 4px rgba(123,109,255,.16)}.btn,.nav-btn{border:0;border-radius:16px;padding:13px 16px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(135deg,#7869ff,#57c4ff);color:#fff}.btn-secondary{background:linear-gradient(135deg,#2b3555,#465685);color:#fff}.btn-ghost,.nav-btn{background:rgba(255,255,255,.06);color:#fff}.btn.tiny{padding:8px 11px;border-radius:12px;font-size:13px}.brand-logo{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#7869ff,#57c4ff);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;color:#fff;box-shadow:0 12px 28px rgba(97,88,255,.33)}.flash{border-radius:18px;padding:14px 16px;margin-bottom:14px}.flash.slim{margin:14px}.flash.error{background:rgba(255,95,122,.12);border:1px solid rgba(255,95,122,.28);color:#ffb9c6}.flash.success{background:rgba(70,214,146,.12);border:1px solid rgba(70,214,146,.28);color:#baf5d7}.label{display:block;font-size:13px;color:#9cabcf;margin:0 0 8px}.check{display:flex;align-items:center;gap:10px;color:#c8d2ef}.tab-btn{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:#fff;border-radius:14px;padding:11px 14px;cursor:pointer}.tab-btn.active{background:rgba(123,109,255,.2);border-color:rgba(123,109,255,.42)}.tab-panel{display:none}.tab-panel.active{display:block}.catalog-tabs{display:flex;gap:10px;flex-wrap:wrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-stack{display:flex;flex-direction:column;gap:14px}.avatar{width:44px;height:44px;border-radius:14px;object-fit:cover;flex:0 0 44px}.avatar.sm{width:40px;height:40px;border-radius:12px;flex-basis:40px}.avatar.lg{width:58px;height:58px;border-radius:18px;flex-basis:58px}.fallback{background:linear-gradient(135deg,#273454,#151d34);display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff}.role-badge{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:800}.role-badge.admin{background:rgba(255,91,123,.14);color:#ffb0c0}.role-badge.moderator{background:rgba(87,196,255,.14);color:#b4e8ff}.role-badge.user{background:rgba(255,255,255,.08);color:#dfe6ff}.role-badge.guest{background:rgba(255,223,120,.12);color:#ffeab4}
/* landing */
.landing-shell{padding:18px;display:flex;flex-direction:column;gap:18px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;border:1px solid rgba(255,255,255,.08);border-radius:24px;background:rgba(16,22,40,.72);backdrop-filter:blur(14px)}.brand-link{display:flex;align-items:center;gap:14px}.brand-link strong{display:block;font-size:18px}.brand-link small{display:block;color:#9cabcf;margin-top:3px}.nav-links{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.nav-links a,.nav-btn{padding:10px 14px;border-radius:14px}.nav-links a:hover,.nav-btn:hover,.btn:hover{transform:translateY(-1px)}.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;padding:30px;border-radius:28px}.eyebrow{display:inline-flex;padding:7px 12px;border-radius:999px;background:rgba(123,109,255,.12);color:#cec7ff;font-size:12px;font-weight:700;margin-bottom:12px}.hero h1{font-size:44px;line-height:1.05;margin:0 0 12px}.hero p{margin:0;color:#a6b3d2;max-width:820px;font-size:16px;line-height:1.6}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.soft-card{padding:22px;border-radius:24px}.mini-stat{display:flex;justify-content:space-between;align-items:end;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.07)}.mini-stat strong{font-size:34px}.mini-stat span{color:#9cabcf}.mini-list{display:flex;flex-direction:column;gap:10px;margin-top:18px}.mini-room{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.04)}.mini-room small{color:#9cabcf}.section-block{display:flex;flex-direction:column;gap:14px}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.section-title-row h2{margin:0;font-size:32px}.section-title-row p{margin:6px 0 0;color:#9cabcf}.feature-room{padding:22px 24px;border-radius:24px;display:flex;justify-content:space-between;gap:18px;align-items:flex-start}.feature-room h3{margin:10px 0 6px;font-size:28px}.feature-room p{margin:0;color:#a6b3d2}.room-stats{display:flex;flex-direction:column;gap:10px;min-width:220px}.room-stats span,.badge,.room-chip{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.05);color:#dbe4ff;font-size:13px;font-weight:700}.room-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.room-card{padding:18px;border-radius:22px;display:flex;flex-direction:column;gap:10px}.room-card-top{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap}.room-card h3{margin:0;font-size:21px}.room-card p{margin:0;color:#a6b3d2;line-height:1.5;min-height:48px}.room-card-meta{display:flex;gap:8px;flex-wrap:wrap}.auth-tabs-wrap{padding:22px;border-radius:24px}.auth-panel{max-width:620px;border-radius:20px;padding:0;margin-top:18px;display:flex;flex-direction:column;gap:14px}.auth-panel h3{margin:0 0 4px}.account-live{padding:22px;border-radius:24px}.account-box{display:flex;align-items:center;gap:16px}
/* chat */
.app-shell{display:grid;grid-template-columns:320px 1fr 300px;gap:18px;padding:18px;min-height:100vh}.app-shell.embed-mode{grid-template-columns:1fr;padding:0}.sidebar,.rightbar,.chat-panel{border-radius:24px;padding:18px}.brand-row{display:flex;gap:14px;align-items:center;margin-bottom:18px}.brand-title{font-weight:800;font-size:20px}.brand-sub,.muted{color:#9cabcf}.self-card{display:flex;gap:14px;align-items:center;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.035);padding:14px;border-radius:20px;cursor:pointer;margin-bottom:18px}.self-name{font-weight:800;font-size:18px}.helper-box{font-size:13px;color:#cbd7f5;background:rgba(123,109,255,.10);border:1px solid rgba(123,109,255,.2);padding:10px 12px;border-radius:14px;margin:0 0 12px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.room-list,.online-list{display:flex;flex-direction:column;gap:10px}.room-item{display:flex;gap:12px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}.room-item.active{background:rgba(123,109,255,.18);border-color:rgba(123,109,255,.38)}.room-item small{display:block;color:#9cabcf;margin-top:4px}.room-hash{width:34px;height:34px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#111a31;color:#9dbcff;font-weight:800}.side-buttons{display:flex;flex-direction:column;gap:10px}.chat-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:4px 4px 16px}.chat-actions-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.chat-title{font-size:26px;font-weight:800}.chat-sub{color:#9cabcf;margin-top:6px}.tab-row{display:flex;gap:10px}.messages{height:calc(100vh - 260px);overflow:auto;padding:10px 4px 6px;display:flex;flex-direction:column;gap:14px}.modal-messages{height:50vh}.msg{display:flex;gap:12px;align-items:flex-start;margin-left: 5px;}.msg.mine .msg-body{background:rgba(123,109,255,.14)}.msg-body{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);padding:13px 15px;border-radius:18px;max-width:min(100%,780px)}.msg-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}.msg-name{font-weight:800}.msg-time{margin-left:auto;color:#9cabcf;font-size:12px}.msg-text{white-space:pre-wrap;word-break:break-word;line-height:1.5}.composer{display:grid;grid-template-columns:1fr 140px;gap:12px;padding-top:12px}.online-user{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);color:#fff;cursor:pointer}.online-left{display:flex;align-items:center;gap:12px;min-width:0}.online-left span{display:flex;flex-direction:column;min-width:0}.online-left strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}.online-left small{color:#9cabcf}.online-right{display:flex;align-items:center;gap:8px}.dot{width:10px;height:10px;border-radius:999px;background:#46d692;box-shadow:0 0 0 4px rgba(70,214,146,.14)}.priv-badge{min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:linear-gradient(135deg,#ff5b7b,#ff8769);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}.you-badge{font-style:normal;font-size:11px;padding:4px 7px;border-radius:999px;background:rgba(87,196,255,.15);color:#b6ebff}.count-pill{display:inline-flex;min-width:28px;height:28px;padding:0 10px;border-radius:999px;background:rgba(123,109,255,.18);align-items:center;justify-content:center}.embed-box{padding:14px 4px}.embed-box h3{margin-top:0}
/* modals + notifications */
.modal-backdrop{position:fixed;inset:0;background:rgba(6,10,20,.66);display:flex;align-items:center;justify-content:center;padding:18px;z-index:50}.modal{border-radius:24px;width:min(720px,100%)}.small-modal{max-width:440px}.modal-lg{max-width:760px}.modal-chat{max-width:900px;display:grid;grid-template-rows:auto 1fr auto}.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.modal-body{padding:18px 20px}.modal-title{font-size:22px;font-weight:800}.modal-sub{color:#9cabcf;margin-top:4px}.icon-btn{width:40px;height:40px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:#fff;font-size:24px;cursor:pointer}.action-list{display:flex;flex-direction:column;gap:10px}.action-btn{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:#fff;border-radius:16px;padding:14px 16px;text-align:left;cursor:pointer;font-weight:700}.action-btn.primary{background:linear-gradient(135deg,#7869ff,#57c4ff)}.action-btn.danger{background:linear-gradient(135deg,#ff5d74,#ff865c)}.user-preview{display:flex;gap:14px;align-items:center;margin-bottom:16px}.toast-wrap{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:10px;z-index:80}.toast-item{min-width:250px;max-width:360px;background:rgba(16,22,40,.96);border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 45px rgba(0,0,0,.28);padding:14px 16px;border-radius:18px}
@media (max-width:1200px){.app-shell{grid-template-columns:280px 1fr}.rightbar{grid-column:1/-1}.room-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero{grid-template-columns:1fr}}
@media (max-width:900px){.grid-2,.room-grid,.app-shell{grid-template-columns:1fr}.app-shell{padding:10px}.messages{height:50vh}.composer{grid-template-columns:1fr}.chat-header{flex-direction:column}.chat-actions-top{justify-content:flex-start}.sidebar,.rightbar,.chat-panel{padding:14px}.landing-shell{padding:10px}.topbar{flex-direction:column;align-items:flex-start}.hero h1{font-size:34px}.feature-room{flex-direction:column}.section-title-row h2{font-size:26px}}

/* home v2 */
.home-shell{max-width:1600px;margin:0 auto;padding:16px}.home-topbar{position:sticky;top:10px;z-index:30}.nav-main a,.nav-main .nav-btn{font-weight:700}.hero-chat{grid-template-columns:1.05fr 1.1fr;align-items:stretch}.compact-copy h1{font-size:38px}.quick-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px}.quick-stat{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:5px}.quick-stat strong{font-size:28px}.quick-stat span{color:#9cabcf}.general-chat-card{border-radius:26px;padding:18px;display:flex;flex-direction:column;gap:16px;min-height:560px}.general-chat-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.chat-preview-title{font-size:24px;font-weight:800}.chat-preview-sub{color:#9cabcf;margin-top:6px;line-height:1.5}.embedded-chat-frame{flex:1;min-height:0;border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.06);background:#0a1020}.embedded-chat-frame iframe{width:100%;height:100%;min-height:480px;border:0;display:block}.chat-preview-box{display:flex;flex-direction:column;gap:14px;flex:1;min-height:0}.chat-preview-list{display:flex;flex-direction:column;gap:12px;overflow:auto;padding-right:4px;max-height:430px}.preview-msg{display:flex;gap:12px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}.preview-body{min-width:0;display:flex;flex-direction:column;gap:6px}.preview-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.preview-head small{margin-left:auto;color:#9cabcf}.preview-text{color:#dde5ff;line-height:1.45;word-break:break-word}.preview-actions{display:flex;gap:12px;flex-wrap:wrap}.empty-box{display:flex;align-items:center;justify-content:center;min-height:220px;border-radius:18px;background:rgba(255,255,255,.03);border:1px dashed rgba(255,255,255,.09);color:#9cabcf}.room-listing-section{margin-top:6px}.room-cover-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.cover-card{position:relative;overflow:hidden;min-height:250px;background:linear-gradient(145deg,rgba(58,74,122,.95),rgba(16,22,40,.96));background-size:contain;background-position:center center}.cover-card .cover-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,13,24,.18),rgba(8,13,24,.72) 55%,rgba(8,13,24,.94));pointer-events:none}.cover-card .room-card-inner{position:relative;z-index:1;margin-top:auto;display:flex;flex-direction:column;gap:10px;height:100%}.cover-card h3{margin-top:auto;font-size:24px}.cover-card p{min-height:66px;color:#dde6ff}.cover-card:hover{transform:translateY(-2px)}.account-section{padding-bottom:8px}#utworz-czat{scroll-margin-top:90px}
@media (max-width:1200px){.room-cover-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:900px){.hero-chat{grid-template-columns:1fr}.general-chat-card{min-height:unset}.embedded-chat-frame iframe{min-height:400px}.quick-stats{grid-template-columns:1fr}.room-cover-grid{grid-template-columns:1fr}.compact-copy h1{font-size:30px}}

.chat-no-room-list{grid-template-columns:280px 1fr 300px}.chat-no-room-list .sidebar{display:flex;flex-direction:column}.chat-no-room-list .helper-box{margin-bottom:18px}@media (max-width: 1280px){.chat-no-room-list{grid-template-columns:260px 1fr 280px}}@media (max-width: 1100px){.chat-no-room-list{grid-template-columns:1fr}.chat-no-room-list .sidebar{order:1}.chat-no-room-list .chat-panel{order:2}.chat-no-room-list .rightbar{order:3}.chat-no-room-list .room-footer-nav-section{order:4}}


.top-nav-layout{grid-template-columns:minmax(0,1fr) 320px;}
.chat-topbar-shell{margin:18px auto 14px;max-width:1400px;display:flex;align-items:center;justify-content:space-between;gap:18px;}
.self-chip{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:#fff;padding:10px 14px;border-radius:999px;cursor:pointer;}
.self-chip .avatar.sm{margin:0;}
@media (max-width: 1100px){.top-nav-layout{grid-template-columns:1fr;}.chat-topbar-shell{flex-wrap:wrap;}}

.nav-inline-btn{border:0;background:transparent;color:inherit;font:inherit;cursor:pointer;padding:0}
.nav-inline-btn:hover{opacity:.8}

/* footer */
.site-footer{max-width:1600px;margin:18px auto 22px;padding:18px;border-radius:24px}
.site-footer__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.site-footer__brand{display:flex;align-items:center;gap:12px;min-width:240px}
.site-footer__logo{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#7869ff,#57c4ff);display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;box-shadow:0 12px 28px rgba(97,88,255,.28)}
.site-footer__name{font-weight:900}
.site-footer__links{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.site-footer__links a{padding:10px 14px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07)}
.site-footer__links a:hover{transform:translateY(-1px)}
.site-footer__meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;color:#9cabcf}
.site-footer__muted{color:#9cabcf}
.site-footer__sep{opacity:.7}
@media (max-width:900px){.site-footer{margin:12px 10px 16px}.site-footer__inner{align-items:flex-start}}

/* games */
.games-shell{max-width:1600px;margin:0 auto;padding:16px;display:flex;flex-direction:column;gap:16px}
.games-topbar{position:sticky;top:10px;z-index:30}
.games-topbar-actions{display:flex;align-items:center;gap:10px}
.games-layout{display:grid;grid-template-columns:320px 1fr;gap:16px;align-items:start}
.games-drawer{border-radius:24px;padding:16px;position:sticky;top:92px;max-height:calc(100vh - 120px);overflow:auto}
.games-drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.games-drawer-title{font-weight:900;font-size:16px}
.games-list{display:flex;flex-direction:column;gap:10px}
.games-item{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.games-item small{color:#9cabcf}
.games-item:hover{transform:translateY(-1px)}
.games-item.active{background:rgba(123,109,255,.18);border-color:rgba(123,109,255,.40)}
.games-meta{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.games-meta-title{font-weight:900}
.games-stage{border-radius:24px;padding:16px;min-width:0}
.games-stage-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.games-stage-title strong{display:block;font-size:18px}
.games-stage-title small{display:block;margin-top:4px}
.games-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.games-size{display:flex;gap:8px;flex-wrap:wrap}
.games-frame-wrap{border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:#060a14;display:flex;align-items:center;justify-content:center;min-height:520px}
.games-frame{width:100%;height:100%;border:0;display:block}
.games-frame-wrap[data-size="fit"]{height:calc(100vh - 220px);min-height:520px}
.games-frame-wrap[data-size="s"]{width:min(900px,100%);height:520px;margin:0 auto}
.games-frame-wrap[data-size="m"]{width:min(1200px,100%);height:680px;margin:0 auto}
.games-frame-wrap[data-size="l"]{width:min(1460px,100%);height:820px;margin:0 auto}
.games-backdrop{position:fixed;inset:0;background:rgba(6,10,20,.66);z-index:60}
@media (max-width:1200px){.games-layout{grid-template-columns:280px 1fr}.games-drawer{top:92px}}
@media (max-width:900px){
  .games-shell{padding:10px}
  .games-layout{grid-template-columns:1fr}
  .games-drawer{position:fixed;top:0;left:0;bottom:0;width:min(360px,92vw);max-height:none;transform:translateX(-105%);transition:transform .22s ease;z-index:70}
  .games-drawer.open{transform:translateX(0)}
  .games-stage{padding:14px}
  .games-frame-wrap[data-size="fit"]{height:calc(100vh - 260px);min-height:440px}
  .games-frame-wrap[data-size="s"],
  .games-frame-wrap[data-size="m"],
  .games-frame-wrap[data-size="l"]{width:100%;height:calc(100vh - 260px);min-height:440px}
}

@media (min-width:901px){
  .games-topbar-actions{display:none}
  .games-backdrop{display:none!important}
  #gamesCloseBtn{display:none}
}


/* compact chat room layout */
.chat-topbar-shell{
    max-width: 980px !important;
    margin: 14px auto 10px !important;
    padding: 14px 18px !important;
}

.chat-compact-layout{
    max-width: 1020px !important;
    width: calc(100% - 24px) !important;
    margin: 0 auto 18px !important;
    grid-template-columns: minmax(0, 1fr) 240px !important;
    gap: 12px !important;
    align-items: start !important;
}

.chat-compact-layout .compact-chat-panel,
.chat-compact-layout .compact-rightbar{
    padding: 14px !important;
    border-radius: 18px !important;
}

.chat-compact-layout .compact-chat-panel{
    min-width: 0 !important;
}

.chat-compact-layout .chat-header{
    padding: 0 0 10px !important;
    align-items: flex-start !important;
}

.chat-compact-layout .chat-title{
    font-size: 20px !important;
}

.chat-compact-layout .chat-sub{
    font-size: 13px !important;
    line-height: 1.45 !important;
    margin-top: 4px !important;
}

.chat-compact-layout .chat-actions-top{
    gap: 8px !important;
}

.chat-compact-layout .tab-btn,
.chat-compact-layout .btn.tiny{
    padding: 8px 10px !important;
    border-radius: 10px !important;
    font-size: 12px !important;
}

.chat-compact-layout .compact-messages{
    height: 420px !important;
    padding: 6px 0 4px !important;
    gap: 2px !important;
}

.chat-compact-layout .msg{
    gap: 8px !important;
    margin-bottom: -5px !important;
}

.chat-compact-layout .avatar{
    width: 36px !important;
    height: 36px !important;
    border-radius: 12px !important;
    flex: 0 0 36px !important;
}

.messages .msg > .avatar,
.messages .msg > img.avatar{
    transition:transform .18s ease,box-shadow .18s ease;
    transform-origin:left top;
    position:relative;
    z-index:1;
}
.messages .msg > .avatar:hover,
.messages .msg > img.avatar:hover{
    transform:scale(1.75);
    box-shadow:0 10px 22px rgba(0,0,0,.35);
    z-index:8;
}
@media (hover:none){
            .messages .msg > .avatar:hover,
    .messages .msg > img.avatar:hover{
        transform:none;
        box-shadow:none;
    }
}

.chat-compact-layout .msg-body{
    max-width: min(100%, 620px) !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
}

.chat-compact-layout .msg-head{
    gap: 8px !important;
    margin-bottom: 5px !important;
}

.chat-compact-layout .msg-name{
    font-size: 14px !important;
}

.chat-compact-layout .msg-time{
    font-size: 11px !important;
}

.chat-compact-layout .msg-text{
    font-size: 14px !important;
    line-height: 1.45 !important;
}

.msg-link{
    color:#8fd2ff;
    text-decoration:underline;
    text-underline-offset:2px;
    word-break:break-word;
    overflow-wrap:anywhere;
}
.msg-link:hover{color:#c8e9ff}
.yt-preview{
    display:inline-flex;
    vertical-align:middle;
    margin-left:0;
    gap:6px;
    align-items:center;
}
.yt-play-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(255,93,93,.36);border-radius:999px;padding:2px 8px;margin:0;background:rgba(130,20,20,.28);color:#ffd7d7;cursor:pointer;line-height:1}
.yt-play-btn:hover{background:rgba(160,26,26,.36)}
.yt-play-icon{width:16px;height:16px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,52,52,.92);color:#fff;font-size:9px;flex:0 0 16px}
.yt-play-label{font-size:11px;font-weight:700;letter-spacing:.02em}
.yt-preview.is-playing{display:block;margin:6px 0 0;max-width:min(100%,340px);border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:rgba(8,12,20,.55)}
.yt-player{position:relative;width:100%;padding-top:56.25%}
.yt-player-frame{position:absolute;inset:0;width:100%;height:100%;border:0}
.page-chat .yt-preview.is-playing{background:rgba(16,23,31,.78);border-color:rgba(141,171,211,.22)}

/* floating YouTube player (draggable, resizable) */
.youtube-floating{
    position:fixed;
    z-index:9999;
    top:35%;
    left:35%;
    display:flex;
    flex-direction:column;
    min-width:260px;
    min-height:180px;
    max-width:90vw;
    max-height:85vh;
    border-radius:12px;
    overflow:hidden;
    box-shadow:0 12px 40px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.1);
    background:#0d1117;
    border:1px solid rgba(255,255,255,.12);
}
.youtube-floating .youtube-toolbar{
    display:flex;
    align-items:center;
    gap:8px;
    padding:6px 10px;
    background:rgba(0,0,0,.5);
    border-bottom:1px solid rgba(255,255,255,.08);
    cursor:move;
    flex-shrink:0;
    user-select:none;
}
.youtube-floating .youtube-toolbar .youtube-title{
    flex:1;
    min-width:0;
    font-size:12px;
    color:rgba(255,255,255,.85);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    pointer-events:none;
}
.youtube-floating .youtube-toolbar .youtube-toolbar-btn{
    flex-shrink:0;
    width:28px;
    height:28px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border:none;
    border-radius:8px;
    background:transparent;
    color:rgba(255,255,255,.7);
    cursor:pointer;
    transition:background .15s, color .15s;
}
.youtube-floating .youtube-toolbar .youtube-toolbar-btn:hover{
    background:rgba(255,255,255,.12);
    color:#fff;
}
.youtube-floating .youtube-toolbar .youtube-toolbar-btn.close:hover{
    background:rgba(255,90,120,.25);
    color:#ff6b8a;
}
.youtube-floating .youtube-frame-wrap{
    flex:1;
    min-height:0;
    position:relative;
    background:#000;
}
.youtube-floating .youtube-frame-wrap iframe{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    border:0;
}
.youtube-floating .youtube-resize{
    position:absolute;
    bottom:0;
    right:0;
    width:24px;
    height:24px;
    cursor:nwse-resize;
    z-index:2;
}
.youtube-floating .youtube-resize::after{
    content:'';
    position:absolute;
    right:4px;
    bottom:4px;
    width:10px;
    height:10px;
    border-right:2px solid rgba(255,255,255,.4);
    border-bottom:2px solid rgba(255,255,255,.4);
    border-radius:0 0 4px 0;
}

/* pinned */
.pinned-notice{margin:0 0 10px;padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.pinned-notice__inner{display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}
.pinned-notice__inner strong{display:inline-flex;padding:4px 10px;border-radius:999px;background:rgba(123,109,255,.18);border:1px solid rgba(123,109,255,.35);font-size:12px}
.pinned-notice__text{color:#dbe4ff;line-height:1.45}

.chat-compact-layout .compact-composer{
    grid-template-columns: 1fr 110px !important;
    gap: 10px !important;
    padding-top: 10px !important;
}

.chat-compact-layout .input{
    padding: 12px 14px !important;
    border-radius: 12px !important;
}

.chat-compact-layout .btn,
.chat-compact-layout .nav-btn{
    padding: 11px 14px !important;
    border-radius: 12px !important;
}

.chat-compact-layout .compact-rightbar .section-head{
    margin-bottom: 10px !important;
}

.chat-compact-layout .count-pill{
    min-width: 24px !important;
    height: 24px !important;
    font-size: 12px !important;
}

.chat-compact-layout .compact-online-list{
    gap: 8px !important;
    scrollbar-gutter: stable;
}

#onlineList,
#friendList{
    scrollbar-gutter: stable;
}

.chat-compact-layout .online-user{
    padding: 10px 11px !important;
    border-radius: 14px !important;
}

.chat-compact-layout .online-left{
    gap: 10px !important;
}

.chat-compact-layout .online-left strong{
    font-size: 14px !important;
}

.chat-compact-layout .online-left small{
    font-size: 12px !important;
}
.online-left > span{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    min-width:0;
}
.online-left > span small{
    display:block;
    margin-top:1px;
}

.chat-compact-layout .priv-badge{
    min-width: 20px !important;
    height: 20px !important;
    font-size: 11px !important;
}

@media (max-width: 1100px){
    .chat-compact-layout{
        max-width: 760px !important;
        grid-template-columns: 1fr !important;
    }

    .chat-compact-layout .compact-messages{
        height: 380px !important;
    }
}

@media (max-width: 820px){
    .chat-topbar-shell,
    .chat-compact-layout{
        width: calc(100% - 12px) !important;
        max-width: calc(100% - 12px) !important;
    }
}

/* tabs chat layout */
.chat-tabs-layout{
    grid-template-columns:minmax(0,1fr) 240px !important;
}
.tabs-chat-panel{
    display:grid;
    grid-template-rows:auto auto 1fr auto;
    min-height:620px;
    position:relative;
}
.modal-backdrop-in-chat{
    position:absolute;
    inset:0;
    border-radius:inherit;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:18px;
    z-index:50;
    background:rgba(6,10,20,.66);
}
.tabs-chat-header{
    align-items:flex-start !important;
}
.conversation-tabs{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
    padding:8px 0 10px;
    margin-top:0;
    border-bottom:1px solid rgba(255,255,255,.06);
    flex-shrink:0;
}
/* pasek zakładek – to samo tło co pole wiadomości */
.page-chat .conversation-shell + .conversation-tabs{
    padding-top:6px;
    padding-bottom:8px;
    background:var(--eye-panel, rgba(247,251,255,.94)) !important;
    border:1px solid var(--eye-border, rgba(127,165,210,.2)) !important;
    border-top:none !important;
    border-radius:0 0 22px 22px;
    box-shadow:var(--eye-shadow, none);
}
.page-chat .conversation-shell + .conversation-tabs .conversation-tab{
    background:transparent !important;
    border:1px solid var(--eye-border, rgba(127,165,210,.25)) !important;
    color:var(--eye-text, #17324f) !important;
}
.page-chat .conversation-shell + .conversation-tabs .conversation-tab:hover{
    background:rgba(255,255,255,.04) !important;
}
.page-chat .conversation-shell + .conversation-tabs .conversation-tab.active{
    background:rgba(255,255,255,.08) !important;
    border-color:var(--eye-border, rgba(127,165,210,.35)) !important;
    color:var(--eye-text, #17324f) !important;
    box-shadow:none;
}
.page-chat .conversation-tabs .conversation-tab{
    border-top:none !important;
}
.dynamic-tabs{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
}
.conversation-tab{
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.04);
    color:#fff;
    border-radius:12px;
    padding:8px 12px;
    font:inherit;
    font-size:13px;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:38px;
}
.conversation-tab.active{
    background:linear-gradient(135deg,#7869ff,#8978ff);
    border-color:transparent;
    box-shadow:0 12px 26px rgba(109,93,252,.22);
}
.tab-unread{
    min-width:20px;
    height:20px;
    border-radius:999px;
    background:#ff5c74;
    color:#fff;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-size:11px;
    font-weight:700;
    padding:0 8px 1px;
}
.tab-unread.hidden{display:none;}
.conversation-shell{
    min-height:0;
    display:block;
    position:relative;
}
.realtime-offline-overlay{
    position:fixed;
    inset:0;
    z-index:2300;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:18px;
}
.realtime-offline-overlay.hidden{
    display:none !important;
}
.realtime-offline-overlay-messages{
    position:absolute;
    inset:0;
    z-index:40;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    border-radius:inherit;
}
.realtime-offline-overlay-messages.hidden{
    display:none !important;
}
.realtime-offline-overlay-messages .realtime-offline-backdrop{
    border-radius:inherit;
}
.realtime-offline-backdrop{
    position:absolute;
    inset:0;
    background:rgba(4,8,14,.82);
    backdrop-filter:blur(4px);
}
.realtime-offline-card{
    position:relative;
    z-index:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:14px;
    padding:18px 22px;
    border-radius:16px;
    border:1px solid rgba(141,171,211,.26);
    background:radial-gradient(circle at top, rgba(69,98,170,.18), transparent 58%), rgba(10,15,24,.94);
    box-shadow:0 30px 80px rgba(0,0,0,.45);
    color:#eef5ff;
    font-size:14px;
    font-weight:700;
}
.realtime-offline-row{
    display:flex;
    align-items:center;
    gap:10px;
}
.realtime-offline-actions{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:10px;
}
.realtime-spinner{
    width:14px;
    height:14px;
    border-radius:999px;
    border:2px solid rgba(255,255,255,.25);
    border-top-color:#57c4ff;
    animation:realtimeSpin .8s linear infinite;
}
@keyframes realtimeSpin{to{transform:rotate(360deg)}}
.composer-row-wrap{
    display:flex;
    align-items:stretch;
    gap:10px;
    padding-top:0;
}
.composer-row-wrap .composer,
.chat-compact-layout .composer-row-wrap .compact-composer,
.page-chat .composer-row-wrap .composer,
.page-chat .chat-compact-layout .composer-row-wrap .compact-composer{
    flex:1;
    min-width:0;
    padding-top:0;
    display:grid !important;
    grid-template-columns:1fr 37px auto !important;
    gap:10px;
    align-items:stretch;
}
.composer-send-btn,
.page-chat .composer-send-btn,
.chat-compact-layout .composer-send-btn,
.page-chat .chat-compact-layout .composer-row-wrap .composer-send-btn{
    width:37px !important;
    min-width:37px !important;
    max-width:37px !important;
    height:60px !important;
    min-height:60px;
    padding:0 !important;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    align-self:stretch;
    box-sizing:border-box;
    flex-shrink:0;
}
.composer-send-icon{
    font-size:18px;
    line-height:1;
    display:block;
}
.composer-auth-btn,
.page-chat .composer-auth-btn,
.chat-compact-layout .composer-auth-btn{
    flex-shrink:0;
    align-self:stretch;
    min-height:60px;
    height:auto;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0 14px;
    box-sizing:border-box;
    border-radius:16px;
}
.composer.realtime-locked{opacity:.78}
.composer.realtime-locked .input,
.composer.realtime-locked .btn{cursor:not-allowed}
.composer.realtime-locked .composer-auth-btn{cursor:pointer !important}
.conversation-panel{
    display:none;
    min-height:0;
}
.conversation-panel.active{
    display:block;
}
.private-panels{min-height:0;}
.private-panel .messages,
#publicPanel .messages{
    height:420px !important;
    min-height:420px;
    max-height:420px;
    overflow-y:auto;
}
.tabs-composer{
    margin-top:10px;
}
.chat-status.ok{color:#7ae6a1;}
.chat-status.offline{color:#ff8c9f;}

@media (max-width:1100px){
    .chat-tabs-layout{grid-template-columns:1fr !important;}
}

.conversation-tab { position: relative; }
.tab-close { display:inline-flex; align-items:center; justify-content:center; width:18px; height:18px; margin-left:6px; border-radius:50%; font-size:12px; line-height:1; opacity:.8; cursor:pointer; }
.tab-close:hover { background: rgba(255,255,255,.12); opacity:1; }

.read-only-row{display:flex;align-items:center;min-height:48px;opacity:.85}
.display-name{font-weight:800;display:inline-block}
/*.name-preview-box{margin-top:10px;padding:14px 16px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.16)}*/
.name-preview-box{margin-top:10px;padding:14px 16px;border-radius:16px;background:rgba(255,255,255,.9);border:0px solid rgba(255,255,255,.16)}
.name-style-default{color:inherit}
.name-style-violet{background:linear-gradient(135deg,#b388ff 0%,#7c4dff 45%,#4fc3f7 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(124,77,255,.20)}
.name-style-gold{background:linear-gradient(135deg,#fff3b0 0%,#ffd54f 30%,#ffb300 55%,#fff8dc 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(255,193,7,.18)}
.name-style-aqua{background:linear-gradient(135deg,#9bf6ff 0%,#4dd0e1 40%,#00bcd4 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(0,188,212,.20)}
.name-style-ice{background:linear-gradient(135deg,#e7f7ff 0%,#b9e8ff 35%,#7fd4ff 65%,#d7f4ff 100%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(118,206,255,.24)}
.name-style-rainbow{background:linear-gradient(90deg,#ff6b6b,#ffd93d,#6bffb8,#57c4ff,#8f7bff,#ff6bcb,#ff6b6b);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(255,255,255,.10)}
.name-style-sunset{background:linear-gradient(135deg,#ffd180 0%,#ff8a65 35%,#ff5fa2 70%,#8b6bff 100%);background-size:240% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(255,143,100,.22)}
.name-style-neon{background:linear-gradient(135deg,#d4ff70 0%,#62ffb0 35%,#25e1ff 70%,#5ba7ff 100%);background-size:230% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(98,255,176,.24)}
.name-style-berry{background:linear-gradient(135deg,#ff9ad8 0%,#ff5fa2 35%,#b06cff 70%,#7b8dff 100%);background-size:230% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(255,95,162,.22)}
.name-style-steel{background:linear-gradient(135deg,#f4f8ff 0%,#dbe7ff 30%,#a5b9df 60%,#e9f1ff 100%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;will-change:background-position;text-shadow:0 0 18px rgba(182,204,240,.24)}
@keyframes nameRainbowShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:200% 50%}}
@-webkit-keyframes nameRainbowShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:200% 50%}}
@keyframes nameGradientShift{0%{background-position:0% 50%}100%{background-position:100% 50%}}
@-webkit-keyframes nameGradientShift{0%{background-position:0% 50%}100%{background-position:100% 50%}}

/* room cover: od conversation-shell do końca inputu (chat-cover-area) */
.chat-compact-layout.has-room-cover .chat-panel,
.chat-compact-layout.has-room-cover .chat-panel::before,
.chat-compact-layout.has-room-cover .chat-panel::after{
    background-image:none !important;
    display:block !important;
    content:none !important;
}

.chat-tabs-layout.has-room-cover .chat-cover-area{
    position:relative;
    display:flex;
    flex-direction:column;
    flex:1 1 auto;
    min-height:0;
    overflow:visible;
    isolation:isolate;
}

.chat-tabs-layout.has-room-cover .chat-cover-area::before{
    content:"";
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    height:100%;
    background-image:var(--room-cover-image);
    background-repeat:no-repeat;
    background-position:center center;
    background-size:cover;
    opacity:.75;
    filter:blur(var(--room-cover-blur, 0px));
    z-index:0;
    pointer-events:none;
}
.chat-tabs-layout.has-room-cover.room-cover-blur-off .chat-cover-area::before{
    filter:none;
}

.chat-tabs-layout.has-room-cover .chat-cover-area::after{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(9,14,27,.14);
    z-index:0;
    pointer-events:none;
}

.chat-tabs-layout.has-room-cover .chat-cover-area > *:not(.chat-effect-overlay){
    position:relative;
    z-index:1;
}

.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-tabs{
    background:rgba(18,25,34,.2) !important;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .chat-toolstrip{
    background:rgb(18 25 34 / 66%) !important;
    border-color:rgba(141,171,211,.22) !important;
    overflow:visible;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .chat-toolstrip .radio-pop-wrap{
    position:relative;
    overflow:visible;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .chat-toolstrip .radio-popover{
    z-index:100;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .tabs-composer{
    background:rgba(18,25,34,.2) !important;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .composer-row-wrap{
    background:transparent !important;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .tabs-composer .input{
    background:rgba(18,25,34,.35) !important;
}

.chat-tabs-layout.has-room-cover .conversation-shell{
    position:relative;
    min-height:0;
    overflow:hidden;
    background-color:transparent !important;
}

.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-shell{
    background-color:transparent !important;
    background-image:none !important;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-shell::before,
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-shell::after{
    display:none !important;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-panel,
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-panel.active{
    background:transparent !important;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .messages{
    background:transparent !important;
}

/* home v4 without general chat embed */
.home-v3-shell{max-width:1600px;margin:0 auto;padding:16px}
.hero-home-v3{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:stretch;padding:28px;border-radius:28px}
.home-settings-card{display:flex;flex-direction:column;gap:16px;border-radius:26px}
.settings-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.settings-title{font-size:24px;font-weight:800}
.settings-sub{margin-top:6px;color:#9cabcf;line-height:1.5}
.home-account-box{padding:16px 0;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.home-user-rooms{padding-top:14px}
.home-user-rooms-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:rgba(255,255,255,.5);margin-bottom:10px}
.home-user-rooms-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.home-user-room-link{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);color:inherit;text-decoration:none;transition:background .15s ease,border-color .15s ease}
.home-user-room-link:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.1)}
.home-user-room-name{font-weight:600}
.home-user-room-meta{font-size:12px;color:rgba(255,255,255,.5)}
.settings-list{display:flex;flex-direction:column;gap:10px}
.settings-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);transition:transform .15s ease,background .15s ease}
.settings-row:hover{transform:translateY(-1px);background:rgba(255,255,255,.06)}
.settings-row strong{display:block;font-size:15px}
.settings-row small{display:block;margin-top:4px;color:#9cabcf;line-height:1.45}
.settings-note{font-size:13px;line-height:1.55;color:#cdd7f4;background:rgba(123,109,255,.10);border:1px solid rgba(123,109,255,.18);padding:12px 14px;border-radius:16px}
@media (max-width: 980px){.hero-home-v3{grid-template-columns:1fr}.home-settings-card{min-height:unset}}

/* home light theme */
.page-home{
    background:
        radial-gradient(circle at top left, rgba(121, 187, 255, .42), transparent 28%),
        radial-gradient(circle at top right, rgba(66, 133, 244, .18), transparent 24%),
        linear-gradient(180deg, #f5fbff 0%, #eef5ff 52%, #e7f0ff 100%);
    color:#17324f;
}
.page-home .panel{
    background:rgba(255,255,255,.78);
    border:1px solid rgba(125,156,196,.22);
    box-shadow:0 18px 48px rgba(53,104,167,.12);
    backdrop-filter:blur(18px);
}
.page-home .topbar,
.page-home .home-topbar-light{
    background:rgba(255,255,255,.72);
    border-color:rgba(123,158,205,.24);
}
.page-home .brand-link small,
.page-home .muted,
.page-home .section-title-row p,
.page-home .hero p,
.page-home .settings-row small,
.page-home .quick-stat span,
.page-home .settings-sub,
.page-home .settings-note,
.page-home .cover-card p,
.page-home .room-card p{
    color:#5f7897;
}
.page-home .brand-logo{
    background:linear-gradient(135deg,#2f80ed,#66b8ff);
    box-shadow:0 14px 28px rgba(47,128,237,.26);
}
.page-home .home-v4-shell{max-width:1580px;margin:0 auto;padding:18px;gap:20px}
.page-home .home-topbar-light{position:sticky;top:10px;z-index:30;border-radius:26px}
.page-home .nav-main-home a{color:#224464;font-weight:700;transition:background .18s ease,color .18s ease,transform .18s ease}
.page-home .nav-main-home a:hover{background:rgba(47,128,237,.08);color:#0e5fca}
.page-home .nav-main-home .nav-cta{background:linear-gradient(135deg,#2f80ed,#5fb8ff);color:#fff;box-shadow:0 12px 24px rgba(47,128,237,.22)}
.page-home .nav-main-home .nav-cta:hover{color:#fff;background:linear-gradient(135deg,#1f74e1,#55b2ff)}
.page-home .hero-home-light{grid-template-columns:minmax(0,1.25fr) minmax(300px,.85fr);gap:22px;padding:32px;border-radius:30px;overflow:hidden;position:relative}
.page-home .hero-home-light::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(255,255,255,.36), rgba(120,186,255,.08));pointer-events:none}
.page-home .hero-copy-light,.page-home .home-side-column{position:relative;z-index:1}
.page-home .eyebrow{background:rgba(47,128,237,.12);color:#1563cf}
.page-home .hero-copy-light h1,.page-home .section-title-row-light h2,.page-home .home-featured-card h3,.page-home .cover-card-light h3,.page-home .settings-title,.page-home .account-box strong{color:#163554}
.page-home .hero-copy-light h1{font-size:46px;line-height:1.04;max-width:820px}
.page-home .hero-actions-light{margin-top:24px}
.page-home .btn-primary{background:linear-gradient(135deg,#2f80ed,#65b7ff);color:#fff}
.page-home .btn-secondary{background:linear-gradient(135deg,#d9e8ff,#c7ddff);color:#1f4a78}
.page-home .btn-ghost,.page-home .home-ghost-btn{background:rgba(255,255,255,.7);color:#27517e;border:1px solid rgba(117,156,203,.26)}
.page-home .btn:hover,.page-home .settings-row-light:hover,.page-home .home-shortcut-card:hover,.page-home .cover-card-light:hover,.page-home .home-featured-card:hover{transform:translateY(-2px)}
.page-home .quick-stats-home{margin-top:22px;grid-template-columns:repeat(3,minmax(0,1fr))}
.page-home .quick-stat-home{border:1px solid rgba(131,170,214,.24)}
.page-home .quick-stat-home strong{color:#1560c7}
.page-home .home-shortcuts-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}
.page-home .home-shortcut-card{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;border-radius:22px;transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.page-home .home-shortcut-card strong{display:block;font-size:16px;color:#163554}
.page-home .home-shortcut-card small{display:block;margin-top:5px;color:#62809f;line-height:1.45}
.page-home .shortcut-icon{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:20px;background:linear-gradient(135deg,#deedff,#cae1ff);flex:0 0 42px}
.page-home .home-side-column{display:flex;flex-direction:column;gap:18px}
.page-home .home-settings-card-light{border-radius:28px}
.page-home .settings-card-head-light,.page-home .home-featured-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.page-home .badge-light,.page-home .room-chip-light,.page-home .room-card-meta span,.page-home .home-featured-meta span{background:rgba(47,128,237,.08);color:#b6c9e6;border:1px solid rgba(47,128,237,.08)}
.page-home .home-account-box-light{border-top:1px solid rgba(123,158,205,.18);border-bottom:1px solid rgba(123,158,205,.18);padding:18px 0}
.page-home .home-user-rooms-title{color:#5a7a9e}
.page-home .home-user-room-link{border:1px solid rgba(131,170,214,.2)/* background: rgb(40 50 60); *//* color: #163554; */}
.page-home .home-user-room-link:hover{border-color:rgba(131,170,214,.35)}
.page-home .home-user-room-meta{color:#6b8aaa}
.page-home .fallback{background:linear-gradient(135deg,#d8ebff,#bddbff);color:#1658b8}
.page-home .settings-list-light{display:flex;flex-direction:column;gap:12px}
.page-home .settings-row-light{border:1px solid rgba(131,170,214,.18);color:#183652}
.page-home .settings-note-light{padding:14px 16px;border-radius:18px;background:rgba(233,242,255,.82);border:1px dashed rgba(101,146,199,.28);line-height:1.55}
.page-home .home-featured-card{display:flex;flex-direction:column;gap:12px;padding:22px;border-radius:28px;color:inherit;transition:transform .18s ease, box-shadow .18s ease;background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(240,247,255,.92)),linear-gradient(135deg, rgba(47,128,237,.08), rgba(95,184,255,.08))}
.page-home .home-featured-card p{margin:0;color:#5f7897;line-height:1.55}
.page-home .home-featured-card h3{margin:0;font-size:24px}
.page-home .home-featured-meta{display:flex;gap:10px;flex-wrap:wrap}
.page-home .room-listing-section-light{gap:18px}
.page-home .main-tabs-light{gap:12px}
.page-home .tab-btn{background:rgba(255,255,255,.75);border:1px solid rgba(128,166,212,.24);color:#2a517d;font-weight:700}
.page-home .tab-btn.active{background:linear-gradient(135deg,#2f80ed,#67b9ff);border-color:transparent;color:#fff;box-shadow:0 12px 26px rgba(47,128,237,.18)}
.page-home .room-cover-grid-light{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.page-home .cover-card-light{min-height:260px;background:linear-gradient(180deg, rgba(255,255,255,.28), rgba(236,244,255,.92)),linear-gradient(145deg,rgba(104,164,229,.18),rgba(255,255,255,.4));border:1px solid rgba(128,166,212,.24);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;background-size:cover;background-position:center}
.page-home .cover-overlay-light{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(237,244,255,.72) 58%,rgba(233,242,255,.95))}
.page-home .cover-card-light .room-card-inner{gap:12px}
.page-home .cover-card-light p{min-height:70px}
.page-home .cover-card-light .room-card-meta{margin-top:auto}
.page-home .flash.error{background:rgba(255, 97, 128, .1);border:1px solid rgba(255, 97, 128, .18);color:#b33d57}
.page-home .flash.success{background:rgba(43, 171, 104, .1);border:1px solid rgba(43, 171, 104, .18);color:#247449}

/* chat light theme */
.page-chat{
    background:
        radial-gradient(circle at top left, rgba(118, 184, 255, .34), transparent 24%),
        linear-gradient(180deg, #f5fbff 0%, #eef5ff 55%, #e8f1ff 100%);
    color:#17324f;
}
.page-chat .panel{
    background:rgba(255,255,255,.82);
    border:1px solid rgba(125,156,196,.22);
    box-shadow:0 16px 42px rgba(53,104,167,.11);
    backdrop-filter:blur(18px);
}
.page-chat .topbar,
.page-chat .chat-topbar-shell{
    background:rgba(255,255,255,.74);
    border:1px solid rgba(123,158,205,.22);
}
.page-chat .chat-topbar-shell{
    width:100% !important;
    max-width:none !important;
    margin:0 !important;
    border-radius:0 !important;
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    z-index:50;
}
.page-chat .chat-topbar-drawer{
    top:0 !important;
    border-radius:0 !important;
}
/* miejsce na przypiętą nawigację – żeby treść nie chowała się pod paskiem */
.page-chat .app-shell{
    padding-top: 96px !important;
}
.page-chat .brand-link strong,
.page-chat .chat-title,
.page-chat .section-head strong,
.page-chat .msg-name,
.page-chat .online-left strong,
.page-chat .modal-title,
.page-chat .display-name,
.page-chat .conversation-tab,
.page-chat .self-chip{
    color:#17324f;
}
.page-chat .brand-link small,
.page-chat .chat-sub,
.page-chat .online-left small,
.page-chat .modal-sub,
.page-chat .muted,
.page-chat .label,
.page-chat .msg-time{
    color:#5f7897;
}
.page-chat .nav-links a,
.page-chat .nav-inline-btn{color:#224464}
.page-chat .nav-links a:hover,
.page-chat .nav-inline-btn:hover{color:#0e5fca}
.page-chat .brand-logo{background:linear-gradient(135deg,#2f80ed,#66b8ff);box-shadow:0 14px 28px rgba(47,128,237,.24)}
.page-chat .self-chip{background:rgba(239,246,255,.88);border:1px solid rgba(126,165,212,.22)}
.page-chat .btn-primary{background:linear-gradient(135deg,#2f80ed,#65b7ff);color:#fff}
.page-chat .btn-secondary{background:linear-gradient(135deg,#d8e8ff,#c7ddff);color:#1f4a78}
.page-chat .btn-ghost,.page-chat .nav-btn{background:rgba(239,246,255,.84);color:#25507d;border:1px solid rgba(120,156,200,.22)}
.page-chat .input,
.page-chat .read-only-row{background:#f8fbff;color:#17324f;border:1px solid rgba(125,156,196,.22)}
.page-chat .input:focus{border-color:#4a9bf1;box-shadow:0 0 0 4px rgba(74,155,241,.14)}
.page-chat .chat-panel,
.page-chat .rightbar{border-radius:24px}
.page-chat .conversation-tabs{border-bottom:1px solid rgba(123,158,205,.18)}
.page-chat .conversation-tab{background:rgba(239,246,255,.88);border:1px solid rgba(127,165,210,.22)}
.page-chat .conversation-tab.active{background:linear-gradient(135deg,#2f80ed,#67b9ff);color:#fff;box-shadow:0 12px 26px rgba(47,128,237,.18)}
.page-chat .tab-close:hover{background:rgba(47,128,237,.12)}
.page-chat .conversation-shell{border-radius:22px 22px 0 0;background:linear-gradient(180deg, rgba(247,251,255,.9), rgba(237,244,255,.85));border:1px solid rgba(127,165,210,.2);padding:6px 8px}
.page-chat .msg-body{
    background:transparent !important;
    border:none !important;
    box-shadow:none !important;
    padding-top:0 !important;
}
.page-chat .msg-head{
    margin-top:0;
    margin-bottom:0;
}
.page-chat .msg-head .role-badge,
.page-chat .msg-head .msg-time{
    display:none !important;
}
.page-chat .msg-text{
    margin-top:-3px;
}
.page-chat .msg.mine .msg-body{
    background:transparent !important;
    border:none !important;
}
.page-chat .messages{
    scrollbar-color:rgba(95,142,199,.45) transparent;
    gap:6px !important;
}
.page-chat .role-badge.user{background:rgba(255,255,255,.08);color:#1766d1}
.page-chat .role-badge.guest{background:rgba(255,193,88,.14);color:#b97b00}
.page-chat .role-badge.moderator{background:rgba(73,183,255,.14);color:#0b87c9}
.page-chat .role-badge.admin{background:rgba(255,96,128,.12);color:#c54262}
.page-chat .online-user{background:rgba(247,251,255,.92);border:1px solid rgba(127,165,210,.18);color:#17324f}
.page-chat .count-pill{background:rgba(255,255,255,.08);color:#1766d1}
.page-chat .you-badge{background:rgba(47,128,237,.12);color:#1766d1}
.page-chat .fallback{background:linear-gradient(135deg,#d8ebff,#bddbff);color:#1658b8}
.page-chat .modal-backdrop{background:rgba(21,46,78,.32)}
.page-chat .modal-head{border-bottom:1px solid rgba(123,158,205,.18)}
.page-chat .icon-btn{background:rgba(239,246,255,.92);border:1px solid rgba(127,165,210,.22);color:#17324f}
.page-chat .action-btn{background:rgba(247,251,255,.92);border:1px solid rgba(127,165,210,.18);color:#17324f}
.page-chat .action-btn.primary{background:linear-gradient(135deg,#2f80ed,#65b7ff);color:#fff}
.page-chat .action-btn.danger{background:linear-gradient(135deg,#ff6f8d,#ff9b7c);color:#fff}
.page-chat .toast-item{background:rgba(255,255,255,.96);border:1px solid rgba(127,165,210,.18);box-shadow:0 18px 45px rgba(53,104,167,.14);color:#17324f}
.page-chat .chat-status.ok{color:#1f9e62}
.page-chat .chat-status.offline{color:#d05b73}
.page-chat .chat-tabs-layout.has-room-cover .conversation-shell{background-color:rgba(245,250,255,.72) !important}
.page-chat .chat-tabs-layout.has-room-cover .conversation-shell::after{background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(239,246,255,.48) 45%,rgba(231,241,255,.78) 100%)}
.page-chat .flash.error{background:rgba(255, 97, 128, .1);border:1px solid rgba(255, 97, 128, .18);color:#b33d57}
.page-chat .flash.success{background:rgba(43, 171, 104, .1);border:1px solid rgba(43, 171, 104, .18);color:#247449}

@media (max-width: 1200px){
    .page-home .hero-home-light{grid-template-columns:1fr}
    .page-home .home-shortcuts-grid,
    .page-home .room-cover-grid-light{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 900px){
    .page-home .home-v4-shell{padding:10px}
    .page-home .hero-home-light{padding:22px;border-radius:24px}
    .page-home .hero-copy-light h1{font-size:34px}
    .page-home .quick-stats-home,
    .page-home .home-shortcuts-grid,
    .page-home .room-cover-grid-light{grid-template-columns:1fr}
    .page-home .home-topbar-light{border-radius:22px}
}

/* toast colors */
.toast-item.toast-success{border-color:rgba(70,214,146,.32)!important;box-shadow:0 18px 45px rgba(70,214,146,.12)!important}
.toast-item.toast-error{border-color:rgba(255,95,122,.36)!important;box-shadow:0 18px 45px rgba(255,95,122,.14)!important}
.toast-item.toast-warn{border-color:rgba(255,223,120,.38)!important;box-shadow:0 18px 45px rgba(255,223,120,.14)!important}
.toast-item.toast-info{border-color:rgba(87,196,255,.26)!important;box-shadow:0 18px 45px rgba(87,196,255,.10)!important}
.page-chat .toast-item.toast-success{border-color:rgba(43,171,104,.35)!important;box-shadow:0 18px 45px rgba(43,171,104,.16)!important}
.page-chat .toast-item.toast-error{border-color:rgba(255,97,128,.34)!important;box-shadow:0 18px 45px rgba(255,97,128,.16)!important}
.page-chat .toast-item.toast-warn{border-color:rgba(245,158,11,.30)!important;box-shadow:0 18px 45px rgba(245,158,11,.14)!important}
.page-chat .toast-item.toast-info{border-color:rgba(47,128,237,.28)!important;box-shadow:0 18px 45px rgba(47,128,237,.12)!important}
.toast-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;background:#6f879f;border:1px solid rgba(255,255,255,.10);font-size:12px;font-weight:900;flex:0 0 20px}
.page-chat .toast-icon{background:#6f879f;border-color:rgba(0,0,0,.06)}



/* auth light pages */
.page-auth .auth-page-shell-light{max-width:1580px;margin:0 auto;padding:18px;gap:20px}
.page-auth .auth-hero-grid,
.page-auth .create-layout-grid{/*display:grid;grid-template-columns:minmax(360px,.95fr) minmax(0,1.05fr);gap:20px;align-items:stretch*/}
.page-auth .auth-showcase-card,
.page-auth .auth-shell-card{padding:28px;border-radius:30px}
.page-auth .auth-showcase-card{display:flex;flex-direction:column;gap:18px;overflow:hidden;position:relative;background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(238,245,255,.92)),linear-gradient(135deg,rgba(47,128,237,.08),rgba(95,184,255,.1))}
.page-auth .auth-showcase-card::before{content:"";position:absolute;right:-80px;top:-80px;width:220px;height:220px;border-radius:999px;background:radial-gradient(circle,rgba(103,182,255,.25),rgba(103,182,255,0) 70%);pointer-events:none}
.page-auth .auth-showcase-card > *{position:relative;z-index:1}
.page-auth .auth-showcase-card h1{margin:0;color:#163554;font-size:42px;line-height:1.05;max-width:720px}
.page-auth .auth-showcase-card p{margin:0;color:#5f7897;line-height:1.7;max-width:760px}
.page-auth .auth-feature-list{display:flex;flex-direction:column;gap:12px}
.page-auth .auth-feature-item{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;border-radius:22px;background:rgba(255,255,255,.72);border:1px solid rgba(128,166,212,.2);box-shadow:0 10px 24px rgba(55,103,168,.06)}
.page-auth .auth-feature-item strong{display:block;color:#17324f;font-size:16px}
.page-auth .auth-feature-item small{display:block;margin-top:4px;color:#6683a2;line-height:1.55}
.page-auth .auth-feature-icon{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#deedff,#cae1ff);color:#1560c7;font-weight:800;flex:0 0 42px}
.page-auth .auth-status-card{margin-top:auto;display:flex;flex-direction:column;gap:14px;padding:20px 22px;border-radius:26px;background:linear-gradient(180deg,rgba(255,255,255,.8),rgba(240,247,255,.88));border:1px solid rgba(128,166,212,.2)}
.page-auth .auth-status-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.page-auth .auth-account-box{border-top:1px solid rgba(123,158,205,.18);border-bottom:1px solid rgba(123,158,205,.18);padding:16px 0}
.page-auth .auth-note{margin-top:0}
.page-auth .auth-shell-card{display:flex;flex-direction:column;gap:18px;background:rgba(255,255,255,.84);border:1px solid rgba(125,156,196,.22);box-shadow:0 18px 48px rgba(53,104,167,.12)}
.page-auth .auth-title-row h2{margin:0;color:#163554}
.page-auth .auth-tabs-light{gap:12px}
.page-auth .auth-tab-panel{padding-top:2px}
.page-auth .auth-form-card{max-width:none;margin-top:0;padding:24px;border-radius:26px;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(240,247,255,.88));border:1px solid rgba(128,166,212,.22);box-shadow:0 14px 30px rgba(53,104,167,.08)}
.page-auth .auth-form-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:6px}
.page-auth .auth-form-head h3{margin:0;color:#163554;font-size:24px}
.page-auth .auth-form-head p{margin:8px 0 0;color:#5f7897;line-height:1.6;max-width:720px}
.page-auth .auth-mini-badge{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:999px;background:rgba(47,128,237,.09);border:1px solid rgba(47,128,237,.12);color:#1667d1;font-weight:700;font-size:13px}
.page-auth .auth-form-grid{gap:16px}
.page-auth .auth-actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
.recaptcha-wrap{margin:12px 0 4px}
.recaptcha-wrap .g-recaptcha{display:inline-block}
/* opcjonalnie: ramka wokół widgetu (kolor dopasuj do strony) */
.page-auth .recaptcha-wrap{border-radius:4px;padding:4px 0}
.page-auth .auth-hint-box{padding:14px 16px;border-radius:18px;background:rgba(233,242,255,.82);border:1px dashed rgba(101,146,199,.28);line-height:1.55;color:#355473}
.page-auth .auth-shell-card .input,
.page-auth .auth-shell-card .read-only-row{background:#f8fbff;color:#17324f;border:1px solid rgba(125,156,196,.22)}
.page-auth .auth-shell-card .input:focus{border-color:#4a9bf1;box-shadow:0 0 0 4px rgba(74,155,241,.14)}
.page-auth .auth-shell-card .label,
.page-auth .auth-shell-card .check{color:#466683}
.page-auth .auth-shell-card .check input{accent-color:#2f80ed}
.page-auth .create-form-card{gap:18px}
.page-auth .create-hint-box strong{color:#17324f}
.page-auth .create-check{padding:6px 2px}
@media (max-width: 1180px){
    .page-auth .auth-hero-grid,
    .page-auth .create-layout-grid{grid-template-columns:1fr}
}
@media (max-width: 900px){
    .page-auth .auth-page-shell-light{padding:10px}
    .page-auth .auth-showcase-card,
    .page-auth .auth-shell-card{padding:22px;border-radius:24px}
    .page-auth .auth-showcase-card h1{font-size:34px}
    .page-auth .auth-form-card{padding:18px;border-radius:22px}
}


/* === Eye-friendly muted theme override === */
:root{
    --eye-bg-1:#0f151c;
    --eye-bg-2:#121a23;
    --eye-bg-3:#16212b;
    --eye-panel:rgba(21,29,39,.90);
    --eye-panel-strong:rgba(18,25,34,.96);
    --eye-surface:rgba(255,255,255,.045);
    --eye-surface-2:rgba(255,255,255,.065);
    --eye-border:rgba(166,184,201,.12);
    --eye-border-strong:rgba(166,184,201,.18);
    --eye-text:#e5ebf2;
    --eye-muted:#9fb0c0;
    --eye-primary:#7991ab;
    --eye-primary-2:#7ca2ad;
    --eye-primary-soft:rgba(121,145,171,.16);
    --eye-success:#82b398;
    --eye-success-soft:rgba(130,179,152,.14);
    --eye-danger:#c68f9a;
    --eye-danger-soft:rgba(198,143,154,.14);
    --eye-warning:#c9af83;
    --eye-warning-soft:rgba(201,175,131,.14);
    --eye-shadow:0 18px 42px rgba(0,0,0,.24);
}

body,
.page-home,
.page-chat,
.page-auth{
    background:
        radial-gradient(circle at top left, rgba(124,148,176,.14), transparent 28%),
        radial-gradient(circle at top right, rgba(111,148,157,.09), transparent 24%),
        linear-gradient(180deg,var(--eye-bg-1) 0%,var(--eye-bg-2) 55%,var(--eye-bg-3) 100%) !important;
    color:var(--eye-text) !important;
}

.panel:not(.cover-card):not(.cover-card-light),
.page-home .panel:not(.cover-card):not(.cover-card-light),
.page-chat .panel:not(.cover-card):not(.cover-card-light),
.page-auth .auth-shell-card,
.page-auth .auth-showcase-card,
.page-auth .auth-form-card,
.page-auth .auth-status-card,
.toast-item,
.page-chat .toast-item,
.modal{
    background:var(--eye-panel) !important;
    border:1px solid var(--eye-border) !important;
    box-shadow:var(--eye-shadow) !important;
    backdrop-filter:blur(16px);
    color:var(--eye-text);
}
.page-chat .conversation-shell{
    background:var(--eye-panel) !important;
    border:1px solid var(--eye-border) !important;
    box-shadow:var(--eye-shadow) !important;
    backdrop-filter:blur(16px);
    color:var(--eye-text);
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-shell{
    backdrop-filter:none !important;
}

.topbar,
.page-home .topbar,
.page-home .home-topbar-light,
.page-chat .topbar,
.page-chat .chat-topbar-shell,
.sidebar,
.rightbar,
.chat-panel{
    background:rgba(18,25,34,.78) !important;
    border:1px solid var(--eye-border) !important;
    box-shadow:var(--eye-shadow) !important;
}

.brand-link small,
.brand-sub,
.muted,
.label,
.section-title-row p,
.hero p,
.room-card p,
.cover-card p,
.feature-room p,
.chat-sub,
.msg-time,
.online-left small,
.modal-sub,
.preview-head small,
.quick-stat span,
.settings-row small,
.settings-sub,
.settings-note,
.auth-showcase-card p,
.auth-form-head p,
.auth-feature-item small,
.auth-hint-box,
.page-home .brand-link small,
.page-home .muted,
.page-home .section-title-row p,
.page-home .hero p,
.page-home .settings-row small,
.page-home .quick-stat span,
.page-home .settings-sub,
.page-home .settings-note,
.page-home .cover-card p,
.page-home .room-card p,
.page-chat .brand-link small,
.page-chat .chat-sub,
.page-chat .online-left small,
.page-chat .modal-sub,
.page-chat .muted,
.page-chat .label,
.page-chat .msg-time{
    color:var(--eye-muted) !important;
}

h1,h2,h3,h4,h5,h6,strong,
.hero-copy-light h1,
.section-title-row-light h2,
.home-featured-card h3,
.cover-card-light h3,
.settings-title,
.account-box strong,
.page-home .hero-copy-light h1,
.page-home .section-title-row-light h2,
.page-home .home-featured-card h3,
.page-home .cover-card-light h3,
.page-home .settings-title,
.page-home .account-box strong,
.page-chat .brand-link strong,
.page-chat .chat-title,
.page-chat .section-head strong,
.page-chat .msg-name,
.page-chat .online-left strong,
.page-chat .modal-title,
.page-chat .display-name,
.page-chat .conversation-tab,
.page-chat .self-chip,
.page-auth .auth-showcase-card h1,
.page-auth .auth-title-row h2,
.page-auth .auth-form-head h3,
.page-auth .auth-feature-item strong,
.page-auth .create-hint-box strong{
    color:var(--eye-text) !important;
}

a,
.nav-main-home a,
.page-chat .nav-links a,
.page-chat .nav-inline-btn{
    color:#c7d4e3;
}

.nav-main-home a:hover,
.page-chat .nav-links a:hover,
.page-chat .nav-inline-btn:hover{
    color:#edf3f8;
    background:rgba(255,255,255,.05);
}

.brand-logo,
.page-home .brand-logo,
.page-chat .brand-logo{
    background:linear-gradient(135deg,#6f879f,#7ca2ad) !important;
    color:#f7fbff !important;
    box-shadow:0 12px 28px rgba(111,135,159,.28) !important;
}

.btn-primary,
.action-btn.primary,
.page-home .btn-primary,
.page-chat .btn-primary,
.page-chat .action-btn.primary,
.page-home .nav-main-home .nav-cta{
    background:linear-gradient(135deg,#6e85a0,#7ca2ad) !important;
    color:#f8fbff !important;
    box-shadow:0 10px 24px rgba(111,135,159,.22);
}

.btn-secondary,
.page-home .btn-secondary,
.page-chat .btn-secondary{
    background:linear-gradient(135deg,#2a3542,#334556) !important;
    color:var(--eye-text) !important;
}

.btn-ghost,
.nav-btn,
.icon-btn,
.action-btn,
.page-home .btn-ghost,
.page-home .home-ghost-btn,
.page-chat .btn-ghost,
.page-chat .nav-btn,
.page-chat .icon-btn,
.page-chat .action-btn,
.page-chat .self-chip,
.self-chip{
    background:rgba(255,255,255,.05) !important;
    border:1px solid var(--eye-border) !important;
    color:var(--eye-text) !important;
}

.input,
.read-only-row,
.page-chat .input,
.page-chat .read-only-row,
.page-auth .auth-shell-card .input,
.page-auth .auth-shell-card .read-only-row{
    background:#10171f !important;
    color:var(--eye-text) !important;
    border:1px solid var(--eye-border-strong) !important;
}

.input:focus,
.page-chat .input:focus,
.page-auth .auth-shell-card .input:focus{
    border-color:rgba(124,162,173,.52) !important;
    box-shadow:0 0 0 4px rgba(124,162,173,.14) !important;
}

.self-card,
.room-item,
.online-user,
.msg-body,
.mini-room,
.quick-stat,
.preview-msg,
.room-card,
.feature-room,
.account-live,
.auth-tabs-wrap,
.home-shortcut-card,
.home-featured-card,
.settings-row-light,
.auth-feature-item,
.general-chat-card,
.quick-stat-home,
.name-preview-box{
    background-color:rgba(255,255,255,.04) !important;
    border:1px solid var(--eye-border) !important;
    color:var(--eye-text) !important;
    box-shadow:none !important;
}

.msg.mine .msg-body{
    background:rgba(121,145,171,.12) !important;
    border-color:rgba(121,145,171,.18) !important;
}
.page-chat .msg.mine .msg-body{
    background:transparent !important;
    border:none !important;
}

.room-item.active,
.tab-btn.active,
.page-home .tab-btn.active,
.page-chat .conversation-tab.active{
    background:rgba(121,145,171,.18) !important;
    border-color:rgba(121,145,171,.30) !important;
    color:#f7fbff !important;
    box-shadow:none !important;
}

.room-hash,
.shortcut-icon,
.auth-feature-icon,
.fallback,
.page-home .fallback,
.page-chat .fallback{
    background:linear-gradient(135deg,#233142,#2c3c4d) !important;
    color:#d8e5f1 !important;
}

.eyebrow,
.badge,
.room-chip,
.room-card-meta span,
.home-featured-meta span,
.count-pill,
.you-badge,
.auth-mini-badge,
.page-home .badge-light,
.page-home .room-chip-light,
.page-home .room-card-meta span,
.page-home .home-featured-meta span,
.page-chat .count-pill,
.page-chat .you-badge{
    background:var(--eye-primary-soft) !important;
    color:#cedae5 !important;
    border:1px solid rgba(121,145,171,.14) !important;
}

.role-badge.user,
.page-chat .role-badge.user{
    background:rgba(160,176,193,.12) !important;
    color:#d4dde7 !important;
}
.role-badge.guest,
.page-chat .role-badge.guest{
    background:var(--eye-warning-soft) !important;
    color:#e2cbab !important;
}
.role-badge.moderator,
.page-chat .role-badge.moderator{
    background:rgba(124,162,173,.14) !important;
    color:#cfe0e4 !important;
}
.role-badge.admin,
.page-chat .role-badge.admin{
    background:var(--eye-danger-soft) !important;
    color:#e0bac2 !important;
}

.flash.error,
.page-home .flash.error,
.page-chat .flash.error{
    background:var(--eye-danger-soft) !important;
    border:1px solid rgba(198,143,154,.24) !important;
    color:#e4c7ce !important;
}
.flash.success,
.page-home .flash.success,
.page-chat .flash.success{
    background:var(--eye-success-soft) !important;
    border:1px solid rgba(130,179,152,.24) !important;
    color:#d1e5d8 !important;
}

.dot{
    background:var(--eye-success) !important;
    box-shadow:0 0 0 4px rgba(130,179,152,.12) !important;
}
.priv-badge{
    background:linear-gradient(135deg,#9a7682,#b08e79) !important;
    color:#fff !important;
}

.cover-card,
.cover-card-light,
.page-home .cover-card-light{
    background-color:rgba(20,28,38,.76) !important;
    border:1px solid var(--eye-border) !important;
}
.cover-overlay,
.cover-overlay-light,
.page-home .cover-overlay-light{
    background:linear-gradient(180deg,rgba(9,13,18,.12),rgba(12,18,24,.70) 58%,rgba(14,21,29,.92)) !important;
}

.embedded-chat-frame{
    background:#0f161e !important;
    border:1px solid var(--eye-border) !important;
}

.conversation-tabs,
.page-chat .conversation-tabs,
.modal-head{
    border-bottom:1px solid var(--eye-border) !important;
}
.conversation-tab,
.tab-btn,
.page-home .tab-btn,
.page-chat .conversation-tab{
    background:rgba(255,255,255,.05) !important;
    border:1px solid var(--eye-border) !important;
    color:var(--eye-text) !important;
}
.tab-close:hover,
.page-chat .tab-close:hover{
    background:rgba(255,255,255,.08) !important;
}

.chat-status.ok,
.page-chat .chat-status.ok{
    color:#9dc5ab !important;
}
.chat-status.offline,
.page-chat .chat-status.offline{
    color:#d0a0aa !important;
}

.helper-box,
.settings-note-light,
.auth-hint-box,
.page-home .settings-note-light{
    background:rgba(121,145,171,.10) !important;
    border:1px dashed rgba(121,145,171,.22) !important;
    color:#ccd7e2 !important;
}

.page-home .hero-home-light::before,
.page-auth .auth-showcase-card::before{
    background:radial-gradient(circle,rgba(124,162,173,.18),rgba(124,162,173,0) 70%) !important;
}

.page-home .quick-stat-home strong,
.page-home .home-shortcut-card strong,
.page-auth .auth-feature-icon{
    color:#d9e4ee !important;
}

.page-auth .auth-shell-card .label,
.page-auth .auth-shell-card .check{
    color:var(--eye-muted) !important;
}
.page-auth .auth-shell-card .check input{
    accent-color:#7c9bac;
}

.page-chat .chat-tabs-layout.has-room-cover .conversation-shell,
.chat-tabs-layout.has-room-cover .conversation-shell{
    background-color:rgba(18,25,34,.68) !important;
}
.page-chat .chat-tabs-layout.has-room-cover .conversation-shell::after,
.chat-tabs-layout.has-room-cover .conversation-shell::after{
    background:linear-gradient(180deg,rgba(14,20,27,.18),rgba(16,24,32,.52) 45%,rgba(18,27,35,.82) 100%) !important;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-shell{
    background:transparent !important;
    background-color:transparent !important;
    background-image:none !important;
}
.page-chat .chat-tabs-layout.has-room-cover .chat-cover-area .conversation-shell::after{
    display:none !important;
}

::-webkit-scrollbar-thumb{
    background:rgba(140,160,178,.30);
    border-radius:999px;
}

/* home room list polish */
.page-home .room-listing-panel{
    padding:24px;
    border-radius:30px;
    background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(241,247,255,.92));
    border:1px solid rgba(128,166,212,.22);
    box-shadow:0 18px 48px rgba(53,104,167,.10);
}
.page-home .room-listing-panel .section-title-row{
    margin-bottom:2px;
}
.page-home .room-listing-panel .catalog-tabs{
    display:inline-flex;
    flex-wrap:wrap;
    gap:10px;
    padding:6px;
    border-radius:18px;
    align-self:flex-start; 
}
.page-home .room-listing-panel .tab-panel{
    width:100%;
}
.page-home .room-listing-panel .room-cover-grid-light{
    margin-top:2px;
}
.page-home .cover-card-light .room-card-inner{
    justify-content:flex-end;
}
.page-home .cover-card-light .room-card-meta{
    margin-top:auto;
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    padding-top:8px;
}
.page-home .cover-card-light .room-card-meta span{
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:10px 12px;
    border-radius:14px;
    background:rgba(10,18,28,.48) !important;
    color:#eef5ff !important;
    border:1px solid rgba(255,255,255,.14) !important;
    backdrop-filter:blur(10px);
    box-shadow:0 10px 24px rgba(10,18,28,.12);
}
@media (max-width: 720px){
    .page-home .room-listing-panel{
        padding:18px;
        border-radius:24px;
    }
    .page-home .cover-card-light .room-card-meta{
        grid-template-columns:1fr;
    }
}

/* Strona czatu ma pełnowymiarowe paski; ucinamy tylko przypadkowy overflow od sekcji full-bleed. */
.page-chat{
    overflow-x:clip;
}

/* Druga nawigacja — pełna szerokość jak górny pasek (chat-topbar-shell) */
.page-chat .room-footer-nav-section{
    grid-column:1 / -1;
    position:relative;
    left:50%;
    transform:translateX(-50%);
    width:100vw;
    max-width:100vw;
    margin-left:0;
    margin-right:0;
    margin-top:clamp(28px,4vw,48px);
    margin-bottom:8px;
    padding:0;
    box-sizing:border-box;
    min-width:0;
}
@supports (width: 100dvw){
    .page-chat .room-footer-nav-section{
        width:100dvw;
        max-width:100dvw;
    }
}
.page-chat .room-footer-nav-section.room-footer-nav-section--empty{
    display:none;
}
.page-chat.embed-mode .room-footer-nav-section{
    display:none;
}
.page-chat .room-footer-nav-bar{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    width:100%;
    margin:0;
    padding:0;
    border-radius:0 !important;
    border:none !important;
    border-top:1px solid var(--eye-border) !important;
    background:rgba(18,25,34,.78) !important;
    box-shadow:var(--eye-shadow) !important;
    backdrop-filter:blur(18px);
}
.page-chat .room-footer-nav-bar--empty .room-footer-nav-tabs:empty{
    min-height:0;
}
.page-chat .room-footer-nav-main{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    width:100%;
    min-width:0;
    gap:0;
}
.page-chat .room-footer-nav-toprow{
    display:flex;
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    width:100%;
    min-height:56px;
    padding:10px 18px;
    box-sizing:border-box;
    border-bottom:1px solid var(--eye-border) !important;
}
.page-chat .room-footer-nav-tabs{
    display:flex;
    flex-direction:row;
    flex-wrap:nowrap;
    align-items:center;
    gap:8px;
    flex:1 1 auto;
    min-width:0;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
    min-height:44px;
    padding:2px 0;
}
.page-chat .room-footer-nav-tab{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:0 18px;
    border-radius:0;
    border-top-right-radius:32px;
    border-bottom-left-radius:32px;
    font-size:13px;
    font-weight:700;
    letter-spacing:.01em;
    border:1px solid var(--eye-border) !important;
    background:transparent !important;
    color:var(--eye-text) !important;
    box-shadow:none !important;
    cursor:pointer;
    white-space:nowrap;
    transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease,color .16s ease;
}
.page-chat .room-footer-nav-tab:hover{
    background:rgba(255,255,255,.08) !important;
    border-color:var(--eye-border) !important;
    color:var(--eye-text) !important;
    transform:translateY(-1px);
}
.page-chat .room-footer-nav-tab:focus-visible{
    outline:2px solid rgba(124,162,173,.52);
    outline-offset:2px;
}
.page-chat .room-footer-nav-tab.is-active{
    background:rgba(255,255,255,.06) !important;
    border-color:var(--eye-border) !important;
    color:var(--eye-text) !important;
    box-shadow:none !important;
}
.page-chat .room-footer-nav-panels{
    min-height:48px;
    width:100%;
    padding:14px 18px 16px;
    box-sizing:border-box;
    border-radius:0;
    background:transparent;
    border:none;
    min-width:0;
    overflow-x:hidden;
}
.page-chat .room-footer-nav-panels:empty{
    display:none;
    min-height:0;
    padding:0;
}
.page-chat .room-footer-nav-bar--empty .room-footer-nav-toprow{
    border-bottom:none;
}
.page-chat .room-footer-nav-tab-panel[hidden]{
    display:none !important;
}
.page-chat .room-footer-nav-tab-html{
    font-size:.9rem;
    line-height:1.5;
    word-break:break-word;
    overflow-wrap:anywhere;
    color:var(--eye-text) !important;
}
.page-chat .room-footer-nav-tab-html img,
.page-chat .room-footer-nav-tab-html video,
.page-chat .room-footer-nav-tab-html iframe,
.page-chat .room-footer-nav-tab-html embed,
.page-chat .room-footer-nav-tab-html object{
    max-width:100%;
}
.page-chat .room-footer-nav-tab-html table{
    display:block;
    max-width:100%;
    overflow-x:auto;
}
.page-chat .room-footer-nav-tab-html a{
    color:#c7d4e3;
    font-weight:600;
}
.page-chat .room-footer-nav-tab-html a:hover{
    color:#edf3f8;
}
.page-chat .room-footer-nav-edit-btn{
    flex:0 0 auto;
    align-self:center;
    white-space:nowrap;
    min-height:42px;
    padding:0 20px;
    border-radius:999px;
    font-size:13px;
    font-weight:700;
    letter-spacing:.01em;
    border:1px solid var(--eye-border) !important;
    background:linear-gradient(135deg,#2a3542,#334556) !important;
    color:var(--eye-text) !important;
    box-shadow:0 10px 24px rgba(111,135,159,.12);
    transition:background .16s ease,border-color .16s ease,transform .16s ease,box-shadow .16s ease;
}
.page-chat .room-footer-nav-edit-btn:hover{
    background:linear-gradient(135deg,#323e4e,#3a4d60) !important;
    border-color:rgba(121,145,171,.22) !important;
    transform:translateY(-1px);
    box-shadow:0 12px 26px rgba(0,0,0,.18);
}
.page-chat .room-footer-nav-edit-btn:focus-visible{
    outline:2px solid rgba(124,162,173,.52);
    outline-offset:2px;
}
@media (max-width:900px){
    .page-chat .room-footer-nav-section{
        margin-top:clamp(22px,5vw,36px);
    }
    .page-chat .room-footer-nav-toprow{
        padding:10px 14px;
        min-height:52px;
        gap:10px;
    }
    .page-chat .room-footer-nav-tab{
        min-height:40px;
        padding:0 14px;
        font-size:12px;
    }
    .page-chat .room-footer-nav-edit-btn{
        min-height:40px;
        padding:0 14px;
        font-size:12px;
    }
    .page-chat .room-footer-nav-panels{
        padding:12px 14px 14px;
    }
}
.page-chat .room-footer-nav-rows{
    display:flex;
    flex-direction:column;
    gap:12px;
    margin-top:4px;
}
.page-chat .modal-room-edit .room-footer-nav-row,
.page-chat #roomFooterNavForm .room-footer-nav-row{
    display:grid;
    grid-template-columns:minmax(0,200px) minmax(0,1fr) auto;
    gap:10px 12px;
    align-items:start;
    padding:12px;
    border-radius:14px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.1);
}
.page-chat .modal-room-edit .room-footer-nav-row .room-footer-nav-remove,
.page-chat #roomFooterNavForm .room-footer-nav-row .room-footer-nav-remove{
    align-self:center;
    white-space:nowrap;
}
.page-chat .modal-room-edit .room-footer-nav-label,
.page-chat #roomFooterNavForm .room-footer-nav-label{
    display:flex;
    flex-direction:column;
    gap:5px;
}
.page-chat .modal-room-edit .room-footer-nav-label textarea,
.page-chat #roomFooterNavForm .room-footer-nav-label textarea{
    min-height:88px;
    resize:vertical;
    font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
    font-size:11px;
}
.page-chat .room-footer-nav-modal-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:12px;
}
@media (max-width:720px){
    .page-chat .room-footer-nav-bar{
        flex-wrap:wrap;
    }
    .page-chat .room-footer-nav-tabs{
        overflow-x:auto;
        flex-wrap:nowrap;
        -webkit-overflow-scrolling:touch;
        padding-bottom:4px;
        margin:0 -4px;
        padding-left:4px;
    }
    .page-chat .modal-room-edit .room-footer-nav-row,
    .page-chat #roomFooterNavForm .room-footer-nav-row{
        grid-template-columns:1fr;
    }
}

/* restore animated / gradient names after eye-friendly overrides */
.display-name.name-style-default,
.page-chat .display-name.name-style-default,
.page-home .display-name.name-style-default{
    color:inherit !important;
    background:none !important;
    -webkit-text-fill-color:currentColor;
    text-shadow:none !important;
    animation:none !important;
}
.display-name.name-style-violet,
.page-chat .display-name.name-style-violet,
.page-home .display-name.name-style-violet{
    background:linear-gradient(135deg,#b388ff 0%,#7c4dff 45%,#4fc3f7 100%) !important;
    background-size:200% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameGradientShift 6s ease-in-out infinite alternate !important;
    -webkit-animation:nameGradientShift 6s ease-in-out infinite alternate !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(124,77,255,.20) !important;
}
.display-name.name-style-gold,
.page-chat .display-name.name-style-gold,
.page-home .display-name.name-style-gold{
    background:linear-gradient(135deg,#fff3b0 0%,#ffd54f 30%,#ffb300 55%,#fff8dc 100%) !important;
    background-size:200% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameGradientShift 6s ease-in-out infinite alternate !important;
    -webkit-animation:nameGradientShift 6s ease-in-out infinite alternate !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(255,193,7,.18) !important;
}
.display-name.name-style-aqua,
.page-chat .display-name.name-style-aqua,
.page-home .display-name.name-style-aqua{
    background:linear-gradient(135deg,#9bf6ff 0%,#4dd0e1 40%,#00bcd4 100%) !important;
    background-size:200% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameGradientShift 6s ease-in-out infinite alternate !important;
    -webkit-animation:nameGradientShift 6s ease-in-out infinite alternate !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(0,188,212,.20) !important;
}
.display-name.name-style-ice,
.page-chat .display-name.name-style-ice,
.page-home .display-name.name-style-ice{
    background:linear-gradient(135deg,#e7f7ff 0%,#b9e8ff 35%,#7fd4ff 65%,#d7f4ff 100%) !important;
    background-size:220% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameGradientShift 5.5s ease-in-out infinite alternate !important;
    -webkit-animation:nameGradientShift 5.5s ease-in-out infinite alternate !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(118,206,255,.24) !important;
}
.display-name.name-style-rainbow,
.page-chat .display-name.name-style-rainbow,
.page-home .display-name.name-style-rainbow{
    background:linear-gradient(90deg,#ff6b6b,#ffd93d,#6bffb8,#57c4ff,#8f7bff,#ff6bcb,#ff6b6b) !important;
    background-size:300% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameRainbowShift 4s linear infinite !important;
    -webkit-animation:nameRainbowShift 4s linear infinite !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(255,255,255,.10) !important;
}
.display-name.name-style-sunset,
.page-chat .display-name.name-style-sunset,
.page-home .display-name.name-style-sunset{
    background:linear-gradient(135deg,#ffd180 0%,#ff8a65 35%,#ff5fa2 70%,#8b6bff 100%) !important;
    background-size:240% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameGradientShift 6.5s ease-in-out infinite alternate !important;
    -webkit-animation:nameGradientShift 6.5s ease-in-out infinite alternate !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(255,143,100,.22) !important;
}
.display-name.name-style-neon,
.page-chat .display-name.name-style-neon,
.page-home .display-name.name-style-neon{
    background:linear-gradient(135deg,#d4ff70 0%,#62ffb0 35%,#25e1ff 70%,#5ba7ff 100%) !important;
    background-size:230% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameGradientShift 5.2s ease-in-out infinite alternate !important;
    -webkit-animation:nameGradientShift 5.2s ease-in-out infinite alternate !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(98,255,176,.24) !important;
}
.display-name.name-style-berry,
.page-chat .display-name.name-style-berry,
.page-home .display-name.name-style-berry{
    background:linear-gradient(135deg,#ff9ad8 0%,#ff5fa2 35%,#b06cff 70%,#7b8dff 100%) !important;
    background-size:230% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameGradientShift 5.8s ease-in-out infinite alternate !important;
    -webkit-animation:nameGradientShift 5.8s ease-in-out infinite alternate !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(255,95,162,.22) !important;
}
.display-name.name-style-steel,
.page-chat .display-name.name-style-steel,
.page-home .display-name.name-style-steel{
    background:linear-gradient(135deg,#f4f8ff 0%,#dbe7ff 30%,#a5b9df 60%,#e9f1ff 100%) !important;
    background-size:220% 100% !important;
    -webkit-background-clip:text !important;
    background-clip:text !important;
    color:transparent !important;
    -webkit-text-fill-color:transparent !important;
    animation:nameGradientShift 6.2s ease-in-out infinite alternate !important;
    -webkit-animation:nameGradientShift 6.2s ease-in-out infinite alternate !important;
    will-change:background-position;
    text-shadow:0 0 18px rgba(182,204,240,.24) !important;
}

.side-divider{height:1px;background:rgba(255,255,255,.08);margin:16px 0}
.friend-list{gap:10px}
.friend-user{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);color:#dfe8ff;cursor:pointer;width:100%;text-align:left;min-width:0}
.friend-user:hover{background:rgba(255,255,255,.045)}
.friend-meta{display:flex;flex-direction:column;min-width:0;flex:1}
.friend-meta strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}
.friend-meta small{color:#9cabcf;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.friend-status-text{font-size:10px;line-height:1.25;opacity:.9}
.friend-right{display:flex;align-items:center;gap:6px;flex-shrink:1;min-width:0}
.friend-state{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:800;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:#dce6ff;max-width:104px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.friend-state.here{background:rgba(70,214,146,.14);border-color:rgba(70,214,146,.28);color:#bff5d7}
.friend-state.elsewhere{background:rgba(87,196,255,.14);border-color:rgba(87,196,255,.26);color:#c6efff}
.friend-state.offline{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.08);color:#c8d4ef}
.empty-side-note{padding:12px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);color:#9cabcf;font-size:13px}
.user-card{
    display:flex;
    flex-direction:column;
    gap:10px;
    padding:12px;
    border-radius:16px;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.06);
}
.user-card-head{
    display:flex;
    gap:12px;
    align-items:flex-start;
    min-width:0;
}
.user-card-main{
    min-width:0;
    flex:1;
    display:flex;
    flex-direction:column;
    gap:7px;
}
.user-card-name-row{
    min-width:0;
    font-size:16px;
    font-weight:800;
    line-height:1.2;
}
.user-card-name-row .display-name{
    display:inline-block;
    max-width:100%;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    vertical-align:top;
}
.user-card-meta{
    display:flex;
    flex-wrap:wrap;
    gap:7px;
    align-items:center;
}
.user-online-state{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:4px 10px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.09);
    background:rgba(255,255,255,.05);
    color:#dce6ff;
    font-size:11px;
    font-weight:800;
    line-height:1;
}
.user-online-state.is-here{
    background:rgba(70,214,146,.14);
    border-color:rgba(70,214,146,.28);
    color:#bff5d7;
}
.user-online-state.is-elsewhere{
    background:rgba(87,196,255,.14);
    border-color:rgba(87,196,255,.26);
    color:#c6efff;
}
.user-online-state.is-offline{
    background:rgba(255,255,255,.05);
    border-color:rgba(255,255,255,.1);
    color:#c8d4ef;
}
.user-note{
    font-size:13px;
    color:#9cabcf;
    line-height:1.5;
}
.user-note-soft{
    padding:8px 10px;
    border-radius:12px;
    background:rgba(87,196,255,.08);
    border:1px solid rgba(87,196,255,.2);
    color:#bcdfff;
    font-size:12px;
}
.action-btn.soft{background:rgba(255,255,255,.06)}
.action-btn.active-friend{background:rgba(87,196,255,.14);border-color:rgba(87,196,255,.24)}
.user-action-list{
    margin-top:12px;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
}
.user-action-list .action-btn{
    width:100%;
    min-height:42px;
    border-radius:13px;
    padding:11px 12px;
    font-size:13px;
    line-height:1.25;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-align:center;
}
.user-action-list .action-btn:disabled{
    opacity:.55;
    cursor:not-allowed;
    filter:saturate(.75);
}
.user-note-private-lock{
    background:rgba(255,255,255,.05);
    border-color:rgba(255,255,255,.12);
    color:#d9e3f8;
}
.page-chat .user-card{
    background:rgba(255,255,255,.08);
    border-color:rgba(141,171,211,.2);
}
.page-chat .user-note{
    color:#6c81a1;
}
.page-chat .user-note-soft{
    background:rgba(92,167,255,.12);
    border-color:rgba(92,167,255,.24);
    color:#d7ebff;
}
@media (max-width:620px){
    .user-card{
        padding:10px;
    }
    .user-card-head{
        gap:10px;
    }
    .user-action-list{
        grid-template-columns:1fr;
    }
}

.side-switcher{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px;min-width:0}
.side-switcher-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 8px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.025);color:#cfdaf2;font-weight:700;font-size:12px;cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .18s ease;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-switcher-btn:hover{background:rgba(255,255,255,.05);transform:translateY(-1px)}
.side-switcher-btn.active{background:rgba(87,196,255,.16);border-color:rgba(87,196,255,.28);color:#fff}
.side-switcher-btn .count-pill{min-width:20px;height:20px;padding:6px 6px 5px;font-size:11px}
.side-panel{display:none}
.side-panel.active{display:block}
.chat-toolstrip{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px;padding:4px 8px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}
.chat-toolstrip-left,.chat-toolstrip-right{display:flex;align-items:center;gap:8px;min-width:0}
.tool-btn{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);color:#eef4ff;font-weight:700;cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}
.tool-btn:hover{background:rgba(255,255,255,.05);transform:translateY(-1px)}
.tool-btn.is-disabled,.tool-btn:disabled{opacity:.55;cursor:not-allowed;transform:none !important}
.tool-btn .tool-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:0;background:transparent;font-size:22px;line-height:1}
.radio-toggle.is-on{background:transparent;border-color:transparent;box-shadow:none}
.radio-toggle.is-on .tool-icon{background:transparent;color:#7ce3a8}
.radio-toggle.is-off .tool-icon{background:transparent;color:#9cabcf;opacity:.9;position:relative}

.radio-toggle{padding:2px 4px;border:0;background:transparent;box-shadow:none}
.radio-toggle:hover{background:transparent;transform:none}
.radio-toggle.is-disabled,.radio-toggle:disabled{opacity:.45}
.radio-toggle.is-off .tool-icon::after{content:'';position:absolute;left:-1px;right:-1px;top:50%;height:2px;background:currentColor;transform:rotate(-30deg);transform-origin:center}
.radio-pop-wrap{position:relative;display:inline-flex;align-items:center}
.radio-popover{position:absolute;left:0;bottom:calc(100% + 8px);width:190px;padding:10px;border-radius:12px;background:rgba(12,18,34,.96);border:1px solid rgba(255,255,255,.12);box-shadow:0 14px 28px rgba(0,0,0,.32);display:flex;flex-direction:column;gap:8px;z-index:35}
.radio-popover::after{content:"";position:absolute;left:10px;top:100%;border:6px solid transparent;border-top-color:rgba(12,18,34,.96)}
.radio-power-btn{width:100%;justify-content:center}
.radio-volume-label{font-size:11px;font-weight:700;color:#9cabcf}
.radio-volume-range{width:100%;accent-color:#57c4ff;cursor:pointer}
.radio-volume-range:disabled{opacity:.45;cursor:not-allowed}
.page-chat .radio-popover{background:rgb(16 23 31);border-color:rgba(141,171,211,.24);box-shadow:0 16px 28px rgba(0,0,0,.34)}
.page-chat .radio-popover::after{border-top-color:rgb(16 23 31)}
.page-chat .radio-volume-label{color:#9cabcf}
.sr-only{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.chat-status{display:inline-flex;align-items:center;justify-content:center;min-width:20px;min-height:20px;padding:0;border:0;background:transparent;font-size:0;line-height:1}
.chat-status-icon{display:inline-flex;align-items:center;justify-content:center;width:8px;height:8px;border-radius:999px;background:currentColor;position:relative}
.chat-status.offline .chat-status-icon::after{content:'';position:absolute;left:-1px;right:-1px;top:50%;height:2px;background:currentColor;transform:rotate(-30deg);transform-origin:center}
.form-hint{margin-top:8px;font-size:12px;line-height:1.45;color:#9cabcf}
@media (max-width:900px){.chat-toolstrip{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px;padding:4px 8px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}.chat-toolstrip-left,.chat-toolstrip-right{display:flex;align-items:center;gap:8px;min-width:0}.side-switcher{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px;min-width:0}}
.page-chat .side-switcher-btn{background:rgba(255,255,255,.14);border-color:rgba(141,171,211,.2);color:#d9e6fb}
.page-chat .side-switcher-btn.active{background:rgba(92,167,255,.18);border-color:rgba(92,167,255,.3);color:#eef6ff}
.page-chat .chat-toolstrip{background:rgba(255,255,255,.08);border-color:rgba(141,171,211,.18)}
.page-chat .tool-btn{background:transparent;border-color:transparent;color:#dbe9ff}
.page-chat .tool-btn .tool-icon{background:transparent}
.page-chat .tool-btn:hover{background:transparent}
.page-chat .radio-toggle.is-on{background:transparent;border-color:transparent}
.page-chat .form-hint{color:#6c81a1}

.page-chat .friend-user{background:rgba(255,255,255,.08);border:1px solid rgba(141,171,211,.18);color:#e6f0ff}
.page-chat .friend-user:hover{background:rgba(255,255,255,.12)}

/* compact profile modal + avatar file picker */
.modal-profile{
    max-width:460px;
}
.modal-profile .modal-head{
    padding:8px 12px;
}
.modal-profile .modal-body{
    padding:8px 12px;
    gap:6px;
}
.modal-profile .grid-2{
    gap:6px;
}
.modal-profile .modal-title{
    font-size:16px;
}
.modal-profile .modal-sub{
    font-size:11px;
    margin-top:1px;
}
.modal-profile .label{
    margin-bottom:3px;
    font-size:11px;
}
.modal-profile .input{
    padding:8px 11px;
    border-radius:12px;
}
.modal-profile .textarea{
    min-height:64px;
}
.modal-profile .btn{
    padding:9px 12px;
    border-radius:12px;
}
.modal-profile .name-preview-box{
    margin-top:4px;
}
.modal-profile .profile-style-row{
    display:flex;
    align-items:center;
    gap:8px;
}
.modal-profile .profile-style-row .input{
    flex:0 0 52%;
}
.modal-profile .profile-style-row .name-preview-box{
    margin-top:0;
    flex:1;
    display:flex;
    align-items:center;
    justify-content:center;
    min-height: 45px;
    padding:8px 11px;
    border-radius:12px;
}

.avatar-file-input{
    padding:8px 11px;
    border-radius:12px;
    line-height:1.2;
    cursor:pointer;
    min-height:45px;
    height:45px;
    display:flex;
    align-items:center;
    box-sizing:border-box;
}
.avatar-file-input::file-selector-button{
    margin-right:10px;
    border:1px solid rgba(255,255,255,.14);
    background:linear-gradient(135deg,#25324b,#33486a);
    color:#eef5ff;
    padding:6px 10px;
    border-radius:8px;
    font-size:12px;
    font-weight:700;
    cursor:pointer;
    position:relative;
    top:-5px;
    left:-5px;
}
.avatar-file-input::-webkit-file-upload-button{
    margin-right:10px;
    border:1px solid rgba(255,255,255,.14);
    background:linear-gradient(135deg,#25324b,#33486a);
    color:#eef5ff;
    padding:6px 10px;
    border-radius:8px;
    font-size:12px;
    font-weight:700;
    cursor:pointer;
    position:relative;
    top:-5px;
    left:-5px;
}
.avatar-file-input:hover::file-selector-button,
.avatar-file-input:hover::-webkit-file-upload-button{
    filter:brightness(1.08);
}
.page-chat .avatar-file-input{
    background:rgba(8,13,22,.7);
    border-color:rgba(141,171,211,.26);
    color:#e6f2ff;
}
.page-chat .avatar-file-input::file-selector-button,
.page-chat .avatar-file-input::-webkit-file-upload-button{
    background:linear-gradient(135deg,#24384d,#2e5b82);
    border-color:rgba(141,171,211,.3);
}

@media (max-width:900px){
    .modal-profile{
        max-width:min(500px,94vw);
    }
    .modal-profile .grid-2{
        grid-template-columns:1fr;
    }
}

/* compact room edit modal (edycja czatu) */
.modal-room-edit{
    max-width:520px;
}
.modal-room-edit .modal-head{
    padding:10px 14px;
}
.modal-room-edit .modal-body{
    padding:10px 14px;
}
.modal-room-edit .modal-body.form-stack{
    gap:10px;
}
.modal-room-edit .modal-title{
    font-size:17px;
}
.modal-room-edit .modal-sub{
    font-size:12px;
    margin-top:2px;
}
.modal-room-edit .grid-2{
    gap:10px;
}
.modal-room-edit .label{
    margin-bottom:4px;
    font-size:12px;
}
.modal-room-edit .input{
    padding:8px 11px;
    border-radius:12px;
}
.modal-room-edit .textarea{
    min-height:52px;
}
.modal-room-edit .form-hint{
    margin-top:4px;
    font-size:11px;
}
.modal-room-edit .btn{
    padding:9px 12px;
    border-radius:12px;
    font-size:14px;
}
.modal-room-edit .icon-btn{
    width:34px;
    height:34px;
    font-size:20px;
    border-radius:11px;
}
.modal-room-edit .check{
    font-size:13px;
}
.modal-room-edit .room-edit-tabs{
    display:flex;
    gap:8px;
    margin-bottom:12px;
}
.modal-room-edit .room-edit-tabs .tab-btn{
    padding:8px 14px;
    border-radius:12px;
    font-size:13px;
    font-weight:700;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.04);
    color:inherit;
    cursor:pointer;
}
.modal-room-edit .room-edit-tabs .tab-btn.active{
    background:rgba(123,109,255,.25);
    border-color:rgba(123,109,255,.4);
}
.modal-room-edit .tab-panel{
    display:none;
}
.modal-room-edit .tab-panel.active{
    display:flex;
    flex-direction:column;
    gap:10px;
}
.modal-room-edit .tab-panel.form-stack + .btn{
    margin-top:8px;
}
.modal-room-edit .room-edit-card{
    padding:16px;
    border-radius:18px;
    background:rgba(255,255,255,.0);
    border:1px solid rgba(255,255,255,.07);
    display:flex;
    flex-direction:column;
    gap:12px;
}
.modal-room-edit .room-edit-card-head{
    display:flex;
    flex-direction:column;
    gap:4px;
}
.modal-room-edit .room-edit-card-head strong{
    font-size:15px;
}
.modal-room-edit .room-edit-card-head span{
    font-size:12px;
    color:#9cabcf;
    line-height:1.45;
}

/* edycja czatu — mobile */
@media (max-width:720px){
    .modal-backdrop-in-chat{
        align-items:flex-end;
        justify-content:center;
        padding:0 0 env(safe-area-inset-bottom,0);
        padding-top:max(8px, env(safe-area-inset-top,0));
    }
    .modal-backdrop-in-chat .modal-room-edit{
        width:100%;
        max-width:100%;
        max-height:min(92dvh,92vh);
        margin:0;
        border-radius:20px 20px 0 0;
        display:flex;
        flex-direction:column;
        overflow:hidden;
        box-shadow:0 -12px 40px rgba(0,0,0,.28);
    }
    .modal-backdrop-in-chat .modal-room-edit .modal-head{
        flex-shrink:0;
        padding:12px 14px;
    }
    .modal-backdrop-in-chat .modal-room-edit .modal-title{
        font-size:16px;
        line-height:1.25;
    }
    .modal-backdrop-in-chat .modal-room-edit .modal-sub{
        font-size:11px;
        line-height:1.35;
    }
    .modal-backdrop-in-chat .modal-room-edit .modal-body.form-stack{
        flex:1 1 auto;
        min-height:0;
        overflow-y:auto;
        -webkit-overflow-scrolling:touch;
        overscroll-behavior:contain;
        padding:10px 12px 14px;
        padding-bottom:calc(14px + env(safe-area-inset-bottom,0));
    }
    .modal-backdrop-in-chat .modal-room-edit .room-edit-tabs{
        display:grid;
        grid-template-columns:1fr 1fr;
        gap:6px;
        margin-bottom:10px;
    }
    .modal-backdrop-in-chat .modal-room-edit .room-edit-tabs .tab-btn{
        display:inline-flex;
        align-items:center;
        justify-content:center;
        width:100%;
        padding:8px 10px;
        font-size:12px;
        text-align:center;
    }
    .modal-backdrop-in-chat .modal-room-edit .grid-2,
    .modal-backdrop-in-chat .modal-room-edit .room-radio-grid{
        grid-template-columns:1fr;
    }
    .modal-backdrop-in-chat .modal-room-edit .room-edit-card{
        padding:12px;
        border-radius:14px;
    }
    .modal-backdrop-in-chat .modal-room-edit .room-edit-bans-inline{
        flex-direction:column;
        align-items:flex-start;
        gap:4px;
        margin-bottom:10px;
    }
    .modal-backdrop-in-chat .modal-room-edit .room-edit-bans-inline .room-edit-bans-hint{
        flex:unset;
    }
    .modal-backdrop-in-chat .modal-room-edit #roomEditForm > .btn.btn-primary[type="submit"]{
        width:100%;
        justify-content:center;
    }
}
@media (max-width:720px) and (max-height:480px){
    .modal-backdrop-in-chat .modal-room-edit{
        max-height:min(96dvh,96vh);
        border-radius:0;
    }
}

/* giphy picker + gif preview */
.giphy-pop-wrap{
    position:relative;
    display:inline-flex;
    align-items:center;
}
.giphy-toggle .tool-icon{
    width:auto;
    height:auto;
    font-size:11px;
    font-weight:800;
    letter-spacing:.04em;
    line-height:1;
}
.giphy-popover{
    position:absolute;
    right:0;
    bottom:calc(100% + 8px);
    width:min(340px,92vw);
    padding:10px;
    border-radius:12px;
    background:rgba(12,18,34,.96);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 14px 28px rgba(0,0,0,.32);
    display:flex;
    flex-direction:column;
    gap:8px;
    z-index:36;
}
.giphy-popover::after{
    content:"";
    position:absolute;
    right:10px;
    top:100%;
    border:6px solid transparent;
    border-top-color:rgba(12,18,34,.96);
}
.giphy-search-row{
    display:grid;
    grid-template-columns:1fr auto;
    gap:8px;
    align-items:center;
}
.giphy-search-input.input{
    padding:8px 10px;
    border-radius:10px;
}
.giphy-search-btn{
    padding:8px 10px;
    border-radius:10px;
}
.giphy-results{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    max-height:230px;
    overflow-y:auto;
    padding-right:2px;
}
.giphy-item{
    border:1px solid rgba(255,255,255,.12);
    border-radius:10px;
    padding:0;
    background:rgba(255,255,255,.04);
    cursor:pointer;
    overflow:hidden;
}
.giphy-item:hover{
    border-color:rgba(87,196,255,.45);
    transform:translateY(-1px);
}
.giphy-item img{
    width:100%;
    height:98px;
    object-fit:cover;
    display:block;
    background:rgba(8,12,20,.6);
}
.giphy-empty{
    grid-column:1 / -1;
    padding:10px;
    border-radius:10px;
    background:rgba(255,255,255,.04);
    border:1px dashed rgba(255,255,255,.12);
    color:#9cabcf;
    font-size:12px;
    text-align:center;
}
.gif-preview{
    position:relative;
    display:block;
    margin:4px 0 0;
    max-width:min(100%,170px);
    border-radius:10px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(8,12,20,.55);
}
.gif-preview img{
    display:block;
    width:100%;
    height:auto;
    max-height:140px;
    object-fit:cover;
}
.msg-gif-fav-btn{
    position:absolute;
    top:5px;
    right:5px;
    width:22px;
    height:22px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.28);
    background:rgba(8,12,20,.72);
    color:#95a8cc;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0;
    cursor:pointer;
    transition:background .16s ease,border-color .16s ease,color .16s ease;
}
.msg-gif-fav-btn:hover{
    background:rgba(17,31,49,.9);
    border-color:rgba(255,230,148,.68);
    color:#ffe28c;
}
.msg-gif-fav-btn.is-on{
    background:rgba(44,57,25,.85);
    border-color:rgba(255,222,125,.72);
    color:#ffd95a;
}
.msg-gif-fav-btn span{
    font-size:13px;
    line-height:1;
}
.page-chat .giphy-popover{
    background:rgb(16 23 31);
    border-color:rgba(141,171,211,.24);
    box-shadow:0 16px 28px rgba(0,0,0,.34);
}
.page-chat .giphy-popover::after{
    border-top-color:rgb(16 23 31);
}
.page-chat .gif-preview{
    background:rgba(16,23,31,.78);
    border-color:rgba(141,171,211,.22);
}
.page-chat .msg-gif-fav-btn{
    background:rgba(16,23,31,.86);
    border-color:rgba(141,171,211,.36);
    color:#b8c8e1;
}
.page-chat .msg-gif-fav-btn.is-on{
    color:#ffd45d;
    border-color:rgba(255,217,115,.78);
}
@media (max-width:900px){
    .giphy-results{
        grid-template-columns:repeat(2,minmax(0,1fr));
        max-height:200px;
    }
}

/* emoji picker */
.emoji-pop-wrap{
    position:relative;
    display:inline-flex;
    align-items:center;
}
.emoji-toggle{
    padding:2px 4px;
    border:0;
    background:transparent;
    box-shadow:none;
}
.emoji-toggle:hover{
    background:transparent;
    transform:none;
}
.emoji-popover{
    position:absolute;
    right:0;
    bottom:calc(100% + 8px);
    width:min(230px,86vw);
    padding:10px;
    border-radius:12px;
    background:rgba(12,18,34,.96);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 14px 28px rgba(0,0,0,.32);
    z-index:36;
}
.emoji-popover::after{
    content:"";
    position:absolute;
    right:10px;
    top:100%;
    border:6px solid transparent;
    border-top-color:rgba(12,18,34,.96);
}
.emoji-grid{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:6px;
}
.emoji-btn{
    border:1px solid rgba(255,255,255,.12);
    border-radius:10px;
    background:rgba(255,255,255,.04);
    color:#eef4ff;
    height:34px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-size:20px;
    line-height:1;
    cursor:pointer;
    transition:background .16s ease,border-color .16s ease,transform .16s ease;
}
.emoji-btn:hover{
    background:rgba(255,255,255,.10);
    border-color:rgba(87,196,255,.46);
    transform:translateY(-1px);
}
.emoji-btn:disabled{
    opacity:.45;
    cursor:not-allowed;
    transform:none;
}
.page-chat .emoji-popover{
    background:rgb(16 23 31);
    border-color:rgba(141,171,211,.24);
    box-shadow:0 16px 28px rgba(0,0,0,.34);
}
.page-chat .emoji-popover::after{
    border-top-color:rgb(16 23 31);
}
.page-chat .emoji-btn{
    background:rgba(255,255,255,.07);
    border-color:rgba(141,171,211,.24);
    color:#e6f1ff;
}
.page-chat .emoji-btn:hover{
    background:rgba(255,255,255,.12);
}

/* quick gif strip */
.chat-toolstrip-right{
    display:flex;
    align-items:center;
    gap:8px;
    min-width:0;
}
.quick-gif-bar{
    order:1;
    display:inline-flex;
    align-items:center;
    gap:4px;
    min-width:0;
    max-width:min(52vw,360px);
    overflow-x:auto;
    padding:1px 2px;
    scrollbar-width:thin;
}
.quick-gif-empty{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:34px;
    height:24px;
    border-radius:8px;
    border:1px dashed rgba(255,255,255,.18);
    color:#9fb0d2;
    font-size:9px;
    font-weight:800;
    letter-spacing:.06em;
    text-transform:uppercase;
    padding:0 6px 5px;
}
.quick-gif-btn{
    width:30px;
    height:24px;
    border-radius:8px;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.03);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0;
    cursor:pointer;
    flex:0 0 auto;
    overflow:hidden;
    transition:background .16s ease,border-color .16s ease,transform .16s ease;
}
.quick-gif-btn img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
}
.quick-emote-btn{
    width:30px;
    height:30px;
}
.quick-emote-btn img{
    width:30px !important;
    height:30px !important;
    min-width:30px !important;
    min-height:30px !important;
    max-width:30px !important;
    max-height:30px !important;
    object-fit:contain;
    padding:0;
}
.quick-gif-btn:hover{
    background:rgba(255,255,255,.08);
    border-color:rgba(87,196,255,.46);
    transform:translateY(-1px);
}
.quick-gif-btn:disabled{
    opacity:.45;
    cursor:not-allowed;
    transform:none;
}
.giphy-pop-wrap{order:2}
.emoji-pop-wrap{order:3}
.radio-pop-wrap{order:4}
.page-chat .quick-gif-btn{
    background:rgba(255,255,255,.07);
    border-color:rgba(141,171,211,.24);
}
.page-chat .quick-gif-btn:hover{
    background:rgba(255,255,255,.12);
}
.page-chat .quick-gif-empty{
    border-color:rgba(141,171,211,.28);
    color:#a8bad6;
}
@media (max-width:900px){
    .quick-gif-bar{
        max-width:46vw;
        gap:3px;
    }
    .quick-gif-btn{
        width:28px;
        height:22px;
    }
    .quick-emote-btn{
        width:30px;
        height:30px;
    }
    .quick-emote-btn img{
        width:30px !important;
        height:30px !important;
        min-width:30px !important;
        min-height:30px !important;
        max-width:30px !important;
        max-height:30px !important;
    }
    .quick-gif-empty{
        min-width:32px;
        height:22px;
        font-size:8px;
    }
}
/* keep offline overlay above whole conversation shell */
.conversation-shell{
    position:relative;
    overflow:hidden;
}
/* chat topbar drawer */
.chat-topbar-drawer{
    position:sticky;
    top:0;
    z-index:42;
}
.chat-drawer-toggle{
    width:42px;
    height:42px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.06);
    color:#eef4ff;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
}
.chat-drawer-toggle:hover{background:rgba(255,255,255,.12)}
.chat-drawer-toggle-icon{font-size:22px;line-height:1}
.chat-drawer-backdrop{
    position:fixed;
    inset:0;
    background:rgba(6,12,22,.52);
    opacity:0;
    pointer-events:none;
    transition:opacity .22s ease;
    z-index:70;
}
.chat-drawer-backdrop.is-open{
    opacity:1;
    pointer-events:auto;
}
.chat-drawer{
    position:fixed;
    top:12px;
    right:12px;
    width:min(320px,92vw);
    max-height:calc(100vh - 24px);
    overflow:auto;
    padding:14px;
    border-radius:16px;
    border:1px solid rgba(255,255,255,.14);
    background:rgba(16,22,40,.98);
    box-shadow:0 18px 42px rgba(0,0,0,.34);
    display:flex;
    flex-direction:column;
    gap:12px;
    transform:translateX(110%);
    opacity:0;
    pointer-events:none;
    transition:transform .24s ease,opacity .2s ease;
    z-index:72;
}
.chat-drawer.is-open{
    transform:translateX(0);
    opacity:1;
    pointer-events:auto;
}
.chat-drawer-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:8px;
}
.chat-drawer-head strong{font-size:16px}
.chat-drawer-close{
    width:34px;
    height:34px;
    border-radius:10px;
    font-size:22px;
}
.chat-drawer-nav{
    display:flex;
    flex-direction:column;
    gap:6px;
}
.chat-drawer-nav a,
.chat-drawer-link{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    padding:9px 10px;
    border-radius:10px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.04);
    color:#e9f1ff;
    font-weight:700;
}
.chat-drawer-link{cursor:pointer}
.chat-drawer-nav a:hover,
.chat-drawer-link:hover{background:rgba(255,255,255,.10)}
.chat-drawer-self{
    width:100%;
    justify-content:flex-start;
    border-radius:12px;
    padding:9px 10px;
}
body.chat-drawer-open{overflow:hidden}
.page-chat .chat-drawer-toggle{background:rgb(16 23 31);border-color:rgba(141,171,211,.30);color:#e6f1ff}
.page-chat .chat-drawer-toggle:hover{background:rgba(23,35,48,.98)}
.page-chat .chat-drawer{background:rgb(16 23 31);border-color:rgba(141,171,211,.24);color:#e6f1ff;box-shadow:0 20px 44px rgba(0,0,0,.42)}
.page-chat .chat-drawer-head strong{color:#e6f1ff}
.page-chat .chat-drawer-nav a,
.page-chat .chat-drawer-link,
.page-chat .chat-drawer-self{background:rgba(255,255,255,.05);border-color:rgba(141,171,211,.24);color:#dfeeff}
.page-chat .chat-drawer-nav a:hover,
.page-chat .chat-drawer-link:hover{background:rgba(255,255,255,.10)}
@media (max-width:700px){
    .chat-drawer{top:8px;right:8px;width:min(340px,96vw);max-height:calc(100vh - 16px)}
}

/* chat nav room description */
.chat-nav-meta{
    display:flex;
    flex-direction:column;
    min-width:0;
    max-width:min(72vw,680px);
}
.chat-nav-meta strong,
.chat-nav-meta small{
    max-width:100%;
}
.chat-nav-room-name{
    display:block;
}
.chat-nav-desc{
    display:block;
    font-size:12px;
    line-height:1.25;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.chat-nav-desc:empty{
    display:none;
}
@media (max-width:700px){
    .chat-nav-meta{max-width:58vw;}
    .chat-nav-desc{font-size:11px;}
}
/* giphy favorites tabs */
.giphy-tabs{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:6px;
}
.giphy-tab{
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.04);
    color:#dfe9ff;
    border-radius:9px;
    padding:7px 9px;
    font:inherit;
    font-size:12px;
    font-weight:700;
    cursor:pointer;
}
.giphy-tab.is-active{
    background:linear-gradient(135deg,#4f79ff,#57c4ff);
    border-color:transparent;
    color:#fff;
    box-shadow:0 10px 18px rgba(67,134,224,.28);
}
.giphy-card{
    position:relative;
    border:1px solid rgba(255,255,255,.12);
    border-radius:10px;
    overflow:hidden;
    background:rgba(255,255,255,.04);
}
.giphy-item{
    width:100%;
    display:block;
    border:0;
    border-radius:0;
    padding:0;
    margin:0;
    background:transparent;
    cursor:pointer;
}
.giphy-card:hover{
    border-color:rgba(87,196,255,.45);
    transform:translateY(-1px);
}
.giphy-fav-btn{
    position:absolute;
    top:5px;
    right:5px;
    width:22px;
    height:22px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.28);
    background:rgba(8,12,20,.72);
    color:#95a8cc;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0;
    cursor:pointer;
    transition:background .16s ease,border-color .16s ease,color .16s ease;
}
.giphy-fav-btn:hover{
    background:rgba(17,31,49,.9);
    border-color:rgba(255,230,148,.68);
    color:#ffe28c;
}
.giphy-fav-btn.is-on{
    background:rgba(44,57,25,.85);
    border-color:rgba(255,222,125,.72);
    color:#ffd95a;
}
.giphy-fav-btn span{
    font-size:13px;
    line-height:1;
}
.page-chat .giphy-tab{
    background:rgba(247,251,255,.92);
    border-color:rgba(126,165,212,.24);
    color:#234b75;
}
.page-chat .giphy-tab.is-active{
    background:linear-gradient(135deg,#2f80ed,#66b8ff);
    color:#fff;
    box-shadow:0 10px 18px rgba(47,128,237,.2);
}
.page-chat .giphy-card{
    background:rgba(255,255,255,.08);
    border-color:rgba(141,171,211,.24);
}
.page-chat .giphy-fav-btn{
    background:rgba(16,23,31,.86);
    border-color:rgba(141,171,211,.36);
    color:#b8c8e1;
}
.page-chat .giphy-fav-btn.is-on{
    color:#ffd45d;
    border-color:rgba(255,217,115,.78);
}
/* force right align for top chat action buttons */
.chat-actions-right{
    margin-left:auto;
    width:100%;
    justify-content:flex-end !important;
}
@media (max-width:900px){
    .chat-actions-right{
        justify-content:flex-end !important;
    }
}
/* embed: dopasowanie do dowolnego rozmiaru iframe */
html.embed-root,
html.embed-root body.page-chat-embed{
    height:100%;
    margin:0;
    overflow:hidden;
}
body.page-chat-embed,
.page-chat.page-chat-embed{
    background:transparent !important;
}
.page-chat-embed .app-shell.embed-mode.chat-compact-layout,
.page-chat-embed .app-shell.embed-mode{
    max-width:100% !important;
    width:100% !important;
    height:100% !important;
    min-height:0 !important;
    margin:0 !important;
    padding:0 !important;
    gap:0 !important;
    grid-template-columns:1fr !important;
    grid-template-rows:1fr !important;
    align-items:stretch !important;
    background:transparent !important;
}
.page-chat-embed .chat-panel,
.page-chat-embed .compact-chat-panel,
.page-chat-embed .tabs-chat-panel{
    border-radius:0 !important;
    margin:0 !important;
    min-height:0 !important;
    height:100% !important;
    display:grid !important;
    grid-template-rows:auto auto 1fr auto !important;
}
.page-chat-embed .chat-header{
    padding:0 8px 10px !important;
}
.page-chat-embed .conversation-shell{
    min-height:0 !important;
    overflow:hidden !important;
    display:flex !important;
    flex-direction:column !important;
}
.page-chat-embed .conversation-shell > .conversation-panel{
    flex:1 1 auto !important;
    min-height:0 !important;
    display:flex !important;
    flex-direction:column !important;
    overflow:hidden !important;
}
.page-chat-embed .conversation-panel .messages{
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow:auto !important;
}
/* embed: users side panel as slide-out drawer */
.embed-users-backdrop{
    display:none;
}
.page-chat-embed .embed-users-backdrop{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(6,12,22,.52);
    opacity:0;
    pointer-events:none;
    transition:opacity .22s ease;
    z-index:73;
}
.page-chat-embed .embed-users-backdrop.is-open{
    opacity:1;
    pointer-events:auto;
}
.page-chat-embed .embed-users-toggle{
    display:inline-flex;
    padding:2px 4px;
    border:0;
    background:transparent;
    box-shadow:none;
}
.page-chat-embed .embed-users-toggle:hover{
    background:transparent;
    transform:none;
}
.page-chat-embed .embed-users-toggle .tool-icon{
    width:20px;
    height:20px;
    font-size:20px;
    color:#dbe9ff;
}
.page-chat-embed .embed-users-toggle[aria-expanded="true"] .tool-icon{
    color:#7ce3a8;
}
.page-chat-embed .rightbar.compact-rightbar{
    position:fixed !important;
    top:0;
    right:0;
    width:min(280px,86vw);
    height:100vh;
    margin:0 !important;
    border-radius:0 !important;
    border-left:1px solid rgba(141,171,211,.24);
    border-top:0;
    border-right:0;
    border-bottom:0;
    background:rgb(16 23 31);
    box-shadow:-16px 0 30px rgba(0,0,0,.38);
    z-index:74;
    transform:translateX(104%);
    transition:transform .24s ease;
    padding:12px !important;
    overflow:auto;
}
.page-chat-embed .rightbar.compact-rightbar.is-open{
    transform:translateX(0);
}
.page-chat-embed .embed-users-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:8px;
    margin-bottom:8px;
}
.page-chat-embed .embed-users-head strong{
    font-size:15px;
    color:#e6f1ff;
}
.page-chat-embed .embed-users-close{
    width:32px;
    height:32px;
    border-radius:10px;
    font-size:22px;
    background:rgba(255,255,255,.06);
    border-color:rgba(141,171,211,.24);
}
body.embed-users-open{
    overflow:hidden;
}
/* mobile polish for chat */
@media (max-width:900px){
    .page-chat .chat-topbar-shell{
        margin:0 !important;
        padding:10px 12px !important;
        border-radius:0;
        flex-direction:row !important;
        align-items:center !important;
        justify-content:space-between !important;
        flex-wrap:nowrap !important;
        gap:10px !important;
    }
    .page-chat .chat-topbar-shell .brand-link{
        min-width:0;
        flex:1 1 auto;
    }
    .page-chat .chat-topbar-shell .chat-drawer-toggle{
        margin-left:auto;
        flex:0 0 auto;
    }
    .page-chat .chat-topbar-shell .brand-logo{
        width:44px;
        height:44px;
        border-radius:12px;
        font-size:18px;
    }
    .page-chat .chat-nav-meta{
        max-width:calc(100vw - 120px);
    }
    .page-chat .chat-nav-desc{
        display:block;
        font-size:11px;
        line-height:1.2;
        white-space:nowrap;
        overflow:hidden;
        text-overflow:ellipsis;
    }
    .page-chat .chat-compact-layout{
        width:calc(100% - 8px) !important;
        max-width:calc(100% - 8px) !important;
        margin:0 auto 10px !important;
        gap:8px !important;
    }
    .page-chat .chat-compact-layout .compact-chat-panel,
    .page-chat .chat-compact-layout .compact-rightbar{
        padding:10px !important;
        border-radius:14px !important;
    }
    .page-chat .conversation-tabs{
        padding:4px 0 8px;
        gap:6px;
    }
    .page-chat .conversation-tab{
        padding:7px 10px;
        font-size:12px;
        min-height:34px;
    }
    .page-chat .chat-actions-right{
        gap:6px !important;
    }
    .page-chat .chat-actions-right .btn.tiny{
        padding:6px 8px !important;
        font-size:11px !important;
    }
    .page-chat .private-panel .messages,
    .page-chat #publicPanel .messages{
        height:50vh !important;
        min-height:50vh;
        max-height:50vh;
    }
    .page-chat .chat-toolstrip{
        padding:4px 6px;
        gap:6px;
        flex-wrap:nowrap;
        overflow:visible;
        scrollbar-width:thin;
    }
    .page-chat .chat-toolstrip-left,
    .page-chat .chat-toolstrip-right{
        gap:6px;
        flex-wrap:nowrap;
        overflow:visible;
    }
    .page-chat .chat-toolstrip-right{
        min-width:0;
        margin-left:auto;
    }
    .page-chat .quick-gif-bar{
        flex:0 1 42vw;
        max-width:42vw;
    }
    .page-chat .quick-gif-btn{
        width:24px;
        height:20px;
        border-radius:6px;
    }
    .page-chat .quick-emote-btn{
        width:30px;
        height:30px;
    }
    .page-chat .quick-emote-btn img{
        width:30px !important;
        height:30px !important;
        min-width:30px !important;
        min-height:30px !important;
        max-width:30px !important;
        max-height:30px !important;
    }
    .page-chat .quick-gif-empty{
        min-width:28px;
        height:20px;
        font-size:7px;
        padding:0 4px;
    }
    .page-chat .tool-btn{
        padding:2px 4px;
    }
    .page-chat .tool-btn .tool-icon{
        font-size:20px;
        width:16px;
        height:16px;
    }
    .page-chat .giphy-popover{
        width:min(320px,92vw);
        right:0;
        left:auto;
    }
    .page-chat .emoji-popover{
        width:min(220px,92vw);
        right:0;
        left:auto;
    }
    .page-chat .radio-popover{
        right:0;
        left:auto;
    }
    .page-chat .giphy-popover::after,
    .page-chat .emoji-popover::after,
    .page-chat .radio-popover::after{
        right:10px;
        left:auto;
    }
    .page-chat .emoji-btn{
        height:30px;
        font-size:18px;
        border-radius:8px;
    }
    .page-chat .emoji-btn.emoji-image-btn{
        height:44px;
    }
    .page-chat .emoji-btn.emoji-image-btn img{
        width:30px !important;
        height:30px !important;
        max-width:30px !important;
        max-height:30px !important;
    }
    .page-chat .tabs-composer{
        margin-top:8px;
    }
    .page-chat .chat-compact-layout .compact-composer{
        grid-template-columns:1fr 37px auto !important;
        gap:8px !important;
        padding-top:8px !important;
    }
    .page-chat .chat-compact-layout .compact-composer .input{
        padding:10px 12px !important;
        min-height:40px;
    }
    .page-chat .chat-compact-layout .compact-composer .btn{
        padding:10px 8px !important;
        border-radius:10px !important;
        font-size:13px !important;
    }
    .page-chat .chat-compact-layout .compact-composer .composer-send-btn{
        width:37px !important;
        min-width:37px !important;
        max-width:37px !important;
        height:60px !important;
        padding:0 !important;
    }
    .page-chat .chat-compact-layout .compact-rightbar{
        max-height:36vh;
        overflow:auto;
    }
}

@media (max-width:560px){
    .page-chat .chat-compact-layout{
        width:100% !important;
        max-width:100% !important;
        margin:0 !important;
        border-radius:0 !important;
    }
    .page-chat .chat-compact-layout .compact-chat-panel,
    .page-chat .chat-compact-layout .compact-rightbar{
        border-radius:0 !important;
    }
    .page-chat .conversation-shell{
        border-radius:14px 14px 0 0;
        padding:4px 5px;
    }
    .page-chat .private-panel .messages,
    .page-chat #publicPanel .messages{
        height:48vh !important;
        min-height:48vh;
        max-height:48vh;
    }
    .page-chat .chat-toolstrip{
        border-radius:8px;
    }
    .page-chat .quick-gif-bar{
        max-width:38vw;
    }
    .page-chat .chat-nav-meta{
        max-width:calc(100vw - 100px);
    }
}
/* tabs attached to chat field – jedno tło: pole wiadomości i zakładki Czat/priv */
.page-chat:not(.page-chat-embed) .conversation-shell,
.page-chat:not(.page-chat-embed) .conversation-tabs{
    background:var(--eye-panel) !important;
}
.page-chat:not(.page-chat-embed) .tabs-chat-panel{
    display:flex !important;
    flex-direction:column;
}
.page-chat:not(.page-chat-embed) .conversation-shell{
    flex:1 1 auto;
    min-height:0;
    border-radius:12px 12px 0 0 !important;
    border-bottom:0 !important;
    padding:6px 8px 2px !important;
}
.page-chat:not(.page-chat-embed) .conversation-tabs{
    display:flex;
    align-items:flex-start;
    gap:4px;
    flex-wrap:nowrap;
    overflow-x:auto;
    margin-top:0;
    padding:2px 8px 6px;
    min-height:34px;
    border:1px solid var(--eye-border) !important;
    border-top:none !important;
    border-radius:0 0 0 0;
    box-shadow:var(--eye-shadow) !important;
    scrollbar-width:thin;
}
.page-chat:not(.page-chat-embed) .dynamic-tabs{
    display:flex;
    align-items:flex-start;
    gap:4px;
    flex-wrap:nowrap;
}
.page-chat:not(.page-chat-embed) .conversation-tab{
    min-height:30px;
    padding:6px 10px 5px;
    border-radius:0 0 8px 8px;
    border-top:0 !important;
    gap:6px;
    line-height:1;
    white-space:nowrap;
    background:transparent !important;
    border:1px solid var(--eye-border) !important;
    color:var(--eye-text) !important;
    box-shadow:none !important;
}
.page-chat:not(.page-chat-embed) .conversation-tab.active{
    background:rgba(255,255,255,.06) !important;
    border-color:var(--eye-border) !important;
    color:var(--eye-text) !important;
    box-shadow:none !important;
}
.page-chat:not(.page-chat-embed) .conversation-tab .tab-label{
    display:inline-flex;
    align-items:center;
    font-weight:700;
}
.page-chat:not(.page-chat-embed) .tab-close{
    width:16px;
    height:16px;
    margin-left:4px;
    border-radius:5px;
    background:rgba(255,255,255,.08);
    color:#b6c9e6;
    font-size:11px;
}
.page-chat:not(.page-chat-embed) .tab-close:hover{
    background:rgba(255,255,255,.16) !important;
}
.page-chat:not(.page-chat-embed) .chat-toolstrip {
    margin-top: 0;
    border-top: 1px solid rgba(141, 171, 211, .22);
    border-bottom: 0 !important;
    border-radius: 0;
    background: rgb(30 37 47) !important;
    border-left: 1px solid rgba(141, 171, 211, .24);
    border-right: 1px solid rgba(141, 171, 211, .24);
}
.page-chat:not(.page-chat-embed) .tabs-composer{
    margin-top:0;
    padding:8px 8px 6px;
    border-left:1px solid var(--eye-border) !important;
    border-right:1px solid var(--eye-border) !important;
    border-top:0 !important;
    border-bottom:1px solid var(--eye-border) !important;
    border-radius:0 0 10px 10px;
    background:rgb(16 23 31) !important;
}
.page-chat:not(.page-chat-embed) .tabs-composer .input{
    background:rgba(8,13,22,.78) !important;
    border-color:rgba(141,171,211,.26) !important;
    color:#e6f2ff !important;
}
@media (max-width:900px){
    .page-chat:not(.page-chat-embed) .conversation-shell{
        border-radius:10px 10px 0 0 !important;
        padding:5px 6px 2px !important;
    }
    .page-chat:not(.page-chat-embed) .conversation-tabs{
        min-height:30px;
        padding:0 6px 5px;
        gap:3px;
    }
    .page-chat:not(.page-chat-embed) .dynamic-tabs{
        gap:3px;
    }
    .page-chat:not(.page-chat-embed) .conversation-tab{
        min-height:28px;
        padding:4px 8px 5px;
        font-size:12px;
    }
}

/* custom emoticons from folder */
.emoji-popover{
    width:min(320px,92vw);
}
.emoji-tabs{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
    margin-bottom:8px;
}
.emoji-page-tab{
    border:1px solid rgba(255,255,255,.12);
    border-radius:999px;
    background:rgba(255,255,255,.04);
    color:#dfeaff;
    padding:5px 9px;
    font-size:11px;
    font-weight:700;
    cursor:pointer;
    transition:background .16s ease,border-color .16s ease,color .16s ease;
}
.emoji-page-tab:hover{
    background:rgba(255,255,255,.08);
}
.emoji-page-tab.is-active{
    background:rgba(87,196,255,.16);
    border-color:rgba(87,196,255,.34);
    color:#f5fbff;
}
.emoji-page-panel{
    display:grid;
}
.emoji-empty{
    padding:10px 8px;
    color:#9fb0d2;
    font-size:13px;
    line-height:1.45;
}
.emoji-btn.emoji-image-btn{
    height:44px;
    padding:4px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
}
.emoji-btn.emoji-image-btn img{
    width:30px !important;
    height:30px !important;
    max-width:30px !important;
    max-height:30px !important;
    min-width:30px !important;
    min-height:30px !important;
    object-fit:contain;
    pointer-events:none;
}
.page-chat .emoji-page-tab{
    background:rgba(255,255,255,.07);
    border-color:rgba(141,171,211,.24);
    color:#dfeaff;
}
.page-chat .emoji-page-tab.is-active{
    background:rgba(87,196,255,.16);
    border-color:rgba(87,196,255,.34);
    color:#f5fbff;
}
.chat-emote{
    display:inline-block;
    width:30px !important;
    height:30px !important;
    min-width:30px !important;
    min-height:30px !important;
    max-width:30px !important;
    max-height:30px !important;
    margin:0 2px;
    vertical-align:middle;
    object-fit:contain;
    transform:translateY(-1px);
    box-sizing:border-box;
}
.msg-text .chat-emote{
    width:30px !important;
    height:30px !important;
    min-width:30px !important;
    min-height:30px !important;
    max-width:30px !important;
    max-height:30px !important;
}

.emoji-category-tabs{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
    margin-bottom:8px;
    padding-bottom:8px;
    border-bottom:1px solid rgba(141,171,211,.18);
}
.emoji-category-tab{
    border:1px solid rgba(141,171,211,.24);
    border-radius:999px;
    background:rgba(17,24,35,.92);
    color:#dfeaff;
    padding:6px 10px;
    font-size:11px;
    font-weight:800;
    letter-spacing:.02em;
    cursor:pointer;
    transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease;
}
.emoji-category-tab:hover{
    background:rgba(34,45,63,.96);
    transform:translateY(-1px);
}
.emoji-category-tab.is-active{
    background:linear-gradient(135deg,rgba(90,125,255,.22),rgba(255,87,87,.16));
    border-color:rgba(128,166,255,.38);
    color:#f8fbff;
}
.emoji-category-panel{
    display:block;
}
.emoji-category-panel.hidden{
    display:none;
}
.emoji-effect-btn{
    border-color:rgba(255,167,86,.34) !important;
    background:linear-gradient(180deg,rgba(46,32,22,.96),rgba(26,19,15,.96)) !important;
    box-shadow:inset 0 0 0 1px rgba(255,214,168,.06);
}
.emoji-effect-btn:hover{
    border-color:rgba(255,197,120,.5) !important;
    box-shadow:0 10px 18px rgba(0,0,0,.24), inset 0 0 0 1px rgba(255,221,180,.1);
}
.chat-effect-overlay{
    position:fixed;
    inset:0;
    z-index:2400;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:18px;
}
.chat-effect-backdrop{
    position:absolute;
    inset:0;
    background:rgba(4,8,14,.82);
    backdrop-filter:blur(4px);
}
.chat-effect-stage{
    position:relative;
    z-index:1;
    width:min(1080px,100%);
    height:min(78vh,760px);
    border-radius:22px;
    border:1px solid rgba(141,171,211,.26);
    background:radial-gradient(circle at top, rgba(69,98,170,.18), transparent 58%), rgba(10,15,24,.94);
    box-shadow:0 30px 80px rgba(0,0,0,.45);
    overflow:hidden;
}
.chat-effect-frame{
    width:100%;
    height:100%;
    border:0;
    background:transparent;
}
.chat-effect-meta{
    position:absolute;
    top:14px;
    left:50%;
    transform:translateX(-50%);
    z-index:2;
    max-width:min(82vw,680px);
    padding:8px 14px;
    border-radius:999px;
    background:rgba(12,18,28,.82);
    border:1px solid rgba(141,171,211,.24);
    color:#eef5ff;
    font-size:13px;
    font-weight:700;
    text-align:center;
    pointer-events:none;
    box-shadow:0 8px 20px rgba(0,0,0,.22);
}
.chat-effect-close{
    position:absolute;
    top:14px;
    right:14px;
    z-index:2;
    width:38px;
    height:38px;
    border-radius:999px;
    border:1px solid rgba(141,171,211,.24);
    background:rgba(9,13,20,.82);
    color:#f4f8ff;
    font-size:26px;
    line-height:1;
    cursor:pointer;
}
body.chat-effect-open{
    overflow:hidden;
}
@media (max-width:720px){
    .chat-effect-overlay{
        padding:10px;
    }
    .chat-effect-stage{
        width:100%;
        height:min(62vh,460px);
        border-radius:16px;
    }
    .chat-effect-meta{
        top:10px;
        max-width:calc(100% - 84px);
        font-size:12px;
        padding:7px 12px;
    }
    .chat-effect-close{
        top:10px;
        right:10px;
        width:34px;
        height:34px;
        font-size:22px;
    }
}
/* chat effect picker */
.effect-pop-wrap{
    position:relative;
    display:inline-flex;
    align-items:center;
}
.effect-toggle{
    padding:2px 4px;
    border:0;
    background:transparent;
    box-shadow:none;
}
.effect-toggle:hover{
    background:transparent;
    transform:none;
}
.effect-popover{
    position:absolute;
    right:0;
    bottom:calc(100% + 8px);
    width:min(320px,92vw);
    padding:10px;
    border-radius:12px;
    background:rgba(12,18,34,.96);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 14px 28px rgba(0,0,0,.32);
    display:flex;
    flex-direction:column;
    gap:8px;
    z-index:36;
}
.effect-popover::after{
    content:"";
    position:absolute;
    right:10px;
    top:100%;
    border:6px solid transparent;
    border-top-color:rgba(12,18,34,.96);
}
.effect-tabs{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
}
.effect-page-tab{
    border:1px solid rgba(255,255,255,.12);
    border-radius:999px;
    background:rgba(255,255,255,.04);
    color:#dfeaff;
    padding:5px 9px;
    font-size:11px;
    font-weight:700;
    cursor:pointer;
    transition:background .16s ease,border-color .16s ease,color .16s ease;
}
.effect-page-tab:hover{
    background:rgba(255,255,255,.08);
}
.effect-page-tab.is-active{
    background:rgba(87,196,255,.16);
    border-color:rgba(87,196,255,.34);
    color:#f5fbff;
}
.effect-grid{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:8px;
    max-height:280px;
    overflow-y:auto;
    padding-right:2px;
}
.effect-thumb-btn{
    border:1px solid rgba(255,255,255,.12);
    border-radius:12px;
    padding:4px;
    background:rgba(255,255,255,.04);
    cursor:pointer;
    overflow:hidden;
    transition:background .16s ease,border-color .16s ease,transform .16s ease;
}
.effect-thumb-btn:hover{
    background:rgba(255,255,255,.08);
    border-color:rgba(87,196,255,.34);
    transform:translateY(-1px);
}
.effect-thumb-btn:disabled{
    opacity:.45;
    cursor:not-allowed;
    transform:none;
}
.effect-thumb-btn img{
    display:block;
    width:100%;
    height:45px;
    object-fit:cover;
    border-radius:8px;
    pointer-events:none;
    background:rgba(8,12,20,.55);
}
.effect-empty{
    padding:10px;
    border-radius:10px;
    background:rgba(255,255,255,.04);
    border:1px dashed rgba(255,255,255,.12);
    color:#9cabcf;
    font-size:12px;
    text-align:center;
}
.page-chat .effect-popover{
    background:rgb(16 23 31);
    border-color:rgba(141,171,211,.24);
    box-shadow:0 16px 28px rgba(0,0,0,.34);
}
.page-chat .effect-popover::after{
    border-top-color:rgb(16 23 31);
}
.page-chat .effect-page-tab{
    background:rgba(255,255,255,.07);
    border-color:rgba(141,171,211,.24);
    color:#dfeaff;
}
.page-chat .effect-page-tab.is-active{
    background:rgba(87,196,255,.16);
    border-color:rgba(87,196,255,.34);
    color:#f5fbff;
}
.page-chat .effect-thumb-btn{
    background:rgba(255,255,255,.07);
    border-color:rgba(141,171,211,.24);
}
.page-chat .effect-thumb-btn:hover{
    background:rgba(255,255,255,.12);
}
.giphy-pop-wrap{order:2}
.effect-pop-wrap{order:3}
.emoji-pop-wrap{order:4}
.radio-pop-wrap{order:5}
@media (max-width:900px){
    .effect-grid{
        grid-template-columns:repeat(5,minmax(0,1fr));
        gap:6px;
        max-height:220px;
    }
    .effect-thumb-btn img{
        height:48px;
    }
}
/* chat effect overlay refresh */
.chat-effect-overlay{
    padding:0;
}
.chat-effect-backdrop{
    background:rgba(8,12,18,.74);
    backdrop-filter:blur(3px) saturate(.92);
}
.chat-effect-stage{
    width:100%;
    height:100%;
    border-radius:0;
    border:0;
    background:transparent;
    box-shadow:none;
    overflow:visible;
    display:flex;
    align-items:center;
    justify-content:center;
}
.chat-effect-frame{
    width:min(1100px,100%);
    height:min(78vh,760px);
    background:transparent;
    filter:drop-shadow(0 18px 38px rgba(0,0,0,.24));
}
.chat-effect-meta{
    top:18px;
    max-width:min(86vw,720px);
    background:rgba(10,14,20,.62);
    border-color:rgba(141,171,211,.18);
    box-shadow:none;
}
.chat-effect-close{
    top:18px;
    right:18px;
    width:36px;
    height:36px;
    border-color:rgba(255,255,255,.10);
    background:rgba(10,14,20,.48);
    font-size:24px;
}
@media (max-width:720px){
    .chat-effect-stage{
        align-items:flex-start;
        padding-top:58px;
    }
    .chat-effect-frame{
        width:100%;
        height:min(58vh,460px);
        filter:none;
    }
    .chat-effect-meta{
        top:10px;
        max-width:calc(100% - 86px);
    }
    .chat-effect-close{
        top:10px;
        right:10px;
    }
}
/* effect composer modal */
.effect-composer-modal{
    width:min(92vw,520px);
    max-width:520px;
    background:linear-gradient(180deg,rgba(18,25,34,.98),rgba(12,18,25,.98));
    border:1px solid rgba(141,171,211,.22);
    box-shadow:0 22px 44px rgba(0,0,0,.34);
}
.effect-composer-preview{
    display:flex;
    align-items:center;
    gap:14px;
    padding:12px;
    border-radius:16px;
    border:1px solid rgba(141,171,211,.16);
    background:rgba(255,255,255,.04);
}
.effect-composer-thumb{
    width:78px;
    height:78px;
    flex:0 0 78px;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    border-radius:18px;
    background:rgba(7,11,18,.88);
    border:1px solid rgba(141,171,211,.18);
}
.effect-composer-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.effect-composer-copy{
    display:grid;
    gap:6px;
    min-width:0;
}
.effect-composer-copy strong{
    font-size:16px;
    color:#f1f6ff;
}
.effect-composer-copy span{
    color:#9fb0cf;
    font-size:13px;
    line-height:1.45;
}
.effect-color-row{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:10px;
}
.effect-color-btn{
    width:28px;
    height:28px;
    padding:0;
    border-radius:999px;
    border:2px solid rgba(255,255,255,.12);
    background:var(--effect-color,#ffffff);
    box-shadow:0 0 0 1px rgba(7,11,18,.46) inset;
    cursor:pointer;
}
.effect-color-btn.is-active{
    transform:scale(1.08);
    border-color:#f5fbff;
    box-shadow:0 0 0 3px rgba(87,196,255,.22);
}
.effect-color-custom{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:6px 10px;
    border-radius:999px;
    border:1px solid rgba(141,171,211,.2);
    background:rgba(255,255,255,.04);
    color:#dce7fb;
    font-size:12px;
    font-weight:700;
}
.effect-color-custom input{
    width:32px;
    height:32px;
    padding:0;
    border:0;
    background:transparent;
    cursor:pointer;
}
.effect-composer-sample{
    margin-top:12px;
    min-height:52px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:12px 14px;
    border-radius:16px;
    border:1px dashed rgba(141,171,211,.24);
    background:rgba(7,11,18,.74);
    color:#ffffff;
    font-size:18px;
    font-weight:800;
    text-align:center;
    letter-spacing:.01em;
    text-shadow:0 0 18px rgba(0,0,0,.32);
}
.effect-composer-actions{
    display:flex;
    justify-content:flex-end;
    gap:10px;
}
.chat-effect-backdrop{
    background:rgba(7,11,18,.92);
    backdrop-filter:blur(2px) saturate(.9);
}
.chat-effect-meta{
    padding:10px 16px;
    background:rgba(16,23,31,.88);
    border:1px solid rgba(255,255,255,.12);
    color:#f7fbff;
    box-shadow:0 14px 28px rgba(0,0,0,.22);
}
.chat-effect-close{
    background:rgba(16,23,31,.86);
    border-color:rgba(255,255,255,.12);
}
@media (max-width:720px){
    .effect-composer-preview{
        align-items:flex-start;
    }
    .effect-composer-thumb{
        width:64px;
        height:64px;
        flex-basis:64px;
        border-radius:14px;
    }
    .effect-composer-actions{
        flex-direction:column-reverse;
    }
    .effect-composer-actions .btn{
        width:100%;
    }
}
#effectComposerBackdrop{
    display:flex;
    align-items:center !important;
    justify-content:center !important;
}
#effectComposerBackdrop .effect-composer-modal{
    margin:0 auto;
}

.page-faq .faq-panel{
    max-width:960px;
    margin:0 auto;
    padding:24px 16px 16px;
}
.page-faq .faq-content{
    padding:24px 20px 32px;
    display:flex;
    flex-direction:column;
    gap:16px;
}
.page-faq h1{
    font-size:24px;
    margin-bottom:12px;
}
.page-faq h2{
    font-size:20px;
    margin-top:20px;
}
.page-faq h3{
    font-size:16px;
    margin-top:12px;
}
.page-faq p,
.page-faq ul{
    font-size:14px;
    line-height:1.6;
}

.radio-station-list{
    display:flex;
    flex-direction:column;
    gap:6px;
    margin-bottom:2px;
}
.radio-station-btn{
    display:flex;
    align-items:center;
    gap:8px;
    width:100%;
    padding:7px 9px;
    border-radius:10px;
    border:1px solid rgba(141,171,211,.28);
    background:rgba(31,44,63,.45);
    color:#d9e8ff;
    cursor:pointer;
    text-align:left;
}
.radio-station-btn:hover{
    background:rgba(62,108,170,.28);
}
.radio-station-btn.is-active{
    border-color:rgba(93,191,255,.8);
    background:rgba(44,109,183,.35);
}
.radio-station-dot{
    width:8px;
    height:8px;
    border-radius:999px;
    background:currentColor;
    opacity:.7;
    flex:0 0 auto;
}
.radio-station-name{
    font-size:12px;
    line-height:1.3;
}
.radio-now-playing{
    font-size:11px;
    color:#9cb2d6;
    padding:2px 1px 0;
}
.modal-room-edit .room-radio-grid{
    margin-top:8px;
}
.modal-room-edit .room-edit-bans-inline{
    display:flex;
    flex-wrap:wrap;
    align-items:baseline;
    gap:6px 10px;
    margin:0 0 14px;
    padding:0 2px;
}
.modal-room-edit .room-edit-bans-link{
    font-size:12px;
    font-weight:600;
    color:#9cb9e8;
    text-decoration:none;
    border-bottom:1px solid rgba(140,180,230,.35);
}
.modal-room-edit .room-edit-bans-link:hover{
    color:#c8ddff;
    border-bottom-color:rgba(200,221,255,.5);
}
.modal-room-edit .room-edit-bans-inline .room-edit-bans-hint{
    margin:0;
    font-size:11px;
    line-height:1.45;
    color:#8a9db8;
    flex:1 1 220px;
}
#userModalBackdrop .ban-reason-panel{
    margin-top:12px;
    padding:12px 14px;
    border-radius:16px;
    border:1px solid rgba(255,107,107,.22);
    background:rgba(24,18,22,.55);
}
#userModalBackdrop .ban-reason-label{
    font-size:12px;
    margin-bottom:6px;
    color:#d0d8ea;
}
#userModalBackdrop .ban-reason-textarea{
    min-height:72px;
    font-size:13px;
    margin-bottom:10px;
}
#userModalBackdrop .ban-reason-actions{
    display:flex;
    justify-content:flex-end;
    gap:10px;
    flex-wrap:wrap;
}
.room-ban-list{
    display:flex;
    flex-direction:column;
    gap:8px;
}
.room-ban-row{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    padding:10px 12px;
    border:1px solid rgba(141,171,211,.24);
    border-radius:12px;
    background:rgba(22,31,49,.42);
}
.room-ban-main{
    display:flex;
    flex-direction:column;
    gap:2px;
    min-width:0;
}
.room-ban-main strong{
    font-size:13px;
    color:#eaf3ff;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.room-ban-main small{
    font-size:11px;
    color:#9db3d4;
}
.room-ban-empty{
    font-size:12px;
    color:#9db3d4;
}
