/* ========== 陪玩平台 桌面版 全局样式 ========== */
:root{--primary:#7150ff;--primary-light:#8f5bff;--gradient:linear-gradient(135deg,#8f5bff,#684bff);--bg:#f5f7ff;--white:#fff;--text:#1f2a44;--text-light:#68708a;--text-lighter:#9b9faf;--pink:#ff456e;--star:#ffb42f;--shadow:0 4px 20px rgba(78,91,151,.08);--radius:12px;--max-width:1200px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.topnav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-bottom:1px solid #eee;height:60px;display:flex;align-items:center;padding:0 24px;box-shadow:0 1px 8px rgba(0,0,0,.04)}
.topnav .logo{display:flex;align-items:center;gap:10px;font-weight:900;font-size:18px;color:var(--primary);margin-right:32px;cursor:pointer}
.topnav .logo .icon{width:34px;height:34px;border-radius:10px;background:var(--gradient);color:#fff;text-align:center;line-height:34px;font-size:18px}
.topnav .links{display:flex;gap:28px;flex:1}
.topnav .links a{font-size:14px;color:var(--text-light);font-weight:500;padding:6px 0;border-bottom:2px solid transparent;transition:color .2s,border-color .2s;cursor:pointer}
.topnav .links a:hover,.topnav .links a.active{color:var(--primary);border-bottom-color:var(--primary)}
.topnav .user{display:flex;align-items:center;gap:12px;cursor:pointer}
.topnav .user .btn-login{padding:6px 16px;border-radius:18px;background:var(--gradient);color:#fff;font-size:13px;font-weight:700;cursor:pointer}
.container{max-width:var(--max-width);margin:0 auto;padding:20px 24px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:8px;font-weight:700;cursor:pointer;padding:10px 20px;font-size:14px;transition:all .15s;white-space:nowrap}
.btn:hover{opacity:.9;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 4px 12px rgba(120,82,255,.2)}
.btn-primary:hover{box-shadow:0 6px 20px rgba(120,82,255,.3)}
.btn-sm{padding:5px 14px;font-size:12px;border-radius:6px}
.btn-lg{padding:14px 32px;font-size:16px;border-radius:10px}
.btn-outline{background:transparent;border:1.5px solid var(--primary);color:var(--primary)}
.btn-danger{background:#e74c3c;color:#fff}
.btn-block{display:flex;width:100%}
.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;transition:box-shadow .2s,transform .15s}
.card:hover{box-shadow:0 8px 30px rgba(78,91,151,.12)}
.card-link{cursor:pointer}
.card-link:hover{transform:translateY(-2px)}
.input{width:100%;height:42px;padding:0 14px;border:1.5px solid #e2e5f0;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s;background:#fff}
.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(113,80,255,.06)}
textarea.input{height:auto;padding:12px 14px;resize:vertical;min-height:80px;font-family:inherit}
select.input{appearance:none;cursor:pointer}
.tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;background:#f0ecff;color:#6b5b9f;font-size:12px;white-space:nowrap;margin-right:6px;margin-bottom:4px}
.price{color:var(--pink);font-weight:900}
.price .unit{color:#8e94a8;font-size:12px;font-weight:400}
.toast{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:9999;padding:10px 28px;border-radius:8px;font-size:13px;font-weight:600;background:rgba(0,0,0,.8);color:#fff;animation:toastIn .25s ease}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(-8px)}}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.page-header h1{font-size:22px;font-weight:900}
.status-tag{display:inline-block;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:700}
.status-pending{background:#fff3e0;color:#ff9800}
.status-paid{background:#e8eaf6;color:#5c6bc0}
.status-completed{background:#e8f5e9;color:#4caf50}
.status-cancelled{background:#fde8e8;color:#ef5350}
.avatar{border-radius:10px;object-fit:cover;background:#e8e9f6}
.avatar-round{border-radius:50%}
.empty{text-align:center;padding:60px;color:var(--text-lighter);font-size:14px}
.loading{text-align:center;padding:40px;color:var(--text-lighter)}
.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-1{flex:1;min-width:0}
.gap-8{gap:8px}.gap-12{gap:12px}
.two-col{display:grid;grid-template-columns:1fr 320px;gap:20px}
.footer{text-align:center;padding:30px;color:var(--text-lighter);font-size:12px;border-top:1px solid #eee;margin-top:40px}
.status-tabs{display:flex;gap:4px;margin-bottom:20px}
.status-tabs .stab{padding:8px 20px;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s;color:var(--text-light);background:var(--white);border:1px solid #e2e5f0}
.status-tabs .stab:hover{border-color:var(--primary);color:var(--primary)}
.status-tabs .stab.active{background:var(--gradient);color:#fff;border-color:transparent}

/* SVG icon system */
.svg-icon{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;color:currentColor}
.svg-icon svg{width:1em;height:1em;display:block}
.svg-icon svg *,.topnav .logo .icon svg *,.login-brand-icon svg *{fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.topnav .logo .icon{display:flex;align-items:center;justify-content:center}
.topnav .logo .icon svg{width:20px;height:20px}
.login-brand-icon{display:flex;align-items:center;justify-content:center}
.login-brand-icon svg{width:30px;height:30px}
.game-item .icon{width:46px;height:46px;margin:0 auto 10px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#f3f0ff;color:var(--primary)}
.game-item .icon svg{width:28px;height:28px}
.comp-card .name .svg-icon,.rating-icon{font-size:15px;color:#ffb42f;margin-left:2px}
.menu-icon-svg{width:44px;height:44px;margin:0 auto 8px;border-radius:12px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px}
.menu-icon-svg.round{border-radius:50%}
.status-visual{font-size:48px;margin-bottom:12px;color:var(--primary)}
