:root{--bg: #000000;--card: #141414;--card-elevated: #1a1a1a;--border: #2a2a2a;--text: #ffffff;--muted: #8b8b8b;--highlight: #c1ff00;--pill-inactive: #212121;--warn: #f5a524;--danger: #ff6b6b;--campaign-cols: repeat(3, minmax(0, 1fr));--campaign-gap: 8px;font-family:PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--bg);line-height:1.5}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg)}#root{max-width:1000px;margin:0 auto;padding:0 16px 48px}.campaign-page{padding-top:8px}.campaign-header{padding:16px 0 24px}.hero-banner{display:grid;grid-template-columns:2fr 1fr;align-items:stretch;gap:4px}.hero-content{min-width:0;display:flex;flex-direction:column;justify-content:center;padding-right:2px}.hero-visual{width:100%;min-height:100%;margin:0;position:relative;overflow:hidden;border-radius:12px;background:var(--bg);pointer-events:none;-webkit-user-select:none;user-select:none}.hero-visual:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--bg) 0%,rgba(0,0,0,.5) 18%,rgba(0,0,0,.15) 32%,transparent 48%);z-index:1;pointer-events:none}.hero-visual img{width:100%;height:100%;min-height:120px;object-fit:cover;object-position:50% 55%;display:block}.wallet-bar{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;align-items:center;margin-bottom:24px}.wallet-bar .btn-wallet{width:auto;flex:none;padding:8px 14px;border-radius:10px;font-size:.85rem;font-weight:600;background:var(--pill-inactive);color:var(--text)}.wallet-bar .btn-wallet.active{background:#fff;color:#000}.wallet-bar .btn-wallet:disabled{opacity:.6}.wallet-hint{flex:1 1 100%;margin:4px 0 0;font-size:.75rem;color:var(--muted);text-align:right;line-height:1.4}.wallet-chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:8px;font-size:.8rem;background:var(--pill-inactive);color:var(--text)}.wallet-chip.ok{color:var(--highlight)}.wallet-chip.warn{color:var(--warn)}.hero-kicker{margin:0 0 8px;font-size:clamp(1.5rem,5vw,2rem);font-weight:700;line-height:1.2;color:var(--text)}.hero-title{margin:0 0 12px;font-size:clamp(1.75rem,6vw,2.5rem);font-weight:800;line-height:1.15;letter-spacing:-.02em}.hero-sub{margin:0;font-size:.95rem;color:var(--muted)}.highlight{color:var(--highlight)}.countdown{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 12px;font-size:.9rem;color:var(--muted)}.countdown-label{width:100%;margin-bottom:4px}@media(max-width:560px){.hero-banner{grid-template-columns:1.05fr 1fr;gap:4px}.hero-visual{border-radius:10px}.hero-visual img{min-height:100px}.hero-kicker{font-size:1.25rem}.hero-title{font-size:1.5rem}.hero-sub{font-size:.8rem;margin-bottom:12px}}.countdown-unit b{color:var(--text);font-size:1.1rem;font-weight:700;margin-right:2px}.pill-nav{display:grid;grid-template-columns:var(--campaign-cols);gap:var(--campaign-gap);margin-bottom:24px}button{font:inherit;cursor:pointer;border:none;transition:opacity .15s ease,transform .12s ease}button:active:not(:disabled){transform:scale(.98)}button:disabled{opacity:.4;cursor:not-allowed}.pill-nav .pill-tab{width:100%}.pill-tab{padding:14px 12px;border-radius:10px;font-size:.95rem;font-weight:600;background:var(--pill-inactive);color:var(--text)}.pill-tab.active{background:#fff;color:#000}.pill-tab.sm{flex:none;padding:8px 14px;font-size:.85rem}.campaign-main{min-height:200px}.section-title{margin:0 0 16px;font-size:1.25rem;font-weight:700}.section-title-stats{display:flex;flex-wrap:wrap;align-items:baseline;gap:0 .35em;line-height:1.45}.countdown-inline{font-size:.72em;font-weight:600;color:var(--muted);white-space:nowrap}.countdown-inline .countdown-unit{margin-left:.15em}.countdown-inline .countdown-unit b{color:var(--text);font-weight:700}@media(max-width:560px){.countdown-inline{white-space:normal}}.panel{background:var(--card);border-radius:12px;padding:20px 16px;margin-bottom:12px}.intro-blocks .reward-card{padding:16px 0;border-bottom:1px solid var(--border)}.intro-blocks .reward-card:last-child{border-bottom:none;padding-bottom:0}.intro-blocks .reward-card h3{margin:0 0 8px;font-size:1rem;font-weight:700}.intro-prize-line{margin:0 0 6px;color:var(--muted);font-size:.9rem;line-height:1.5}.intro-prize-line:last-child{margin-bottom:0}.steps-list{margin:0;padding-left:1.2rem;color:var(--muted)}.steps-list li{margin-bottom:8px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{background:var(--card-elevated);border-radius:10px;padding:16px;text-align:center}.stat-label{color:var(--muted);font-size:.8rem}.stat-value{font-size:1.5rem;font-weight:800;margin-top:6px;line-height:1.2}.stat-value .highlight{font-size:inherit}.btn-primary{background:var(--highlight);color:#000;font-weight:700;font-size:1rem;padding:16px 28px;border-radius:999px;white-space:nowrap}.btn-primary:disabled{background:#757575;color:#000;opacity:1}.btn-outline{background:var(--pill-inactive);color:var(--text);padding:10px 16px;border-radius:10px;font-weight:600}.team-grid{display:grid;gap:8px}.team-grid-6x6{grid-template-columns:repeat(6,1fr)}@media(max-width:400px){.team-btn .team-name{font-size:.62rem}.team-btn{min-height:64px}}.team-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:72px;background:var(--card-elevated);border:1px solid var(--border);color:var(--text);padding:8px 4px;text-align:center;border-radius:10px;font-weight:600}.team-btn .team-name{font-size:.72rem;line-height:1.2}.team-cell-empty{min-height:72px;border-radius:10px;background:transparent}.team-flag{display:block;object-fit:cover;border-radius:2px;box-shadow:0 0 0 1px #ffffff14}.grid-hint{margin:0 0 10px}.team-pick-badge{display:flex;flex-direction:column;align-items:center;gap:6px}.team-pick-label{font-size:.75rem;color:var(--muted);font-weight:500}.team-pick-name{font-size:1rem;font-weight:700}.panel-predicted{text-align:center}.panel-predicted .badge.ok{display:inline-block}.picked-summary{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:12px;margin-top:16px}.picked-card{flex:1 1 140px;max-width:220px;min-width:130px;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--pill-inactive)}.picked-card-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:14px 10px 16px;text-align:center}.picked-card-champion .picked-card-header{background:linear-gradient(180deg,#f5d547,#d4af37);color:#000}.picked-card-runner-up .picked-card-header{background:linear-gradient(180deg,#ececec,#b0b0b0);color:#000}.picked-role{font-size:.95rem;font-weight:700;line-height:1.2}.picked-card-name{font-size:1.1rem;font-weight:700;line-height:1.2}.panel-predicted .msg{margin-top:12px}.confirm-picks{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-start}.team-btn.selected-champion{border-color:var(--highlight);box-shadow:0 0 0 1px var(--highlight);color:var(--highlight)}.team-btn.selected-runner{border-color:#fff;box-shadow:0 0 0 1px #fff}.team-btn.disabled-team{opacity:.3}.role-tabs,.mode-tabs{display:flex;gap:8px;margin-bottom:0}.role-sign-wrap{display:flex;justify-content:center;margin:14px 0 16px}.btn-sign{display:inline-block;width:auto;min-width:168px;max-width:88%;padding:14px 36px;border-radius:999px;font-size:1rem;font-weight:700;color:#000;text-align:center;background:var(--highlight)}.btn-sign:disabled{background:#757575;color:#000;opacity:1}.mode-tab{flex:1;padding:12px;border-radius:10px;font-weight:600;background:var(--pill-inactive);color:var(--muted)}.role-tab{flex:1;display:flex;flex-direction:column;align-items:stretch;padding:0;overflow:hidden;min-height:130px;border-radius:10px;font-weight:600;background:var(--pill-inactive);border:1px solid var(--border);color:var(--muted)}.role-tab-header{display:block;width:100%;padding:12px 8px;text-align:center;font-size:.95rem;font-weight:700;color:var(--muted);background:transparent}.role-tab-champion.active .role-tab-header{background:linear-gradient(180deg,#f5d547,#d4af37);color:#000}.role-tab-runnerUp.active .role-tab-header{background:linear-gradient(180deg,#ececec,#b0b0b0);color:#000}.role-tab-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:14px 8px 16px}.role-tab.active .role-tab-body{padding:18px 8px 20px}.role-tab-team-name{font-size:1rem;font-weight:700;color:var(--text);line-height:1.2}.role-tab.active .role-tab-team-name{font-size:1.2rem}.role-tab-placeholder{font-size:.8rem;color:var(--muted);text-align:center}.pick-hint{margin:12px 0 4px;text-align:center;color:var(--muted);font-size:.9rem}.role-tab:disabled{opacity:.45}.mode-tab.active{background:#fff;color:#000}.confirm-bar{display:flex;flex-direction:column;align-items:stretch;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.confirm-bar>span{color:var(--muted);font-size:.9rem;text-align:center}.confirm-bar .btn-primary{width:100%;text-align:center}.badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.75rem;background:var(--pill-inactive);color:var(--muted)}.badge.ok,.badge.open{background:#c1ff0026;color:var(--highlight)}.badge.warn{background:#f5a52426;color:var(--warn)}.msg{margin-top:8px;font-size:.9rem;color:var(--muted)}.msg.error{color:var(--danger)}.msg.success,.msg.warn{color:var(--highlight)}a{color:var(--highlight);text-decoration:none}a:hover{text-decoration:underline}.match-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.match-card{background:var(--card-elevated);border-radius:10px;padding:14px}.match-title{font-weight:700;margin-bottom:10px}.match-title .vs{color:var(--muted);font-weight:400;margin:0 6px}.pick-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.pick-btn{background:var(--pill-inactive);color:var(--text);padding:12px 6px;font-size:.85rem;font-weight:600;border-radius:10px}.pick-btn.selected{background:#fff;color:#000}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th,.data-table td{border-bottom:1px solid var(--border);padding:10px 6px;text-align:left}.data-table th{color:var(--muted);font-weight:500}.deadline-banner{margin:0 0 16px;padding:12px 14px;border-radius:10px;background:var(--card-elevated);font-size:.9rem;color:var(--muted)}.deadline-banner strong{color:var(--highlight);font-weight:700}.campaign-footer{margin-top:32px;padding-top:16px;font-size:.75rem;color:var(--muted);border-top:1px solid var(--border)}.campaign-footer a{margin-left:8px}
