:root{
  --bg:#d9f6f4;
  --panel:#5668dc;
  --panel-dark:#4758c7;
  --card:#ffffff;
  --text:#1f2430;
  --muted:#95a0b5;
  --line:#e8ebf3;
  --accent:#ffaf00;
  --green:#2ed573;
  --danger:#ff5a7b;
  --shadow:0 10px 30px rgba(55,71,132,.12);
  --radius:22px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,Arial,sans-serif;color:var(--text);background:var(--bg)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
.container{max-width:1180px;margin:0 auto;padding:0 18px}
.topbar{background:var(--panel);height:78px;position:sticky;top:0;z-index:20;box-shadow:0 2px 10px rgba(0,0,0,.06)}
.topbar-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand-wrap{display:flex;align-items:center;gap:16px}
.menu-btn{width:42px;height:42px;border:0;border-radius:12px;background:transparent;color:#fff;font-size:28px;cursor:pointer}
.brand{font-weight:800;font-size:22px;letter-spacing:.3px;color:#fff;display:flex;align-items:center;gap:10px}
.brand-heart{font-size:28px;color:#ff6da1}
.balance-chip{display:flex;align-items:center;gap:10px;background:#fff;border-radius:999px;padding:6px 8px 6px 18px;font-weight:700;color:#384260;box-shadow:var(--shadow)}
.plus-btn{width:34px;height:34px;border:0;border-radius:50%;background:#ff5a96;color:#fff;font-size:24px;cursor:pointer;line-height:1}
.layout{display:flex;gap:22px;align-items:flex-start;padding:20px 0 30px}
.sidebar{width:270px;background:var(--panel);color:#fff;min-height:calc(100vh - 120px);border-radius:0 0 24px 24px;padding:22px 18px 26px;position:sticky;top:98px}
.side-nav{display:flex;flex-direction:column;gap:10px}
.side-link{display:flex;align-items:center;gap:14px;padding:15px 16px;border-radius:18px;color:#eff2ff;font-size:17px}
.side-link.active,.side-link:hover{background:rgba(255,255,255,.13)}
.side-link.support{background:var(--accent);color:#111;font-weight:700;margin-top:8px}
.side-footer{margin-top:auto;padding-top:20px;color:#d7dcff;font-size:15px}
.content{flex:1;min-width:0}
.card{background:var(--card);border-radius:28px;box-shadow:var(--shadow);padding:20px}
.flash-wrap{display:grid;gap:10px;margin-bottom:14px}
.flash{padding:14px 16px;border-radius:16px;font-weight:600}
.flash.success{background:#eaf9ef;color:#1f7a42}
.flash.error{background:#ffe9ee;color:#b2314b}
.hero-card{padding:24px;margin-bottom:18px}
.hero-title{font-size:26px;font-weight:800;margin:0 0 10px}
.hero-sub{font-size:17px;color:#677188;line-height:1.6;margin:0}
.section-card{margin-bottom:18px}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.section-title{font-size:21px;font-weight:800;margin:0}
.badge-green{background:#35e27d;color:#fff;border-radius:10px;padding:6px 10px;font-size:15px;font-weight:800}
.popular-row{display:flex;gap:22px;overflow:auto;padding-bottom:4px}
.popular-item{min-width:110px;text-align:center}
.popular-item img{width:88px;height:88px;border-radius:50%;object-fit:cover;margin:0 auto 9px;border:4px solid #f2f5fb}
.popular-item .name{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.broadcaster-tile{position:relative;border-radius:18px;overflow:hidden;background:#eef1f8;aspect-ratio:1/1.18;box-shadow:0 6px 18px rgba(56,66,96,.08)}
.broadcaster-tile img{width:100%;height:100%;object-fit:cover}
.tile-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.02),rgba(0,0,0,.42));display:flex;flex-direction:column;justify-content:space-between;padding:10px}
.hd-tag{align-self:flex-end;background:rgba(20,24,36,.76);color:#fff;padding:4px 8px;border-radius:10px;font-size:13px;font-weight:800}
.tile-name{color:#fff;font-weight:700;font-size:16px;text-shadow:0 1px 2px rgba(0,0,0,.45)}
.form-card{max-width:780px;margin:0 auto}
.form-title{font-size:58px;line-height:1.02;margin:0;color:#1d2431;font-weight:800}
.form-muted-title{font-size:46px;line-height:1.05;color:#babcc5;font-weight:300;margin:0 0 26px}
.form-grid{display:grid;gap:18px}
.input-line{border:0;border-bottom:2px solid #ececf1;padding:16px 2px;background:transparent;font-size:18px;outline:none;width:100%}
.textarea-line{border:1px solid #ececf1;border-radius:16px;padding:14px;min-height:110px;width:100%;outline:none}
.btn{display:inline-flex;justify-content:center;align-items:center;border:0;border-radius:999px;padding:18px 28px;font-weight:700;cursor:pointer}
.btn-primary{background:var(--panel);color:#fff;box-shadow:0 10px 20px rgba(83,105,220,.22)}
.btn-secondary{background:#fff;border:1px solid #d8dcf0;color:var(--panel)}
.btn-danger{background:#ff4767;color:#fff}
.btn-sm{padding:11px 16px;font-size:14px}
.row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.muted{color:#7c879c}
.right{margin-left:auto}
.package-list{display:grid;gap:14px}
.package-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border:1px solid var(--line);border-radius:18px}
.package-item h4{margin:0 0 6px;font-size:18px}
.package-item small{display:inline-block;background:#ffd329;padding:4px 8px;border-radius:999px;font-weight:700}
.stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px}
.stat{background:#fff;border-radius:20px;padding:18px;box-shadow:var(--shadow)}
.stat .label{color:#7f89a1;font-size:14px}
.stat .value{font-size:28px;font-weight:800;margin-top:8px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px}
table{width:100%;border-collapse:collapse;background:#fff}
th,td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}
th{background:#1f2430;color:#fff}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.video-shell{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:18px;align-items:stretch}
.video-stage{background:#111;border-radius:22px;min-height:68vh;position:relative;overflow:hidden}
.video-stage .demo-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.video-stage .overlay-info{position:absolute;top:14px;left:14px;color:#fff;font-weight:700;z-index:2}
.video-stage .bottom-left{position:absolute;left:14px;bottom:14px;z-index:2;color:#fff}
.chat-box{background:#1c222c;color:#fff;border-radius:22px;padding:16px;display:flex;flex-direction:column;min-height:68vh}
.chat-rules{font-size:14px;line-height:1.5;background:rgba(255,255,255,.06);padding:14px;border-radius:14px;color:#eef1f8;margin-top:auto;margin-bottom:12px}
.chat-input{display:flex;gap:10px}
.chat-input input{flex:1;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:transparent;padding:12px 14px;color:#fff}
.chat-send{width:48px;height:48px;border-radius:50%;border:0;background:#ffd400;cursor:pointer}
.drawer{position:fixed;inset:0;pointer-events:none;z-index:40}
.drawer.open{pointer-events:auto}
.drawer-backdrop{position:absolute;inset:0;background:rgba(22,26,41,.38);opacity:0;transition:.25s}
.drawer.open .drawer-backdrop{opacity:1}
.drawer-panel{position:absolute;top:0;left:0;bottom:0;width:min(84vw,320px);background:var(--panel);color:#fff;padding:26px 20px;transform:translateX(-105%);transition:.28s;display:flex;flex-direction:column;gap:10px}
.drawer.open .drawer-panel{transform:translateX(0)}
@media (max-width: 991px){
  .layout{display:block;padding-top:12px}
  .sidebar{display:none}
  .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .form-title{font-size:40px}
  .form-muted-title{font-size:28px}
  .video-shell{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .topbar{height:94px}
  .topbar-inner{align-items:center}
  .brand{font-size:20px}
  .balance-chip{padding-left:14px}
  .container{padding:0 12px}
  .card{border-radius:24px;padding:18px}
  .popular-row{gap:16px}
  .popular-item{min-width:86px}
  .popular-item img{width:74px;height:74px}
  .grid{gap:12px}
  .section-title{font-size:19px}
  .form-title{font-size:34px}
  .form-muted-title{font-size:26px;margin-bottom:20px}
  .stat-grid{grid-template-columns:1fr}
}
.content.full{max-width:860px;margin:0 auto;width:100%}
.tile-sub{color:#edf1ff;font-size:12px;opacity:.92;margin-top:4px}
.info-box{padding:14px 16px;border-radius:16px;background:#f5f7ff;color:#57607a}
.modal-backdrop{position:fixed;inset:0;background:rgba(20,25,38,.4);display:none;align-items:center;justify-content:center;padding:20px;z-index:50}
.modal-backdrop.open{display:flex}
.modal-card{background:#fff;width:min(680px,100%);border-radius:24px;padding:22px;box-shadow:var(--shadow)}
.bank-box{border:1px solid var(--line);border-radius:16px;padding:14px 16px;margin:12px 0;background:#fafbff}
.messages-layout{display:grid;grid-template-columns:280px 1fr;gap:18px}
.messages-list{border-right:1px solid var(--line);padding-right:12px;display:grid;gap:8px}
.message-user{padding:12px 14px;border-radius:14px;background:#f6f8fd}
.message-user.active{background:#e8edff;color:#3346b8;font-weight:700}
.messages-thread{display:flex;flex-direction:column;min-height:420px}
.message-bubbles{display:grid;gap:10px;flex:1;max-height:440px;overflow:auto;padding:4px 0 12px}
.bubble{padding:12px 14px;border-radius:16px;max-width:75%}
.bubble.me{background:#596bde;color:#fff;justify-self:end}
.bubble.them{background:#f4f6fb;color:#293146}
.chat-compose{display:flex;gap:10px;margin-top:10px}.chat-compose input{flex:1;border:1px solid var(--line);border-radius:999px;padding:13px 14px}
.accordion{display:grid;gap:12px}.accordion-item{border:1px solid var(--line);border-radius:16px;padding:14px 16px;background:#fff}.accordion-item.unread{background:#eef4ff}.accordion-title{font-weight:800;margin-bottom:6px}
.jitsi-stage{min-height:72vh}
@media (max-width: 991px){.messages-layout{grid-template-columns:1fr}.messages-list{border-right:0;border-bottom:1px solid var(--line);padding-right:0;padding-bottom:12px}}
.avatar{border-radius:50%;object-fit:cover;display:block}
.avatar.xs{width:42px;height:42px}
.avatar.lg{width:104px;height:104px}
.message-user{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.chat-header{padding:8px 0 14px;border-bottom:1px solid var(--line);margin-bottom:12px}
.bubble-meta{font-size:12px;font-weight:700;opacity:.8;margin-bottom:4px}
.broadcaster-profile{display:flex;gap:16px;align-items:center}
.broadcaster-modal{width:min(760px,100%)}
code{background:#f4f6fb;padding:4px 8px;border-radius:8px;display:inline-block;margin-top:6px}
.premium-login{background:linear-gradient(180deg,#ffffff,#f8f9ff)}
.balance-chip{align-items:center}
.plus-btn{display:inline-flex;align-items:center;justify-content:center}
@media (max-width:640px){.broadcaster-profile{flex-direction:column;align-items:flex-start}}
.away-screen{position:absolute;inset:0;display:none;align-items:center;justify-content:center;text-align:center;padding:30px;color:#fff;font-size:28px;font-weight:700;background:linear-gradient(135deg, rgba(14,17,25,.92), rgba(58,68,112,.92));}

.balance-chip [data-balance-live]{min-width:54px;display:inline-block;text-align:center}
.input-line.compact{padding:12px 2px;font-size:15px}
.small{font-size:12px}
.light{background:#f5f7fd;color:#2a3552;margin:0 0 12px}
.msg-user-meta{min-width:0}.msg-user-meta strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.whatsapp-layout .messages-list{max-height:70vh;overflow:auto}
.whatsapp-layout .messages-thread{min-height:65vh}
.chat-header-call{display:flex;align-items:center;justify-content:space-between;gap:10px}
.compact-actions{gap:8px}
.inline-form{display:inline}
.ajax-compose input{font-size:16px}
.compact-stat{padding:12px 14px;border-radius:16px;margin-bottom:10px}
.compact-stat .value{font-size:22px}
.compact-side{min-height:unset}
.private-room-layout .private-chat-box{min-height:unset;max-height:78vh}
.private-chat-thread{flex:1;max-height:38vh;overflow:auto;margin:10px 0}
.compact-compose{margin-top:0;margin-bottom:10px}
.btn.full{width:100%}
.compact-modal{max-width:560px}
.bank-head{margin-bottom:6px}
.readable-box{color:#30415f;background:#eef4ff;font-size:14px;line-height:1.5;margin:14px 0}
.copy-btn{cursor:pointer}
.wide-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
.compact-tile{aspect-ratio:1/1.08}
.compact-tile .tile-name{font-size:15px}
.compact-tile .tile-sub{font-size:11px}
.watch-layout .chat-box{min-height:unset}
.native-stage video{transform:none !important}
.local-thumb{transform:none !important}
#incoming-call-modal .modal-card{max-width:360px;padding:18px}
@media (max-width: 1180px){.wide-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (max-width: 991px){
  .wide-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .video-stage{min-height:50vh}
  .chat-box{min-height:unset}
}
@media (max-width: 640px){
  .balance-chip{padding:5px 6px 5px 12px;gap:8px}
  .plus-btn{width:30px;height:30px;font-size:22px}
  .grid,.wide-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .broadcaster-tile,.compact-tile{aspect-ratio:1/1.02;border-radius:16px}
  .tile-name{font-size:14px}
  .tile-sub{display:none}
  .messages-thread{min-height:56vh}
  .private-room-layout .private-chat-box{max-height:none}
  .private-chat-thread{max-height:24vh}
  .chat-header-call{align-items:flex-start;flex-direction:column}
  .video-stage{min-height:42vh}
  .compact-modal{padding:18px}
}


/* v10 fixes */
.call-strip{display:none;margin:0 0 12px}
.call-btn{white-space:nowrap}
.local-video{transform:none !important}
@media (max-width: 640px){
  .chat-header-call{display:block}
  .mobile-visible-call{display:none}
  .call-strip{display:block}
  .call-strip .btn{width:100%;justify-content:center}
  .messages-list{max-height:28vh}
}
@media (min-width: 641px){
  .call-strip{display:none}
  .mobile-visible-call{display:inline-block}
}
/* v11 live, private call and admin polish */
.container{max-width:1240px}
.content.full{max-width:920px}
.layout{gap:24px}
.video-shell{grid-template-columns:minmax(0,1fr) 360px;gap:20px}
.video-stage{min-height:66vh}
.card{padding:22px}

.stage-canvas{position:relative}
.stage-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#000}
.stage-top-tools{position:absolute;top:14px;left:14px;right:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:4}
.stage-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(12,16,24,.74);color:#fff;padding:8px 12px;border-radius:999px;font-size:13px;font-weight:800;backdrop-filter:blur(10px)}
.stage-toolbar-right{display:flex;align-items:center;gap:10px}
.stage-icon-btn{width:42px;height:42px;border:0;border-radius:14px;background:rgba(12,16,24,.74);color:#fff;font-size:21px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(10px);box-shadow:0 8px 18px rgba(0,0,0,.18)}
.viewer-counter{min-width:42px;height:42px;border-radius:14px;background:rgba(255,255,255,.95);color:#25304c;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;font-weight:800;box-shadow:0 8px 18px rgba(0,0,0,.14)}
.viewer-popover{position:absolute;top:68px;right:14px;width:min(290px,calc(100% - 28px));background:rgba(12,16,24,.94);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px;z-index:5;box-shadow:0 22px 40px rgba(0,0,0,.28)}
.viewer-popover-head{font-size:14px;font-weight:800;color:#fff;margin-bottom:10px}
.viewer-popover-body{display:grid;gap:4px;max-height:240px;overflow:auto}
.viewer-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.08);color:#f5f7ff}
.viewer-row:last-child{border-bottom:0}
.viewer-empty{color:#dbe3ff;font-size:14px;line-height:1.45;padding:6px 0}
.badge-inline{display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);color:#fff;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:800}
.live-side-panel,.watch-chat-panel,.private-chat-box{gap:12px}
.live-tools-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.panel-actions-stack{display:grid;gap:10px}
.live-chat-panel{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px;display:flex;flex-direction:column;min-height:0;flex:1}
.live-chat-panel-fill{min-height:340px}
.live-chat-head{font-size:15px;font-weight:800;color:#fff;margin-bottom:10px}
.live-chat-thread{display:grid;gap:10px;flex:1;min-height:220px;max-height:42vh;overflow:auto;padding-right:4px}
.live-chat-message{display:grid;gap:4px;background:rgba(255,255,255,.08);padding:10px 12px;border-radius:14px;font-size:14px;line-height:1.45}
.live-chat-message.host{background:rgba(255,175,0,.16);border:1px solid rgba(255,175,0,.22)}
.live-chat-message strong{font-size:12px;color:#fff}
.live-chat-message span{color:#eef1ff}
.live-actions-card{display:grid;gap:12px}
.full-width-form{width:100%}
.floating-call-card{position:fixed;right:18px;bottom:18px;width:min(360px,calc(100vw - 24px));background:#fff;border-radius:22px;padding:16px;box-shadow:0 24px 44px rgba(19,28,53,.24);z-index:70}
.floating-call-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.call-chip{display:inline-flex;align-items:center;justify-content:center;background:#eef2ff;color:#3e4fc4;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:800}
.call-expire{font-size:13px;font-weight:700;color:#6a748d}
.floating-call-body{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.floating-call-actions{display:flex;gap:10px}
.floating-call-actions .btn{flex:1}
.local-thumb{position:absolute;right:14px;bottom:14px;width:124px;height:170px;object-fit:cover;background:#111;border-radius:16px;border:2px solid rgba(255,255,255,.32);z-index:4;box-shadow:0 12px 26px rgba(0,0,0,.26)}
.private-video-stage .stage-video{background:#000}
.private-room-layout .private-chat-box{min-height:unset;max-height:80vh}
.private-room-layout .private-chat-thread{max-height:36vh}
.watch-chat-panel .live-chat-panel{margin-top:2px}
.chat-box .btn.full{width:100%}

@media (max-width: 1180px){
  .video-shell{grid-template-columns:minmax(0,1fr) 340px}
}
@media (max-width: 991px){
  .video-shell{grid-template-columns:1fr}
  .live-chat-thread{max-height:28vh}
  .private-room-layout .private-chat-thread{max-height:24vh}
}
@media (max-width: 640px){
  .container{padding:0 12px}
  .floating-call-card{left:12px;right:12px;width:auto;bottom:12px}
  .stage-top-tools{top:10px;left:10px;right:10px}
  .stage-icon-btn,.viewer-counter{width:38px;height:38px;min-width:38px;border-radius:12px;font-size:18px}
  .viewer-counter{padding:0 10px}
  .video-stage{min-height:40vh}
  .local-thumb{width:92px;height:126px;right:10px;bottom:10px;border-radius:14px}
  .live-tools-grid{grid-template-columns:1fr 1fr}
  .live-chat-thread{max-height:22vh;min-height:160px}
  .live-chat-panel-fill{min-height:260px}
}

/* v12 immersive live pages, google login and compact incoming card */
body.stage-expanded-mode{overflow:hidden}
.video-stage.is-expanded{position:fixed;inset:0;z-index:120;width:100vw;height:100vh;min-height:100vh;border-radius:0 !important;margin:0;box-shadow:none;background:#000}
.video-stage.is-expanded .stage-video{border-radius:0}
.video-stage.is-expanded .stage-top-tools{top:max(12px,env(safe-area-inset-top));left:14px;right:14px}
.video-stage.is-expanded .stage-chat-dock{left:14px;right:14px;bottom:max(14px,env(safe-area-inset-bottom))}
.video-stage.is-expanded .watch-action-rail{top:max(82px,calc(env(safe-area-inset-top) + 66px));right:14px}
.video-stage.is-expanded .stage-chat-thread{max-height:min(32vh,320px)}

.google-login-wrap{margin-top:20px;display:grid;gap:14px}
.google-login-divider{position:relative;text-align:center;color:#97a3bc;font-size:14px}
.google-login-divider::before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:#e6ebf5;transform:translateY(-50%)}
.google-login-divider span{position:relative;display:inline-block;background:#fff;padding:0 14px}
.google-login-box{display:flex;justify-content:center;min-height:44px}
.google-login-box > div{width:100% !important;display:flex;justify-content:center}

.floating-call-card{right:16px;bottom:16px;width:min(318px,calc(100vw - 24px));padding:14px 14px 12px;border-radius:20px}
.floating-call-head{margin-bottom:10px}
.call-chip{padding:7px 11px;font-size:12px}
.call-expire{font-size:12px}
.floating-call-body{gap:10px;margin-bottom:10px}
.floating-call-body .avatar{width:52px;height:52px;border-radius:50%;object-fit:cover}
#incoming-call-name{display:block;font-size:16px;line-height:1.2}
#incoming-call-meta{font-size:13px;line-height:1.35}
.floating-call-actions .btn{padding:12px 10px;font-size:14px}

.watch-side-info,.live-side-panel.slim-side-panel{min-height:unset}
.watch-side-card{background:linear-gradient(180deg,#131c31,#0d1627);border-radius:28px;padding:22px;display:grid;gap:14px;color:#fff;box-shadow:0 18px 38px rgba(18,29,54,.22)}
.watch-side-meta{font-size:14px;font-weight:700;color:#dbe5ff}
.watch-side-bio{font-size:14px;line-height:1.55;color:#c4cde5}
.watch-side-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.watch-gift-grid{display:grid;gap:10px}
.watch-gift-grid .gift-chip{justify-content:center;background:#eef2ff;color:#2a3760}
.slim-side-panel{display:grid;gap:12px}

.watch-action-rail{position:absolute;top:88px;right:16px;display:grid;gap:10px;z-index:6}
.watch-rail-btn{width:52px;height:52px;border:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:22px;color:#fff;cursor:pointer;box-shadow:0 12px 24px rgba(0,0,0,.22)}
.watch-rail-btn.call{background:#17c764}
.watch-rail-btn.msg{background:#ef476f}
.watch-rail-btn.gift{background:#f59e0b}
.watch-rail-btn.share{background:#3b82f6}

.stage-chat-dock{position:absolute;left:16px;right:16px;bottom:16px;z-index:5;background:rgba(11,16,27,.62);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:12px;backdrop-filter:blur(14px);box-shadow:0 16px 40px rgba(0,0,0,.24)}
.stage-chat-head{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#fff;font-size:14px;font-weight:800;margin-bottom:10px}
.stage-chat-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:rgba(255,255,255,.12);padding:7px 12px;font-size:12px;font-weight:800;color:#fff}
.stage-chat-thread{display:grid;gap:8px;max-height:172px;overflow:auto;padding-right:4px}
.stage-chat-message{display:grid;gap:3px;background:rgba(255,255,255,.08);padding:9px 11px;border-radius:14px;font-size:13px;line-height:1.45;color:#eef2ff}
.stage-chat-message.host{background:rgba(255,175,0,.14);border:1px solid rgba(255,175,0,.18)}
.stage-chat-message strong{font-size:11px;color:#fff}
.stage-chat-compose{display:flex;gap:10px;align-items:center;margin-top:10px}
.stage-chat-compose input{flex:1;min-width:0;background:rgba(255,255,255,.94);border:0;border-radius:999px;padding:14px 18px;font-size:16px;color:#202a42}
.stage-chat-compose input:disabled{opacity:.7}
.stage-chat-compose .chat-send{border:0;border-radius:50%;width:54px;height:54px;background:#ffd400;color:#3c2f00;font-size:22px;font-weight:800;cursor:pointer;box-shadow:0 10px 18px rgba(255,212,0,.28)}
.stage-chat-compose .chat-send:disabled{opacity:.6;cursor:not-allowed}
.viewer-stage-chat{max-width:calc(100% - 32px)}
.broadcaster-stage-chat{max-width:min(560px,calc(100% - 32px))}

.gift-tray{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.gift-chip{border:0;border-radius:999px;padding:10px 14px;background:rgba(255,255,255,.12);color:#fff;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.gift-chip:disabled{opacity:.55;cursor:not-allowed}

.immersive-watch-layout .video-stage{min-height:74vh}
.broadcaster-stage .video-stage,.broadcaster-stage{min-height:72vh}
.immersive-watch-layout .stage-pill,.broadcaster-stage .stage-pill{font-size:14px}

@media (max-width: 1180px){
  .stage-chat-thread{max-height:150px}
}
@media (max-width: 991px){
  .watch-side-info{display:none}
  .watch-action-rail{top:84px;right:12px}
  .stage-chat-dock{left:12px;right:12px;bottom:12px}
  .immersive-watch-layout .video-stage{min-height:68vh}
}
@media (max-width: 640px){
  .video-stage.is-expanded .watch-action-rail{top:max(74px,calc(env(safe-area-inset-top) + 56px));right:10px}
  .watch-rail-btn{width:50px;height:50px;font-size:21px}
  .stage-chat-dock{padding:10px;border-radius:20px}
  .stage-chat-thread{max-height:132px}
  .stage-chat-message{font-size:12px;padding:8px 10px}
  .stage-chat-head{font-size:13px;margin-bottom:8px}
  .stage-chat-badge{padding:6px 10px;font-size:11px}
  .stage-chat-compose{gap:8px}
  .stage-chat-compose input{padding:13px 16px;font-size:16px}
  .stage-chat-compose .chat-send{width:50px;height:50px}
  .gift-chip{padding:9px 12px;font-size:13px}
  .immersive-watch-layout .video-stage{min-height:72vh}
  .broadcaster-stage,.live-room-layout .video-stage{min-height:68vh}
  .floating-call-card{right:12px;left:12px;width:auto;bottom:12px}
}

/* v13 immersive reference live screens */
body.immersive-stage-page{background:#000;color:#fff}
body.immersive-stage-page .container{max-width:none}
.immersive-stage-main{max-width:none;padding:0;width:100%}
.immersive-stage-layout{gap:0;padding:0}
.immersive-stage-content{width:100%;max-width:none !important;padding:0}
body.immersive-stage-page .content.full{padding:0}
body.immersive-stage-page .flash-wrap{position:fixed;top:max(12px,env(safe-area-inset-top));left:12px;right:12px;z-index:140}
body.immersive-stage-page .flash{backdrop-filter:blur(14px)}

.immersive-reference-page{min-height:100vh;background:#000}
.reference-stage{position:relative;min-height:100vh;border-radius:0;background:#000;overflow:hidden;box-shadow:none}
.reference-stage::after{content:"";position:absolute;left:0;right:0;bottom:0;height:38vh;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.58));pointer-events:none;z-index:1}
.reference-stage-video{width:100%;height:100%;object-fit:cover;background:#000;border-radius:0;position:absolute;inset:0;z-index:0}
.reference-topbar{position:absolute;top:max(12px,env(safe-area-inset-top));left:max(12px,env(safe-area-inset-left));right:max(12px,env(safe-area-inset-right));display:flex;align-items:flex-start;justify-content:space-between;gap:14px;z-index:9;pointer-events:none}
.reference-topbar > *{pointer-events:auto}
.reference-left{display:flex;align-items:flex-start;gap:12px;min-width:0}
.reference-right{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.reference-back-btn,.reference-icon-btn{width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;border-radius:16px;background:rgba(10,14,22,.76);border:1px solid rgba(255,255,255,.12);color:#fff;text-decoration:none;font-size:24px;box-shadow:0 14px 28px rgba(0,0,0,.24)}
.reference-title-stack{display:grid;gap:4px;padding-top:2px;min-width:0}
.reference-title{font-size:clamp(22px,2.8vw,34px);font-weight:800;line-height:1.02;color:#fff;text-shadow:0 6px 18px rgba(0,0,0,.28);max-width:min(52vw,420px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.reference-meta{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.88);font-size:14px;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.24)}
.reference-balance-pill{display:inline-flex;align-items:center;gap:12px;min-height:46px;padding:0 8px 0 16px;border-radius:999px;border:2px solid rgba(255,255,255,.86);background:rgba(10,14,22,.76);color:#fff;font-weight:800;box-shadow:0 14px 28px rgba(0,0,0,.24)}
.reference-balance-pill span{white-space:nowrap}
.reference-balance-pill a{width:34px;height:34px;border-radius:50%;background:#ff4f96;color:#fff;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-size:24px;line-height:1;font-weight:800}
.cash-pill{padding-right:16px}
.cash-pill a{display:none}

.reference-side-actions{position:absolute;top:50%;right:max(12px,env(safe-area-inset-right));transform:translateY(-10%);display:grid;gap:12px;z-index:9}
.reference-action-btn{width:58px;height:58px;border:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:27px;color:#fff;text-decoration:none;box-shadow:0 16px 32px rgba(0,0,0,.24);cursor:pointer}
.reference-action-btn.call{background:#18c964}
.reference-action-btn.msg{background:#f3487a}
.reference-action-btn.gift{background:#f4a30b}
.reference-action-btn.share{background:#4a8dff}
.reference-action-btn.viewer{background:#101826}
.reference-action-btn.stop{background:#ff4f70}

.reference-chat-dock{position:absolute;left:max(12px,env(safe-area-inset-left));right:max(12px,env(safe-area-inset-right));bottom:max(12px,env(safe-area-inset-bottom));z-index:8;background:rgba(5,8,14,.86);border:1px solid rgba(255,255,255,.14);border-radius:28px;padding:14px;backdrop-filter:blur(16px);box-shadow:0 24px 44px rgba(0,0,0,.32)}
.reference-rules-box{padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.06);border-left:3px solid #6277ff;color:#f4f6ff;font-size:14px;line-height:1.5;margin-bottom:12px}
.reference-chat-thread{display:grid;gap:10px;max-height:min(26vh,220px);overflow:auto;padding-right:4px}
.reference-chat-message{display:grid;gap:4px;padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.08);color:#eef2ff;font-size:14px;line-height:1.45}
.reference-chat-message strong{font-size:12px;color:#fff}
.reference-chat-message.host{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16)}
.reference-compose{display:flex;gap:10px;align-items:center;margin-top:12px}
.reference-compose input{flex:1;min-width:0;padding:14px 18px;border-radius:999px;border:2px solid rgba(255,255,255,.86);background:rgba(255,255,255,.03);color:#fff;font-size:17px}
.reference-compose input::placeholder{color:rgba(255,255,255,.65)}
.reference-compose input:disabled{opacity:.65}
.reference-send-btn{width:56px;height:56px;border:0;border-radius:50%;background:#ffd400;color:#302500;font-size:24px;font-weight:800;box-shadow:0 14px 24px rgba(255,212,0,.28);cursor:pointer}
.reference-send-btn:disabled{opacity:.6;cursor:not-allowed}
.reference-gift-tray{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.reference-gift-tray .gift-chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14)}
.reference-viewer-popover{top:max(76px,calc(env(safe-area-inset-top) + 64px));right:max(12px,env(safe-area-inset-right));width:min(290px,calc(100% - 24px));z-index:10}

.reference-empty-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(560px,calc(100% - 32px));padding:28px;border-radius:28px;background:rgba(8,12,19,.78);border:1px solid rgba(255,255,255,.12);text-align:center;display:grid;gap:14px;z-index:8;backdrop-filter:blur(12px)}
.reference-empty-panel h1{margin:0;font-size:clamp(28px,4vw,42px);line-height:1.06;color:#fff}
.reference-empty-panel p{margin:0;color:#d7def5;font-size:15px;line-height:1.6}
.reference-empty-kicker{display:inline-flex;justify-self:center;align-items:center;padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.08);color:#fff;font-size:13px;font-weight:800}
.reference-start-form{display:flex;justify-content:center}
.reference-start-form .btn{min-width:220px}
.ghost-dock{right:max(12px,env(safe-area-inset-right));max-width:min(760px,calc(100% - 24px))}

.reference-stage .away-screen{z-index:6;background:rgba(0,0,0,.66);backdrop-filter:blur(4px)}
.reference-stage .away-screen::after{display:none}
.viewer-reference-dock,.broadcaster-reference-dock{max-width:min(920px,calc(100% - 24px))}

.video-stage.is-expanded .reference-topbar{top:max(12px,env(safe-area-inset-top));left:14px;right:14px}
.video-stage.is-expanded .reference-side-actions{right:14px}
.video-stage.is-expanded .reference-chat-dock{left:14px;right:14px;bottom:max(14px,env(safe-area-inset-bottom));border-radius:26px}
.video-stage.is-expanded .reference-viewer-popover{right:14px;top:max(74px,calc(env(safe-area-inset-top) + 62px))}

@media (max-width: 991px){
  .reference-title{max-width:46vw}
  .reference-side-actions{top:auto;bottom:max(196px,calc(env(safe-area-inset-bottom) + 184px));transform:none}
  .reference-chat-thread{max-height:180px}
}

@media (max-width: 680px){
  .reference-topbar{top:max(10px,env(safe-area-inset-top));left:10px;right:10px;gap:10px}
  .reference-back-btn,.reference-icon-btn{width:42px;height:42px;border-radius:14px;font-size:22px}
  .reference-right{gap:8px}
  .reference-title{font-size:18px;max-width:42vw}
  .reference-meta{font-size:12px}
  .reference-balance-pill{min-height:42px;padding:0 8px 0 13px;gap:10px;font-size:14px}
  .reference-balance-pill a{width:30px;height:30px;font-size:22px}
  .reference-side-actions{right:10px;gap:10px;bottom:max(174px,calc(env(safe-area-inset-bottom) + 164px))}
  .reference-action-btn{width:54px;height:54px;font-size:24px}
  .reference-chat-dock{left:10px;right:10px;bottom:max(10px,env(safe-area-inset-bottom));padding:12px;border-radius:24px}
  .reference-rules-box{font-size:13px;padding:11px 12px;margin-bottom:10px}
  .reference-chat-thread{gap:8px;max-height:156px}
  .reference-chat-message{padding:9px 10px;font-size:13px}
  .reference-compose{gap:8px;margin-top:10px}
  .reference-compose input{padding:13px 16px;font-size:16px}
  .reference-send-btn{width:52px;height:52px;font-size:22px}
  .reference-viewer-popover{top:max(68px,calc(env(safe-area-inset-top) + 56px));right:10px}
  .reference-empty-panel{width:calc(100% - 20px);padding:22px;border-radius:24px}
  .reference-empty-panel h1{font-size:30px}
  .video-stage.is-expanded .reference-topbar{left:10px;right:10px}
  .video-stage.is-expanded .reference-chat-dock{left:10px;right:10px;bottom:max(10px,env(safe-area-inset-bottom))}
  .video-stage.is-expanded .reference-side-actions{right:10px}
}


/* v14 mobile/live polish */
.google-login-title{font-size:14px;font-weight:800;color:#445070;text-align:center}
.immersive-reference-page{min-height:100dvh}
.reference-stage{min-height:100dvh;height:100dvh}
.video-stage.is-expanded{height:100dvh;min-height:100dvh}
.reference-chat-dock{background:linear-gradient(180deg,rgba(6,10,18,.24),rgba(6,10,18,.52));border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(10px)}
.reference-rules-box{background:rgba(255,255,255,.05)}
.reference-chat-message{background:rgba(255,255,255,.06)}
.reference-chat-message.host{background:rgba(255,255,255,.10)}
.reference-gift-popover{position:absolute;right:max(82px,calc(env(safe-area-inset-right) + 70px));bottom:max(138px,calc(env(safe-area-inset-bottom) + 126px));width:min(240px,calc(100vw - 112px));display:grid;gap:8px;padding:12px;border-radius:22px;background:rgba(7,11,19,.74);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(12px);box-shadow:0 18px 38px rgba(0,0,0,.26);z-index:10}
.reference-gift-title{font-size:13px;font-weight:800;color:#fff;padding:0 2px 4px}
.reference-gift-chip{width:100%;justify-content:flex-start;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12)}
.reference-toast{position:absolute;left:max(12px,env(safe-area-inset-left));bottom:max(132px,calc(env(safe-area-inset-bottom) + 120px));z-index:12;max-width:min(320px,calc(100vw - 96px));padding:10px 14px;border-radius:999px;background:rgba(9,13,22,.84);color:#fff;font-weight:700;font-size:13px;box-shadow:0 14px 28px rgba(0,0,0,.24);opacity:0;transform:translateY(10px);transition:opacity .18s ease, transform .18s ease}
.reference-toast.is-visible{opacity:1;transform:translateY(0)}
.viewer-reference-dock,.broadcaster-reference-dock{max-width:min(640px,calc(100% - 104px))}

@media (max-width: 991px){
  .viewer-reference-dock,.broadcaster-reference-dock{max-width:min(560px,calc(100% - 94px))}
  .reference-chat-thread{max-height:148px}
  .reference-gift-popover{right:74px;bottom:max(126px,calc(env(safe-area-inset-bottom) + 114px))}
}

@media (max-width: 680px){
  .reference-side-actions{bottom:max(160px,calc(env(safe-area-inset-bottom) + 148px))}
  .reference-chat-dock{right:72px;left:10px;bottom:max(14px,calc(env(safe-area-inset-bottom) + 12px));padding:10px 10px 10px 10px}
  .reference-chat-thread{max-height:112px;gap:7px}
  .reference-rules-box{font-size:12px;line-height:1.42;padding:10px 11px;margin-bottom:8px}
  .reference-chat-message{font-size:12px;padding:8px 9px}
  .reference-compose{margin-top:8px}
  .reference-compose input{padding:12px 15px}
  .reference-gift-popover{right:68px;bottom:max(126px,calc(env(safe-area-inset-bottom) + 114px));width:min(220px,calc(100vw - 96px));padding:10px;border-radius:20px}
  .reference-toast{left:10px;right:auto;bottom:max(124px,calc(env(safe-area-inset-bottom) + 112px));max-width:min(300px,calc(100vw - 92px))}
}

body.is-ios .reference-chat-dock{bottom:max(92px,calc(env(safe-area-inset-bottom) + 12px))}
body.is-ios .reference-side-actions{bottom:max(238px,calc(env(safe-area-inset-bottom) + 226px))}
body.is-ios .reference-gift-popover{bottom:max(204px,calc(env(safe-area-inset-bottom) + 192px))}
body.is-ios .reference-toast{bottom:max(198px,calc(env(safe-area-inset-bottom) + 186px))}
body.is-ios .video-stage.is-expanded .reference-chat-dock{bottom:max(92px,calc(env(safe-area-inset-bottom) + 12px))}

body.is-android .reference-chat-dock{right:74px;max-width:min(430px,calc(100vw - 88px));padding:9px 10px;background:linear-gradient(180deg,rgba(6,10,18,.20),rgba(6,10,18,.46))}
body.is-android .reference-rules-box{font-size:11px;line-height:1.36;padding:9px 10px;margin-bottom:7px}
body.is-android .reference-chat-thread{max-height:96px;gap:6px}
body.is-android .reference-chat-message{font-size:11px;padding:7px 9px}
body.is-android .reference-compose input{padding:11px 14px;font-size:15px}
body.is-android .reference-send-btn{width:48px;height:48px;font-size:20px}
body.is-android .reference-side-actions{bottom:max(150px,calc(env(safe-area-inset-bottom) + 138px))}
body.is-android .reference-gift-popover{bottom:max(118px,calc(env(safe-area-inset-bottom) + 106px))}
body.is-android .reference-toast{bottom:max(116px,calc(env(safe-area-inset-bottom) + 104px))}

/* v15 chat/gift overlay fixes */
[hidden]{display:none !important}
.reference-gift-popover[hidden]{display:none !important}

.viewer-reference-dock .reference-rules-box,
.broadcaster-reference-dock .reference-rules-box{
  display:block;
  width:fit-content;
  max-width:min(380px,100%);
  margin:0 0 8px;
  padding:8px 10px;
  border-radius:16px;
  border-left:3px solid #6277ff;
  background:rgba(9,13,22,.26);
  color:#eef2ff;
  font-size:11px;
  line-height:1.38;
}

@media (max-width: 991px){
  .viewer-reference-dock,
  .broadcaster-reference-dock{
    max-width:min(560px,calc(100% - 88px));
    padding:10px;
    border-radius:22px;
  }
  .reference-chat-thread{max-height:92px;gap:7px}
  .reference-chat-message{padding:8px 9px;font-size:12px}
  .reference-chat-message strong{font-size:11px}
  .reference-compose{margin-top:8px;gap:8px}
  .reference-compose input{padding:11px 14px;font-size:15px}
  .reference-send-btn{width:50px;height:50px;font-size:21px}
  .reference-side-actions{top:auto;bottom:max(128px,calc(env(safe-area-inset-bottom) + 116px));transform:none}
  .reference-gift-popover{right:70px;bottom:max(112px,calc(env(safe-area-inset-bottom) + 100px));width:min(220px,calc(100vw - 94px))}
  .reference-toast{bottom:max(104px,calc(env(safe-area-inset-bottom) + 92px))}
}

@media (max-width: 680px){
  .reference-chat-dock{
    left:10px;
    right:70px;
    bottom:max(8px,calc(env(safe-area-inset-bottom) + 4px));
    padding:9px;
    border-radius:22px;
    background:linear-gradient(180deg,rgba(6,10,18,.12),rgba(6,10,18,.34));
  }
  .viewer-reference-dock,
  .broadcaster-reference-dock{max-width:min(460px,calc(100% - 80px))}
  .reference-chat-thread{max-height:84px;gap:6px}
  .reference-compose{margin-top:7px}
  .reference-compose input{padding:10px 13px;font-size:15px}
  .reference-send-btn{width:46px;height:46px;font-size:20px}
  .reference-side-actions{right:10px;gap:10px;bottom:max(116px,calc(env(safe-area-inset-bottom) + 104px))}
  .reference-action-btn{width:52px;height:52px;font-size:23px}
  .reference-gift-popover{right:66px;bottom:max(100px,calc(env(safe-area-inset-bottom) + 88px));width:min(210px,calc(100vw - 86px));padding:10px}
  .reference-toast{left:10px;bottom:max(94px,calc(env(safe-area-inset-bottom) + 82px));max-width:min(280px,calc(100vw - 88px))}
}

body.is-ios .reference-chat-dock{bottom:max(74px,calc(env(safe-area-inset-bottom) + 6px))}
body.is-ios .reference-side-actions{bottom:max(182px,calc(env(safe-area-inset-bottom) + 168px))}
body.is-ios .reference-gift-popover{bottom:max(158px,calc(env(safe-area-inset-bottom) + 144px))}
body.is-ios .reference-toast{bottom:max(150px,calc(env(safe-area-inset-bottom) + 136px))}
body.is-ios .video-stage.is-expanded .reference-chat-dock{bottom:max(74px,calc(env(safe-area-inset-bottom) + 6px))}

body.is-android .reference-chat-dock{
  right:70px;
  max-width:min(420px,calc(100vw - 82px));
  padding:8px 9px;
  background:linear-gradient(180deg,rgba(6,10,18,.10),rgba(6,10,18,.30));
}
body.is-android .reference-rules-box{font-size:10px;line-height:1.34;padding:7px 9px;margin-bottom:6px;max-width:min(320px,100%)}
body.is-android .reference-chat-thread{max-height:76px;gap:6px}
body.is-android .reference-chat-message{font-size:11px;padding:7px 8px}
body.is-android .reference-compose input{padding:9px 12px;font-size:14px}
body.is-android .reference-send-btn{width:44px;height:44px;font-size:19px}
body.is-android .reference-side-actions{bottom:max(108px,calc(env(safe-area-inset-bottom) + 96px))}
body.is-android .reference-gift-popover{bottom:max(92px,calc(env(safe-area-inset-bottom) + 80px))}
body.is-android .reference-toast{bottom:max(88px,calc(env(safe-area-inset-bottom) + 76px))}

/* v16 mobile live fixes */
html, body { -webkit-text-size-adjust: 100%; }
body.is-ios input,
body.is-ios textarea,
body.is-ios select,
.reference-compose input,
.stage-chat-compose input,
.chat-compose input {
  font-size: 16px !important;
}

.google-fallback-btn{
  width:100%;
  min-height:44px;
  border-radius:999px;
  border:1px solid #d8deea;
  background:#fff;
  color:#24314f;
  font-weight:700;
  font-size:15px;
  cursor:pointer;
  box-shadow:0 8px 20px rgba(20,34,64,.08);
}

@media (max-width: 820px){
.reference-chat-dock{
  padding:10px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(6,10,18,.10),rgba(6,10,18,.34));
}
.viewer-reference-dock,
.broadcaster-reference-dock{
  max-width:min(520px,calc(100% - 80px));
}
.viewer-reference-dock .reference-rules-box,
.broadcaster-reference-dock .reference-rules-box{
  margin:0 0 7px;
  padding:7px 9px;
  font-size:10px;
  line-height:1.32;
  max-width:min(300px,100%);
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:3;
  overflow:hidden;
}
.reference-chat-thread{
  gap:6px;
  max-height:76px;
}
.reference-chat-message{
  padding:7px 9px;
  font-size:11px;
}
.reference-chat-message strong{font-size:11px}
.reference-compose{
  gap:8px;
  margin-top:7px;
}
.reference-compose input{
  padding:10px 13px;
  line-height:1.2;
}
.reference-send-btn{
  width:46px;
  height:46px;
  font-size:20px;
}
.reference-side-actions{
  right:10px;
  gap:10px;
  top:auto;
  transform:none;
  bottom:max(96px,calc(env(safe-area-inset-bottom) + 84px));
}
.reference-action-btn{
  width:52px;
  height:52px;
  font-size:23px;
}
.reference-chat-dock{
  left:10px;
  right:70px;
  bottom:max(8px,calc(env(safe-area-inset-bottom) + 4px));
}
.reference-gift-popover{
  right:66px;
  bottom:max(94px,calc(env(safe-area-inset-bottom) + 82px));
  width:min(210px,calc(100vw - 86px));
}
.reference-toast{
  left:10px;
  bottom:max(88px,calc(env(safe-area-inset-bottom) + 76px));
  max-width:min(280px,calc(100vw - 88px));
}
.video-stage.is-expanded .reference-chat-dock{
  left:10px;
  right:70px;
  bottom:max(8px,calc(env(safe-area-inset-bottom) + 4px));
}
.video-stage.is-expanded .reference-side-actions{
  right:10px;
  bottom:max(96px,calc(env(safe-area-inset-bottom) + 84px));
}

body.is-ios .reference-chat-dock{
  bottom:max(6px,calc(env(safe-area-inset-bottom) + 2px));
}
body.is-ios .reference-side-actions{
  bottom:max(92px,calc(env(safe-area-inset-bottom) + 80px));
}
body.is-ios .reference-gift-popover{
  bottom:max(86px,calc(env(safe-area-inset-bottom) + 74px));
}
body.is-ios .reference-toast{
  bottom:max(84px,calc(env(safe-area-inset-bottom) + 72px));
}
body.is-ios .video-stage.is-expanded .reference-chat-dock{
  bottom:max(6px,calc(env(safe-area-inset-bottom) + 2px));
}

body.is-android .reference-chat-dock{
  right:70px;
  max-width:min(400px,calc(100vw - 82px));
  bottom:max(6px,calc(env(safe-area-inset-bottom) + 2px));
}
body.is-android .reference-rules-box{
  max-width:min(280px,100%);
}
body.is-android .reference-chat-thread{
  max-height:70px;
}
body.is-android .reference-side-actions{
  bottom:max(92px,calc(env(safe-area-inset-bottom) + 80px));
}
body.is-android .reference-gift-popover{
  bottom:max(86px,calc(env(safe-area-inset-bottom) + 74px));
}
body.is-android .reference-toast{
  bottom:max(82px,calc(env(safe-area-inset-bottom) + 70px));
}
}

.gift-only strong{color:#ffd86b}


.flash{transition:opacity .22s ease, transform .22s ease}
.flash.is-hiding{opacity:0;transform:translateY(-8px)}
.reference-audio-overlay{position:absolute;inset:0;z-index:11;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;border:0;background:linear-gradient(180deg,rgba(5,8,14,.12),rgba(5,8,14,.46));color:#fff;text-align:center;cursor:pointer;backdrop-filter:blur(4px)}
.reference-audio-overlay[hidden]{display:none}
.reference-audio-overlay-icon{width:74px;height:74px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:28px;background:rgba(255,255,255,.18);box-shadow:0 12px 30px rgba(0,0,0,.25)}
.reference-audio-overlay-text{font-size:20px;font-weight:800}
.reference-audio-overlay small{font-size:13px;opacity:.9}
@media (max-width:640px){
  .reference-audio-overlay-icon{width:66px;height:66px;font-size:24px}
  .reference-audio-overlay-text{font-size:18px}
}

/* v17 product polish */
body.app-shell{
  --swipe-progress:0px;
  background:
    radial-gradient(circle at top, rgba(86,104,220,.14), transparent 28%),
    linear-gradient(180deg, #f6f8fc 0%, #eef3fb 100%);
  color:#1f2940;
}
body.app-shell:not(.immersive-stage-page) main.container{
  padding-top:18px;
  padding-bottom:calc(96px + env(safe-area-inset-bottom));
  transition:transform .22s ease, opacity .22s ease;
}
body.app-shell:not(.page-ready) main.container{
  opacity:.01;
  transform:translateY(8px);
}
body.swipe-back-ready main.container{
  transform:translateX(min(var(--swipe-progress), 30px));
}
body.swipe-back-commit main.container{
  opacity:.82;
}
.app-topbar{
  position:sticky;
  top:0;
  z-index:30;
  background:rgba(246,248,252,.86);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(31,41,64,.06);
}
.app-brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  letter-spacing:.01em;
}
.app-brand-drawer{margin-bottom:18px}
.brand-logo{
  width:34px;
  height:34px;
  object-fit:cover;
  border-radius:12px;
  box-shadow:0 10px 22px rgba(17,26,46,.16);
}
.app-balance-chip{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(31,41,64,.08);
  box-shadow:0 10px 26px rgba(20,34,64,.08);
}
.app-sidebar .side-nav,
.admin-sidebar .side-nav{
  background:rgba(255,255,255,.76);
  border:1px solid rgba(31,41,64,.08);
  box-shadow:0 16px 36px rgba(20,34,64,.08);
  backdrop-filter:blur(16px);
}
.mobile-tabbar{
  position:fixed;
  left:50%;
  bottom:max(10px,calc(env(safe-area-inset-bottom) + 6px));
  transform:translateX(-50%);
  width:min(680px, calc(100% - 18px));
  display:none;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  padding:8px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(31,41,64,.08);
  border-radius:24px;
  box-shadow:0 18px 36px rgba(20,34,64,.14);
  backdrop-filter:blur(18px);
  z-index:38;
}
.mobile-tab{
  display:grid;
  gap:4px;
  justify-items:center;
  padding:10px 6px;
  border-radius:18px;
  color:#5b6782;
  font-weight:700;
  font-size:13px;
}
.mobile-tab span{font-size:20px;line-height:1}
.mobile-tab small{font-size:11px;font-weight:800}
.mobile-tab.active{
  color:var(--panel);
  background:linear-gradient(180deg, rgba(86,104,220,.12), rgba(86,104,220,.04));
}
.profile-summary-grid.compact,
.dashboard-stat-grid,
.dashboard-two-col,
.admin-queue-grid,
.admin-user-layout,
.admin-split-grid,
.packages-grid-layout,
.messages-shell,
.profile-shell{
  display:grid;
  gap:18px;
}
.dashboard-stack,
.app-profile-page,
.app-packages-page,
.app-messages-page,
.member-dashboard-upgrade,
.broadcaster-dashboard-upgrade,
.admin-dashboard-page,
.admin-finance-page,
.admin-payments-page,
.admin-users-page,
.admin-settings-page{
  display:grid;
  gap:18px;
}
.dashboard-hero-card,
.profile-hero,
.packages-hero-card,
.admin-hero-card{
  border-radius:30px;
  box-shadow:0 18px 40px rgba(20,34,64,.12);
}
.dashboard-hero-card,
.packages-hero-card,
.admin-hero-card{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  background:linear-gradient(135deg, rgba(86,104,220,.98), rgba(120,139,240,.92));
  color:#fff;
}
.hero-title{margin:6px 0 8px;font-size:clamp(26px,3vw,38px);line-height:1.05;letter-spacing:-.02em}
.hero-sub{margin:0;color:rgba(255,255,255,.82);max-width:720px;font-size:15px;line-height:1.6}
.dashboard-hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
.dashboard-two-col,
.admin-split-grid,
.packages-grid-layout,
.messages-shell,
.profile-shell{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
.messages-shell{grid-template-columns:320px minmax(0,1fr);min-height:72vh}
.packages-grid-layout{grid-template-columns:minmax(0,1fr) 320px;align-items:start}
.admin-user-layout{grid-template-columns:320px minmax(0,1fr);align-items:start}
.admin-queue-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.admin-stat-grid{grid-template-columns:repeat(6,minmax(0,1fr))}
.compact-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.profile-summary-grid.compact{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.profile-summary-card,
.profile-stat-card,
.package-card-modern,
.messages-thread-modern,
.messages-sidebar-modern,
.profile-panel,
.admin-list-card{
  border-radius:24px;
  border:1px solid rgba(31,41,64,.08);
  background:rgba(255,255,255,.92);
  box-shadow:0 16px 34px rgba(20,34,64,.08);
}
.profile-summary-card,
.profile-stat-card{padding:16px 18px}
.profile-summary-label,
.profile-stat-label{font-size:12px;font-weight:800;letter-spacing:.03em;color:#8390aa;text-transform:uppercase}
.profile-summary-card strong,
.profile-stat-value{display:block;margin-top:10px;font-size:20px;font-weight:900;color:#1e2942}
.profile-hero{
  display:flex;
  justify-content:space-between;
  gap:24px;
  padding:26px;
  background:linear-gradient(140deg, rgba(86,104,220,.98), rgba(255,175,0,.86));
  color:#fff;
}
.profile-hero-main{display:flex;gap:18px;align-items:center;min-width:0}
.profile-avatar-wrap{position:relative;flex:0 0 auto}
.profile-avatar{
  width:104px;
  height:104px;
  border-radius:28px;
  object-fit:cover;
  box-shadow:0 20px 40px rgba(0,0,0,.18);
  border:3px solid rgba(255,255,255,.22);
}
.profile-status-dot{
  position:absolute;
  right:6px;
  bottom:6px;
  width:16px;
  height:16px;
  border-radius:999px;
  background:#34d37a;
  border:3px solid rgba(255,255,255,.9);
}
.profile-ident{min-width:0}
.profile-ident h1,
.profile-ident h2{margin:0;font-size:clamp(28px,3vw,38px);line-height:1.04;letter-spacing:-.02em}
.profile-bio{margin:10px 0 0;color:rgba(255,255,255,.86);max-width:760px;line-height:1.55}
.profile-meta-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.profile-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  color:#fff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
}
.profile-chip.soft{background:rgba(31,41,64,.08);color:#4f5c78}
.profile-chip.gold{background:rgba(255,215,120,.18);color:#fff4c0}
.profile-chip.live{background:rgba(46,213,115,.18);color:#dafbe5}
.profile-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start;justify-content:flex-end}
.profile-action-form{display:inline-flex}
.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}
.profile-stat-card{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.12);box-shadow:none;color:#fff}
.profile-stat-card .profile-stat-label{color:rgba(255,255,255,.72)}
.profile-stat-card .profile-stat-value{color:#fff}
.profile-panel{padding:18px}
.profile-activity-list{display:grid;gap:10px}
.profile-activity-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 0;
  border-bottom:1px solid rgba(31,41,64,.08);
}
.profile-activity-item:last-child{border-bottom:0}
.profile-list-head{display:flex;align-items:center;gap:12px}
.profile-tabs{
  display:flex;
  gap:8px;
  padding:8px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(31,41,64,.08);
  border-radius:22px;
  box-shadow:0 12px 28px rgba(20,34,64,.08);
}
.profile-tab{
  flex:1;
  min-height:46px;
  border:0;
  border-radius:16px;
  background:transparent;
  color:#67748d;
  font-weight:800;
  cursor:pointer;
}
.profile-tab.is-active{background:linear-gradient(180deg, rgba(86,104,220,.14), rgba(86,104,220,.04));color:var(--panel)}
.profile-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.profile-full-row{grid-column:1/-1}
.profile-edit-actions{display:flex;justify-content:flex-start;gap:10px}
.profile-file-field{display:grid;gap:8px}
.messages-sidebar-modern,
.messages-thread-modern{padding:18px}
.messages-sidebar-head,
.messages-thread-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.messages-search-wrap{display:grid;gap:10px}
.messages-conversation-list{display:grid;gap:10px;max-height:68vh;overflow:auto;padding-right:4px}
.message-thread-row{
  display:flex;
  gap:12px;
  align-items:center;
  padding:14px;
  border-radius:20px;
  border:1px solid rgba(31,41,64,.08);
  background:rgba(246,248,252,.9);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.message-thread-row:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(20,34,64,.08)}
.message-thread-row.active{border-color:rgba(86,104,220,.22);background:linear-gradient(180deg, rgba(86,104,220,.11), rgba(86,104,220,.03))}
.message-thread-copy{display:grid;gap:4px;min-width:0;flex:1}
.message-thread-snippet{font-size:13px;color:#65728c;line-height:1.45;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}
.messages-thread-body{
  display:grid;
  gap:12px;
  background:linear-gradient(180deg, rgba(243,246,253,.9), rgba(248,250,255,.95));
  border:1px solid rgba(31,41,64,.06);
  border-radius:24px;
  padding:18px;
  min-height:56vh;
}
.messages-thread-target{display:flex;align-items:center;gap:12px;min-width:0}
.messages-thread-actions{display:flex;gap:8px;flex-wrap:wrap}
.messages-composer-modern{margin-top:auto;display:flex;gap:10px;align-items:center}
.messages-composer-modern input{
  flex:1;
  min-height:52px;
  border-radius:18px;
  border:1px solid rgba(31,41,64,.08);
  background:#fff;
  padding:0 16px;
}
.packages-hero-card{padding:24px}
.packages-hero-balance{display:grid;gap:12px}
.packages-hero-card .profile-chip{background:rgba(255,255,255,.16);color:#fff}
.packages-side-column{display:grid;gap:16px}
.packages-side-card{padding:18px}
.packages-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.package-card-modern{
  display:grid;
  gap:14px;
  padding:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,255,.94));
}
.package-card-modern.featured{border-color:rgba(255,175,0,.32);box-shadow:0 18px 34px rgba(255,175,0,.12)}
.package-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.package-price-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.package-benefits{display:grid;gap:6px;font-size:13px;color:#65728c}
.package-history-list{display:grid;gap:10px}
.package-history-item{padding:14px 0;border-bottom:1px solid rgba(31,41,64,.08)}
.package-history-item:last-child{border-bottom:0}
.watch-app-page,
.broadcaster-reference-page,
.premium-private-layout,
.enhanced-private-layout{display:grid;gap:18px}
.app-live-stage,
.private-video-stage{
  border-radius:34px;
  overflow:hidden;
  background:#05070b;
  box-shadow:0 22px 46px rgba(8,12,18,.24);
}
.app-live-topbar{
  position:absolute;
  top:0;
  left:0;
  right:0;
  z-index:6;
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:16px;
  pointer-events:none;
}
.app-live-topbar > *{pointer-events:auto}
.app-live-identity{display:flex;align-items:center;gap:12px;min-width:0}
.app-live-identity strong{display:block;color:#fff;font-size:15px}
.app-live-meta{display:flex;align-items:center;gap:8px;margin-top:6px;flex-wrap:wrap}
.app-live-toolbar{display:flex;align-items:center;gap:10px}
.app-live-note-card,
.reference-rules-box{
  display:grid;
  gap:6px;
  max-width:min(360px,100%);
  padding:14px 16px;
  border-radius:22px;
  background:rgba(11,16,26,.74);
  border:1px solid rgba(255,255,255,.10);
  color:#fff;
  box-shadow:0 16px 32px rgba(0,0,0,.22);
  backdrop-filter:blur(14px);
}
.watch-stage-center,
.broadcaster-stage-chrome{
  position:absolute;
  left:16px;
  right:16px;
  bottom:132px;
  z-index:5;
  display:flex;
  justify-content:flex-start;
}
.watch-bottom-actions,
.broadcaster-side-actions,
.reference-side-actions{
  position:absolute;
  left:50%;
  bottom:max(16px,calc(env(safe-area-inset-bottom) + 12px));
  transform:translateX(-50%);
  display:flex;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(8,12,18,.74);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 34px rgba(0,0,0,.24);
  backdrop-filter:blur(14px);
  z-index:7;
}
.app-sheet-backdrop,
.watch-sheet-backdrop{
  position:fixed;
  inset:0;
  background:rgba(6,10,18,.46);
  backdrop-filter:blur(10px);
  z-index:60;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:16px;
}
.app-sheet-card,
.watch-sheet-actions,
.private-gift-sheet{
  width:min(560px,100%);
  border-radius:28px 28px 22px 22px;
  background:#fff;
  box-shadow:0 26px 60px rgba(10,16,30,.28);
  padding:18px;
}
.reference-audio-overlay.compact{
  inset:auto;
  left:50%;
  transform:translateX(-50%);
  bottom:max(94px,calc(env(safe-area-inset-bottom) + 82px));
  width:min(360px,calc(100% - 28px));
  padding:14px 16px;
  border-radius:24px;
  display:grid;
  grid-template-columns:48px 1fr;
  align-items:center;
  justify-items:start;
  text-align:left;
  background:rgba(8,12,18,.86);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 18px 34px rgba(0,0,0,.28);
}
.reference-audio-overlay.compact .reference-audio-overlay-icon{
  width:48px;
  height:48px;
  font-size:20px;
  background:rgba(255,255,255,.12);
  box-shadow:none;
}
.reference-audio-overlay.compact .reference-audio-overlay-text{font-size:16px}
.reference-audio-overlay.compact small{grid-column:2/-1;opacity:.84}
.gift-grid-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:12px}
.gift-card-modern{
  display:grid;
  gap:8px;
  justify-items:center;
  padding:14px 10px;
  border:1px solid rgba(31,41,64,.08);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,255,.94));
  box-shadow:0 12px 24px rgba(20,34,64,.06);
}
.gift-emoji{font-size:28px;line-height:1}
.gift-label{font-weight:800;color:#24314f}
.live-status-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.viewer-card-live,
.admin-inline-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 0;
  border-bottom:1px solid rgba(31,41,64,.08);
}
.viewer-card-live:last-child,
.admin-inline-item:last-child{border-bottom:0}
.viewer-card-tags,
.admin-row-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  font-size:12px;
  color:#687792;
}
.advanced-viewer-popover,
.viewer-popover{width:min(340px,calc(100% - 28px))}
.private-room-layout,
.premium-private-layout{grid-template-columns:minmax(0,1fr) 360px;align-items:start}
.private-room-gradient{background:linear-gradient(180deg, rgba(86,104,220,.12), rgba(255,255,255,.96))}
.premium-private-side,
.private-chat-box{padding:18px}
.private-gift-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:0 0 10px}
.private-gift-toolbar .reference-gift-chip{background:#fff}
.admin-shell{
  background:linear-gradient(180deg, #f5f8fd 0%, #eef3fb 100%);
}
.admin-shell main.container{max-width:1320px}
.admin-auth-page{background:linear-gradient(180deg, #eef3fb 0%, #f8fbff 100%)}
.admin-shell .content{max-width:none}
.admin-list-card,
.admin-user-list-card,
.admin-user-detail-card,
.admin-create-user-card{padding:18px}
.admin-inline-list{display:grid;gap:0}
.admin-inline-item.is-highlight{background:linear-gradient(180deg, rgba(86,104,220,.06), rgba(86,104,220,.02));padding-left:14px;padding-right:14px;border-radius:18px;border:1px solid rgba(86,104,220,.08)}
.admin-inline-item.clickable{color:inherit}
.admin-inline-main{display:flex;gap:12px;align-items:center;min-width:0}
.admin-inline-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.admin-metric-stack{display:grid;gap:6px;justify-items:end}
.admin-metric-stack.align-right{justify-items:end}
.metric-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:112px;
  padding:9px 12px;
  border-radius:14px;
  background:rgba(86,104,220,.12);
  color:var(--panel);
  font-weight:900;
  font-size:13px;
}
.metric-badge.soft{background:rgba(31,41,64,.06);color:#55637e}
.segment-tabs{
  display:inline-flex;
  gap:8px;
  padding:6px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
  border-radius:18px;
}
.segment-tab{
  min-width:118px;
  padding:10px 14px;
  border-radius:14px;
  color:rgba(255,255,255,.84);
  font-weight:800;
  text-align:center;
}
.segment-tab.is-active{background:#fff;color:var(--panel)}
.admin-user-list{display:grid;gap:10px;max-height:78vh;overflow:auto;padding-right:4px}
.admin-user-row{
  display:flex;
  gap:12px;
  align-items:center;
  padding:14px;
  border-radius:22px;
  background:rgba(246,248,252,.92);
  border:1px solid rgba(31,41,64,.08);
}
.admin-user-row.is-active{background:linear-gradient(180deg, rgba(86,104,220,.11), rgba(86,104,220,.03));border-color:rgba(86,104,220,.22)}
.admin-user-row .avatar{width:54px;height:54px;border-radius:18px;object-fit:cover}
.admin-user-row-main{display:grid;gap:4px;min-width:0;flex:1}
.admin-user-hero{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.admin-user-identity{display:flex;gap:16px;align-items:center;min-width:0}
.admin-user-identity .avatar.xl{width:92px;height:92px;border-radius:28px;object-fit:cover}
.admin-user-actions,
.admin-detail-actions-row{display:flex;gap:10px;flex-wrap:wrap}
.admin-reset-form{display:flex;gap:10px;flex-wrap:wrap;width:100%}
.admin-reset-form .input-line{flex:1;min-width:200px}
.admin-brand-preview-card{overflow:hidden}
.admin-brand-preview{
  display:grid;
  gap:16px;
  border-radius:26px;
  padding:18px;
  background:linear-gradient(135deg, var(--preview-primary, var(--panel)), var(--preview-accent, var(--accent)));
  color:#fff;
  box-shadow:0 20px 44px rgba(20,34,64,.16);
}
.admin-brand-preview-top{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:900}
.admin-brand-preview-top img{width:44px;height:44px;border-radius:14px;object-fit:cover;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.admin-brand-preview-body{display:grid;gap:10px}
.admin-brand-preview-body h3{margin:0;font-size:22px}
.admin-brand-preview-body p{margin:0;max-width:300px;color:rgba(255,255,255,.84);line-height:1.55}
.admin-message-list .admin-inline-item{align-items:flex-start}
@media (max-width: 1180px){
  .admin-queue-grid{grid-template-columns:1fr}
  .admin-stat-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width: 991px){
  .layout{grid-template-columns:1fr}
  .dashboard-two-col,
  .admin-split-grid,
  .packages-grid-layout,
  .messages-shell,
  .profile-shell,
  .admin-user-layout,
  .private-room-layout,
  .premium-private-layout{grid-template-columns:1fr}
  .admin-sidebar,
  .app-sidebar{display:none !important}
  .mobile-tabbar{display:grid}
  .dashboard-hero-card,
  .packages-hero-card,
  .admin-hero-card,
  .profile-hero{padding:22px}
  .messages-conversation-list,
  .admin-user-list{max-height:none}
  .watch-stage-center,
  .broadcaster-stage-chrome{bottom:128px}
}
@media (max-width: 720px){
  .admin-stat-grid,
  .compact-grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-hero-card,
  .packages-hero-card,
  .admin-hero-card,
  .profile-hero{flex-direction:column}
  .profile-hero-main,
  .admin-user-hero,
  .admin-user-identity{align-items:flex-start}
  .profile-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .messages-thread-head,
  .messages-sidebar-head,
  .panel-head{align-items:flex-start;flex-direction:column}
  .watch-bottom-actions,
  .broadcaster-side-actions,
  .reference-side-actions{
    bottom:max(10px,calc(env(safe-area-inset-bottom) + 6px));
    padding:8px 12px;
  }
  .reference-audio-overlay.compact{bottom:max(88px,calc(env(safe-area-inset-bottom) + 76px))}
}
@media (max-width: 560px){
  body.app-shell:not(.immersive-stage-page) main.container{padding-bottom:calc(102px + env(safe-area-inset-bottom))}
  .dashboard-hero-actions,
  .profile-actions,
  .admin-inline-actions,
  .admin-detail-actions-row{width:100%;justify-content:stretch}
  .dashboard-hero-actions .btn,
  .profile-actions .btn,
  .admin-inline-actions .btn,
  .admin-detail-actions-row .btn,
  .admin-reset-form .btn{width:100%;justify-content:center}
  .profile-hero{padding:20px;border-radius:26px}
  .profile-avatar{width:88px;height:88px;border-radius:24px}
  .messages-thread-body{padding:14px;min-height:50vh}
  .messages-composer-modern{flex-direction:column}
  .messages-composer-modern input,
  .messages-composer-modern .btn{width:100%}
  .packages-cards-grid,
  .gift-grid-modern{grid-template-columns:repeat(2,minmax(0,1fr))}
  .watch-bottom-actions,
  .broadcaster-side-actions,
  .reference-side-actions{gap:8px}
  .app-live-topbar{padding:12px}
  .watch-stage-center,
  .broadcaster-stage-chrome{left:12px;right:12px;bottom:120px}
  .reference-audio-overlay.compact{grid-template-columns:42px 1fr;padding:12px 14px}
}

/* v18 compact mobile rescue */
.avatar.sm{
  width:44px;
  height:44px;
  flex:0 0 44px;
  border-radius:16px;
  object-fit:cover;
}
.avatar.md{
  width:56px;
  height:56px;
  flex:0 0 56px;
  border-radius:18px;
  object-fit:cover;
}
.profile-kicker{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin:0 0 6px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#8a97b0;
}
.profile-empty{
  padding:14px;
  border:1px dashed rgba(31,41,64,.12);
  border-radius:18px;
  background:rgba(246,248,252,.72);
  color:#66738d;
  font-size:13px;
  line-height:1.45;
}
.profile-note-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border:1px solid rgba(31,41,64,.08);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(247,249,255,.96), rgba(243,246,253,.9));
}
.profile-note-card p{margin:4px 0 0;font-size:13px;line-height:1.48}
.profile-switch{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(31,41,64,.08);
  background:rgba(246,248,252,.88);
}
.profile-switch input{width:18px;height:18px}
.profile-summary-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.profile-panel{display:none}
.profile-panel.is-active{display:block}
.message-thread-card{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(31,41,64,.08);
  background:#fff;
  color:#1f2940;
  box-shadow:0 12px 26px rgba(20,34,64,.06);
}
.message-thread-card.active{
  border-color:rgba(86,104,220,.22);
  background:linear-gradient(180deg, rgba(86,104,220,.10), rgba(86,104,220,.03));
}
.message-thread-card .message-thread-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.message-thread-card .message-thread-copy{min-width:0;flex:1;display:grid;gap:4px}
.message-thread-card .message-thread-row strong{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:14px;
}
.message-thread-card .message-thread-row span{font-size:12px;color:#73809a;white-space:nowrap}
.messages-empty-state{
  display:grid;
  gap:8px;
  align-content:center;
  justify-items:start;
  min-height:40vh;
  padding:18px;
}
.messages-empty-state h2{margin:0;font-size:20px}
.messages-empty-state p{margin:0;font-size:13px;line-height:1.5}
.package-line-list{display:grid;gap:10px}
.package-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:14px 16px;
  border-radius:22px;
  border:1px solid rgba(31,41,64,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,255,.94));
  box-shadow:0 14px 30px rgba(20,34,64,.06);
}
.package-row.featured{border-color:rgba(255,175,0,.34);box-shadow:0 16px 34px rgba(255,175,0,.10)}
.package-row-main{display:grid;gap:6px;min-width:0}
.package-row-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.package-row-title{font-size:15px;font-weight:900;color:#1f2940}
.package-row-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:13px;color:#64718a}
.package-row-bonus{font-size:12px;color:#7b879f;line-height:1.4}
.package-row-btn{min-width:72px}
.page-watch_stream .watch-stage-center,
.page-watch_stream .app-live-note-card{display:none !important}
.page-watch_stream .app-live-stage{
  min-height:100dvh;
  border-radius:0;
  box-shadow:none;
}
.page-watch_stream .app-live-topbar{
  align-items:flex-start;
  padding:10px 10px 0;
}
.page-watch_stream .app-live-identity{
  gap:8px;
  min-width:0;
  max-width:calc(100% - 150px);
}
.page-watch_stream .app-live-identity > div{min-width:0}
.page-watch_stream .app-live-identity strong{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;line-height:1.18}
.page-watch_stream .app-live-meta{margin-top:4px;gap:6px}
.page-watch_stream .profile-chip{
  padding:6px 9px;
  font-size:11px;
  border-radius:999px;
}
.page-watch_stream .reference-back-btn,
.page-watch_stream .reference-icon-btn{
  width:40px;
  height:40px;
  border-radius:14px;
  font-size:20px;
}
.page-watch_stream .reference-balance-pill{
  min-height:40px;
  padding:0 6px 0 12px;
  gap:8px;
  font-size:14px;
}
.page-watch_stream .reference-balance-pill a{width:28px;height:28px;font-size:20px}
.page-watch_stream .app-live-toolbar{gap:8px}
.page-watch_stream .watch-bottom-actions{
  left:auto;
  right:10px;
  top:96px;
  bottom:auto;
  transform:none;
  display:grid;
  gap:8px;
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
}
.page-watch_stream .watch-bottom-actions .reference-action-btn{
  width:42px;
  height:42px;
  border-radius:14px;
  font-size:18px;
  background:rgba(10,14,22,.74);
  border:1px solid rgba(255,255,255,.10);
}
.page-watch_stream .reference-chat-dock{
  left:10px;
  right:10px;
  bottom:max(8px,calc(env(safe-area-inset-bottom) + 4px));
  max-width:none;
  padding:10px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(6,10,18,.12), rgba(6,10,18,.38));
}
.page-watch_stream .viewer-reference-dock{max-width:none}
.page-watch_stream .viewer-reference-dock .reference-rules-box{
  margin:0 0 8px;
  padding:6px 8px;
  max-width:260px;
  border-radius:12px;
  font-size:10px;
  line-height:1.32;
}
.page-watch_stream .reference-chat-thread{max-height:92px;gap:6px}
.page-watch_stream .reference-chat-message{padding:7px 8px;font-size:11px}
.page-watch_stream .reference-chat-message strong{font-size:11px}
.page-watch_stream .reference-compose{gap:8px;margin-top:8px}
.page-watch_stream .reference-compose input{padding:11px 14px;font-size:15px}
.page-watch_stream .reference-send-btn{width:44px;height:44px;font-size:18px}
.page-watch_stream .reference-gift-popover{
  right:60px;
  top:146px;
  bottom:auto;
  width:min(196px,calc(100vw - 82px));
  padding:10px;
  border-radius:18px;
}
.page-watch_stream .gift-grid-modern{grid-template-columns:1fr;gap:8px}
.page-watch_stream .gift-card-modern{
  grid-template-columns:32px 1fr auto;
  align-items:center;
  justify-items:start;
  padding:10px 12px;
}
.page-watch_stream .gift-card-modern small{justify-self:end;font-size:11px}
.page-watch_stream .gift-emoji{font-size:20px}
.page-watch_stream .gift-label{font-size:13px}
.page-watch_stream .reference-audio-overlay.compact{
  bottom:max(72px,calc(env(safe-area-inset-bottom) + 60px));
  width:min(280px,calc(100% - 20px));
  padding:10px 12px;
  border-radius:18px;
}
.page-watch_stream .reference-audio-overlay.compact .reference-audio-overlay-icon{width:40px;height:40px;font-size:18px}
.page-watch_stream .reference-audio-overlay.compact .reference-audio-overlay-text{font-size:14px}
.page-watch_stream .reference-audio-overlay.compact small{font-size:11px}
.page-watch_stream .away-screen{font-size:18px;padding:20px}
.page-watch_stream .watch-sheet-actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.page-messages .app-messages-page.card,
.page-profile .profile-shell.card,
.page-packages .packages-hero-card,
.page-packages .packages-side-card,
.page-messages .messages-sidebar-modern,
.page-messages .messages-thread-modern{border-radius:22px}
.page-messages .app-messages-page.card{padding:14px}
.page-messages .messages-shell{grid-template-columns:300px minmax(0,1fr);gap:14px;min-height:auto}
.page-messages .messages-sidebar-modern,
.page-messages .messages-thread-modern{padding:14px}
.page-messages .messages-conversation-list{gap:8px;max-height:64vh}
.page-messages .messages-thread-head strong{font-size:15px}
.page-messages .messages-thread-body{
  padding:14px;
  min-height:48vh;
  max-height:60vh;
  overflow:auto;
  gap:10px;
  border-radius:20px;
}
.page-messages .bubble{
  padding:10px 12px;
  border-radius:16px;
  font-size:13px;
  line-height:1.42;
  max-width:84%;
}
.page-messages .bubble-meta{font-size:11px}
.page-messages .messages-thread-actions{gap:6px}
.page-messages .messages-thread-actions .btn,
.page-messages .messages-thread-actions .btn-sm,
.page-messages .messages-thread-actions form .btn{
  padding:10px 12px;
  font-size:12px;
}
.page-messages .messages-composer-modern{gap:8px}
.page-messages .messages-composer-modern input{
  min-height:46px;
  border-radius:16px;
  padding:0 14px;
}
.page-messages .messages-composer-modern .chat-send{
  width:46px;
  height:46px;
  flex:0 0 46px;
}
.page-profile .profile-shell.card{padding:14px}
.page-profile .profile-shell{gap:12px}
.page-profile .profile-hero{
  padding:18px;
  gap:14px;
  border-radius:24px;
}
.page-profile .profile-hero-main{gap:12px;align-items:flex-start}
.page-profile .profile-avatar{width:72px;height:72px;border-radius:22px}
.page-profile .profile-status-dot{width:12px;height:12px;right:4px;bottom:4px;border-width:2px}
.page-profile .profile-ident h1,
.page-profile .profile-ident h2{font-size:22px}
.page-profile .profile-bio{margin-top:8px;font-size:13px;line-height:1.45}
.page-profile .profile-meta-row{margin-top:8px;gap:6px}
.page-profile .profile-actions{gap:8px}
.page-profile .profile-actions .btn{padding:10px 12px;font-size:12px}
.page-profile .profile-edit-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%}
.page-profile .profile-edit-actions .btn{min-height:42px;padding:10px 12px;font-size:13px;justify-content:center;white-space:nowrap}
.page-profile .profile-file-field .muted{line-height:1.4}
.page-profile .profile-stats{gap:8px}
.page-profile .profile-stat-card{padding:12px 14px;border-radius:18px}
.page-profile .profile-stat-value{font-size:17px;margin-top:0}
.page-profile .profile-summary-card{padding:12px 14px}
.page-profile .profile-summary-card strong{font-size:15px;margin-top:6px}
.page-profile .profile-tab{min-height:40px;font-size:12px}
.page-profile .profile-activity-item{padding:12px 0}
.page-profile .profile-activity-item .btn{padding:8px 10px;font-size:12px}
.page-packages .packages-hero-card{
  padding:16px 18px;
  gap:12px;
}
.page-packages .packages-hero-card.compact{align-items:center}
.page-packages .packages-hero-card .hero-title{font-size:22px}
.page-packages .packages-hero-card .hero-sub{font-size:13px;line-height:1.5;max-width:none}
.page-packages .packages-hero-balance strong{font-size:20px;line-height:1}
.page-packages .packages-grid-layout{grid-template-columns:minmax(0,1fr) 300px;gap:14px}
.page-packages .packages-side-column{gap:12px}
.page-packages .packages-side-card{padding:14px}
.page-packages .package-history-item{padding:12px 0}
@media (max-width: 820px){
  body.app-shell:not(.immersive-stage-page) main.container{
    padding-top:12px;
    padding-bottom:calc(84px + env(safe-area-inset-bottom));
  }
  .topbar{height:70px}
  .topbar-inner{gap:10px}
  .menu-btn{width:34px;height:34px;font-size:22px}
  .brand{font-size:18px;gap:8px}
  .brand-logo{width:28px;height:28px;border-radius:10px}
  .balance-chip{padding:4px 6px 4px 12px;gap:6px;font-size:14px}
  .plus-btn{width:28px;height:28px;font-size:20px}
  .mobile-tabbar{
    width:calc(100% - 12px);
    gap:4px;
    padding:6px;
    border-radius:20px;
    bottom:max(8px,calc(env(safe-area-inset-bottom) + 4px));
  }
  .mobile-tab{padding:8px 4px;border-radius:14px}
  .mobile-tab span{font-size:17px}
  .mobile-tab small{font-size:10px}
  .card{padding:14px;border-radius:20px}
  .btn{padding:12px 16px;font-size:14px}
  .page-messages .messages-shell,
  .page-packages .packages-grid-layout,
  .page-watch_stream .watch-sheet-actions{grid-template-columns:1fr}
  .page-profile .profile-summary-grid,
  .page-profile .profile-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .page-messages .messages-conversation-list{max-height:none}
  .page-messages .messages-thread-actions{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    width:100%;
  }
  .page-messages .messages-thread-actions .btn,
  .page-messages .messages-thread-actions form,
  .page-messages .messages-thread-actions form .btn{width:100%;justify-content:center}
  .page-packages .package-row{padding:12px 14px;border-radius:18px}
  .page-packages .package-row-title{font-size:14px}
  .page-packages .package-row-meta{font-size:12px}
  .page-packages .package-row-btn{padding:10px 12px;font-size:12px}
}
@media (max-width: 560px){
  .page-messages .messages-thread-actions{grid-template-columns:1fr 1fr}
  .page-messages .messages-thread-body{min-height:42vh;max-height:46vh;padding:12px}
  .page-messages .bubble{max-width:88%;font-size:12px;padding:9px 11px}
  .page-messages .messages-sidebar-modern,
  .page-messages .messages-thread-modern{padding:12px}
  .page-profile .profile-hero{padding:16px;border-radius:22px}
  .page-profile .profile-avatar{width:64px;height:64px;border-radius:20px}
  .page-profile .profile-ident h1,
  .page-profile .profile-ident h2{font-size:20px}
  .page-profile .profile-note-card{flex-direction:column;align-items:flex-start}
  .page-profile .profile-summary-grid,
  .page-profile .profile-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .page-profile .profile-edit-actions .btn{padding:9px 10px;font-size:12px;border-radius:14px}
  .page-watch_stream .app-live-identity{max-width:calc(100% - 136px)}
  .page-watch_stream .app-live-identity strong{font-size:13px}
  .page-watch_stream .watch-bottom-actions{top:86px;right:8px}
  .page-watch_stream .watch-bottom-actions .reference-action-btn{width:40px;height:40px;font-size:17px}
  .page-watch_stream .reference-chat-dock{left:8px;right:8px;padding:9px;border-radius:18px}
  .page-watch_stream .viewer-reference-dock .reference-rules-box{max-width:220px}
  .page-watch_stream .reference-chat-thread{max-height:84px}
  .page-watch_stream .reference-compose input{padding:10px 12px;font-size:14px}
  .page-watch_stream .reference-send-btn{width:42px;height:42px;font-size:17px}
  .page-watch_stream .reference-gift-popover{right:54px;top:132px;width:min(188px,calc(100vw - 74px))}
}
.watch-stage{position:relative}
.watch-stage-chrome{transition:opacity .18s ease, transform .18s ease}
.watch-stage.cinema-ui-hidden .watch-stage-chrome{opacity:0;pointer-events:none;transform:translateY(6px)}
.app-gift-sheet{z-index:9}

/* === v19 mobile hardening, payment restore, contrast fixes === */
.app-topbar,
.admin-shell .topbar{
  background:rgba(248,250,255,.96) !important;
  border-bottom:1px solid rgba(31,41,64,.08) !important;
  box-shadow:0 10px 28px rgba(20,34,64,.06);
}
.app-topbar .app-brand,
.app-topbar .app-brand span,
.admin-shell .topbar .app-brand,
.admin-shell .topbar .app-brand span{
  color:#1f2940 !important;
}
.app-topbar .brand-heart,
.admin-shell .topbar .brand-heart{
  color:var(--panel) !important;
}
.app-topbar .menu-btn,
.admin-shell .menu-btn,
.app-topbar .balance-chip,
.admin-shell .balance-chip,
.app-topbar .balance-chip span,
.admin-shell .balance-chip span{
  color:#1f2940 !important;
}
.app-topbar .balance-chip,
.admin-shell .balance-chip{
  background:rgba(255,255,255,.96) !important;
  border:1px solid rgba(31,41,64,.08) !important;
}
.app-topbar .plus-btn,
.admin-shell .plus-btn{
  background:var(--panel) !important;
  color:#fff !important;
}
.app-shell:not(.immersive-stage-page) .profile-chip.live,
.admin-shell .profile-chip.live{
  background:rgba(26,176,92,.14) !important;
  color:#0b7a37 !important;
  border:1px solid rgba(26,176,92,.24) !important;
}
.app-shell:not(.immersive-stage-page) .profile-chip.gold,
.admin-shell .profile-chip.gold{
  background:rgba(255,191,0,.16) !important;
  color:#8a5a00 !important;
  border:1px solid rgba(255,191,0,.24) !important;
}
.gift-card-modern,
.reference-gift-chip.gift-card-modern{
  color:#1f2940 !important;
}
.gift-card-modern .gift-label,
.reference-gift-chip.gift-card-modern .gift-label{
  color:#1f2940 !important;
}
.gift-card-modern small,
.reference-gift-chip.gift-card-modern small{
  color:#62728b !important;
  font-weight:800;
}
.reference-gift-title{font-weight:900}

.compact-payment-page{display:grid;gap:12px}
.packages-balance-strip{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
}
.packages-balance-amount{
  display:block;
  margin-top:4px;
  font-size:26px;
  line-height:1;
  color:#1f2940;
}
.packages-list-card{padding:14px}
.packages-list-card .section-title{font-size:18px}
.package-line-list{display:grid;gap:10px}
.package-row{align-items:center}
.packages-history-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.packages-side-card{padding:14px}
.payment-history-amount{display:grid;justify-items:end;gap:2px}
.payment-history-amount strong{font-size:14px;color:#1f2940}
.payment-history-amount span{font-size:12px;color:#65748e}
.payment-sheet-card{width:min(460px,calc(100% - 18px));padding:14px}
.payment-sheet-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}
.payment-bank-list{display:grid;gap:10px;margin-bottom:12px}
.payment-bank-card{
  padding:12px 13px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,248,254,.96));
  border:1px solid rgba(31,41,64,.08);
  box-shadow:0 12px 26px rgba(20,34,64,.06);
}
.payment-bank-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.payment-bank-head strong{font-size:14px;color:#1f2940}
.payment-bank-owner{font-size:13px;font-weight:700;color:#33405e;margin-bottom:6px}
.payment-bank-card code{
  display:block;
  white-space:normal;
  word-break:break-word;
  padding:10px 12px;
  border-radius:14px;
  background:#eef2fb;
  color:#1f2940;
  font-size:12px;
  line-height:1.45;
}

.statement-card{padding:14px}
.statement-list{display:grid;gap:10px}
.statement-item{
  padding:12px 14px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,248,254,.95));
  border:1px solid rgba(31,41,64,.08);
}
.statement-main{display:flex;align-items:center;justify-content:space-between;gap:12px}
.statement-values{display:grid;justify-items:end;gap:2px;text-align:right}
.statement-values strong{font-size:14px;color:#1f2940}
.statement-values span{font-size:12px;color:#64728a}
.statement-desc{margin-top:6px;line-height:1.4}

.admin-inline-note{padding:12px 14px;margin:0;min-height:48px;display:flex;align-items:center}
.admin-user-detail-card .admin-detail-actions-row{display:grid;gap:10px}
.admin-user-detail-card .admin-reset-form{display:grid;gap:8px}

.page-profile .profile-chip.live,
.page-profile .profile-chip.soft,
.page-profile .profile-chip.gold{font-weight:800}
.page-profile .profile-note-card p{margin:4px 0 0}

.page-watch_stream .watch-stage-center,
.page-watch_stream #watch-chat-notice,
.page-watch_stream .reference-rules-box,
.page-live_room .reference-rules-box{display:none !important}
.page-watch_stream .app-live-topbar,
.page-live_room .app-live-topbar{padding:10px 10px 0}
.page-watch_stream .app-live-identity,
.page-live_room .app-live-identity{gap:8px;max-width:calc(100% - 132px)}
.page-watch_stream .app-live-identity .avatar.sm,
.page-live_room .app-live-identity .avatar.sm{width:34px !important;height:34px !important;border-radius:12px !important}
.page-watch_stream .app-live-identity strong,
.page-live_room .app-live-identity strong{font-size:13px;line-height:1.18;max-width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.page-watch_stream .app-live-meta,
.page-live_room .app-live-meta{gap:5px}
.page-watch_stream .app-live-meta .profile-chip,
.page-live_room .app-live-meta .profile-chip{padding:5px 8px;font-size:10px;border-radius:999px}
.page-watch_stream .reference-balance-pill,
.page-live_room .reference-balance-pill{min-height:40px;padding:0 6px 0 12px;gap:8px;font-size:14px}
.page-watch_stream .reference-back-btn,
.page-watch_stream .reference-icon-btn,
.page-live_room .reference-back-btn,
.page-live_room .reference-icon-btn{width:40px;height:40px;border-radius:14px;font-size:20px}
.page-watch_stream .watch-bottom-actions{top:88px;right:10px}
.page-watch_stream .watch-bottom-actions .reference-action-btn,
.page-live_room .broadcaster-side-actions .reference-action-btn{width:42px;height:42px;border-radius:14px;font-size:18px}
.page-watch_stream .reference-chat-dock,
.page-live_room .reference-chat-dock{
  left:10px;
  right:10px;
  bottom:max(8px,calc(env(safe-area-inset-bottom) + 4px));
  max-width:none;
  padding:10px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(6,10,18,.18), rgba(6,10,18,.40));
}
.page-watch_stream .reference-chat-thread,
.page-live_room .reference-chat-thread{max-height:96px;gap:6px}
.page-watch_stream .reference-chat-message,
.page-live_room .reference-chat-message{padding:7px 8px;font-size:11px;line-height:1.38}
.page-watch_stream .reference-chat-message strong,
.page-live_room .reference-chat-message strong{font-size:11px}
.page-watch_stream .viewer-empty,
.page-live_room .viewer-empty{font-size:12px;line-height:1.4;color:rgba(255,255,255,.86)}
.page-watch_stream .reference-compose,
.page-live_room .reference-compose{gap:8px;margin-top:8px}
.page-watch_stream .reference-compose input,
.page-live_room .reference-compose input{padding:10px 12px;font-size:14px;min-height:42px}
.page-watch_stream .reference-send-btn,
.page-live_room .reference-send-btn{width:42px;height:42px;font-size:17px}
.page-watch_stream .reference-gift-popover{
  right:56px;
  top:132px;
  bottom:auto;
  width:min(188px,calc(100vw - 74px));
  padding:10px;
  border-radius:18px;
}
.page-watch_stream .gift-grid-modern{grid-template-columns:1fr;gap:8px}
.page-watch_stream .gift-card-modern{grid-template-columns:30px 1fr auto;align-items:center;justify-items:start;padding:10px 12px}
.page-watch_stream .gift-emoji{font-size:20px}
.page-watch_stream .gift-label{font-size:13px}
.page-watch_stream .reference-audio-overlay.compact{grid-template-columns:40px 1fr;align-items:center;gap:10px;padding:10px 12px;width:min(240px,calc(100% - 20px));bottom:max(72px,calc(env(safe-area-inset-bottom) + 58px))}
.page-watch_stream .reference-audio-overlay.compact .reference-audio-overlay-icon{width:40px;height:40px;font-size:18px}
.page-watch_stream .reference-audio-overlay.compact .reference-audio-overlay-text{font-size:13px}
.page-watch_stream .reference-audio-overlay.compact small{display:none}

.page-live_room .app-live-stage{min-height:100dvh;border-radius:0;box-shadow:none}
.page-live_room .app-live-toolbar{gap:8px}
.page-live_room .cash-pill span{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block}
.page-live_room .live-status-cards{
  position:absolute;
  left:10px;
  top:88px;
  width:min(188px,calc(100% - 84px));
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:6px;
  z-index:6;
}
.page-live_room .live-status-cards .profile-summary-card{
  min-width:0;
  padding:8px 10px;
  border-radius:16px;
  background:rgba(8,12,18,.56);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:none;
  backdrop-filter:blur(14px);
}
.page-live_room .live-status-cards .profile-summary-label{
  color:rgba(255,255,255,.74);
  font-size:10px;
  letter-spacing:.08em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.page-live_room .live-status-cards strong{
  color:#fff;
  font-size:15px;
  line-height:1.18;
  display:block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.page-live_room .broadcaster-side-actions{
  left:auto;
  right:10px;
  top:88px;
  bottom:auto;
  transform:none;
  display:grid;
  gap:8px;
  padding:0;
  background:none;
  border:0;
  box-shadow:none;
  backdrop-filter:none;
}
.page-live_room .viewer-popover,
.page-live_room .advanced-viewer-popover{right:10px;left:auto;top:140px;width:min(260px,calc(100vw - 20px))}
.page-live_room .viewer-card-live{padding:10px 0;align-items:flex-start}
.page-live_room .viewer-card-live .btn{padding:8px 10px;font-size:11px}
.page-live_room .viewer-card-tags{gap:6px}

.page-messages .app-messages-page.card{padding:10px}
.page-messages .messages-shell{grid-template-columns:288px minmax(0,1fr);gap:10px}
.page-messages .messages-sidebar-modern,
.page-messages .messages-thread-modern{padding:12px;border-radius:20px}
.page-messages .messages-conversation-list{gap:8px}
.page-messages .message-thread-card{padding:10px 12px;border-radius:16px;align-items:center}
.page-messages .message-thread-card .avatar.sm{width:44px;height:44px;border-radius:14px}
.page-messages .message-thread-snippet{font-size:12px;line-height:1.42}
.page-messages .messages-thread-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.page-messages .messages-thread-target{display:flex;align-items:center;gap:10px;min-width:0}
.page-messages .messages-thread-target .avatar.sm{width:42px;height:42px;border-radius:14px}
.page-messages .messages-thread-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.page-messages .messages-thread-body{padding:12px;min-height:44vh;max-height:56vh}
.page-messages .bubble{padding:9px 11px;font-size:12px;border-radius:15px;max-width:88%}
.page-messages .messages-composer-modern{gap:8px}
.page-messages .messages-composer-modern input{min-height:44px;padding:0 14px;border-radius:15px}
.page-messages .messages-composer-modern .chat-send{width:44px;height:44px;flex:0 0 44px}
.mobile-thread-back{
  display:none;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:12px;
  background:#eef2fb;
  color:#1f2940;
  font-size:20px;
  flex:0 0 36px;
}

@media (max-width: 900px){
  .packages-history-grid{grid-template-columns:1fr}
}
@media (max-width: 820px){
  .packages-balance-strip,
  .packages-list-card,
  .packages-side-card,
  .statement-card{padding:12px}
  .packages-balance-amount{font-size:22px}
  .payment-sheet-card{width:min(420px,calc(100% - 14px));padding:12px}
  .payment-sheet-summary{gap:8px}
  .page-messages .app-messages-page.has-active-conversation .messages-sidebar-modern{display:none}
  .page-messages .app-messages-page.show-conversation-list .messages-thread-modern{display:none}
  .page-messages .app-messages-page.has-active-conversation .messages-thread-modern{display:flex;flex-direction:column}
  .page-messages .messages-shell{grid-template-columns:1fr}
  .page-messages .messages-thread-head{align-items:flex-start}
  .page-messages .messages-thread-target{width:100%}
  .page-messages .messages-thread-actions{width:100%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}
  .page-messages .messages-thread-actions .btn,
  .page-messages .messages-thread-actions form,
  .page-messages .messages-thread-actions form .btn{width:100%;justify-content:center}
  .mobile-thread-back{display:inline-flex}
  .page-watch_stream .app-live-identity,
  .page-live_room .app-live-identity{max-width:calc(100% - 124px)}
}
@media (max-width: 560px){
  .app-topbar .app-brand,
  .admin-shell .topbar .app-brand{gap:8px}
  .app-topbar .app-brand span:last-child,
  .admin-shell .topbar .app-brand span:last-child{font-size:16px}
  .page-watch_stream .watch-bottom-actions{top:82px;right:8px}
  .page-watch_stream .watch-bottom-actions .reference-action-btn,
  .page-live_room .broadcaster-side-actions .reference-action-btn{width:40px;height:40px;font-size:17px}
  .page-watch_stream .reference-chat-dock,
  .page-live_room .reference-chat-dock{left:8px;right:8px;padding:9px;border-radius:18px}
  .page-live_room .live-status-cards{top:82px;left:8px;width:min(176px,calc(100% - 78px))}
  .page-live_room .broadcaster-side-actions{top:82px;right:8px}
  .page-live_room .viewer-popover,
  .page-live_room .advanced-viewer-popover{right:8px;width:min(244px,calc(100vw - 16px))}
  .page-messages .messages-thread-actions{grid-template-columns:1fr 1fr}
  .page-messages .messages-thread-body{min-height:40vh;max-height:44vh;padding:10px}
  .payment-bank-card{padding:11px 12px}
  .statement-item{padding:11px 12px}
}

/* v20 broadcaster live mobile cleanup */
.page-live_room .app-live-stage{min-height:100dvh;border-radius:0;box-shadow:none}
.page-live_room .broadcaster-topbar-compact{
  top:max(6px,env(safe-area-inset-top));
  left:8px;
  right:8px;
  padding:0;
  align-items:flex-start;
}
.page-live_room .broadcaster-topbar-right{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  min-width:0;
}
.page-live_room .broadcaster-stop-pill,
.page-live_room .viewer-count-pill{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(10,14,22,.78);
  color:#fff;
  box-shadow:0 14px 28px rgba(0,0,0,.24);
  backdrop-filter:blur(14px);
}
.page-live_room .broadcaster-stop-pill{
  min-width:74px;
  height:40px;
  padding:0 12px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  font-size:13px;
  font-weight:800;
  background:linear-gradient(180deg,rgba(111,24,37,.96),rgba(79,15,24,.96));
  border-color:rgba(255,123,141,.28);
}
.page-live_room .viewer-count-pill{
  min-width:58px;
  height:40px;
  padding:0 12px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  font-size:13px;
  font-weight:800;
}
.page-live_room .viewer-count-pill strong{font-size:14px;line-height:1;color:#fff}
.page-live_room .broadcaster-cash-pill{
  min-height:40px;
  padding:0 12px;
  border-radius:16px;
  background:rgba(10,14,22,.78);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 14px 28px rgba(0,0,0,.24);
  backdrop-filter:blur(14px);
}
.page-live_room .broadcaster-cash-pill span{
  max-width:132px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  display:inline-block;
  color:#fff;
  font-size:13px;
  font-weight:800;
}
.page-live_room .broadcaster-live-badges{
  position:absolute;
  top:max(54px,calc(env(safe-area-inset-top) + 46px));
  left:8px;
  z-index:6;
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.page-live_room .broadcaster-live-badges .profile-chip{
  padding:6px 10px;
  font-size:11px;
  border-radius:999px;
}
.page-live_room .reference-chat-dock{
  left:8px;
  right:8px;
  bottom:max(8px,calc(env(safe-area-inset-bottom) + 4px));
  max-width:none;
  padding:10px;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(6,10,18,.24),rgba(6,10,18,.52));
}
.page-live_room .reference-chat-thread{max-height:108px;gap:6px}
.page-live_room .reference-chat-message{padding:7px 8px;font-size:11px;line-height:1.4}
.page-live_room .reference-chat-message strong{font-size:11px}
.page-live_room .reference-compose{gap:8px;margin-top:8px}
.page-live_room .reference-compose input{padding:10px 12px;font-size:14px;min-height:42px}
.page-live_room .reference-send-btn{width:42px;height:42px;font-size:17px}
.page-live_room .viewer-popover,
.page-live_room .advanced-viewer-popover{
  top:max(52px,calc(env(safe-area-inset-top) + 44px));
  right:8px;
  left:auto;
  width:min(254px,calc(100vw - 16px));
}
.page-live_room .stop-stream-sheet-card{width:min(360px,calc(100% - 20px))}
.page-live_room .stop-stream-actions{grid-template-columns:1fr 1fr}
.page-live_room .reference-icon-btn{width:40px;height:40px;border-radius:14px;font-size:18px}
.page-live_room .live-status-cards,
.page-live_room .broadcaster-side-actions{display:none !important}

@media (max-width: 560px){
  .page-live_room .broadcaster-topbar-compact{left:8px;right:8px}
  .page-live_room .broadcaster-stop-pill,
  .page-live_room .viewer-count-pill,
  .page-live_room .broadcaster-cash-pill,
  .page-live_room .reference-icon-btn{height:38px}
  .page-live_room .broadcaster-stop-pill{min-width:68px;padding:0 10px;border-radius:15px;font-size:12px}
  .page-live_room .viewer-count-pill{min-width:52px;padding:0 10px;border-radius:15px}
  .page-live_room .broadcaster-cash-pill{padding:0 10px;border-radius:15px}
  .page-live_room .broadcaster-cash-pill span{max-width:118px;font-size:12px}
  .page-live_room .reference-icon-btn{width:38px;border-radius:14px;font-size:17px}
  .page-live_room .broadcaster-live-badges{top:max(50px,calc(env(safe-area-inset-top) + 42px))}
  .page-live_room .viewer-popover,
  .page-live_room .advanced-viewer-popover{top:max(48px,calc(env(safe-area-inset-top) + 40px));width:min(240px,calc(100vw - 16px))}
}

@media (max-width: 390px){
  .page-live_room .broadcaster-topbar-right{gap:6px}
  .page-live_room .broadcaster-cash-pill span{max-width:104px}
  .page-live_room .broadcaster-live-badges .profile-chip.soft{display:none}
}

/* ===== v21 mobile reference overrides ===== */
:root{
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --ink-strong:#ffffff;
  --ink-soft:rgba(255,255,255,.82);
  --surface-dark:rgba(8,10,18,.74);
  --surface-dark-strong:rgba(6,8,14,.92);
  --surface-light:#f6f7fb;
  --line-soft:rgba(255,255,255,.14);
}
body{background:#eef1f7;}
.topbar.app-topbar{background:var(--panel); color:#fff; position:sticky; top:0; z-index:40; padding-top:max(10px,var(--safe-top));}
.app-topbar .app-brand, .app-topbar .menu-btn, .app-topbar .balance-chip span{color:#fff;}
.app-topbar .brand-heart{color:var(--accent);}
.app-topbar .balance-chip{background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.18);}
.mobile-tabbar{backdrop-filter:blur(18px); background:rgba(255,255,255,.92); padding-bottom:calc(8px + var(--safe-bottom));}
.mobile-tab{font-size:13px; gap:5px;}
.mobile-tab small{font-size:13px;}
.profile-chip.silver{background:#eef2f7;color:#6d7385;}
.profile-chip.vip{background:#f0e7ff;color:#6d36dc;}
.profile-chip.base{background:#eef1f7;color:#7c8498;}
.app-global-toast{position:fixed;left:50%;bottom:calc(92px + var(--safe-bottom));transform:translateX(-50%) translateY(20px);background:rgba(9,12,21,.94);color:#fff;padding:12px 16px;border-radius:16px;box-shadow:0 18px 40px rgba(7,12,24,.28);opacity:0;pointer-events:none;z-index:1200;transition:.22s ease;max-width:min(92vw,420px);font-size:14px;text-align:center;}
.app-global-toast.is-visible{opacity:1;transform:translateX(-50%) translateY(0);}
.app-global-toast.success{background:rgba(16,122,62,.94);}
.app-global-toast.error{background:rgba(168,39,39,.96);}
.app-global-toast.warning{background:rgba(118,79,0,.96);}
.app-modal-backdrop{position:fixed;inset:0;background:rgba(7,10,18,.72);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1100;}
.app-modal-card{background:#fff;border-radius:28px;padding:28px 24px;max-width:min(92vw,520px);width:100%;text-align:center;box-shadow:0 22px 60px rgba(10,16,32,.28);}
.gold-modal-card h2,.busy-private-modal-card h2{font-size:28px;line-height:1.08;margin:0 0 14px;color:#4a4a55;}
.gold-modal-card p,.busy-private-modal-card p{font-size:15px;color:#7b8194;line-height:1.55;margin:0 0 16px;}
.gold-modal-icon{width:110px;height:110px;border-radius:999px;border:4px solid rgba(242,111,129,.92);display:flex;align-items:center;justify-content:center;color:rgba(242,111,129,.92);font-size:58px;margin:0 auto 18px;}
.gift-burst-layer{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center;z-index:20;}
.gift-burst-layer .gift-burst-item{background:rgba(7,10,18,.82);color:#fff;padding:18px 26px;border-radius:26px;display:flex;flex-direction:column;align-items:center;gap:8px;transform:scale(.86);opacity:0;transition:.25s ease;}
.gift-burst-layer.show .gift-burst-item{transform:scale(1);opacity:1;}
.gift-burst-emoji{font-size:58px;line-height:1;}
.gift-burst-label{font-size:16px;font-weight:700;}
.checkbox-line{display:flex;gap:10px;align-items:center;}
.btn-outline-danger{background:#fff;border:1px solid rgba(244,95,120,.7);color:#e75b78;}
.admin-accordion-card{border:1px solid #e6e9f2;border-radius:22px;padding:14px 16px;background:#fff;}
.admin-accordion-card summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;list-style:none;}
.admin-accordion-card summary::-webkit-details-marker{display:none;}
.payment-request-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px;}
.payment-request-block{background:#f6f7fb;border-radius:18px;padding:14px;min-height:82px;}
.payment-request-note{grid-column:1/-1;}
.payment-method-inline-list{gap:14px;}
.broadcaster-private-toggle{border:0;cursor:pointer;}

/* Watch stream reference */
.page-watch_stream .container.immersive-stage-main, .page-live_room .container.immersive-stage-main{max-width:none;padding:0;}
.watch-reference-page,.broadcaster-reference-page{min-height:100dvh; background:#000;}
.watch-reference-stage, .broadcaster-stage{min-height:100dvh;border-radius:0;overflow:hidden;background:#000;}
.watch-topbar-reference{position:absolute;left:0;right:0;top:0;padding:calc(10px + var(--safe-top)) 12px 0;display:flex;align-items:flex-start;justify-content:space-between;z-index:12;gap:12px;pointer-events:none;}
.watch-topbar-reference > *{pointer-events:auto;}
.watch-topbar-left,.watch-topbar-right{display:flex;align-items:center;gap:8px;min-width:0;}
.watch-title-stack{display:flex;flex-direction:column;gap:2px;min-width:0;max-width:132px;color:#fff;}
.watch-title-stack strong{font-size:16px;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.watch-top-meta{display:flex;align-items:center;gap:4px;font-size:14px;color:rgba(255,255,255,.9);}
.watch-icon-circle{width:42px;height:42px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:0;text-decoration:none;font-size:30px;line-height:1;color:#fff;backdrop-filter:blur(14px);}
.watch-icon-circle.dark{background:rgba(26,28,34,.72);color:#fff;box-shadow:0 8px 18px rgba(0,0,0,.22);}
.watch-minute-pill{min-width:126px;height:48px;padding:0 0 0 18px;background:rgba(6,8,16,.82);backdrop-filter:blur(18px);box-shadow:none;border:2px solid rgba(255,255,255,.72);}
.watch-minute-pill span{font-size:18px;color:#fff;}
.watch-minute-pill a{width:42px;height:42px;font-size:28px;background:var(--accent);color:#fff;}
.watch-side-rail{position:absolute;right:10px;bottom:calc(110px + var(--safe-bottom));display:flex;flex-direction:column;gap:12px;z-index:12;}
.watch-rail-btn{width:56px;height:56px;border-radius:999px;border:0;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;box-shadow:0 12px 22px rgba(0,0,0,.18);}
.watch-rail-btn.green{background:#1bb44a;}
.watch-rail-btn.yellow{background:#f5b007;color:#1a1300;}
.watch-rail-btn.pink{background:#ff5c7b;}
.watch-rail-btn.orange{background:#ea9046;}
.watch-rail-btn.blue{background:#1138ff;}
.watch-rail-btn.purple{background:#d54aa0;}
.watch-chat-dock{position:absolute;left:10px;right:76px;bottom:calc(10px + var(--safe-bottom));padding:12px 12px 12px;background:rgba(5,7,14,.76);backdrop-filter:blur(20px);border-radius:24px;z-index:12;display:flex;flex-direction:column;gap:10px;transition:.18s ease;}
.watch-chat-dock.is-hidden{opacity:0;pointer-events:none;transform:translateY(12px);}
.watch-chat-list{display:flex;flex-direction:column;gap:8px;max-height:220px;overflow:auto;padding-right:4px;}
.watch-system-card{background:rgba(255,255,255,.08);border-left:3px solid #4f5fff;border-radius:18px;padding:14px 14px;color:#fff;font-size:15px;line-height:1.55;}
.watch-chat-item{display:flex;flex-direction:column;gap:3px;background:rgba(255,255,255,.08);padding:10px 12px;border-radius:16px;color:#fff;font-size:15px;max-width:92%;}
.watch-chat-item strong{font-size:15px;color:#ffd34b;}
.watch-chat-item.host strong{color:#fff;}
.watch-chat-compose{display:flex;gap:10px;align-items:center;}
.watch-chat-compose input{flex:1;height:52px;border-radius:999px;border:2px solid rgba(255,255,255,.86);background:rgba(255,255,255,.02);color:#fff;padding:0 20px;font-size:17px;outline:none;}
.watch-chat-compose input::placeholder{color:rgba(255,255,255,.66);}
.watch-chat-compose button{width:58px;height:52px;border-radius:999px;border:0;background:#f4d00c;color:#1b1700;font-size:28px;}
.watch-people-panel{position:absolute;left:10px;right:96px;bottom:calc(112px + var(--safe-bottom));background:rgba(6,8,14,.72);backdrop-filter:blur(18px);border-radius:24px;padding:14px 16px 16px;z-index:13;color:#fff;min-height:180px;max-height:340px;overflow:auto;}
.watch-people-head{display:flex;align-items:center;gap:10px;font-size:17px;margin-bottom:12px;}
.watch-people-head button{border:0;background:transparent;color:#fff;font-size:26px;line-height:1;padding:0;}
.watch-people-list{display:flex;flex-direction:column;gap:10px;}
.watch-people-item{display:flex;align-items:center;justify-content:space-between;font-size:16px;color:#fff;}
.watch-people-name{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.watch-people-name .crown{color:#f7c746;font-size:18px;}
.watch-people-name .rank{font-size:12px;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.12);}
.watch-people-name .rank.gold{background:rgba(246,188,48,.18);color:#f7c746;}
.watch-people-name .rank.silver{background:rgba(210,216,226,.2);color:#d8dfef;}
.watch-people-name .rank.vip{background:rgba(182,136,255,.2);color:#c4a0ff;}
.watch-gift-sheet{position:absolute;left:0;right:0;bottom:0;background:rgba(5,7,14,.96);padding:16px 16px calc(16px + var(--safe-bottom));border-radius:28px 28px 0 0;z-index:14;color:#fff;box-shadow:0 -20px 40px rgba(0,0,0,.28);}
.watch-gift-head{display:flex;align-items:center;gap:10px;font-size:18px;margin-bottom:14px;}
.watch-gift-head button{border:0;background:transparent;color:#fff;font-size:28px;padding:0;line-height:1;}
.watch-gift-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px 10px;}
.watch-gift-card{background:transparent;border:0;color:#fff;display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;border-radius:18px;}
.watch-gift-card.selected{background:rgba(255,255,255,.08);}
.watch-gift-emoji{font-size:56px;line-height:1;}
.watch-gift-name{font-size:16px;font-weight:700;}
.watch-gift-minutes{font-size:15px;color:rgba(255,255,255,.86);}
.watch-gift-submit{margin-top:18px;width:100%;height:58px;border-radius:18px;border:0;background:#b56d3a;color:#111;font-size:18px;font-weight:800;letter-spacing:.03em;}
.watch-gift-submit:disabled{opacity:.5;}
.watch-system-toast{position:absolute;left:10px;right:86px;bottom:calc(240px + var(--safe-bottom));background:rgba(7,10,18,.84);color:#fff;padding:14px 16px;border-radius:20px;z-index:12;font-size:15px;line-height:1.45;}
.busy-private-modal-card{max-width:min(92vw,520px);}
.watch-reference-stage .away-screen{z-index:11;font-size:20px;padding:32px;text-align:center;background:rgba(0,0,0,.62);}

/* Broadcaster live */
.broadcaster-topbar-compact{padding-top:calc(10px + var(--safe-top));}
.broadcaster-topbar-compact .broadcaster-private-toggle{font-size:13px;padding:0 10px;min-height:34px;}
.broadcaster-reference-dock{right:18px;left:18px;bottom:calc(10px + var(--safe-bottom));background:rgba(5,7,14,.76);backdrop-filter:blur(20px);border-radius:24px;padding:12px;z-index:12;}
.broadcaster-reference-dock .reference-chat-thread{max-height:220px;overflow:auto;display:flex;flex-direction:column;gap:8px;}
.broadcaster-reference-dock .reference-chat-message{max-width:94%;background:rgba(255,255,255,.08);border-radius:16px;padding:10px 12px;color:#fff;}
.broadcaster-reference-dock .reference-chat-message strong{color:#ffd34b;}
.broadcaster-reference-dock .reference-chat-message.host strong{color:#fff;}
.broadcaster-reference-dock .reference-compose input{background:rgba(255,255,255,.02);border:2px solid rgba(255,255,255,.86);color:#fff;}
.broadcaster-reference-dock .reference-compose button{background:#f4d00c;color:#1b1700;}
.viewer-popover.advanced-viewer-popover{background:rgba(6,8,14,.88);backdrop-filter:blur(18px);border-radius:22px;color:#fff;max-width:min(92vw,420px);}
.viewer-card-live{background:rgba(255,255,255,.06);border-radius:16px;padding:10px 12px;}
.viewer-card-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px;}

/* Messages reference */
.messages-reference-page{padding-bottom:calc(88px + var(--safe-bottom));}
.messages-reference-card{background:#f6f7fb;border-radius:28px;padding:0;overflow:hidden;min-height:calc(100dvh - 92px);}
.messages-reference-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 14px;background:var(--panel);color:#fff;}
.messages-reference-header h1{margin:0;font-size:24px;line-height:1.05;}
.messages-reference-kicker{font-size:12px;letter-spacing:.12em;text-transform:uppercase;opacity:.72;margin-bottom:6px;}
.messages-layout-grid{display:grid;grid-template-columns:320px minmax(0,1fr);min-height:calc(100dvh - 174px);}
.messages-list-pane{padding:16px;border-right:1px solid #e5e8f0;display:flex;flex-direction:column;gap:10px;background:#fff;overflow:auto;}
.message-list-row{display:flex;gap:12px;align-items:center;padding:12px;border-radius:20px;background:#f6f7fb;text-decoration:none;color:#202335;}
.message-list-row.active{background:#edf0ff;box-shadow:inset 0 0 0 1px rgba(86,104,220,.18);}
.message-list-main{min-width:0;flex:1;}
.message-list-top{display:flex;justify-content:space-between;gap:8px;font-size:14px;}
.message-list-top strong{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;}
.message-list-bottom{font-size:14px;color:#7b8194;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px;}
.messages-thread-pane{display:flex;flex-direction:column;min-width:0;background:#f6f7fb;}
.message-thread-head{display:flex;align-items:center;gap:14px;padding:18px 18px 10px;}
.message-thread-meta{min-width:0;display:flex;flex-direction:column;}
.message-thread-meta strong{font-size:24px;line-height:1.05;color:#10131f;}
.message-thread-meta span{font-size:15px;color:#979ca9;font-style:italic;margin-top:4px;}
.message-thread-actions{margin-left:auto;}
.message-thread-toolbar{padding:0 18px 12px;}
.message-policy-card{margin:0 18px 10px;background:#fff;border-radius:24px;padding:18px;text-align:center;font-size:18px;line-height:1.55;color:#303543;}
.message-thread-body{flex:1;overflow:auto;padding:10px 18px 120px;display:flex;flex-direction:column;gap:10px;}
.message-bubble-row{display:flex;}
.message-bubble-row.outgoing{justify-content:flex-end;}
.message-bubble{max-width:min(78%,420px);border-radius:22px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;box-shadow:0 8px 22px rgba(20,24,35,.06);}
.message-bubble.incoming{background:#fff;color:#202335;border-bottom-left-radius:8px;}
.message-bubble.outgoing{background:linear-gradient(135deg,var(--panel),var(--panel-dark));color:#fff;border-bottom-right-radius:8px;}
.message-bubble-time{font-size:12px;opacity:.64;align-self:flex-end;}
.message-compose-bar{position:sticky;bottom:0;display:flex;gap:10px;align-items:center;padding:14px 18px calc(14px + var(--safe-bottom));background:#f6f7fb;border-top:1px solid #e8ebf4;}
.message-compose-bar input{flex:1;height:56px;border-radius:16px;border:1px solid #d7dce9;background:#fff;padding:0 18px;font-size:17px;}
.message-compose-bar button{width:56px;height:56px;border-radius:999px;border:0;background:var(--panel);color:#fff;font-size:24px;}

/* Packages purchase */
.purchase-reference-page{padding-bottom:calc(88px + var(--safe-bottom));}
.purchase-modal-frame{background:#f2f4f8;border-radius:28px;overflow:hidden;min-height:calc(100dvh - 96px);box-shadow:0 18px 50px rgba(10,16,32,.08);}
.purchase-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px;background:var(--panel);color:#fff;font-size:24px;letter-spacing:.02em;}
.purchase-modal-body{padding:18px 18px 120px;}
.purchase-balance-inline{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px;color:#5a6074;font-size:14px;}
.purchase-balance-inline strong{font-size:18px;color:#11152a;}
.purchase-step-title{font-size:28px;color:var(--panel);font-weight:700;text-align:center;margin:10px 0 18px;}
.purchase-method-list,.purchase-package-list{display:flex;flex-direction:column;gap:14px;}
.purchase-method-row,.purchase-package-row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:20px 18px;border-radius:26px;background:#fff;border:1px solid #d9deeb;color:#171a24;text-decoration:none;box-shadow:0 10px 24px rgba(14,18,30,.04);}
.purchase-method-row strong,.purchase-package-row strong{font-size:22px;line-height:1.08;}
.purchase-package-row span{font-size:22px;font-weight:700;}
.purchase-package-row.active{box-shadow:inset 0 0 0 2px rgba(86,104,220,.78);border-color:rgba(86,104,220,.35);}
.purchase-package-bonus{display:inline-flex;margin-top:8px;font-size:13px;font-weight:700;padding:6px 10px;border-radius:10px;background:#ffce12;color:#3b2c00;}
.purchase-confirm-card{background:#fff;border:1px solid #dce1ee;border-radius:26px;padding:18px;}
.purchase-confirm-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;}
.purchase-confirm-top strong{font-size:22px;}
.purchase-confirm-top span{font-size:24px;font-weight:700;}
.purchase-payment-details{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;}
.payment-detail-row{display:flex;justify-content:space-between;gap:12px;background:#f6f7fb;border-radius:16px;padding:14px;}
.payment-detail-row span{color:#7b8194;}
.payment-detail-row strong{max-width:60%;text-align:right;word-break:break-word;}
.payment-detail-note{background:#f6f7fb;border-radius:16px;padding:14px;color:#40465a;font-size:14px;line-height:1.55;}
.purchase-submit-button{height:54px;font-size:16px;border-radius:16px;}
.purchase-modal-footer{position:sticky;bottom:0;display:flex;justify-content:flex-end;gap:12px;padding:14px 18px calc(14px + var(--safe-bottom));background:#f2f4f8;border-top:1px solid #dde1ec;}
.purchase-modal-footer .btn{min-width:150px;border-radius:18px;}
.purchase-history-card{margin-top:18px;}

/* Notifications */
.notifications-reference-card{border-radius:30px;overflow:hidden;min-height:calc(100dvh - 96px);}
.notifications-reference-header{background:var(--panel);}
.notifications-accordion{padding:18px;background:#fff;display:flex;flex-direction:column;gap:14px;}
.notification-accordion-item{border:1px solid #e5e8f0;border-radius:24px;overflow:hidden;background:#fff;}
.notification-accordion-item summary{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:18px;font-size:18px;cursor:pointer;list-style:none;}
.notification-accordion-item summary::-webkit-details-marker{display:none;}
.notification-accordion-item.is-unread summary{background:#eef3ff;color:#2d66d3;}
.notification-accordion-body{padding:18px;font-size:18px;line-height:1.55;color:#2d3142;background:#fff;}
.notification-accordion-body small{display:block;margin-top:16px;color:#9096a7;}

@media (max-width: 900px){
  .messages-layout-grid{grid-template-columns:1fr;}
  .messages-list-pane.thread-open{display:none;}
  .messages-thread-pane{display:none;}
  .messages-thread-pane.is-active{display:flex;min-height:calc(100dvh - 174px);}
  .message-thread-meta strong{font-size:20px;}
  .message-policy-card{font-size:16px;}
}
@media (max-width: 640px){
  .topbar.app-topbar{padding-bottom:12px;}
  .watch-title-stack{max-width:104px;}
  .watch-icon-circle{width:40px;height:40px;font-size:28px;}
  .watch-minute-pill{min-width:118px;height:46px;padding-left:14px;}
  .watch-minute-pill span{font-size:17px;}
  .watch-side-rail{right:8px;bottom:calc(116px + var(--safe-bottom));gap:10px;}
  .watch-rail-btn{width:54px;height:54px;font-size:26px;}
  .watch-chat-dock{left:8px;right:72px;border-radius:22px;padding:10px;}
  .watch-chat-list{max-height:190px;}
  .watch-chat-item,.watch-system-card{font-size:14px;}
  .watch-chat-compose input{height:50px;font-size:16px;}
  .watch-chat-compose button{width:54px;height:50px;}
  .watch-people-panel{left:8px;right:84px;bottom:calc(122px + var(--safe-bottom));}
  .watch-gift-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px 8px;}
  .watch-gift-emoji{font-size:48px;}
  .watch-gift-name{font-size:15px;}
  .watch-gift-minutes{font-size:14px;}
  .purchase-modal-header{font-size:22px;}
  .purchase-step-title{font-size:24px;}
  .purchase-method-row strong,.purchase-package-row strong,.purchase-package-row span{font-size:18px;}
  .purchase-modal-footer{justify-content:space-between;}
  .purchase-modal-footer .btn{min-width:0;flex:1;}
  .message-compose-bar{padding-inline:12px;}
  .message-thread-body{padding-inline:12px;}
  .message-policy-card{margin-inline:12px;}
}
