*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --g:#6b9e78;--g1:#5a8a67;--gs:rgba(107,158,120,.1);--gg:rgba(107,158,120,.22);
  --bg:#0e0e0e;--s1:#141414;--s2:#1a1a1a;--s3:#202020;--s4:#282828;
  --b:rgba(255,255,255,.07);--b2:rgba(255,255,255,.12);
  --t1:#eeeeec;--t2:#a0a099;--t3:#5a5a54;
  --r:10px;--rl:14px;--rx:18px;--nh:56px;
  --f:'DM Sans',sans-serif;
  --red:#c05050;--amber:#b8943a;--blue:#5b84b1;
}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--f);color:var(--t1);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden;background:#0a0a0a;background-image:radial-gradient(ellipse 70% 50% at 15% 0%,rgba(107,158,120,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 45% at 85% 30%,rgba(192,80,80,.05) 0%,transparent 50%),radial-gradient(ellipse 80% 50% at 50% 100%,rgba(107,158,120,.06) 0%,transparent 60%),linear-gradient(180deg,#0a0a0a 0%,#0d0e0d 50%,#0a0a0a 100%);background-attachment:fixed}
#app{background:transparent}
@media(min-width:900px){body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(circle at 20% 20%,rgba(107,158,120,.04) 0%,transparent 25%),radial-gradient(circle at 80% 60%,rgba(192,80,80,.03) 0%,transparent 25%);pointer-events:none;z-index:0}}
input,textarea,select{font-size:16px!important;font-family:var(--f);touch-action:manipulation}
button{cursor:pointer;font-family:var(--f);border:none;background:none}
a{text-decoration:none;color:inherit}
::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-thumb{background:var(--gg);border-radius:3px}
.view{display:none}.view.active{display:block}
.screen{display:none}.screen.active{display:block}

/* TOP NAV */
.top-nav{position:sticky;top:0;z-index:300;height:var(--nh);background:var(--s1);border-bottom:1px solid var(--b);display:flex;align-items:center;padding:0 16px;gap:10px}
.nav-logo{display:flex;align-items:center;gap:9px;cursor:pointer;flex-shrink:0}
.nav-logo-icon{width:34px;height:34px;flex-shrink:0;display:block}
.logo-name{font-size:17px;font-weight:800;letter-spacing:-.5px;line-height:1;color:var(--t1)}
.logo-name span{color:var(--g)}
.logo-sub{font-size:8px;color:var(--t3);letter-spacing:.4px;text-transform:uppercase;margin-top:2px}
.nav-center{flex:1;display:none;justify-content:center;gap:3px}
.nav-tab{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;color:var(--t2);cursor:pointer;border:1px solid transparent;white-space:nowrap;transition:all .15s}
.nav-tab:hover{background:var(--s3);color:var(--t1)}
.nav-tab.on{background:var(--gs);border-color:var(--gg);color:var(--g)}
.nav-spacer{flex:1}
.nav-online{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--g);font-weight:500;flex-shrink:0}
.n-dot{width:6px;height:6px;background:var(--g);border-radius:50%;animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.nav-purge{font-size:10px;color:var(--red);background:rgba(192,80,80,.08);border:1px solid rgba(192,80,80,.15);border-radius:6px;padding:3px 8px;flex-shrink:0;display:none}
.nav-join-btn{background:var(--g);color:#fff;border-radius:8px;padding:6px 15px;font-size:12px;font-weight:700;flex-shrink:0;transition:background .2s}
.nav-join-btn:hover{background:var(--g1)}
.nav-user-av{width:30px;height:30px;border-radius:50%;background:var(--g);color:#fff;font-size:12px;font-weight:700;display:none;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--gg);flex-shrink:0}
.hamburger{width:34px;height:34px;border-radius:8px;border:1px solid var(--b);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4.5px;cursor:pointer;flex-shrink:0;transition:all .2s;background:var(--s2)}
.hamburger:hover,.hamburger.open{border-color:var(--gg);background:var(--gs)}
.hamburger span{width:15px;height:1.5px;background:var(--t2);border-radius:2px;transition:all .25s;display:block}
.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* TICKERS */
.ticker-top{height:28px;background:var(--s2);border-bottom:1px solid var(--b);overflow:hidden;display:flex;align-items:center}
.ticker-inner{display:flex;animation:tk 30s linear infinite;width:max-content}
.ticker-inner:hover{animation-play-state:paused}
@keyframes tk{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.tick-item{display:flex;align-items:center;gap:7px;padding:0 24px;font-size:10.5px;color:var(--t2);white-space:nowrap;border-right:1px solid var(--b)}
.ad-tag{background:var(--gs);border:1px solid rgba(107,158,120,.2);color:var(--g);font-size:8.5px;font-weight:700;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.4px}
.ticker-fat{height:34px;background:rgba(107,158,120,.04);border-bottom:1px solid rgba(107,158,120,.08);overflow:hidden;display:flex;align-items:center}
.ticker-fat-inner{display:flex;animation:tkf 65s linear infinite;width:max-content}
@keyframes tkf{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.tick-fat-item{display:flex;align-items:center;gap:8px;padding:0 36px;font-size:11px;font-weight:500;color:var(--g);white-space:nowrap;border-right:1px solid rgba(107,158,120,.1)}

/* BOTTOM RED-LABEL TICKER */
.ticker-red{height:32px;background:rgba(192,80,80,.05);border-bottom:1px solid rgba(192,80,80,.1);overflow:hidden;display:flex;align-items:center}
.ticker-red-label{background:var(--red);color:#fff;font-size:9.5px;font-weight:800;padding:0 12px;height:100%;display:flex;align-items:center;letter-spacing:.6px;flex-shrink:0;white-space:nowrap}
.ticker-red-scroll{flex:1;overflow:hidden}
.ticker-red-inner{display:flex;animation:tk 45s linear infinite;width:max-content}
.tick-red-item{padding:0 26px;font-size:11px;color:var(--red);font-weight:500;white-space:nowrap;border-right:1px solid rgba(192,80,80,.18);display:flex;align-items:center;height:32px}

/* DRAWER */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:400;opacity:0;pointer-events:none;transition:opacity .25s}
.overlay.show{opacity:1;pointer-events:all}
.drawer{position:fixed;top:0;left:-300px;width:280px;max-width:88vw;height:100vh;background:var(--s1);border-right:1px solid var(--b);z-index:401;transition:left .28s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}
.drawer.open{left:0}
.drawer-hd{padding:14px 14px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.drawer-close{width:28px;height:28px;border-radius:7px;border:1px solid var(--b);color:var(--t2);font-size:13px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.drawer-scroll{flex:1;overflow-y:auto}
.d-section{font-size:9px;font-weight:700;color:var(--t3);letter-spacing:1.4px;text-transform:uppercase;padding:10px 15px 4px}
.d-link{display:flex;align-items:center;gap:9px;padding:8px 15px;font-size:13px;color:var(--t2);cursor:pointer;border-left:2px solid transparent;transition:all .15s}
.d-link:hover,.d-link.on{background:var(--gs);color:var(--t1);border-left-color:var(--g)}
.d-link .di{font-size:13px;width:18px;text-align:center;flex-shrink:0;color:var(--t3)}
.d-link.on .di{color:var(--g)}
.d-link .dc{margin-left:auto;font-size:10px;color:var(--t3);background:var(--s3);padding:1px 7px;border-radius:10px}
.d-country{display:flex;align-items:center;gap:8px;padding:6px 15px;font-size:12px;color:var(--t2);cursor:pointer;transition:background .12s}
.d-country:hover{background:var(--s2)}
.d-country-flag{font-size:14px;flex-shrink:0}
.d-country-name{flex:1;font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.d-country-online{font-size:10px;color:var(--g);flex-shrink:0}
.drawer-auth{padding:12px 14px;border-top:1px solid var(--b);display:flex;flex-direction:column;gap:6px;flex-shrink:0}
.da-btn{width:100%;padding:10px;border-radius:9px;font-size:13px;font-weight:700;transition:all .2s}
.da-join{background:var(--g);color:#fff}
.da-join:hover{background:var(--g1)}
.da-sign{background:transparent;border:1px solid var(--b2);color:var(--t2)}

/* DESKTOP RESPONSIVE */
@media(min-width:900px){
  body{background:#080808}
  #app{background:var(--bg);width:100%;min-height:100vh}
  .nav-center{display:flex}
  .nav-purge{display:flex}
  .bottom-nav{display:none!important}
  .home-wrap,.lobby-inner,.screen-wrap{max-width:1280px;margin:0 auto;padding:0 24px}
  .blog-grid{grid-template-columns:repeat(4,1fr)!important}
  .blog-img{height:150px}
  .cat-grid2{grid-template-columns:repeat(4,1fr)!important}
  .countries-grid{grid-template-columns:repeat(4,1fr)!important}
  .hero{padding:50px 24px 40px}
  .hero-h1{font-size:40px}
  .hero-stats{max-width:600px}
  .modal-bg{align-items:center;padding:20px}
  .modal-sheet{border-radius:var(--rx)!important;max-width:500px;margin:auto}
  .footer-body-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;max-width:1280px;margin:0 auto;padding:0 24px}
  .footer-bottom-inner{max-width:1280px;margin:0 auto;padding:0 24px}
  .chat-input-bar{position:sticky;bottom:0}
  .fab{display:none}
}
@media(min-width:600px) and (max-width:899px){
  body{background:#080808}
  #app{background:var(--bg);width:100%}
  .bottom-nav{display:none!important}
  .home-wrap,.lobby-inner,.screen-wrap{max-width:760px;margin:0 auto;padding:0 20px}
  .blog-grid{grid-template-columns:repeat(2,1fr)!important}
  .cat-grid2{grid-template-columns:repeat(2,1fr)!important}
  .countries-grid{grid-template-columns:repeat(2,1fr)!important}
  .modal-bg{align-items:center;padding:20px}
  .modal-sheet{border-radius:var(--rx)!important;max-width:480px;margin:auto}
  .nav-center{display:flex}
}
@media(max-width:599px){
  #app{min-height:100vh}
  .home-wrap,.lobby-inner,.screen-wrap{padding:0}
  .chat-input-bar{bottom:54px}
  .page-pad{padding-bottom:70px}
}

/* HERO */
.hero{padding:32px 20px 26px;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid var(--b)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -20%,rgba(107,158,120,.07) 0%,transparent 70%);pointer-events:none}
.hero-inner{position:relative;z-index:1;max-width:720px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--gs);border:1px solid rgba(107,158,120,.2);border-radius:20px;padding:4px 14px;font-size:11px;color:var(--g);font-weight:500;margin-bottom:14px}
.hero-h1{font-size:clamp(22px,5.5vw,38px);font-weight:800;line-height:1.15;letter-spacing:-.5px;margin-bottom:10px}
.hero-h1 em{color:var(--g);font-style:normal}
.hero-sub{font-size:12.5px;color:var(--t2);line-height:1.65;margin-bottom:18px;max-width:560px;margin-left:auto;margin-right:auto}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);overflow:hidden;max-width:480px;margin:0 auto}
.hst{padding:11px 8px;text-align:center;border-right:1px solid var(--b)}
.hst:last-child{border-right:none}
.hst-n{font-size:18px;font-weight:800;color:var(--g)}
.hst-l{font-size:8.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.7px;margin-top:3px}

/* GUEST BANNER */
.guest-banner{background:var(--gs);border:1px solid rgba(107,158,120,.15);margin:14px 20px;border-radius:var(--rl);padding:12px 13px;display:flex;align-items:center;gap:10px}
.gb-text{flex:1;font-size:12px;color:var(--t2);line-height:1.45}
.gb-text strong{color:var(--t1);display:block;margin-bottom:1px;font-size:12.5px}
.gb-btn{background:var(--g);color:#fff;font-weight:700;padding:7px 13px;border-radius:8px;font-size:12px;cursor:pointer;border:none;white-space:nowrap;flex-shrink:0}

/* SECTIONS */
.sec-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 8px}
.sec-title{font-size:12px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:7px;text-transform:uppercase;letter-spacing:.6px}
.sec-dot{width:7px;height:7px;background:var(--g);border-radius:50%;flex-shrink:0}
.sec-live{background:rgba(192,80,80,.1);border:1px solid rgba(192,80,80,.2);color:var(--red);font-size:8px;font-weight:700;padding:2px 6px;border-radius:5px;letter-spacing:.8px}
.sec-link{font-size:11px;color:var(--g);cursor:pointer;flex-shrink:0;font-weight:500}

/* H-SCROLL ROOMS */
.h-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0 20px 12px;display:flex;gap:9px}
.h-scroll::-webkit-scrollbar{display:none}
.room-chip{min-width:145px;background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:11px 12px;flex-shrink:0;cursor:pointer;transition:all .18s}
.room-chip:hover{border-color:var(--gg);transform:translateY(-1px)}
.rc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.rc-code{font-size:10px;font-weight:700;color:var(--t3)}
.rc-flag{font-size:18px}
.rc-name{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:3px}
.rc-cnt{font-size:10px;color:var(--g);display:flex;align-items:center;gap:3px}
.rc-cnt::before{content:'';width:5px;height:5px;background:var(--g);border-radius:50%}
.rc-preview{font-size:10px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-style:italic;margin-top:4px}

/* TOPICS BAR */
.topics-bar{background:var(--s1);border-bottom:1px solid var(--b)}
.topics-hd{display:flex;align-items:center;justify-content:space-between;padding:8px 20px 5px}
.topics-title{font-size:10px;font-weight:700;color:var(--g);text-transform:uppercase;letter-spacing:.9px}
.topics-create{font-size:10px;color:var(--t3);cursor:pointer;background:var(--s3);border:1px solid var(--b);padding:3px 9px;border-radius:6px;transition:all .15s}
.topics-create:hover{color:var(--g);border-color:var(--gg)}
.topics-scroll{overflow-x:auto;white-space:nowrap;padding:0 20px 10px;scrollbar-width:none}
.topics-scroll::-webkit-scrollbar{display:none}
.topic-chip{display:inline-flex;align-items:center;gap:5px;background:var(--s3);border:1px solid var(--b);border-radius:20px;padding:5px 12px;margin-right:6px;cursor:pointer;transition:all .15s}
.topic-chip:hover{border-color:var(--gg);background:var(--gs)}
.tc-text{font-size:11px;color:var(--t1);font-weight:500}
.tc-badge{font-size:8.5px;background:var(--gs);color:var(--g);border-radius:8px;padding:1px 5px;font-weight:700}

/* INFO NOTE */
.info-note{margin:12px 20px;background:var(--gs);border:1px solid rgba(107,158,120,.15);border-radius:9px;padding:10px 13px;display:flex;align-items:flex-start;gap:9px}
.info-i{width:18px;height:18px;border-radius:50%;background:var(--g);color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.info-text{font-size:11.5px;color:var(--t2);line-height:1.55}

/* BLOG GRID */
.blog-section{padding:0 20px}
@media(min-width:900px){.blog-section{padding:0}}
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.blog-card{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);overflow:hidden;cursor:pointer;transition:all .2s}
.blog-card:hover{border-color:var(--gg);transform:translateY(-2px)}
.blog-img{height:100px;background:var(--s3);overflow:hidden;position:relative}
.blog-img img{width:100%;height:100%;object-fit:cover;opacity:.88;display:block}
.blog-img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--t3);background:linear-gradient(135deg,var(--s3),var(--s4));font-weight:600}
.blog-body{padding:10px}
.blog-cat{font-size:9.5px;font-weight:700;color:var(--g);letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px}
.blog-title{font-size:12px;font-weight:600;line-height:1.35;color:var(--t1)}
.blog-meta{font-size:10px;color:var(--t3);margin-top:5px}
.view-more-btn{display:block;width:100%;margin-top:12px;background:transparent;border:1px solid var(--b2);color:var(--t2);padding:11px;border-radius:var(--r);font-size:12px;font-weight:600;text-align:center;cursor:pointer;transition:all .2s}
.view-more-btn:hover{border-color:var(--gg);color:var(--g)}

/* CATEGORIES */
.cat-section{margin-bottom:6px}
.cat-section-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 8px}
.cat-section-title{font-size:12px;font-weight:700;color:var(--t1)}
.cat-grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 20px}
.cat-card{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:13px 11px;cursor:pointer;transition:all .18s;position:relative}
.cat-card:hover{border-color:var(--gg);background:var(--s3)}
.cat-name{font-size:12.5px;font-weight:700;line-height:1.3;margin-bottom:5px;padding-top:2px}
.cat-count{font-size:10.5px;color:var(--g);font-weight:600;display:flex;align-items:center;gap:4px}
.cat-count::before{content:'';width:4px;height:4px;background:var(--g);border-radius:50%;flex-shrink:0}
.cat-tag{position:absolute;top:8px;right:8px;font-size:8.5px;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.4px}
.tag-hot{background:rgba(192,80,80,.15);color:var(--red);border:1px solid rgba(192,80,80,.25)}
.tag-new{background:var(--gs);color:var(--g);border:1px solid rgba(107,158,120,.25)}
.tag-trending{background:rgba(184,148,58,.12);color:var(--amber);border:1px solid rgba(184,148,58,.25)}

/* COUNTRIES */
.countries-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;padding:0 20px}
.country-item{background:var(--s2);border:1px solid var(--b);border-radius:var(--r);padding:10px 11px;display:flex;align-items:center;gap:9px;cursor:pointer;transition:all .15s}
.country-item:hover{background:var(--s3);border-color:var(--b2)}
.ci-flag{font-size:20px;flex-shrink:0}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ci-region{font-size:9.5px;color:var(--t3)}
.ci-online{font-size:10px;color:var(--g);font-weight:600;flex-shrink:0}
.country-hidden{display:none!important}
.load-more-btn{display:block;width:calc(100% - 40px);margin:12px 20px;background:var(--s2);border:1px solid var(--b2);color:var(--t2);padding:11px;border-radius:var(--r);font-size:12px;font-weight:600;text-align:center;cursor:pointer;transition:all .2s}
.load-more-btn:hover{border-color:var(--gg);color:var(--g)}

/* BACK HEADER */
.back-hd{position:sticky;top:0;z-index:200;height:var(--nh);background:rgba(14,14,14,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--b);display:flex;align-items:center;gap:11px;padding:0 16px}
.back-btn{width:32px;height:32px;background:var(--s2);border-radius:8px;border:1px solid var(--b);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--t2);cursor:pointer;flex-shrink:0}
.back-title{font-size:16px;font-weight:700;flex:1}
.icon-btn{width:32px;height:32px;background:var(--s2);border-radius:8px;border:1px solid var(--b);color:var(--t2);font-size:13px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;font-weight:600;transition:all .2s}
.icon-btn:hover{border-color:var(--gg);color:var(--g)}

/* TABS */
.f-tabs{display:flex;border-bottom:1px solid var(--b);overflow-x:auto;scrollbar-width:none}
.f-tabs::-webkit-scrollbar{display:none}
.f-tab{font-size:12.5px;font-weight:600;padding:11px 14px;color:var(--t3);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all .18s;flex-shrink:0}
.f-tab.on{color:var(--g);border-bottom-color:var(--g)}

/* POST CARDS */
.post-list{padding:10px 20px;display:flex;flex-direction:column;gap:7px}
.post-card{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:13px;cursor:pointer;transition:all .18s}
.post-card:hover{border-color:var(--gg);background:var(--s3)}
.post-author{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.post-av{width:30px;height:30px;background:var(--s4);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;border:1px solid var(--b)}
.post-username{font-size:12px;font-weight:700}
.pro-badge{font-size:8px;background:var(--gs);color:var(--g);border:1px solid var(--gg);padding:1px 5px;border-radius:4px;margin-left:4px;font-weight:700}
.post-time{font-size:10px;color:var(--t3);margin-left:auto;flex-shrink:0}
.post-title{font-size:13.5px;font-weight:700;line-height:1.35;margin-bottom:7px}
.post-body{font-size:12.5px;color:var(--t2);line-height:1.5;margin-bottom:9px}
.post-acts{display:flex;gap:12px}
.post-act{font-size:11.5px;color:var(--t3);display:flex;align-items:center;gap:4px;cursor:pointer;transition:color .15s}
.post-act:hover{color:var(--g)}
.status-live{background:rgba(107,158,120,.12);color:var(--g);font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px}
.status-pending{background:rgba(184,148,58,.12);color:var(--amber);font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px}
.status-draft{background:rgba(90,90,84,.2);color:var(--t3);font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px}
.fab{position:fixed;bottom:70px;right:18px;width:48px;height:48px;background:var(--g);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;cursor:pointer;z-index:199;box-shadow:0 4px 18px rgba(107,158,120,.35);transition:all .2s}
.fab:hover{background:var(--g1);transform:scale(1.07)}

/* CATEGORY HERO */
.cat-hero{background:linear-gradient(135deg,#0d1810,#0e0e0e);padding:18px 20px;border-bottom:1px solid var(--b)}
.cat-hero-name{font-size:20px;font-weight:800;margin-bottom:7px;letter-spacing:-.3px}
.cat-hero-stats{display:flex;gap:14px;flex-wrap:wrap}
.cat-hs{font-size:11.5px;color:var(--t2)}
.cat-hs strong{color:var(--g)}

/* CHAT */
.chat-hd{position:sticky;top:0;z-index:200;background:rgba(14,14,14,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--b);display:flex;align-items:center;gap:10px;padding:0 14px;height:var(--nh)}
.chat-room-info{flex:1;min-width:0}
.chat-room-name{font-size:15px;font-weight:700}
.chat-room-sub{font-size:10px;color:var(--t3);margin-top:1px}
.destruct-bar{background:rgba(192,80,80,.05);border-bottom:1px solid rgba(192,80,80,.1);padding:6px 14px;font-size:10.5px;color:var(--t3);display:flex;align-items:center;gap:6px}
.destruct-bar strong{color:var(--red)}
.anon-notice{background:rgba(184,148,58,.06);border-bottom:1px solid rgba(184,148,58,.12);padding:8px 14px;font-size:11.5px;color:var(--amber);display:flex;align-items:center;gap:6px}
.anon-link{color:var(--amber);font-weight:700;text-decoration:underline;cursor:pointer}
.chat-msgs{padding:14px;display:flex;flex-direction:column;gap:13px;padding-bottom:130px}
@media(min-width:900px){.chat-msgs{padding:14px 20px;padding-bottom:90px}}
.msg-row{display:flex;gap:9px}
.msg-row.own{flex-direction:row-reverse}
.msg-av{width:30px;height:30px;background:var(--s4);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;margin-top:2px;border:1px solid var(--b)}
.msg-bubble{max-width:76%;background:var(--s3);border:1px solid var(--b);border-radius:14px 14px 14px 4px;padding:9px 12px}
.msg-row.own .msg-bubble{background:#0f1f13;border-color:rgba(107,158,120,.18);border-radius:14px 14px 4px 14px}
.msg-name{font-size:11px;font-weight:700;color:var(--g);margin-bottom:3px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.msg-text{font-size:13px;line-height:1.48;color:var(--t1);word-break:break-word}
.msg-time{font-size:9.5px;color:var(--t3);margin-top:4px;text-align:right}
.msg-destruct{font-size:9px;color:var(--t3);margin-top:2px}
.chat-input-bar{position:fixed;bottom:54px;left:0;right:0;z-index:199;background:rgba(20,20,20,.97);backdrop-filter:blur(12px);border-top:1px solid var(--b);padding:9px 14px;display:flex;align-items:center;gap:7px;padding-bottom:calc(9px + env(safe-area-inset-bottom,0))}
.chat-tools{display:flex;gap:5px;flex-shrink:0}
.chat-tool-btn{width:34px;height:34px;background:var(--s3);border:1px solid var(--b);border-radius:7px;color:var(--t2);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.chat-tool-btn:hover{border-color:var(--gg);color:var(--g)}
.chat-inp{flex:1;background:var(--s3);border:1px solid var(--b);border-radius:20px;padding:9px 14px;font-size:13px;color:var(--t1);outline:none;resize:none;max-height:80px;transition:border .2s}
.chat-inp:focus{border-color:var(--gg)}
.chat-send{width:38px;height:38px;background:var(--g);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff;cursor:pointer;flex-shrink:0;transition:all .2s}
.chat-send:hover{background:var(--g1)}
.sticker-picker{position:fixed;bottom:104px;left:14px;right:14px;background:var(--s1);border:1px solid var(--b2);border-radius:var(--rl);padding:12px;z-index:198;display:none;max-height:240px;overflow-y:auto}
.sticker-picker.show{display:block}
.sticker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:6px}
.sticker-item{aspect-ratio:1;background:var(--s3);border:1px solid var(--b);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;transition:all .15s}
.sticker-item:hover{border-color:var(--gg);transform:scale(1.05)}

/* PROFILE */
.profile-hd{background:linear-gradient(135deg,#0d1810,#0e0e0e);padding:24px 20px 20px;border-bottom:1px solid var(--b);text-align:center}
.profile-av{width:72px;height:72px;background:var(--s3);border-radius:50%;border:3px solid var(--g);margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:var(--g)}
.profile-username{font-size:20px;font-weight:800;letter-spacing:-.3px;margin-bottom:6px}
.p-badges{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-bottom:8px}
.p-badge{font-size:9.5px;font-weight:700;padding:3px 9px;border-radius:20px}
.badge-pro{background:var(--gs);color:var(--g);border:1px solid var(--gg)}
.badge-verified{background:rgba(91,132,177,.12);color:var(--blue);border:1px solid rgba(91,132,177,.25)}
.profile-meta{font-size:11px;color:var(--t3)}
.profile-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px;max-width:480px;margin-left:auto;margin-right:auto}
.ps{background:rgba(0,0,0,.25);border-radius:10px;padding:10px 6px;text-align:center}
.ps-n{font-size:18px;font-weight:800;color:var(--g)}
.ps-l{font-size:8.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.create-post-bar{margin:12px 20px;background:var(--s2);border:1px solid var(--gg);border-radius:var(--rl);padding:12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .18s}
.create-post-bar:hover{background:var(--s3)}
.profile-tabs{display:flex;border-bottom:1px solid var(--b);overflow-x:auto;scrollbar-width:none}
.profile-tabs::-webkit-scrollbar{display:none}
.pt{font-size:12px;font-weight:600;padding:11px 14px;color:var(--t3);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .15s}
.pt.on{color:var(--g);border-bottom-color:var(--g)}
.ptab{display:none;padding:12px 20px;flex-direction:column;gap:7px;padding-bottom:74px}
.ptab.on{display:flex}
.p-item{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:12px 13px;display:flex;align-items:center;gap:11px;cursor:pointer;transition:all .18s}
.p-item:hover{border-color:var(--gg)}
.p-item-icon{font-size:18px;width:36px;text-align:center;flex-shrink:0;color:var(--t2)}
.p-item-info{flex:1;min-width:0}
.p-item-title{font-size:13px;font-weight:600;margin-bottom:2px}
.p-item-meta{font-size:10.5px;color:var(--t3)}

/* DASHBOARD LAYOUT */
.dash-layout{display:flex;min-height:calc(100vh - var(--nh));overflow:hidden}
.dash-side{width:230px;background:var(--s1);border-right:1px solid var(--b);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;max-height:calc(100vh - var(--nh))}
@media(max-width:600px){.dash-side{width:200px}}
.dash-mini{padding:14px 12px;border-bottom:1px solid var(--b);text-align:center}
.dash-mini-av{width:46px;height:46px;border-radius:50%;background:var(--g);color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 7px}
.dash-mini-name{font-size:12px;font-weight:700;color:var(--t1)}
.dash-mini-plan{font-size:10px;color:var(--g);margin-top:2px}
.dash-main{flex:1;overflow-y:auto;background:var(--bg);max-height:calc(100vh - var(--nh))}
.dash-tab{display:none;padding:16px 20px;padding-bottom:30px}
.dash-tab.on{display:block}
.dash-section-title{font-size:13px;font-weight:700;margin-bottom:12px}

/* ADMIN BUTTONS */
.admin-btn{font-size:10px;font-weight:700;padding:5px 9px;border-radius:6px;cursor:pointer;transition:all .18s}
.btn-approve{background:var(--gs);color:var(--g);border:1px solid var(--gg)}
.btn-approve:hover{background:var(--g);color:#fff}
.btn-reject{background:rgba(192,80,80,.1);color:var(--red);border:1px solid rgba(192,80,80,.2)}
.btn-warn{background:rgba(184,148,58,.1);color:var(--amber);border:1px solid rgba(184,148,58,.2)}

/* FORMS */
.form-group{margin-bottom:14px}
.form-label{font-size:11.5px;font-weight:600;color:var(--t2);margin-bottom:5px;display:block;letter-spacing:.2px}
.form-input{width:100%;background:var(--s2);border:1px solid rgba(107,158,120,.15);border-radius:9px;padding:10px 13px;color:var(--t1);outline:none;transition:border .2s}
.form-input:focus{border-color:rgba(107,158,120,.4)}
.form-input::placeholder{color:var(--t3)}
.char-cnt{font-size:10px;color:var(--t3);text-align:right;margin-top:3px}
.type-pills{display:flex;gap:7px;flex-wrap:wrap}
.type-pill{padding:7px 12px;border-radius:9px;border:1px solid var(--b);background:var(--s3);color:var(--t2);font-size:12px;font-weight:600;cursor:pointer;transition:all .18s}
.type-pill.on{border-color:var(--gg);background:var(--gs);color:var(--g)}
.draft-notice{background:rgba(184,148,58,.06);border:1px solid rgba(184,148,58,.2);border-radius:9px;padding:11px 13px;margin-bottom:16px;font-size:12px;color:var(--amber);line-height:1.55}
.submit-btn{width:100%;background:var(--g);color:#fff;font-weight:700;padding:13px;border-radius:10px;font-size:14px;border:none;cursor:pointer;transition:background .2s;margin-top:18px}
.submit-btn:hover{background:var(--g1)}
.info-box{background:var(--s2);border:1px solid var(--b);border-radius:9px;padding:11px;margin-bottom:14px;font-size:11.5px;color:var(--t2);line-height:1.6}
.info-box strong{color:var(--g)}
.green-box{background:var(--gs);border:1px solid rgba(107,158,120,.15);border-radius:9px;padding:11px;margin-bottom:12px}
.green-box-title{font-size:11px;color:var(--g);font-weight:600;margin-bottom:3px}
.green-box-body{font-size:10.5px;color:var(--t2);line-height:1.5}

/* PRICING */
.pricing-hero{text-align:center;padding:24px 20px 18px}
.pricing-card{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:18px 16px;margin-bottom:10px;transition:all .2s;position:relative}
.pricing-card.featured{border-color:rgba(107,158,120,.3);background:linear-gradient(135deg,#0d1810,var(--s2))}
.pricing-plan{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--t3);margin-bottom:5px}
.pricing-card.featured .pricing-plan{color:var(--g)}
.pricing-price{font-size:28px;font-weight:800;margin-bottom:4px}
.pricing-price span{font-size:13px;font-weight:400;color:var(--t2)}
.pricing-desc{font-size:12px;color:var(--t2);margin-bottom:14px}
.pricing-features{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.pf-item{font-size:12.5px;display:flex;align-items:center;gap:8px;color:var(--t1)}
.pf-item::before{content:'✓';color:var(--g);font-weight:800;flex-shrink:0}
.pf-no::before{content:'✗';color:var(--red)}
.pf-no{color:var(--t3)}
.pricing-btn{width:100%;padding:13px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .2s}
.pricing-btn.primary{background:var(--g);color:#fff}
.pricing-btn.primary:hover{background:var(--g1)}
.pricing-btn.ghost{background:transparent;border:1px solid var(--b2);color:var(--t2)}
.pricing-btn.ghost:hover{border-color:var(--gg);color:var(--g)}
.popular-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--g);color:#fff;font-size:9px;font-weight:800;padding:2px 12px;border-radius:0 0 7px 7px;letter-spacing:.4px}

/* ADMIN */
.admin-tabs{display:flex;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--b);background:var(--s1)}
.admin-tabs::-webkit-scrollbar{display:none}
.admin-tab{font-size:11.5px;font-weight:600;padding:11px 13px;color:var(--t3);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;flex-shrink:0}
.admin-tab.on{color:var(--g);border-bottom-color:var(--g)}
.admin-body{padding:14px 20px;padding-bottom:80px}
.admin-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
@media(min-width:900px){.admin-stat-grid{grid-template-columns:repeat(3,1fr)}}
.admin-stat{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:13px 11px}
.admin-stat-label{font-size:9.5px;color:var(--t3);font-weight:600;letter-spacing:.4px;text-transform:uppercase;margin-bottom:5px}
.admin-stat-num{font-size:22px;font-weight:800;line-height:1}
.admin-stat-change{font-size:10px;color:var(--g);margin-top:4px}
.admin-row{background:var(--s2);border:1px solid var(--b);border-radius:var(--r);padding:11px 13px;display:flex;align-items:center;gap:9px;margin-bottom:7px}
.admin-row-info{flex:1;min-width:0}
.admin-row-title{font-size:12.5px;font-weight:600;margin-bottom:2px}
.admin-row-meta{font-size:10.5px;color:var(--t3)}
.admin-btns{display:flex;gap:5px;flex-shrink:0;flex-wrap:wrap}
.toggle-row{display:flex;align-items:center;justify-content:space-between;background:var(--s2);border:1px solid var(--b);border-radius:var(--r);padding:11px 13px;margin-bottom:7px;gap:10px}
.toggle-info{flex:1;min-width:0}
.toggle-title{font-size:12.5px;font-weight:600;margin-bottom:2px}
.toggle-desc{font-size:10px;color:var(--t3)}
.toggle{width:42px;height:23px;background:var(--s4);border-radius:12px;border:1px solid var(--b2);cursor:pointer;position:relative;transition:all .28s;flex-shrink:0}
.toggle.on{background:var(--g);border-color:var(--g)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:17px;height:17px;background:#fff;border-radius:50%;transition:left .28s}
.toggle.on::after{left:21px}

/* MODALS */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(5px);z-index:600;display:none;align-items:flex-end;justify-content:center;padding:0;overflow-y:auto}
.modal-bg.open{display:flex}
.modal-sheet{background:var(--s1);border:1px solid var(--b2);border-radius:var(--rx) var(--rx) 0 0;width:100%;max-width:560px;margin:auto 0 0;box-shadow:0 -20px 50px rgba(0,0,0,.5);max-height:92vh;overflow-y:auto;padding:0 0 24px}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-bg.open .modal-sheet{animation:sheetUp .28s ease}
.modal-handle{width:36px;height:4px;background:var(--b2);border-radius:2px;margin:12px auto 16px}
.modal-body{padding:0 22px 10px}
.modal-title{font-size:18px;font-weight:800;margin-bottom:5px;letter-spacing:-.3px}
.modal-sub{font-size:12px;color:var(--t2);margin-bottom:18px;line-height:1.55}
.modal-inp{width:100%;background:var(--s3);border:1px solid rgba(107,158,120,.15);border-radius:9px;padding:11px 13px;font-size:14px;color:var(--t1);outline:none;margin-bottom:10px;transition:border .2s}
.modal-inp:focus{border-color:rgba(107,158,120,.4)}
.modal-inp::placeholder{color:var(--t3)}
.modal-btn{width:100%;background:var(--g);border:none;border-radius:10px;padding:13px;font-size:13.5px;font-weight:700;color:#fff;cursor:pointer;transition:background .2s;margin-top:4px}
.modal-btn:hover{background:var(--g1)}
.modal-btn-ghost{width:100%;background:transparent;border:1px solid var(--b2);color:var(--t2);border-radius:10px;padding:12px;font-size:13px;font-weight:600;cursor:pointer;margin-top:7px}
.modal-skip{display:block;text-align:center;font-size:11px;color:var(--t3);margin-top:10px;cursor:pointer}
.modal-skip:hover{color:var(--t1)}
.tc-accept{display:flex;align-items:flex-start;gap:9px;background:var(--s2);border:1px solid var(--b);border-radius:9px;padding:11px 13px;margin-bottom:14px}
.tc-check{width:16px;height:16px;border:1.5px solid var(--gg);border-radius:4px;flex-shrink:0;cursor:pointer;margin-top:2px;position:relative;background:transparent;transition:all .15s}
.tc-check.checked{background:var(--g);border-color:var(--g)}
.tc-check.checked::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:800}
.tc-text{font-size:11px;color:var(--t2);line-height:1.5}
.tc-text a{color:var(--g)}
.wallet-list{display:flex;flex-direction:column;gap:5px;margin:9px 0}
.wallet-item{display:flex;align-items:center;gap:8px;background:var(--s3);border:1px solid var(--b);border-radius:7px;padding:7px 10px}
.w-coin{font-size:10px;font-weight:700;color:var(--g);min-width:38px}
.w-addr{font-size:9px;color:var(--t2);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.w-copy{font-size:10px;color:var(--t3);cursor:pointer;flex-shrink:0;padding:2px 7px;border:1px solid var(--b);border-radius:5px;transition:color .15s}
.w-copy:hover{color:var(--g);border-color:var(--gg)}
.plans-grid{display:flex;flex-direction:column;gap:9px;margin-bottom:14px}
.plan-card{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:14px;cursor:pointer;transition:all .18s;position:relative}
.plan-card:hover,.plan-card.on{border-color:var(--gg);background:var(--gs)}
.plan-card.on::after{content:'✓';position:absolute;top:10px;right:12px;font-size:14px;color:var(--g);font-weight:800}
.plan-popular{position:absolute;top:-8px;left:50%;transform:translateX(-50%);background:var(--g);color:#fff;font-size:9px;font-weight:800;padding:2px 10px;border-radius:8px}
.plan-name{font-size:13px;font-weight:700;margin-bottom:3px}
.plan-price{font-size:20px;font-weight:800;color:var(--g);margin-bottom:3px}
.plan-features{list-style:none;font-size:11px;color:var(--t2);margin-top:7px;display:flex;flex-direction:column;gap:3px}
.plan-features li::before{content:'✓ ';color:var(--g);font-weight:700}
.plan-features li.no::before{content:'✗ ';color:var(--red)}
.name-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.name-chip{background:var(--s3);border:1px solid var(--gg);border-radius:20px;padding:4px 11px;font-size:11px;color:var(--g);cursor:pointer;font-weight:500;transition:all .15s}
.name-chip:hover{background:var(--gs)}

/* BOTTOM NAV */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:200;height:54px;background:rgba(20,20,20,.97);backdrop-filter:blur(12px);border-top:1px solid var(--b);display:flex;align-items:center;justify-content:space-around;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0)}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;padding:5px 4px;border-radius:8px;color:var(--t3);border:none;background:none;transition:color .15s}
.bn.on{color:var(--g)}
.bn-icon{font-size:17px;line-height:1}
.bn-label{font-size:9px;font-weight:600}

/* FOOTER */
footer{background:var(--s1);border-top:1px solid var(--b);margin-top:0;padding-bottom:60px}
@media(min-width:900px){footer{padding-bottom:0}}
.footer-ticker{background:rgba(107,158,120,.04);border-bottom:1px solid rgba(107,158,120,.08);overflow:hidden;height:36px;display:flex;align-items:center}
.footer-body{padding:30px 20px 16px}
.footer-body-inner{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:600px){.footer-body-inner{grid-template-columns:1fr 1fr 1fr}}
.footer-brand-name{font-size:18px;font-weight:800;letter-spacing:-.3px;margin-bottom:5px}
.footer-brand-name span{color:var(--g)}
.footer-brand-desc{font-size:11px;color:var(--t2);line-height:1.65;margin-bottom:12px;max-width:300px}
.footer-col h4{font-size:10.5px;font-weight:700;color:var(--t1);text-transform:uppercase;letter-spacing:.7px;margin-bottom:11px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:7px}
.footer-links a{font-size:12px;color:var(--t3);transition:color .15s}
.footer-links a:hover{color:var(--g)}
.footer-bottom{border-top:1px solid var(--b);padding:14px 20px}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;font-size:10px;color:var(--t3);flex-wrap:wrap;gap:6px}
.footer-bottom-inner a{color:var(--t3)}
.footer-bottom-inner a:hover{color:var(--g)}

/* TOAST */
.toast{position:fixed;bottom:72px;left:50%;transform:translateX(-50%) translateY(8px);background:var(--s1);border:1px solid var(--b2);border-radius:9px;padding:10px 18px;font-size:12px;color:var(--t1);z-index:9999;opacity:0;transition:all .3s;pointer-events:none;white-space:nowrap;box-shadow:0 8px 30px rgba(0,0,0,.4);max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:var(--gg);color:#85c293}
.toast.err{border-color:rgba(192,80,80,.35);color:#e88080}

/* ==== HOMEPAGE AD BANNERS ==== */
.qonvo-banner-wrap{padding:0 8px;margin:14px 0}
@media(min-width:600px){.qonvo-banner-wrap{padding:0 20px;margin:16px 0}}
@media(min-width:900px){.qonvo-banner-wrap{padding:0 24px;margin:18px 0;max-width:1280px;margin-left:auto;margin-right:auto}}
.qonvo-banner{display:block;width:100%;border-radius:12px;overflow:hidden;position:relative;background:linear-gradient(135deg,rgba(107,158,120,.18),rgba(107,158,120,.08),rgba(0,0,0,.4));border:1px solid var(--gg);min-height:90px;text-decoration:none;color:inherit;transition:all .25s;display:flex;align-items:center;justify-content:center}
.qonvo-banner:hover{transform:translateY(-2px);border-color:var(--g)}
.qonvo-banner img{display:block;width:100%;height:auto;max-height:200px;object-fit:cover}
.qonvo-banner-overlay{padding:18px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.qonvo-banner-tag{font-size:9.5px;font-weight:800;letter-spacing:1.4px;color:#fff;background:rgba(255,255,255,.15);padding:3px 9px;border-radius:4px}
.qonvo-banner-text{font-size:13.5px;font-weight:600;color:#fff;line-height:1.4;max-width:520px}
@media(min-width:600px){.qonvo-banner{min-height:110px}.qonvo-banner-text{font-size:15px}}
@media(min-width:900px){.qonvo-banner{min-height:130px}.qonvo-banner-text{font-size:17px;max-width:600px}}

/* Comment system */
.comments-wrap{padding:14px;margin-top:10px;border-top:1px solid var(--b)}
.comments-hd{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.comments-hd-count{background:var(--gs);color:var(--g);padding:2px 8px;border-radius:9px;font-size:11px;font-weight:600}
.comment-compose{display:flex;gap:10px;align-items:flex-start;background:var(--s2);border:1px solid var(--b);border-radius:12px;padding:10px;margin-bottom:14px}
.comment-compose-av{width:32px;height:32px;border-radius:50%;background:rgba(107,158,120,.15);color:var(--g);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:13px}
.comment-compose-input{flex:1}
.comment-compose-input textarea{width:100%;background:transparent;border:0;color:var(--t1);font-family:inherit;font-size:13px;resize:none;min-height:48px;outline:none}
.comment-compose-actions{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-top:6px}
.comment-post-btn{background:var(--g);color:#fff;border:0;padding:6px 14px;border-radius:7px;font-size:11.5px;font-weight:700;cursor:pointer}
.comment-post-btn:hover{background:var(--g1)}
.comment-card{display:flex;gap:10px;padding:10px;border-bottom:1px solid var(--b)}
.comment-card:last-child{border-bottom:0}
.comment-card.is-reply{margin-left:42px;border-left:2px solid var(--gg);padding-left:14px;background:rgba(107,158,120,.03)}
.comment-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:13px}
.comment-body{flex:1;min-width:0}
.comment-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}
.comment-username{font-size:13px;font-weight:600;color:var(--t1)}
.comment-time{font-size:11px;color:var(--t3)}
.comment-text{font-size:13px;color:var(--t1);line-height:1.5;word-wrap:break-word}
.comment-actions{display:flex;align-items:center;gap:14px;margin-top:8px;font-size:11.5px;color:var(--t3)}
.comment-act{display:flex;align-items:center;gap:4px;cursor:pointer;transition:color .15s}
.comment-act:hover{color:var(--g)}
.comment-act.liked{color:var(--red)}

/* Onboarding overlay */
.onboarding-step{padding:24px;text-align:center}
.onb-icon{font-size:48px;margin-bottom:14px}
.onb-title{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--t1)}
.onb-desc{font-size:13px;color:var(--t2);line-height:1.5;margin-bottom:18px}
.onb-dots{display:flex;justify-content:center;gap:6px;margin:14px 0}
.onb-dot{width:8px;height:8px;border-radius:50%;background:var(--b2);transition:all .25s}
.onb-dot.on{background:var(--g);width:24px;border-radius:4px}
/* ====================================================================
   WORDPRESS INTEGRATION ADDITIONS — match design source language
   ==================================================================== */

/* Show WP admin bar offset */
body.admin-bar #app { padding-top: 32px; }
@media (max-width: 782px) {
    body.admin-bar #app { padding-top: 46px; }
}

/* Notification bell in top nav */
.notif-bell {
    width: 36px; height: 36px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    background: var(--b2);
    cursor: pointer;
    position: relative;
    font-size: 18px;
    transition: background 0.15s;
}
.notif-bell:hover { background: var(--b3); }
.notif-count {
    position: absolute;
    top: -2px; right: -2px;
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    border-radius: 10px;
    padding: 1px 5px;
    min-width: 16px;
    text-align: center;
}

/* Language picker dropdown */
.lang-picker-dropdown {
    position: absolute;
    top: 44px; right: 0;
    background: var(--b1);
    border: 1px solid var(--ln);
    border-radius: 12px;
    padding: 12px;
    width: 260px;
    max-height: 360px;
    overflow-y: auto;
    box-shadow: 0 10px 32px rgba(0,0,0,0.6);
    z-index: 100;
    display: none;
}
.lang-picker-dropdown.open { display: block; }
.lang-header {
    font-size: 12px;
    color: var(--t3);
    padding: 6px 4px;
}
.lang-option {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 10px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
}
.lang-option:hover { background: var(--b2); }
.lang-option.active { background: var(--g); color: #fff; }
.lang-flag { font-size: 18px; }

/* Reactions on chat messages */
.msg-reactions {
    display: flex; gap: 4px;
    margin-top: 4px;
    flex-wrap: wrap;
}
.reaction-chip {
    display: inline-flex; align-items: center; gap: 3px;
    background: var(--b2);
    border: 1px solid var(--ln);
    border-radius: 12px;
    padding: 2px 8px;
    font-size: 11px;
    cursor: pointer;
    transition: all 0.15s;
}
.reaction-chip.mine { background: rgba(34,197,94,0.15); border-color: var(--g); }
.reaction-chip:hover { background: var(--b3); }

/* Typing indicator */
.typing-indicator {
    padding: 6px 12px;
    color: var(--t3);
    font-size: 12px;
    font-style: italic;
}

/* Translated banner above messages */
.translated-from {
    font-size: 10px;
    color: var(--t3);
    margin-top: 2px;
    cursor: pointer;
}
.translated-from:hover { text-decoration: underline; }

/* Online dot on avatars */
.online-dot {
    position: absolute;
    bottom: 0; right: 0;
    width: 10px; height: 10px;
    background: #22c55e;
    border: 2px solid var(--b);
    border-radius: 50%;
}

/* Forum poll */
.forum-poll {
    margin-top: 8px;
    padding: 10px;
    background: var(--b2);
    border-radius: 10px;
}
.poll-opt {
    display: block;
    padding: 8px 12px;
    background: var(--b1);
    border: 1px solid var(--ln);
    border-radius: 8px;
    margin: 4px 0;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: all 0.15s;
    font-size: 13px;
}
.poll-opt:hover { background: var(--b3); }
.poll-opt.voted-mine { border-color: var(--g); background: rgba(34,197,94,0.1); }
.poll-bar {
    position: absolute;
    top: 0; left: 0; bottom: 0;
    background: rgba(34,197,94,0.18);
    transition: width 0.4s ease;
}
.poll-opt-label { position: relative; z-index: 1; display: flex; justify-content: space-between; }

/* PRO badge */
.pro-badge {
    display: inline-block;
    background: linear-gradient(135deg, #f59e0b, #f97316);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    margin-left: 4px;
}
.verified-badge {
    display: inline-block;
    color: #3b82f6;
    margin-left: 4px;
    font-size: 14px;
}

/* Trending tags row */
.trending-row {
    display: flex; align-items: center; gap: 10px;
    padding: 12px;
    background: var(--b1);
    border-radius: 12px;
    margin-bottom: 8px;
    cursor: pointer;
    transition: background 0.15s;
}
.trending-row:hover { background: var(--b2); }
.trending-rank {
    font-size: 18px;
    font-weight: 700;
    color: var(--g);
    width: 30px;
    text-align: center;
}
.trending-name { flex: 1; font-weight: 600; font-size: 15px; }
.trending-meta { font-size: 11px; color: var(--t3); }
.trending-fire { color: #f97316; }

/* Leaderboard row */
.leaderboard-row {
    display: flex; align-items: center; gap: 12px;
    padding: 12px;
    background: var(--b1);
    border-radius: 12px;
    margin-bottom: 8px;
}
.leaderboard-rank {
    font-size: 20px;
    font-weight: 700;
    width: 36px;
    text-align: center;
    color: var(--t3);
}
.leaderboard-row:nth-child(1) .leaderboard-rank { color: #fbbf24; }
.leaderboard-row:nth-child(2) .leaderboard-rank { color: #94a3b8; }
.leaderboard-row:nth-child(3) .leaderboard-rank { color: #f97316; }
.leaderboard-info { flex: 1; }
.leaderboard-name { font-weight: 700; font-size: 14px; }
.leaderboard-stats { font-size: 11px; color: var(--t3); margin-top: 2px; }
.leaderboard-points {
    font-weight: 700;
    color: var(--g);
    font-size: 14px;
}

/* FAQ accordion */
.faq-item {
    border-bottom: 1px solid var(--ln);
    padding: 12px 0;
    cursor: pointer;
}
.faq-item h4 {
    font-size: 14px;
    font-weight: 600;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.faq-item h4::after {
    content: '+';
    font-size: 18px;
    color: var(--t3);
    transition: transform 0.2s;
}
.faq-item.open h4::after { content: '−'; }
.faq-answer {
    display: none;
    margin-top: 8px;
    font-size: 13px;
    color: var(--t2);
    line-height: 1.6;
}
.faq-item.open .faq-answer { display: block; }

/* Bookmarks filter */
.bookmarks-filter {
    display: flex; gap: 8px;
    overflow-x: auto;
    margin-bottom: 12px;
    padding-bottom: 4px;
}
.bookmarks-filter button {
    padding: 6px 14px;
    background: var(--b1);
    border: 1px solid var(--ln);
    color: var(--t1);
    border-radius: 16px;
    font-size: 12px;
    white-space: nowrap;
    cursor: pointer;
}
.bookmarks-filter button.active {
    background: var(--g);
    color: #fff;
    border-color: var(--g);
}

/* 2FA QR */
.tfa-qr-wrap {
    display: inline-block;
    padding: 14px;
    background: #fff;
    border-radius: 12px;
}
.tfa-code {
    font-family: monospace;
    font-size: 14px;
    letter-spacing: 1px;
    background: var(--b2);
    padding: 8px 14px;
    border-radius: 8px;
    display: inline-block;
    margin-top: 6px;
}

/* Privacy radio groups */
.privacy-section {
    background: var(--b1);
    padding: 14px;
    border-radius: 12px;
    margin-bottom: 12px;
}
.privacy-section h4 {
    font-size: 14px;
    margin: 0 0 10px;
    font-weight: 700;
}
.privacy-section label {
    display: flex; align-items: center; gap: 10px;
    padding: 6px 0;
    cursor: pointer;
    font-size: 13px;
}
.privacy-section input[type="radio"],
.privacy-section input[type="checkbox"] {
    width: 16px; height: 16px;
    accent-color: var(--g);
}

/* Activity log items */
.activity-item {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--ln);
    font-size: 13px;
}
.activity-item .a-bullet {
    width: 6px; height: 6px;
    background: var(--g);
    border-radius: 50%;
    margin-top: 6px;
    flex-shrink: 0;
}
.activity-item .a-title { font-weight: 600; }
.activity-item .a-detail { color: var(--t3); font-size: 11px; margin-top: 2px; }
.activity-item .a-time { color: var(--t3); font-size: 11px; }

/* QR invite */
.qr-invite-box {
    text-align: center;
    background: var(--b1);
    padding: 20px;
    border-radius: 14px;
}
.invite-link {
    background: var(--b2);
    padding: 10px;
    border-radius: 8px;
    font-family: monospace;
    font-size: 12px;
    margin-top: 12px;
    word-break: break-all;
}

/* Notification list items */
.notif-item {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 12px;
    border-bottom: 1px solid var(--ln);
    cursor: pointer;
    transition: background 0.15s;
}
.notif-item.unread { background: rgba(34,197,94,0.06); }
.notif-item:hover { background: var(--b2); }
.notif-dot {
    width: 8px; height: 8px;
    background: var(--g);
    border-radius: 50%;
    margin-top: 8px;
}
.notif-item:not(.unread) .notif-dot { background: transparent; }
.notif-msg { flex: 1; font-size: 13px; }
.notif-time { font-size: 11px; color: var(--t3); margin-top: 2px; }

/* Screen header action button */
.screen-hd-action {
    background: transparent;
    border: 1px solid var(--ln);
    color: var(--t2);
    padding: 4px 12px;
    border-radius: 14px;
    font-size: 12px;
    cursor: pointer;
}

/* Modal input baseline */
.modal-inp {
    width: 100%;
    background: var(--b1);
    border: 1px solid var(--ln);
    border-radius: 10px;
    padding: 12px;
    color: var(--t1);
    font-size: 14px;
    margin-bottom: 10px;
    font-family: inherit;
}
.modal-inp:focus { outline: none; border-color: var(--g); }

.modal-btn {
    width: 100%;
    background: var(--g);
    color: #fff;
    border: none;
    border-radius: 10px;
    padding: 14px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    margin-top: 6px;
    transition: opacity 0.15s;
}
.modal-btn:hover { opacity: 0.9; }
.modal-btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Sub-hint paragraph */
.sub-hint { font-size: 13px; color: var(--t3); margin-bottom: 14px; line-height: 1.5; }

/* Info box (yellow) */
.info-box {
    background: rgba(251,191,36,0.1);
    border: 1px solid rgba(251,191,36,0.3);
    color: #fbbf24;
    padding: 10px 14px;
    border-radius: 10px;
    font-size: 13px;
    margin-bottom: 14px;
}

/* Segmented tabs */
.seg-tabs {
    display: flex;
    background: var(--b1);
    border-radius: 10px;
    padding: 4px;
    margin-bottom: 12px;
}
.seg-tab {
    flex: 1;
    background: transparent;
    border: none;
    padding: 8px;
    font-size: 13px;
    color: var(--t2);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s;
}
.seg-tab.on {
    background: var(--g);
    color: #fff;
    font-weight: 600;
}

/* Toast notification */
.qonvo-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--b3);
    color: var(--t1);
    padding: 12px 20px;
    border-radius: 24px;
    font-size: 14px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
    z-index: 9999;
    animation: qonvoToastIn 0.25s ease-out;
}
@keyframes qonvoToastIn {
    from { opacity: 0; transform: translate(-50%, 20px); }
    to { opacity: 1; transform: translate(-50%, 0); }
}

/* Skeleton loaders */
.skeleton-row {
    background: var(--b1);
    border-radius: 12px;
    padding: 14px;
    margin-bottom: 8px;
    animation: skeletonPulse 1.4s ease-in-out infinite;
}
@keyframes skeletonPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.55; }
}
.skeleton-line {
    height: 12px;
    background: var(--b2);
    border-radius: 6px;
    margin: 6px 0;
}
.skeleton-line.short { width: 40%; }

/* ====================================================================
   SESSION 10 — REAL-TIME CHAT VISUAL STATES
   ==================================================================== */

/* Pending message — sender's optimistic placeholder before server confirms */
.msg-pending .msg-bubble {
    opacity: 0.65;
    transition: opacity 0.3s ease;
}
.msg-pending .msg-status {
    color: var(--t3);
    font-size: 11px;
    font-style: italic;
}
.msg-pending .msg-status::after {
    content: '';
    display: inline-block;
    width: 4px;
    height: 4px;
    background: var(--t3);
    border-radius: 50%;
    margin-left: 4px;
    animation: qonvoPendingDot 1s infinite;
    vertical-align: middle;
}
@keyframes qonvoPendingDot {
    0%, 100% { opacity: 0.3; }
    50% { opacity: 1; }
}

/* Failed message — surfaced retry control */
.msg-failed .msg-bubble {
    opacity: 0.85;
    border-left: 3px solid #ef4444;
    padding-left: 10px;
}
.msg-failed .msg-status {
    color: #ef4444;
    font-size: 11px;
    font-weight: 600;
}

/* Typing indicator — bouncing dot animation */
.typing-indicator {
    padding: 8px 14px;
    color: var(--t3);
    font-size: 12px;
    font-style: italic;
    display: flex;
    align-items: center;
    gap: 6px;
    line-height: 1.4;
}
.typing-indicator::before {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    background: var(--t3);
    border-radius: 50%;
    animation: qonvoTypingBounce 1.4s infinite ease-in-out;
    box-shadow: 8px 0 0 var(--t3), 16px 0 0 var(--t3);
}
@keyframes qonvoTypingBounce {
    0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
    30% { transform: translateY(-4px); opacity: 1; }
}

/* Per-room unread badge — used in rooms list */
.room-unread-badge {
    display: inline-block;
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    border-radius: 10px;
    padding: 1px 6px;
    min-width: 18px;
    text-align: center;
    margin-left: 6px;
    vertical-align: middle;
}

/* Smooth fade-in on newly arrived messages */
.msg-row {
    animation: qonvoMsgIn 0.18s ease-out;
}
@keyframes qonvoMsgIn {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ====================================================================
   SESSION 15 — THREE-STATE THEME TOGGLE
   ==================================================================== */

/* Dark mode (default — uses the base CSS variables) */
body.theme-dark { /* uses default :root vars */ }

/* Light mode — inverts the background/text scheme */
body.theme-light {
    --b0: #ffffff;
    --b1: #f5f5f7;
    --b2: #e8e8ed;
    --t1: #1a1a1a;
    --t2: #4a4a4a;
    --t3: #888888;
    --ln: rgba(0,0,0,0.1);
}

/* Pure black mode — for OLED screens, maximum contrast */
body.theme-pure-black {
    --b0: #000000;
    --b1: #0a0a0a;
    --b2: #161616;
    --t1: #ffffff;
    --t2: #cccccc;
    --t3: #888888;
    --ln: rgba(255,255,255,0.06);
}

/* Theme toggle button visual cue */
.theme-mode-toggle {
    cursor: pointer;
    padding: 6px 10px;
    border-radius: 8px;
    background: var(--b1);
    border: 1px solid var(--ln);
    font-size: 12px;
    color: var(--t2);
}
.theme-mode-toggle:hover {
    background: var(--b2);
}

/* Sticker picker scrollbar */
#qonvoStickerPicker::-webkit-scrollbar {
    width: 6px;
}
#qonvoStickerPicker::-webkit-scrollbar-thumb {
    background: var(--ln);
    border-radius: 3px;
}

/* Disclaimer styling */
.qonvo-disclaimer {
    line-height: 1.4;
}
.qonvo-disclaimer-top {
    border-bottom: 1px solid var(--ln);
}
.qonvo-disclaimer-bottom {
    border-top: 1px solid var(--ln);
}

/* Badge card classes — primarily for JS hooks, styling is applied inline */
.badge-card { transition: transform 0.15s ease, box-shadow 0.15s ease; }
.badge-card:hover { transform: translateY(-1px); }
.badge-unlocked { /* inline styles applied per badge by JS */ }
.badge-locked { /* inline styles applied per badge by JS */ }
