/* 夏梦湖漂流瓶 — 动漫游戏画风 · 手机优先 */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#1a1028;--bg2:#231436;--card:#2a1d42;--card2:#342556;
  --purple:#9b6dff;--pink:#ff6db6;--blue:#6db8ff;--gold:#ffd86d;
  --grad1:linear-gradient(135deg,#9b6dff,#ff6db6);
  --grad2:linear-gradient(135deg,#6db8ff,#9b6dff);
  --grad3:linear-gradient(135deg,#ff6db6,#ffd86d);
  --text:#f0e8ff;--text2:#b8a5d8;--text3:#7a6a96;
  --radius:16px;--radius-lg:24px;
}
html{font-size:16px;-webkit-tap-highlight-color:transparent}
body{font-family:'Noto Sans SC',system-ui,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
input,button,textarea{font-family:inherit;outline:none;border:none}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--purple);color:#fff}
::-webkit-scrollbar{width:0;display:none}

/* ===== 欢迎页 ===== */
.splash{position:fixed;inset:0;z-index:1000;background:var(--bg);overflow:hidden;display:flex;align-items:center;justify-content:center}
.splash-scene{position:absolute;inset:0;pointer-events:none}

/* 粒子 */
.particles{position:absolute;inset:0}
.particle{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--purple);opacity:.4;animation:particleFloat 8s ease-in-out infinite}
@keyframes particleFloat{0%,100%{transform:translateY(0) scale(1);opacity:.2}50%{transform:translateY(-80px) scale(1.5);opacity:.6}}

/* 星星 */
.star-field .star{position:absolute;width:3px;height:3px;background:#fff;border-radius:50%;animation:twinkle 3s ease-in-out infinite}
.star.s1{top:10%;left:15%;animation-delay:0s}.star.s2{top:20%;left:75%;animation-delay:.5s}
.star.s3{top:35%;left:45%;animation-delay:1s}.star.s4{top:15%;left:85%;animation-delay:1.5s}
.star.s5{top:50%;left:25%;animation-delay:2s}.star.s6{top:8%;left:55%;animation-delay:.3s}
.star.s7{top:45%;left:90%;animation-delay:1.8s}.star.s8{top:60%;left:10%;animation-delay:2.5s}
@keyframes twinkle{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(2)}}

/* 漂浮瓶子 */
.floating-bottles .fb{position:absolute;font-size:28px;animation:floatBottle 10s ease-in-out infinite;opacity:.5}
.fb1{top:15%;left:10%;animation-delay:0s}.fb2{top:25%;right:15%;animation-delay:2s;font-size:22px}
.fb3{bottom:30%;left:20%;animation-delay:4s;font-size:20px}.fb4{bottom:20%;right:10%;animation-delay:1s}
.fb5{top:40%;left:50%;animation-delay:3s;font-size:18px}
@keyframes floatBottle{0%,100%{transform:translate(0,0) rotate(0deg)}25%{transform:translate(15px,-20px) rotate(5deg)}50%{transform:translate(-10px,-35px) rotate(-3deg)}75%{transform:translate(20px,-15px) rotate(4deg)}}

/* 欢迎页中心 */
.splash-center{position:relative;z-index:2;text-align:center;padding:0 24px;width:100%;max-width:380px}
.splash-icon{font-size:64px;animation:bottleBounce 2s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(155,109,255,.4))}
@keyframes bottleBounce{0%,100%{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-15px) rotate(5deg)}}
.splash-title{font-size:48px;font-weight:900;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:12px 0 4px;letter-spacing:4px;text-shadow:0 0 40px rgba(155,109,255,.3)}
.splash-tagline{font-size:14px;color:var(--text2);letter-spacing:4px}
.splash-deco{margin-top:8px;color:var(--gold);font-size:10px;letter-spacing:6px;opacity:.6}

/* 注册面板 */
.register-panel{margin-top:36px;background:rgba(42,29,66,.85);backdrop-filter:blur(20px);border:1px solid rgba(155,109,255,.2);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:0 20px 60px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.05)}
.panel-header{display:flex;align-items:center;justify-content:center;gap:6px;font-size:15px;font-weight:700;margin-bottom:20px;color:var(--gold)}
.panel-icon{font-size:18px}
.input-game{width:100%;padding:14px 18px;background:rgba(0,0,0,.3);border:2px solid rgba(155,109,255,.2);border-radius:12px;color:var(--text);font-size:15px;text-align:center;transition:border-color .3s}
.input-game:focus{border-color:var(--purple);box-shadow:0 0 20px rgba(155,109,255,.15)}
.input-game::placeholder{color:var(--text3);font-size:13px}
.avatar-label{font-size:12px;color:var(--text2);margin:16px 0 10px;text-align:center;letter-spacing:2px}
.avatar-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:20px}
.avatar-cell{aspect-ratio:1;border-radius:12px;background:rgba(0,0,0,.25);border:2px solid transparent;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;transition:all .2s}
.avatar-cell:active{transform:scale(.9)}
.avatar-cell.selected{border-color:var(--purple);background:rgba(155,109,255,.15);box-shadow:0 0 15px rgba(155,109,255,.25)}
.btn-enter{width:100%;padding:15px;background:var(--grad1);border-radius:12px;color:#fff;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 8px 30px rgba(155,109,255,.4);transition:all .2s;letter-spacing:2px}
.btn-enter:active{transform:scale(.97);box-shadow:0 4px 15px rgba(155,109,255,.3)}
.btn-sparkle{font-size:12px;animation:sparkle 1.5s ease-in-out infinite}
@keyframes sparkle{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}

/* ===== 主应用 ===== */
.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}

/* 顶栏 */
.top-bar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:rgba(26,16,40,.9);backdrop-filter:blur(20px);border-bottom:1px solid rgba(155,109,255,.1)}
.top-logo{font-size:16px;font-weight:700;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.top-title{font-size:15px;font-weight:600;position:absolute;left:50%;transform:translateX(-50%)}
.top-avatar{width:36px;height:36px;border-radius:50%;background:var(--card);border:2px solid var(--purple);display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer}

/* 主区域 */
.main-area{flex:1;overflow-y:auto;padding:16px;padding-bottom:calc(60px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch}

/* 底部导航 */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom));background:rgba(26,16,40,.95);backdrop-filter:blur(20px);border-top:1px solid rgba(155,109,255,.1);z-index:50}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--text3);padding:4px 12px;cursor:pointer;transition:color .2s;-webkit-tap-highlight-color:transparent}
.nav-btn.active{color:var(--purple)}
.nav-btn.active .nav-ico{transform:scale(1.15);filter:drop-shadow(0 0 8px rgba(155,109,255,.4))}
.nav-ico{font-size:22px;transition:all .2s}
.nav-txt{font-size:10px;font-weight:500;letter-spacing:1px}

/* ===== 通用游戏UI组件 ===== */

/* 卡片 */
.game-card{background:var(--card);border:1px solid rgba(155,109,255,.1);border-radius:var(--radius);padding:16px;margin-bottom:12px;transition:all .3s;position:relative;overflow:hidden}
.game-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}
.game-card:active{transform:scale(.98)}

/* 按钮 */
.btn-game{padding:12px 28px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:6px;letter-spacing:1px}
.btn-game:active{transform:scale(.96)}
.btn-purple{background:var(--grad1);color:#fff;box-shadow:0 6px 20px rgba(155,109,255,.35)}
.btn-outline{background:transparent;border:2px solid rgba(155,109,255,.3);color:var(--purple)}
.btn-outline:active{background:rgba(155,109,255,.1)}
.btn-pink{background:var(--grad3);color:#fff;box-shadow:0 6px 20px rgba(255,109,182,.3)}
.btn-blue{background:var(--grad2);color:#fff;box-shadow:0 6px 20px rgba(109,184,255,.3)}
.btn-sm{padding:8px 18px;font-size:12px;border-radius:8px}
.btn-full{width:100%}

/* 标签 */
.tag{display:inline-block;padding:4px 12px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:1px}
.tag-purple{background:rgba(155,109,255,.15);color:var(--purple)}
.tag-pink{background:rgba(255,109,182,.15);color:var(--pink)}
.tag-blue{background:rgba(109,184,255,.15);color:var(--blue)}
.tag-gold{background:rgba(255,216,109,.15);color:var(--gold)}

/* Section标题 */
.sec-title{font-size:18px;font-weight:800;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.sec-title .sec-icon{font-size:20px}

/* Tab切换 */
.tab-switch{display:flex;background:var(--card);border-radius:12px;padding:3px;margin-bottom:16px;gap:2px}
.tab-btn{flex:1;padding:10px;border-radius:10px;background:none;border:none;color:var(--text3);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.tab-btn.active{background:var(--grad1);color:#fff;box-shadow:0 4px 15px rgba(155,109,255,.3)}

/* 空状态 */
.empty-state{text-align:center;padding:60px 20px;color:var(--text3)}
.empty-state .empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}
.empty-state p{font-size:14px;line-height:1.6}

/* 加载点 */
.loading-dots{display:flex;justify-content:center;gap:6px;padding:20px}
.loading-dots span{width:8px;height:8px;border-radius:50%;background:var(--purple);animation:dotBounce .8s ease-in-out infinite}
.loading-dots span:nth-child(2){animation-delay:.15s}
.loading-dots span:nth-child(3){animation-delay:.3s}
@keyframes dotBounce{0%,100%{transform:translateY(0);opacity:.3}50%{transform:translateY(-8px);opacity:1}}

/* Toast */
.game-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%) translateY(-20px);background:var(--card);border:1px solid rgba(155,109,255,.3);border-radius:12px;padding:12px 24px;font-size:13px;font-weight:600;color:var(--text);opacity:0;transition:all .3s;z-index:9999;pointer-events:none;white-space:nowrap;backdrop-filter:blur(20px);box-shadow:0 10px 30px rgba(0,0,0,.4)}
.game-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* 模态框 */
.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:100;backdrop-filter:blur(4px)}
.modal-box{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:360px;max-height:80vh;overflow-y:auto;background:var(--card);border:1px solid rgba(155,109,255,.2);border-radius:var(--radius-lg);padding:28px;z-index:101;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-close{position:absolute;top:12px;right:16px;background:none;color:var(--text3);font-size:20px;cursor:pointer}
.modal-title{font-size:18px;font-weight:800;text-align:center;margin-bottom:20px}

/* 输入框 */
.input-field{width:100%;padding:12px 16px;background:rgba(0,0,0,.25);border:2px solid rgba(155,109,255,.15);border-radius:12px;color:var(--text);font-size:14px;transition:border-color .3s}
.input-field:focus{border-color:var(--purple)}
.input-field::placeholder{color:var(--text3)}
.textarea-field{width:100%;padding:14px 16px;background:rgba(0,0,0,.25);border:2px solid rgba(155,109,255,.15);border-radius:12px;color:var(--text);font-size:14px;resize:none;min-height:120px;transition:border-color .3s;line-height:1.6}
.textarea-field:focus{border-color:var(--purple)}
.textarea-field::placeholder{color:var(--text3)}

/* ===== 首页 ===== */
.home-hero{position:relative;text-align:center;padding:20px 0 30px;margin-bottom:16px;overflow:hidden;border-radius:var(--radius-lg);background:linear-gradient(180deg,rgba(155,109,255,.08),transparent)}
.home-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 30%,rgba(155,109,255,.1),transparent 70%)}
.home-hero-title{font-size:28px;font-weight:900;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}
.home-hero-sub{font-size:13px;color:var(--text2);margin-top:4px;position:relative}
.home-hero-bottles{position:relative;margin-top:20px;display:flex;justify-content:center;gap:20px}
.home-hero-bottles span{font-size:32px;animation:floatBottle 6s ease-in-out infinite;display:block}
.home-hero-bottles span:nth-child(2){animation-delay:2s}
.home-hero-bottles span:nth-child(3){animation-delay:4s}

.home-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}
.stat-box{background:var(--card);border-radius:12px;padding:14px 8px;text-align:center;border:1px solid rgba(155,109,255,.08)}
.stat-val{font-size:22px;font-weight:900;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-lbl{font-size:10px;color:var(--text3);margin-top:2px;letter-spacing:1px}

.home-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.home-action{background:var(--card);border:1px solid rgba(155,109,255,.1);border-radius:var(--radius);padding:20px 16px;text-align:center;cursor:pointer;transition:all .3s}
.home-action:active{transform:scale(.96)}
.home-action .ha-icon{font-size:36px;margin-bottom:8px;display:block}
.home-action .ha-title{font-size:14px;font-weight:700}
.home-action .ha-desc{font-size:11px;color:var(--text3);margin-top:4px}

/* ===== 投瓶页 ===== */
.throw-page{padding-bottom:20px}
.bottle-types{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px}
.bottle-type{background:var(--card);border:2px solid transparent;border-radius:12px;padding:14px 8px;text-align:center;cursor:pointer;transition:all .2s}
.bottle-type.active{border-color:var(--purple);background:rgba(155,109,255,.1)}
.bottle-type .bt-icon{font-size:24px;display:block;margin-bottom:4px}
.bottle-type .bt-name{font-size:11px;color:var(--text2)}
.throw-textarea{min-height:150px}
.throw-counter{text-align:right;font-size:11px;color:var(--text3);margin:8px 0 16px}
.throw-counter.warn{color:var(--pink)}

/* ===== 捞瓶页 ===== */
.fish-area{text-align:center;padding:30px 0}
.fish-lake{position:relative;width:200px;height:200px;margin:0 auto 24px;border-radius:50%;background:radial-gradient(circle,rgba(109,184,255,.15),rgba(155,109,255,.05));border:2px solid rgba(109,184,255,.15);overflow:hidden}
.fish-lake::after{content:'';position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.05),transparent);animation:lakeShimmer 4s ease-in-out infinite}
@keyframes lakeShimmer{0%,100%{opacity:.3}50%{opacity:.7}}
.fish-lake-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;z-index:1}
.fish-wave{position:absolute;bottom:0;left:-50%;width:200%;height:40%;background:rgba(109,184,255,.08);border-radius:40%;animation:fishWave 3s ease-in-out infinite}
.fish-wave:nth-child(2){animation-delay:1s;opacity:.5;height:30%}
@keyframes fishWave{0%,100%{transform:translateX(0) rotate(0deg)}50%{transform:translateX(5%) rotate(2deg)}}
.fish-count{font-size:13px;color:var(--text2);margin-bottom:16px}
.fish-count strong{color:var(--gold)}

/* 捞到的瓶子卡片 */
.bottle-result{background:var(--card);border:1px solid rgba(155,109,255,.15);border-radius:var(--radius-lg);padding:24px;margin-top:20px;text-align:left;animation:slideUp .5s ease;position:relative;overflow:hidden}
.bottle-result::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad1)}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.bottle-result-type{margin-bottom:12px}
.bottle-result-content{font-size:15px;line-height:1.8;color:var(--text);margin-bottom:16px;padding:16px;background:rgba(0,0,0,.2);border-radius:12px}
.bottle-result-meta{font-size:11px;color:var(--text3);margin-bottom:16px}
.bottle-result-actions{display:flex;gap:8px}

/* ===== 广场页 ===== */
.post-composer{background:var(--card);border:1px solid rgba(155,109,255,.1);border-radius:var(--radius);padding:16px;margin-bottom:16px}
.post-composer-row{display:flex;gap:10px;align-items:flex-start}
.post-composer .post-avatar{font-size:28px;flex-shrink:0}
.post-composer textarea{flex:1;min-height:48px;max-height:120px;padding:10px 14px;background:rgba(0,0,0,.2);border:1px solid rgba(155,109,255,.1);border-radius:10px;color:var(--text);font-size:13px;resize:none}
.post-composer textarea::placeholder{color:var(--text3)}
.post-composer-bottom{display:flex;justify-content:flex-end;margin-top:10px}

.post-card{background:var(--card);border:1px solid rgba(155,109,255,.08);border-radius:var(--radius);padding:16px;margin-bottom:12px}
.post-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.post-avatar-sm{width:36px;height:36px;border-radius:50%;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:18px;border:2px solid rgba(155,109,255,.15)}
.post-user-info .post-username{font-size:13px;font-weight:600}
.post-user-info .post-time{font-size:11px;color:var(--text3)}
.post-body{font-size:14px;line-height:1.7;color:var(--text);margin-bottom:12px}
.post-actions{display:flex;gap:20px}
.post-action{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text3);cursor:pointer;padding:4px 0;background:none;border:none;transition:color .2s}
.post-action.liked{color:var(--pink)}
.post-action:active{transform:scale(.95)}

/* ===== 匹配页 ===== */
.match-card{background:var(--card);border:1px solid rgba(155,109,255,.1);border-radius:var(--radius-lg);padding:24px;text-align:center;margin-bottom:16px;position:relative;overflow:hidden}
.match-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad2)}
.match-avatar{font-size:56px;margin-bottom:12px;display:block}
.match-name{font-size:18px;font-weight:700;margin-bottom:4px}
.match-mood{font-size:13px;color:var(--text2);margin-bottom:16px}
.match-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:16px}
.match-interests{margin-bottom:20px}
.match-interests h4{font-size:13px;color:var(--text2);margin-bottom:10px}
.interest-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.interest-tag{padding:8px 16px;border-radius:100px;background:rgba(0,0,0,.2);border:2px solid transparent;font-size:12px;color:var(--text2);cursor:pointer;transition:all .2s}
.interest-tag.selected{border-color:var(--purple);color:var(--purple);background:rgba(155,109,255,.08)}
.interest-tag:active{transform:scale(.95)}

/* ===== 聊天页 ===== */
.chat-page{position:fixed;inset:0;z-index:200;background:var(--bg);display:flex;flex-direction:column}
.chat-top-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:rgba(26,16,40,.95);backdrop-filter:blur(20px);border-bottom:1px solid rgba(155,109,255,.1)}
.chat-back{background:none;color:var(--purple);font-size:14px;font-weight:600;cursor:pointer}
.chat-title{font-size:15px;font-weight:700}
.chat-action{background:none;color:var(--gold);font-size:12px;cursor:pointer}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;-webkit-overflow-scrolling:touch}
.msg-bubble{max-width:75%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.6;word-break:break-word;animation:msgIn .3s ease}
@keyframes msgIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.msg-left{align-self:flex-start;background:var(--card);border-bottom-left-radius:4px}
.msg-right{align-self:flex-end;background:var(--purple);color:#fff;border-bottom-right-radius:4px}
.msg-time{font-size:10px;color:var(--text3);margin-top:4px}
.msg-time-right{text-align:right;color:rgba(255,255,255,.5)}
.msg-system{align-self:center;background:rgba(155,109,255,.1);color:var(--purple);font-size:12px;padding:6px 16px;border-radius:100px}
.chat-input-bar{display:flex;gap:8px;padding:10px 16px;padding-bottom:max(10px,env(safe-area-inset-bottom));background:rgba(26,16,40,.95);border-top:1px solid rgba(155,109,255,.1)}
.chat-input{flex:1;padding:12px 16px;background:rgba(0,0,0,.3);border:1px solid rgba(155,109,255,.15);border-radius:100px;color:var(--text);font-size:14px}
.chat-input::placeholder{color:var(--text3)}
.chat-send{padding:12px 24px;background:var(--grad1);color:#fff;border-radius:100px;font-size:14px;font-weight:700;cursor:pointer}

/* ===== 个人中心 ===== */
.profile-header{text-align:center;padding:30px 0 20px;background:linear-gradient(180deg,rgba(155,109,255,.1),transparent);border-radius:var(--radius-lg);margin-bottom:20px}
.profile-avatar{font-size:56px;margin-bottom:8px;display:block}
.profile-name{font-size:20px;font-weight:800}
.profile-id{font-size:11px;color:var(--text3);margin-top:4px}
.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.profile-stat{background:var(--card);border-radius:12px;padding:16px;text-align:center;border:1px solid rgba(155,109,255,.08)}
.profile-stat .ps-val{font-size:20px;font-weight:900;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.profile-stat .ps-lbl{font-size:10px;color:var(--text3);margin-top:2px}
.profile-menu{display:flex;flex-direction:column;gap:8px}
.menu-item{display:flex;align-items:center;gap:12px;padding:16px;background:var(--card);border-radius:12px;cursor:pointer;border:1px solid rgba(155,109,255,.06);transition:all .2s}
.menu-item:active{transform:scale(.98)}
.menu-item .mi-icon{font-size:20px}
.menu-item .mi-text{flex:1;font-size:14px;font-weight:600}
.menu-item .mi-arrow{color:var(--text3)}

/* ===== 聊天列表 ===== */
.chat-list-item{display:flex;align-items:center;gap:12px;padding:14px;background:var(--card);border-radius:12px;margin-bottom:8px;cursor:pointer;border:1px solid rgba(155,109,255,.06);transition:all .2s}
.chat-list-item:active{transform:scale(.98)}
.cli-avatar{width:44px;height:44px;border-radius:50%;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:22px;border:2px solid rgba(155,109,255,.15);flex-shrink:0}
.cli-info{flex:1;min-width:0}
.cli-name{font-size:14px;font-weight:600}
.cli-msg{font-size:12px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.cli-time{font-size:10px;color:var(--text3);flex-shrink:0}
.cli-badge{width:8px;height:8px;border-radius:50%;background:var(--pink);flex-shrink:0}

/* ===== 响应式 ===== */
@media(min-width:480px){
  .main-area{max-width:480px;margin:0 auto}
  .bottom-nav{max-width:480px;left:50%;transform:translateX(-50%)}
}
