.side-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}.side-drawer-overlay.open{opacity:1;visibility:visible}.side-drawer{position:fixed;top:0;left:0;bottom:0;width:78%;max-width:320px;background:#1a1a1e;z-index:1001;transform:translate(-100%);transition:transform .25s ease;overflow-y:auto;box-shadow:4px 0 24px #0006}.side-drawer.open{transform:translate(0)}.drawer-inner{padding:16px 0 24px;min-height:100%;display:flex;flex-direction:column}.drawer-user{display:flex;align-items:center;gap:12px;padding:12px 16px 8px}.drawer-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#2d2d3a,#1e1e24);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.drawer-user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.drawer-username{font-size:16px;font-weight:600;color:#fff}.drawer-user-id{font-size:12px;color:#fff9;display:flex;align-items:center;gap:4px}.drawer-copy{padding:0 4px;background:none;border:none;color:#ffffff80;font-size:12px;cursor:pointer}.drawer-arrow{padding:8px;background:none;border:none;color:#ffffff80;font-size:20px;cursor:pointer}.drawer-vip{display:flex;align-items:center;gap:8px;padding:0 16px 16px;font-size:12px;color:#ffffffb3}.drawer-vip-bar{flex:1;height:6px;background:#ffffff26;border-radius:3px;overflow:hidden}.drawer-vip-fill{height:100%;background:linear-gradient(90deg,#facc15,#4ade80);border-radius:3px}.drawer-vip-pct{min-width:28px;text-align:right}.drawer-menu{display:flex;flex-direction:column;padding:0 8px}.drawer-menu-item{display:flex;align-items:center;gap:12px;padding:14px 12px;background:none;border:none;border-radius:10px;color:#fff;font-size:15px;text-align:left;width:100%;cursor:pointer;transition:background .15s}.drawer-menu-item:hover,.drawer-menu-item:active{background:#ffffff14}.drawer-menu-icon{font-size:20px;width:28px;text-align:center;color:#ffffffd9}.drawer-menu-label{flex:1}.drawer-menu-label.highlight{color:#facc15}.drawer-menu-arrow{color:#fff6;font-size:18px}.drawer-app{padding:16px}.drawer-app-bg{background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.drawer-app-title{font-size:18px;font-weight:700;color:#fff}.drawer-app-desc{font-size:13px;color:#ffffffe6}.drawer-app-btn{align-self:flex-start;padding:10px 20px;font-size:14px;font-weight:600;color:#166534;background:#fff;border:none;border-radius:10px;cursor:pointer;margin-top:4px}.drawer-section-title{display:block;font-size:14px;font-weight:600;color:#fff;margin-bottom:10px;padding:0 16px}.drawer-social{padding:8px 16px 16px}.drawer-social-icons{display:flex;gap:12px;flex-wrap:wrap}.drawer-social-icon{width:40px;height:40px;border-radius:50%;background:#2d2d35;border:none;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer}.drawer-legal{padding:0 16px 16px}.drawer-legal-links{display:flex;flex-wrap:wrap;gap:8px 16px}.drawer-link{background:none;border:none;color:#ffffffa6;font-size:13px;cursor:pointer;padding:0}.drawer-coins{padding:0 16px 16px}.drawer-coins-row{display:flex;gap:12px}.coin-badge{width:36px;height:36px;border-radius:50%;background:#22c55e;color:#fff;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center}.coin-badge.trx{background:#ef4444}.coin-badge:last-of-type{background:#3b82f6}.drawer-age{padding:0 16px 24px}.drawer-age-badge{display:inline-flex;width:44px;height:44px;border-radius:50%;border:2px solid rgba(255,255,255,.5);align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff}.drawer-footer{margin-top:auto;padding:16px 16px 24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0));display:flex;align-items:center;gap:16px;border-top:1px solid rgba(255,255,255,.08)}.drawer-footer-item{display:flex;align-items:center;gap:6px;background:none;border:none;color:#ffffffd9;font-size:14px;cursor:pointer;padding:0}.drawer-footer-icon{font-size:18px}.drawer-lang,.drawer-settings{width:40px;height:40px;padding:0;justify-content:center;border-radius:50%;background:#ffffff14;font-size:20px}.layout{min-height:100%;display:flex;flex-direction:column;background:#0d0d0f;color:#e5e5e5}.header{position:sticky;top:0;z-index:100;background:#12121a;border-bottom:1px solid rgba(255,255,255,.08)}.header-simple .header-inner{height:48px}.header-home .header-inner{height:52px;padding:0 12px}.header-logo{display:flex;align-items:center;justify-content:center;background:none;border:none;padding:0;cursor:pointer}.header-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#2d2d3a,#1e1e24);display:flex;align-items:center;justify-content:center;font-size:24px}.header-balance-wrap{display:flex;align-items:center;gap:6px;flex:1;min-width:0;justify-content:center}.header-coin{font-size:18px}.header-balance{font-size:15px;font-weight:600;color:#fff}.header-gift{font-size:16px;opacity:.9}.header-chevron{font-size:12px;color:#fff9}.header-wallet{position:relative;width:44px;height:36px;display:flex;align-items:center;justify-content:center;background:#4ade80;border:none;border-radius:8px;font-size:20px;cursor:pointer}.header-icon-btn{position:relative;width:40px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:20px;cursor:pointer}.header-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:600;color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center}.header-badge.green{background:#22c55e}.header-badge.red{background:#ef4444}.logo-wrap{display:flex;align-items:center;cursor:pointer}.logo-text{font-size:18px;font-weight:700;color:#fff;letter-spacing:.02em}.header-actions{display:flex;align-items:center;gap:8px}.btn-login{padding:6px 12px;font-size:14px;color:#fff;background:none;border:none;cursor:pointer}.btn-register-wrap{position:relative}.register-badge{position:absolute;top:-6px;right:-4px;padding:1px 4px;font-size:10px;color:#fff;background:#e63950;border-radius:4px}.btn-register{padding:8px 18px;font-size:14px;font-weight:500;color:#fff;background:#4ade80;border:none;border-radius:8px;cursor:pointer}.header-inner{display:flex;align-items:center;justify-content:space-between;padding:0 16px;max-width:100%}.header-home .header-inner{padding:0 12px}.nav-primary{display:flex;gap:4px;padding:0 12px 10px;overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-primary-item{flex-shrink:0;padding:8px 14px;font-size:14px;color:#ffffffb3;background:transparent;border:none;border-radius:8px;cursor:pointer}.nav-primary-item.active{color:#fff;background:#4ade8040;border-bottom:2px solid #4ade80}.main{flex:1;overflow-y:auto;padding-bottom:60px}.tabbar{position:fixed;bottom:0;left:0;right:0;max-width:430px;margin:0 auto;display:flex;justify-content:space-around;align-items:center;height:56px;padding-bottom:env(safe-area-inset-bottom,0);background:#12121a;border-top:1px solid rgba(255,255,255,.08);z-index:99}.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 0;background:none;border:none;color:#fff9;font-size:11px;cursor:pointer}.tab.active{color:#4ade80}.tab-icon{font-size:20px}.page-home{padding-bottom:80px;background:#0d0d0f;color:#e5e5e5}.home-banner{position:relative;margin:0 12px 12px;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#1a2e1a,#0d1a0d);min-height:140px}.home-banner-inner{display:flex;align-items:center;justify-content:space-between;padding:20px 16px}.home-banner-left{display:flex;flex-direction:column;gap:4px}.home-banner-brand{font-size:12px;color:#4ade80;font-weight:600}.home-banner-title{font-size:20px;font-weight:700;color:#fff}.home-banner-value{font-size:24px;font-weight:800;color:#4ade80}.home-banner-cta{margin-top:10px;padding:10px 24px;font-size:14px;font-weight:600;color:#fff;background:#4ade80;border:none;border-radius:10px;cursor:pointer;align-self:flex-start}.home-banner-visual{width:120px;height:100px;background:radial-gradient(circle at 50% 50%,rgba(74,222,128,.2),transparent);border-radius:12px}.home-banner-dots{position:absolute;bottom:10px;left:0;right:0;display:flex;justify-content:center;gap:6px}.home-banner-dots .dot{width:6px;height:6px;border-radius:50%;background:#fff6}.home-banner-dots .dot.active{background:#4ade80}.home-section{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.home-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.home-section-title{font-size:16px;font-weight:600;color:#fff;margin:0}.home-link-all{font-size:14px;color:#4ade80;background:none;border:none;cursor:pointer;padding:0}.home-tabs{display:flex;gap:4px}.home-tab{padding:6px 12px;font-size:14px;color:#ffffff80;background:none;border:none;border-radius:8px;cursor:pointer}.home-tab.active{color:#fff;background:#4ade8033;border-bottom:2px solid #4ade80}.home-game-cards{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.home-game-card{flex:0 0 140px;position:relative;border-radius:10px;overflow:hidden;background:#1a1a1e}.home-game-card-cover{width:100%;height:90px;background:linear-gradient(145deg,#2d2d35,#1e1e24)}.home-game-card-cover.live{background:linear-gradient(145deg,#3d2d45,#2a1e2e)}.home-game-card-cover.slot{background:linear-gradient(145deg,#2d3545,#1e2430)}.home-game-card-cover.card{background:linear-gradient(145deg,#2d3d45,#1e2a30)}.home-game-card-name{padding:6px 8px 0;font-size:13px;font-weight:600;color:#fff;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-game-card-provider{padding:0 8px;font-size:11px;color:#ffffff80;margin:0}.home-game-card-count{display:inline-block;padding:0 8px 8px;font-size:11px;color:#4ade80}.home-game-hot{position:absolute;top:6px;left:6px;padding:2px 6px;font-size:10px;background:#ef4444;color:#fff;border-radius:4px;z-index:1}.home-section-hash{padding-top:12px}.home-hash-block{position:relative;padding:14px;background:#1a1a1e;border-radius:12px;overflow:hidden}.home-hash-block:after{content:"";position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:48px;color:#4ade8014;font-weight:800;letter-spacing:-2px}.home-hash-label{font-size:14px;font-weight:600;color:#fff;margin-bottom:6px}.home-info{display:inline-flex;width:14px;height:14px;align-items:center;justify-content:center;font-size:10px;color:#fff9;border:1px solid rgba(255,255,255,.3);border-radius:50%;margin-left:4px}.home-hash-desc{font-size:12px;color:#ffffffb3;margin:0 0 10px}.home-hash-address{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#0d0d0f;border-radius:8px;margin-bottom:12px}.home-hash-address code{flex:1;font-size:11px;color:#fffc;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-hash-copy{background:none;border:none;font-size:14px;cursor:pointer;padding:0 4px}.home-hash-actions{display:flex;gap:10px;margin-bottom:8px}.home-hash-btn{flex:1;padding:12px;font-size:14px;font-weight:600;border:none;border-radius:10px;cursor:pointer}.home-hash-btn.primary{background:#4ade80;color:#0d0d0f}.home-hash-btn.yellow{background:#facc15;color:#0d0d0f}.home-hash-odds{font-size:14px;font-weight:600;color:#4ade80}.home-roulette-sub{font-size:13px;color:#ffffffb3;margin:0 0 10px}.home-roulette-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;padding:12px;background:#1a1a1e;border-radius:12px}.home-roulette-num{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;border-radius:6px}.home-roulette-num.green{background:#166534}.home-roulette-num.red{background:#b91c1c}.home-roulette-num.black{background:#1f2937}.home-roulette-bottom{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-around;gap:8px;padding:8px 0 0;font-size:12px;color:#fffc}.home-roulette-bottom .diamond{width:12px;height:12px;transform:rotate(45deg)}.home-roulette-bottom .diamond.red{background:#b91c1c}.home-roulette-bottom .diamond.black{background:#1f2937}.home-lottery-cards{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.home-lottery-card{flex:0 0 180px;padding:14px;background:#1a1a1e;border-radius:12px;display:flex;flex-direction:column;gap:6px}.home-lottery-name{font-size:14px;font-weight:600;color:#fff}.home-lottery-issue{font-size:11px;color:#fff9}.home-lottery-next{font-size:11px;color:#ffffff80}.home-lottery-timer{font-size:16px;font-weight:600;color:#1f2937;letter-spacing:1px}.home-lottery-btn{margin-top:6px;padding:10px;font-size:13px;font-weight:600;color:#fff;background:#4ade80;border:none;border-radius:8px;cursor:pointer}.home-lottery-card .home-game-card-count{padding:0}.home-bet-head{flex-wrap:wrap;gap:10px}.home-bet-tabs{display:flex;gap:4px}.home-bet-tab{padding:4px 10px;font-size:12px;color:#fff9;background:#ffffff14;border:none;border-radius:6px;cursor:pointer}.home-bet-tab.active{color:#fff;background:#4ade80}.home-bet-table{background:#1a1a1e;border-radius:12px;overflow:hidden}.home-bet-row{display:grid;grid-template-columns:1.2fr .8fr .6fr .8fr;gap:8px;padding:12px 14px;font-size:13px;align-items:center;border-bottom:1px solid rgba(255,255,255,.06)}.home-bet-row:last-child{border-bottom:none}.home-bet-row.head{color:#fff9;font-size:12px}.home-bet-row .green{color:#4ade80}.home-bet-row .game{display:flex;align-items:center;gap:8px}.game-thumb{width:32px;height:32px;border-radius:6px;background:#2d2d35;flex-shrink:0}.home-providers{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.home-provider-card{flex:0 0 160px;padding:14px;background:#1a1a1e;border-radius:12px}.home-provider-name{display:block;font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.home-provider-count{font-size:12px;color:#fff9;margin-bottom:10px}.home-provider-grid{height:80px;background:#ffffff0d;border-radius:8px}.home-legal{border-bottom:none;padding-bottom:24px}.home-legal-links{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:8px}.home-legal-link{font-size:13px;color:#ffffffa6;background:none;border:none;cursor:pointer;padding:0}.page-sports{min-height:100%;background:#0d0d0f;color:#e5e5e5;padding-bottom:80px}.sports-header{display:flex;align-items:center;gap:10px;padding:10px 12px;padding-top:calc(10px + env(safe-area-inset-top,0));background:#12121a;border-bottom:1px solid rgba(255,255,255,.08)}.btn-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;background:none;border:none;cursor:pointer}.header-balance{display:flex;align-items:center;gap:4px;flex:1;min-width:0}.balance-icon{font-size:18px}.balance-value{font-size:15px;font-weight:600;color:#f59e0b}.balance-arrow{font-size:12px;color:#fff9}.header-actions{display:flex;align-items:center;gap:4px}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px;background:none;border:none;cursor:pointer;position:relative}.icon-btn.badge .badge-num{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;font-size:10px;line-height:16px;text-align:center;color:#fff;background:#ef4444;border-radius:8px}.sports-tabs{display:flex;align-items:center;gap:4px;padding:10px 12px;background:#12121a;border-bottom:1px solid rgba(255,255,255,.06);overflow-x:auto;-webkit-overflow-scrolling:touch}.sport-tab{flex-shrink:0;padding:8px 12px;font-size:13px;color:#ffffffb3;background:#ffffff0f;border:none;border-radius:8px;cursor:pointer}.sport-tab.active{color:#f59e0b;background:#f59e0b33;border-bottom:2px solid #f59e0b}.sport-tab.icon-only{padding:8px 10px}.event-filters{display:flex;flex-wrap:wrap;gap:8px;padding:12px;border-bottom:1px solid rgba(255,255,255,.06)}.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:8px 12px;font-size:13px;color:#fffc;background:#ffffff14;border:none;border-radius:8px;cursor:pointer}.filter-chip.active{color:#fff;background:#ea580c}.live-tag{margin-left:4px;padding:2px 6px;font-size:10px;color:#fff;background:#ef4444;border-radius:4px}.search-wrap{position:relative;display:flex;align-items:center;gap:8px;padding:10px 12px;background:#12121a}.search-input{flex:1;padding:10px 12px 10px 36px;font-size:14px;color:#fff;background:#1a1a24;border:1px solid rgba(255,255,255,.1);border-radius:8px;outline:none}.search-icon{position:absolute;left:24px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none}.search-arrow{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff9;background:none;border:none;cursor:pointer}.league-list{padding:8px 12px}.league-item{display:flex;align-items:center;gap:12px;padding:14px 12px;margin-bottom:6px;background:#1a1a24;border-radius:10px;cursor:pointer}.league-checkbox,.league-icon{flex-shrink:0;font-size:20px}.league-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.league-name{font-size:14px;font-weight:500;color:#fff}.league-time{font-size:12px;color:#ffffff80}.league-arrow{flex-shrink:0;font-size:14px;color:#ffffff80}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;display:flex;align-items:flex-end;justify-content:center;animation:overlayIn .2s ease-out}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.bottom-sheet{width:100%;max-width:430px;max-height:85vh;background:#12121a;border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:sheetIn .25s ease-out;box-shadow:0 -4px 24px #0000004d}@keyframes sheetIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet-handle{width:36px;height:4px;margin:8px auto 0;background:#ffffff4d;border-radius:2px}.bottom-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.bottom-sheet-title{font-size:16px;font-weight:600;color:#fff;margin:0}.bottom-sheet-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#ffffffb3;background:none;border:none;border-radius:50%}.bottom-sheet-body{flex:1;overflow-y:auto;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0))}.page-recommend{padding-bottom:16px}.filter-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.filter-btn{padding:6px 12px;font-size:12px;color:#ffffffb3;background:#ffffff14;border:none;border-radius:14px}.live-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.live-card{position:relative;border-radius:10px;overflow:hidden;background:#ffffff0a}.live-cover{width:100%;aspect-ratio:4/3;object-fit:cover}.live-type{position:absolute;top:6px;left:6px;padding:2px 6px;font-size:10px;background:#0009;border-radius:4px}.live-online{position:absolute;bottom:32px;right:6px;font-size:11px;color:#fff}.live-title{padding:8px;font-size:13px;color:#e0e0e0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-section{border-top:1px solid rgba(255,255,255,.06)}.video-list{display:flex;flex-direction:column;gap:12px}.video-card{display:flex;gap:12px;align-items:center;padding:8px 0;border-radius:10px}.video-cover{width:120px;height:160px;object-fit:cover;border-radius:8px}.video-title{flex:1;font-size:14px;color:#e0e0e0}.video-likes{font-size:12px;color:#fff9}.sheet-live .sheet-cover,.sheet-video .sheet-cover{width:100%;height:180px;background-size:cover;background-position:center;border-radius:8px;margin-bottom:12px;position:relative}.sheet-live .sheet-badge{position:absolute;top:8px;left:8px;padding:4px 10px;font-size:12px;background:#ff6b35;border-radius:4px}.sheet-live .sheet-online{position:absolute;bottom:8px;right:8px;font-size:13px;color:#fff}.sheet-desc{font-size:14px;color:#ffffffb3}.page-activity{padding-bottom:16px}.block-title{font-size:16px;font-weight:600;margin-bottom:8px;color:#fff}.hint{font-size:12px;color:#ffffff80;margin-bottom:12px}.filter-bar{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.filter-btn{padding:6px 14px;font-size:13px;color:#ffffffb3;background:#ffffff14;border:none;border-radius:16px}.filter-btn.active{color:#ff6b35;background:#ff6b3533}.activity-card{margin-bottom:16px;border-radius:12px;overflow:hidden;background:#ffffff0a}.activity-cover-wrap{position:relative;height:140px}.activity-cover{width:100%;height:100%;object-fit:cover}.activity-hot{position:absolute;top:8px;left:8px;padding:2px 8px;font-size:11px;background:#ff6b35;border-radius:4px}.activity-status{position:absolute;bottom:8px;right:8px;font-size:12px;color:#ffffffe6}.activity-title{padding:10px 12px;font-weight:500;color:#fff}.activity-desc{padding:0 12px 10px;font-size:12px;color:#ffffff80}.sheet-activity .sheet-cover{width:100%;height:140px;background-size:cover;background-position:center;border-radius:8px;margin-bottom:12px}.sheet-activity .sheet-btn-primary{width:100%;padding:12px;font-size:15px;color:#fff;background:#ff6b35;border:none;border-radius:10px;margin-bottom:16px}.sheet-activity .sheet-block{margin-bottom:16px}.sheet-activity .sheet-block h4{font-size:14px;color:#fff;margin-bottom:6px}.sheet-activity .sheet-block p{font-size:13px;color:#ffffffb3}.page-chat{padding-bottom:16px}.section{padding:12px 16px}.block-title{font-size:16px;font-weight:600;margin-bottom:12px;color:#fff}.search-bar{border-bottom:1px solid rgba(255,255,255,.06)}.search-input{width:100%;padding:10px 14px;font-size:14px;color:#e0e0e0;background:#ffffff14;border:none;border-radius:20px;margin-bottom:8px}.search-input::placeholder{color:#fff6}.hint{font-size:12px;color:#ffffff80}.friend-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.06)}.friend-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.friend-info{flex:1;min-width:0}.friend-name{display:block;font-weight:500;color:#fff}.friend-msg{font-size:12px;color:#ffffff80;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-time{font-size:12px;color:#fff6}.sheet-chat{display:flex;flex-direction:column;min-height:300px}.sheet-chat-messages{flex:1;display:flex;flex-direction:column;gap:12px;margin-bottom:16px;max-height:40vh;overflow-y:auto}.sheet-msg.me{align-self:flex-end}.sheet-msg.friend{align-self:flex-start}.sheet-msg-bubble{max-width:80%;padding:10px 14px;border-radius:12px;font-size:14px}.sheet-msg.me .sheet-msg-bubble{background:#ff6b35;color:#fff}.sheet-msg.friend .sheet-msg-bubble{background:#ffffff1a;color:#e0e0e0}.sheet-chat-input{display:flex;gap:8px}.sheet-chat-field{flex:1;padding:10px 14px;font-size:14px;color:#e0e0e0;background:#ffffff14;border:none;border-radius:20px}.sheet-chat-send{padding:10px 18px;font-size:14px;color:#fff;background:#ff6b35;border:none;border-radius:20px}.page-login{min-height:100vh;background:#0d0d0f;color:#e5e5e5}.login-header{position:relative;width:100%;height:0;padding-top:52%;background:#12121a;overflow:hidden}.login-header-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:top center}.login-header-overlay{position:absolute;top:0;left:0;right:0;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0));display:flex;justify-content:space-between;align-items:flex-start;pointer-events:none}.login-header-top{display:flex;justify-content:space-between;align-items:center;width:100%;pointer-events:auto}.logo-text{font-size:20px;font-weight:700;color:#fff;letter-spacing:.05em}.btn-close{width:32px;height:32px;border-radius:50%;background:#00000080;color:#fff;font-size:20px;line-height:1;border:none;cursor:pointer}.login-form-wrap{padding:20px 20px 32px;padding-bottom:calc(32px + env(safe-area-inset-bottom,0))}.form-title{font-size:22px;font-weight:700;color:#fff;margin-bottom:20px}.form-fields{margin-bottom:20px}.input-field{width:100%;padding:14px 16px;margin-bottom:12px;font-size:15px;color:#fff;background:#1a1a24;border:1px solid rgba(255,255,255,.1);border-radius:10px;outline:none}.input-field::placeholder{color:#fff6}.input-wrap-pwd{position:relative;margin-bottom:8px}.input-wrap-pwd .input-field{margin-bottom:0;padding-right:48px}.btn-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:18px;cursor:pointer;padding:4px}.forgot-wrap{text-align:right;margin-bottom:16px}.link-forgot{color:#888;font-size:14px}.expand-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;color:#ffffffb3;font-size:14px;cursor:pointer}.arrow{font-size:12px}.checkbox-row{margin-bottom:12px}.checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;color:#ffffffe6}.checkbox-label input{display:none}.check-icon{flex-shrink:0;width:20px;height:20px;border:2px solid #4ade80;border-radius:4px;background:#4ade80;color:#0d0d0f;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.checkbox-label input:not(:checked)+.check-icon{background:transparent;color:transparent}.link-green{color:#4ade80;font-weight:500}.btn-submit{width:100%;padding:14px;font-size:16px;font-weight:600;color:#fff;background:#2d5a3d;border:none;border-radius:10px;cursor:pointer;margin-bottom:16px}.form-footer{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#fffc}.icon-service{font-size:18px}.divider{display:flex;align-items:center;gap:12px;margin:24px 0 16px;color:#ffffff80;font-size:13px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#ffffff26}.social-icons{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.social-btn{width:48px;height:48px;border-radius:10px;background:#1a1a24;border:1px solid rgba(255,255,255,.1);color:#fff;font-size:16px;font-weight:600;cursor:pointer}.page-placeholder{min-height:100%;background:#0d0d0f;color:#e5e5e5}.ph-header{display:flex;align-items:center;gap:12px;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0));background:#12121a;border-bottom:1px solid rgba(255,255,255,.08)}.btn-back{padding:4px 8px;font-size:16px;color:#4ade80;background:none;border:none}.ph-title{font-size:16px;font-weight:600}.ph-content{padding:20px 16px}.ph-content .hint{color:#666;font-size:13px;margin-top:8px}.page-personal{padding-bottom:24px;background:#0f0f0f;color:#e0e0e0}.personal-header{display:flex;flex-direction:column;align-items:center;padding:32px 16px;background:linear-gradient(180deg,#1a1a1a,#0f0f0f)}.personal-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;margin-bottom:12px}.personal-name{font-size:18px;font-weight:500;color:#fff}.personal-menu{padding:0 16px}.menu-item{display:block;width:100%;padding:14px 0;font-size:15px;color:#e0e0e0;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.06);text-align:left}.page-all-menu{min-height:100%;background:#0f0f0f;color:#e0e0e0}.all-menu-header{display:flex;align-items:center;gap:12px;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0));background:#1a1a1a;border-bottom:1px solid rgba(255,255,255,.06)}.btn-back{padding:4px 8px;font-size:16px;color:#fff;background:none;border:none}.all-menu-title{font-size:16px;font-weight:600;color:#fff}.all-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;padding:16px;background:#ffffff0f}.menu-tile{padding:20px;font-size:14px;color:#e0e0e0;background:#141414;border:none}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:14px;color:#333;background:#0f0f0f;-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}img{max-width:100%;vertical-align:middle}ul,ol{list-style:none}.safe-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.safe-top{padding-top:env(safe-area-inset-top,0)}.app-viewport{min-height:100%;width:100%;margin:0 auto}@media (min-width: 768px){.app-viewport{max-width:430px;box-shadow:0 0 0 1px #0000001a;min-height:100vh}}@media (min-width: 1024px){body{background:#1a1a1a}.app-viewport{box-shadow:0 0 40px #0006}}
