:root{
  --primary:#16a34a;
  --accent:#f7b500;
  --primary-d:#0c7a37;
  --ink:#173322;
  --bg:#0a3d20;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:"PingFang SC","Microsoft YaHei",system-ui,-apple-system,sans-serif;
  color:#1f2d23;background:#0c5a2c;
  background-image:linear-gradient(180deg,#0c7a37,#0a4f27 60%,#073d1e);
  background-attachment:fixed;
}
#app{max-width:480px;margin:0 auto;min-height:100vh;position:relative;overflow:hidden}
img{max-width:100%;display:block}

/* 顶栏 */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:center;
  height:50px;background:rgba(8,60,30,.92);backdrop-filter:blur(6px);border-bottom:1px solid rgba(255,255,255,.08)}
.brand{font-weight:900;font-size:19px;letter-spacing:.5px;display:flex;align-items:center;gap:6px}
.brand img{height:34px;width:auto}
.brand .w1{color:#f7b500}.brand .w2{color:#fff}.brand .w3{color:#7ed957}

/* 视图切换 */
.view{display:none;padding-bottom:30px;animation:fade .25s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* 英雄区 */
.hero{position:relative;min-height:300px;display:flex;align-items:flex-end;
  background:radial-gradient(120% 90% at 50% 0,#1fb255 0,#0c7a37 55%,#085f2b 100%);
  background-size:cover;background-position:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background:
   repeating-linear-gradient(90deg,rgba(255,255,255,.045) 0 38px,transparent 38px 76px);
  opacity:.6}
.hero::after{content:"⚽";position:absolute;right:-14px;top:18px;font-size:120px;opacity:.12;transform:rotate(12deg)}
.hero-mask{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(6,50,24,.85))}
.hero-inner{position:relative;z-index:2;padding:26px 20px 24px;width:100%;text-align:center;color:#fff}
.hero-title{font-size:30px;font-weight:900;margin:0 0 10px;letter-spacing:1px;
  text-shadow:0 2px 0 #0a5128,0 4px 14px rgba(0,0,0,.4)}
.hero-slogan{font-size:17px;font-weight:800;margin:0 0 6px;color:#ffe49b}
.hero-sub{font-size:13px;margin:0 0 14px;color:#dff5e6;opacity:.95}
.hero-date{display:inline-block;background:rgba(247,181,0,.95);color:#5a3d00;font-weight:800;
  font-size:12.5px;padding:6px 14px;border-radius:20px}

/* 统计 */
.stats{display:flex;gap:10px;padding:16px 14px 4px}
.stat{flex:1;background:linear-gradient(180deg,#fff,#f3fff7);border-radius:14px;padding:12px 6px;text-align:center;
  box-shadow:0 6px 16px rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.6)}
.stat b{display:block;font-size:22px;color:var(--primary);font-weight:900;line-height:1.1}
.stat span{display:block;font-size:11.5px;color:#5b6b60;margin-top:3px}

/* 卡片 */
.card{background:#fff;margin:14px;border-radius:16px;padding:16px 16px 18px;box-shadow:0 6px 18px rgba(0,0,0,.16)}
.card-title{font-size:18px;font-weight:900;color:var(--primary-d);margin-bottom:12px;padding-left:12px;position:relative}
.card-title::before{content:"";position:absolute;left:0;top:2px;bottom:2px;width:5px;border-radius:3px;
  background:linear-gradient(var(--accent),var(--primary))}
.rich{font-size:14px;line-height:1.95;color:#33433a}
.rich.small{font-size:12.8px;line-height:1.85;color:#566;}
.rich p{margin:0 0 4px}
.rich b{color:var(--primary-d)}

/* 奖品 */
.prize-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.prize{background:linear-gradient(180deg,#f6fff9,#eafff0);border:1px solid #d8f0e0;border-radius:12px;
  padding:10px 6px;text-align:center}
.prize .pimg{height:62px;display:flex;align-items:center;justify-content:center;font-size:34px}
.prize .pimg img{max-height:62px;width:auto;margin:0 auto}
.prize .ptitle{font-size:12px;font-weight:700;color:#2b3a31;margin-top:4px;line-height:1.3}
.prize .prank{display:inline-block;margin-top:5px;font-size:10.5px;color:#fff;background:var(--primary);
  padding:2px 7px;border-radius:10px}
.prize-note{margin-top:12px;font-size:12px;color:#d9534f;font-weight:600;text-align:center}

/* 入口按钮 */
.entries{padding:6px 14px 0;display:flex;flex-direction:column;gap:12px}
.entry{border:0;border-radius:16px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;
  font-size:21px;font-weight:900;color:#5a3d00;cursor:pointer;box-shadow:0 8px 18px rgba(0,0,0,.22);
  position:relative;overflow:hidden}
.entry i{font-size:13px;font-weight:700;font-style:normal;opacity:.8}
.entry-1{background:linear-gradient(100deg,#ffe259,#ffa751)}
.entry-2{background:linear-gradient(100deg,#7ee8a0,#42c98a);color:#0a3d20}
.entry::after{content:"⚽";position:absolute;right:90px;font-size:46px;opacity:.18}

/* 页面横幅 */
.page-banner{position:relative;height:150px;display:flex;align-items:center;justify-content:center;overflow:hidden;
  background-size:cover;background-position:center}
.banner-predict{background:radial-gradient(120% 120% at 30% 0,#1fb255,#0a5026)}
.banner-rank{background:radial-gradient(120% 120% at 70% 0,#ffb43a,#e07b00)}
.banner-rules{background:radial-gradient(120% 120% at 50% 0,#3aa0ff,#0a5bb5)}
.page-banner::before{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0 34px,transparent 34px 68px)}
.page-banner h2{position:relative;color:#fff;font-size:30px;font-weight:900;margin:0;letter-spacing:2px;
  text-shadow:0 3px 0 rgba(0,0,0,.18),0 6px 14px rgba(0,0,0,.3)}
.page-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.back{position:absolute;left:12px;top:12px;z-index:3;background:rgba(0,0,0,.32);color:#fff;border:0;
  border-radius:18px;padding:6px 14px;font-size:13px;cursor:pointer}

.sub-actions{display:flex;gap:10px;padding:12px 14px 0}
.sub-actions.center{justify-content:center}
.link-btn{flex:1;background:rgba(255,255,255,.92);border:0;border-radius:10px;padding:10px;font-size:13.5px;
  font-weight:700;color:var(--primary-d);cursor:pointer}

/* 比赛卡片 */
.match-list{padding:12px 14px 0}
.loading{color:#dff5e6;text-align:center;padding:40px 0;font-size:14px}
.match{background:#fff;border-radius:16px;margin-bottom:14px;overflow:hidden;box-shadow:0 6px 16px rgba(0,0,0,.16)}
.match-top{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;
  background:linear-gradient(90deg,#eafff1,#f6fff9);font-size:12px;color:#5b6b60}
.match-stage{font-weight:700;color:var(--primary-d)}
.m-state{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:700}
.s-upcoming{background:#e6f7ee;color:var(--primary)}
.s-live{background:#fdecec;color:#d9534f}
.s-finished{background:#eef1f4;color:#7a8a99}
.teams{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 4px}
.team{flex:1;text-align:center}
.team .flag{font-size:32px;line-height:1}
.team .tname{font-size:14px;font-weight:800;margin-top:4px;color:#1f2d23}
.vs{width:62px;text-align:center;color:#9aa;font-weight:800;font-size:13px}
.vs .sc{font-size:20px;color:#1f2d23;font-weight:900}
.choices{display:flex;gap:8px;padding:10px 16px 4px}
.choice{flex:1;border:1.5px solid #d8e4dc;background:#fff;border-radius:10px;padding:9px 0;font-size:14px;
  font-weight:800;color:#48584e;cursor:pointer;transition:.12s}
.choice .cl{display:block;font-size:10px;font-weight:600;color:#9aa;margin-top:1px}
.choice.sel{border-color:var(--primary);background:var(--primary);color:#fff}
.choice.sel .cl{color:#e6ffee}
.choice.win{border-color:var(--accent);background:#fff7e0}
.choice.disabled{opacity:.55;pointer-events:none}
.choice.correct{border-color:var(--primary);background:#e9fbef;color:var(--primary-d)}
.match-foot{padding:10px 16px 14px}
.confirm-btn{width:100%;border:0;border-radius:10px;padding:11px;font-size:15px;font-weight:800;color:#5a3d00;
  background:linear-gradient(90deg,#ffe259,#ffb43a);cursor:pointer}
.confirm-btn.locked{background:#eef1f4;color:#8a97a3}
.confirm-tip{text-align:center;font-size:12px;color:#9aa;padding:4px 0 0}
.badge-correct{color:var(--primary);font-weight:800}
.badge-wrong{color:#d9534f;font-weight:800}

/* 我的排名卡 */
.myrank{margin:14px;background:linear-gradient(110deg,#0c7a37,#16a34a);border-radius:16px;padding:16px;color:#fff;
  box-shadow:0 8px 18px rgba(0,0,0,.25)}
.myrank .mr-top{display:flex;justify-content:space-between;align-items:center}
.myrank .mr-name{font-weight:800;font-size:15px}
.myrank .mr-rank{font-size:13px;background:rgba(255,255,255,.2);padding:3px 12px;border-radius:14px}
.myrank .mr-rank b{font-size:20px;color:var(--accent)}
.myrank .mr-stats{display:flex;gap:18px;margin-top:12px;font-size:13px}
.myrank .mr-stats div b{font-size:19px;display:block;color:#fff;font-weight:900}
.myrank .mr-stats div span{opacity:.85;font-size:11.5px}
.myrank.nologin,.myrank.norank{text-align:center;font-size:13.5px}
.myrank .mr-go{margin-top:10px;background:var(--accent);color:#5a3d00;border:0;border-radius:10px;
  padding:9px 18px;font-weight:800;cursor:pointer}

.rank-head{display:flex;align-items:center;padding:8px 18px;color:#dff5e6;font-size:12px;font-weight:700;margin-top:4px}
.rank-head span{width:48px;text-align:center}.rank-head .rh-user{flex:1;text-align:left}
.rank-list{margin:0 14px;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 6px 16px rgba(0,0,0,.16)}
.rank-row{display:flex;align-items:center;padding:12px 4px;border-bottom:1px solid #f0f3f1;font-size:13px}
.rank-row:last-child{border-bottom:0}
.rank-row .rk{width:48px;text-align:center;font-weight:900;color:#7a8a99}
.rank-row.top1 .rk,.rank-row.top2 .rk,.rank-row.top3 .rk{font-size:18px}
.rank-row.top1 .rk{color:#f7b500}.rank-row.top2 .rk{color:#9aa7b3}.rank-row.top3 .rk{color:#cd7f32}
.rank-row .ru{flex:1;text-align:left}
.rank-row .ru .rn{font-weight:700;color:#1f2d23}
.rank-row .ru .rp{font-size:11px;color:#9aa}
.rank-row .rc{width:48px;text-align:center;color:#5b6b60}
.rank-row .rs{width:48px;text-align:center;font-weight:900;color:var(--primary)}
.rank-row.me{background:#fff7e0}
.rank-empty{padding:40px 0;text-align:center;color:#9aa;font-size:13px}
.rank-note{margin:14px;color:#dff5e6;font-size:12px;line-height:1.7;background:rgba(0,0,0,.18);padding:12px;border-radius:12px}

/* 底部 */
.foot{text-align:center;color:#cfe9d8;font-size:12px;padding:20px 16px 8px;line-height:1.8}
.foot.mini{padding-top:10px}

/* 弹窗 */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:50;display:none;align-items:center;justify-content:center;padding:24px}
.modal.show{display:flex}
.modal-box{width:100%;max-width:340px;background:#fff;border-radius:18px;padding:22px 20px 20px;text-align:center}
.modal-title{font-size:19px;font-weight:900;color:var(--primary-d)}
.modal-sub{font-size:12.5px;color:#7a8a99;margin:6px 0 16px}
.modal-box input{width:100%;padding:12px 14px;border:1.5px solid #e0e8e3;border-radius:10px;font-size:15px;margin-bottom:11px;outline:none}
.modal-box input:focus{border-color:var(--primary)}
.modal-err{color:#d9534f;font-size:12.5px;min-height:18px;margin-bottom:4px}
.modal-btn{width:100%;border:0;border-radius:11px;padding:13px;font-size:16px;font-weight:800;color:#fff;
  background:linear-gradient(90deg,#16a34a,#0c7a37);cursor:pointer}

/* toast */
.toast{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.82);color:#fff;
  padding:11px 20px;border-radius:10px;font-size:14px;z-index:99;opacity:0;pointer-events:none;transition:.2s;max-width:80%;text-align:center}
.toast.show{opacity:1}
